From 50a36c3d1f5fa8ed467851357ba3f400beb1be15 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Legat?= Date: Thu, 23 Nov 2023 11:21:55 +0100 Subject: [PATCH] Bool coefficient_type for monomials --- src/MultivariatePolynomials.jl | 4 ++-- src/term.jl | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/MultivariatePolynomials.jl b/src/MultivariatePolynomials.jl index f3bc5f34..b4116690 100644 --- a/src/MultivariatePolynomials.jl +++ b/src/MultivariatePolynomials.jl @@ -18,7 +18,7 @@ abstract type AbstractPolynomialLike{T} <: MA.AbstractMutable end """ AbstractTermLike{T} -Abstract type for a value that can act like a term. For instance, an `AbstractMonomial` is an `AbstractTermLike{Int}` since it can act as a term with coefficient `1`. +Abstract type for a value that can act like a term. For instance, an `AbstractMonomial` is an `AbstractTermLike{Bool}` since it can act as a term with coefficient `1`. """ abstract type AbstractTermLike{T} <: AbstractPolynomialLike{T} end @@ -27,7 +27,7 @@ abstract type AbstractTermLike{T} <: AbstractPolynomialLike{T} end Abstract type for a value that can act like a monomial. For instance, an `AbstractVariable` is an `AbstractMonomialLike` since it can act as a monomial of one variable with degree `1`. """ -abstract type AbstractMonomialLike <: AbstractTermLike{Int} end +abstract type AbstractMonomialLike <: AbstractTermLike{Bool} end """ AbstractVariable <: AbstractMonomialLike diff --git a/src/term.jl b/src/term.jl index cfaf6797..52e02834 100644 --- a/src/term.jl +++ b/src/term.jl @@ -17,7 +17,7 @@ difference between this and `coef * mono`: Converts the polynomial `p` to a term. When applied on a polynomial, it throws an `InexactError` if it has more than one term. When applied to a term, it is the identity and does not copy it. -When applied to a monomial, it create a term of type `AbstractTerm{Int}`. +When applied to a monomial, it create a term of type `AbstractTerm{Bool}`. """ function term end term(coef, var::AbstractVariable) = term(coef, monomial(var)) @@ -45,7 +45,7 @@ Returns the type of the terms of a polynomial of type `PT` but with coefficient """ term_type(::Type{T}) where {T<:AbstractTerm} = T term_type(p::Type{<:_APL}, ::Type{T}) where {T} = term_type(term_type(p), T) -term_type(::Type{M}) where {M<:AbstractMonomialLike} = term_type(M, Int) +term_type(::Type{M}) where {M<:AbstractMonomialLike} = term_type(M, Bool) term_type(v::Type{<:AbstractVariable}) = term_type(monomial_type(v)) function term_type(v::Type{<:AbstractVariable}, ::Type{T}) where {T} return term_type(monomial_type(v), T) @@ -134,7 +134,7 @@ Returns the coefficient type of a polynomial of type `PT`. Calling `coefficient_type` on ``(4//5)x^2y`` should return `Rational{Int}`, calling `coefficient_type` on ``1.0x^2y + 2.0x`` should return `Float64` and -calling `coefficient_type` on ``xy`` should return `Int`. +calling `coefficient_type` on ``xy`` should return `Bool`. """ function coefficient_type( ::Union{PT,Type{PT},AbstractVector{PT},Type{<:AbstractVector{PT}}},