Skip to content

Commit

Permalink
replace further uses of basis(parent(…))
Browse files Browse the repository at this point in the history
  • Loading branch information
kalmarek committed May 30, 2024
1 parent f5473ac commit 12f153f
Show file tree
Hide file tree
Showing 6 changed files with 14 additions and 10 deletions.
6 changes: 3 additions & 3 deletions src/algebra_elts.jl
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,13 @@ function Base.deepcopy_internal(a::AlgebraElement, id::IdDict)
end

# call overload:
(a::AlgebraElement)(x) = coeffs(a)[basis(parent(a))[x]]
Base.setindex!(a::AlgebraElement, v, idx) = a.coeffs[basis(parent(a))[idx]] = v
(a::AlgebraElement)(x) = coeffs(a)[basis(a)[x]]
Base.setindex!(a::AlgebraElement, v, idx) = a.coeffs[basis(a)[idx]] = v

# AlgebraElement specific functions

function supp(a::AlgebraElement)
b = basis(parent(a))
b = basis(a)
return [b[i] for (i, _) in nonzero_pairs(coeffs(a))]
end

Expand Down
2 changes: 1 addition & 1 deletion src/arithmetic.jl
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ function MA.operate_to!(
Y::AlgebraElement,
)
@assert parent(res) == parent(X) == parent(Y)
mstr = mstructure(basis(parent(res)))
mstr = mstructure(basis(res))
MA.operate_to!(coeffs(res), mstr, coeffs(X), coeffs(Y))
return res
end
Expand Down
2 changes: 1 addition & 1 deletion src/star.jl
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ Base.adjoint(a::AlgebraElement) = star(a)
star(x::Any) = x'

function star(X::AlgebraElement)
res = star(basis(parent(X)), coeffs(X))
res = star(basis(X), coeffs(X))
return AlgebraElement(res, parent(X))
end

Expand Down
2 changes: 1 addition & 1 deletion src/types.jl
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ function Base.isone(a::AlgebraElement)
if basis(A) isa DiracBasis
return c == cfs1
else
dc = coeffs(c, basis(parent(a)), DiracBasis{UInt}(object(parent(a))))
dc = coeffs(c, basis(a), DiracBasis{UInt}(object(parent(a))))
return dc == cfs1
end
end
Expand Down
10 changes: 7 additions & 3 deletions test/caching_allocations.jl
Original file line number Diff line number Diff line change
Expand Up @@ -43,15 +43,19 @@ end
@test_throws SA.UndefRefError all(!iszero, SA.mstructure(fRG).table)

@static if v"1.10" VERSION < v"1.11"
@test (@allocations Y * Y) > k^2 - 2 * k
k1 = @allocations Y * Y
@test k1 > k^2 - 2 * k
@test Y * Y isa AlgebraElement
@test (@allocations Y * Y) 26
k2 = @allocations Y * Y
@info "allocated" k1 k2 k2 / k1
@test k2 26
else
k1 = @allocated Y * Y
@test Y * Y isa AlgebraElement
Y * Y
k2 = @allocated Y * Y
@test k2 / k1 < 0.7
@info "allocated" k1 k2 k2 / k1
@test_broken k2 / k1 < 0.12
end

@test all(!iszero, SA.mstructure(fRG).table)
Expand Down
2 changes: 1 addition & 1 deletion test/group_algebra.jl
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@
z = sum((one(RG) - RG(g)) * star(one(RG) - RG(g)) for g in G)
@test SA.aug(z) == 0

@test SA.supp(z) == sort(collect(basis(parent(z))))
@test SA.supp(z) == sort(collect(basis(z)))
@test SA.supp(RG(1) + RG(g)) == [one(G), g]
@test SA.supp(a) == [one(G), h, g]

Expand Down

0 comments on commit 12f153f

Please sign in to comment.