1
0
mirror of https://github.com/kalmarek/SmallHyperbolic synced 2025-01-12 22:37:33 +01:00

formatter

This commit is contained in:
kalmarek 2020-05-15 15:02:28 +02:00
parent d9bb982c84
commit b0941d17a8
No known key found for this signature in database
GPG Key ID: 8BF1A3855328FC15

View File

@ -1,13 +1,13 @@
Base.hash(a::acb, h::UInt) = h
const libarb = Nemo.libarb
import Base.reim
reim(x::Nemo.acb) = reim(convert(ComplexF64, x))
Base.hash(a::acb, h::UInt) = h
Base.reim(x::acb) = reim(convert(ComplexF64, x))
function root_of_unity(CC::AcbField, p, k = 1)
@assert p > 0
res = zero(CC)
ccall(
(:acb_unit_root, Nemo.libarb),
(:acb_unit_root, libarb),
Cvoid,
(Ref{acb}, Culong, Clong),
res,
@ -21,7 +21,7 @@ import Base.adjoint
function Base.adjoint(m::acb_mat)
res = zero(m)
ccall(
(:acb_mat_conjugate_transpose, Nemo.libarb),
(:acb_mat_conjugate_transpose, libarb),
Cvoid,
(Ref{acb_mat}, Ref{acb_mat}),
res,
@ -38,7 +38,6 @@ rand(rng::AbstractRNG, rs::Random.SamplerTrivial{AcbField}) =
import Nemo.acb_struct
const libarb = Nemo.libarb
mutable struct AcbVector <: AbstractVector{acb_struct}
ptr::Ptr{acb_struct}
@ -49,7 +48,7 @@ mutable struct AcbVector <: AbstractVector{acb_struct}
v = new(
ccall((:_acb_vec_init, libarb), Ptr{acb_struct}, (Clong,), n),
n,
precision
precision,
)
finalizer(clear!, v)
return v
@ -78,13 +77,13 @@ end
_get_ptr(acb_v::AcbVector, i::Int = 1) =
acb_v.ptr + (i - 1) * sizeof(acb_struct)
function AcbVector(v::AbstractVector{Nemo.acb}, p = prec(parent(first(v))))
function AcbVector(v::AbstractVector{acb}, p = prec(parent(first(v))))
acb_v = AcbVector(length(v), p)
for (i, val) in zip(eachindex(acb_v), v)
ccall(
(:acb_set, libarb),
Cvoid,
(Ptr{acb_struct}, Ref{Nemo.acb}),
(Ptr{acb_struct}, Ref{acb}),
_get_ptr(acb_v, i),
val,
)
@ -94,7 +93,7 @@ end
function approx_eig_qr!(v::AcbVector, R::acb_mat, A::acb_mat)
ccall(
(:acb_mat_approx_eig_qr, Nemo.libarb),
(:acb_mat_approx_eig_qr, libarb),
Cint,
(
Ptr{acb_struct},
@ -122,7 +121,7 @@ function (C::AcbField)(z::acb_struct)
return res
end
function LinearAlgebra.eigvals(A::Nemo.acb_mat)
function LinearAlgebra.eigvals(A::acb_mat)
n = nrows(A)
CC = base_ring(A)
p = prec(CC)
@ -132,7 +131,7 @@ function LinearAlgebra.eigvals(A::Nemo.acb_mat)
λ = AcbVector(n, p)
b = ccall(
(:acb_mat_eig_multiple, Nemo.libarb),
(:acb_mat_eig_multiple, libarb),
Cint,
(Ptr{acb_struct}, Ref{acb_mat}, Ptr{acb_struct}, Ref{acb_mat}, Int),
λ,
@ -158,5 +157,9 @@ function _count_multiplicites(evs)
push!(λ_m, (evs[i], m))
i += m
end
return sort(λ_m, lt=(a,b)->(real(first(a))<real(first(b))), rev=true)
return sort(
λ_m,
lt = (a, b) -> (real(first(a)) < real(first(b))),
rev = true,
)
end