TriangularSetCategory(R, E, V, P)¶
triset.spad line 1 [edit on github]
- V: OrderedSet 
- P: RecursivePolynomialCategory(R, E, V) 
The category of triangular sets of multivariate polynomials with coefficients in an integral domain. Let R be an integral domain and V a finite ordered set of variables, say X1 < X2 < ... < Xn. A set S of polynomials in R[X1, X2, ..., Xn] is triangular if no elements of S lies in R, and if two distinct elements of S have distinct main variables. Note that the empty set is a triangular set. A triangular set is not necessarily a (lexicographical) Groebner basis and the notion of reduction related to triangular sets is based on the recursive view of polynomials. We recall this notion here and refer to [1] for more details. A polynomial P is reduced w.r.t a non-constant polynomial Q if the degree of P in the main variable of Q is less than the main degree of Q. A polynomial P is reduced w.r.t a triangular set T if it is reduced w.r.t. every polynomial of T.
- #: % -> NonNegativeInteger
- from Aggregate 
- algebraic?: (V, %) -> Boolean
- algebraic?(v, ts)returns- trueiff- vis the main variable of some polynomial in- ts.
- algebraicVariables: % -> List V
- algebraicVariables(ts)returns the decreasingly sorted list of the main variables of the polynomials of- ts.
- any?: (P -> Boolean, %) -> Boolean
- from HomogeneousAggregate P 
- autoReduced?: (%, (P, List P) -> Boolean) -> Boolean
- autoReduced?(ts, redOp?)returns- trueiff every element of- tsis reduced- w.- r.- tto every other in the sense of- redOp?
- basicSet: (List P, (P, P) -> Boolean) -> Union(Record(bas: %, top: List P), failed)
- basicSet(ps, redOp?)returns- [bs, ts]where- concat(bs, ts)is- psand- bsis a basic set in Wu Wen Tsun sense of- ps- w.- r.- tthe reduction-test- redOp?, if no non-zero constant polynomial lie in- ps, otherwise- "failed"is returned.
- basicSet: (List P, P -> Boolean, (P, P) -> Boolean) -> Union(Record(bas: %, top: List P), failed)
- basicSet(ps, pred?, redOp?)returns the same as- basicSet(qs, redOp?)where- qsconsists of the polynomials of- pssatisfying property- pred?.
- coerce: % -> List P
- from CoercibleTo List P 
- coerce: % -> OutputForm
- from CoercibleTo OutputForm 
- coHeight: % -> NonNegativeInteger if V has Finite
- coHeight(ts)returns- size()\$Vminus- \#ts.
- collect: (%, V) -> %
- from PolynomialSetCategory(R, E, V, P) 
- collectQuasiMonic: % -> %
- collectQuasiMonic(ts)returns the subset of- tsconsisting of the polynomials with initial in- R.
- collectUnder: (%, V) -> %
- from PolynomialSetCategory(R, E, V, P) 
- collectUpper: (%, V) -> %
- from PolynomialSetCategory(R, E, V, P) 
- construct: List P -> %
- from Collection P 
- convert: % -> InputForm
- from ConvertibleTo InputForm 
- count: (P -> Boolean, %) -> NonNegativeInteger
- from HomogeneousAggregate P 
- count: (P, %) -> NonNegativeInteger
- from HomogeneousAggregate P 
- degree: % -> NonNegativeInteger
- degree(ts)returns the product of main degrees of the members of- ts.
- eval: (%, Equation P) -> % if P has Evalable P
- from Evalable P 
- eval: (%, List Equation P) -> % if P has Evalable P
- from Evalable P 
- eval: (%, List P, List P) -> % if P has Evalable P
- from InnerEvalable(P, P) 
- eval: (%, P, P) -> % if P has Evalable P
- from InnerEvalable(P, P) 
- every?: (P -> Boolean, %) -> Boolean
- from HomogeneousAggregate P 
- extend: (%, P) -> %
- extend(ts, p)returns a triangular set which encodes the simple extension by- pof the extension of the base field defined by- ts, according to the properties of triangular sets of the current category If the required properties do not hold an error is returned.
- extendIfCan: (%, P) -> Union(%, failed)
- extendIfCan(ts, p)returns a triangular set which encodes the simple extension by- pof the extension of the base field defined by- ts, according to the properties of triangular sets of the current domain. If the required properties do not hold then “failed” is returned. This operation encodes in some sense the properties of the triangular sets of the current category. Is is used to implement the- constructoperation to guarantee that every triangular set build from a list of polynomials has the required properties.
- find: (P -> Boolean, %) -> Union(P, failed)
- from Collection P 
- first: % -> Union(P, failed)
- first(ts)returns the polynomial of- tswith greatest main variable if- tsis not empty, otherwise returns- "failed".
- headReduce: (P, %) -> P
- headReduce(p, ts)returns a polynomial- rsuch that- headReduce?(r, ts)holds and there exists some product- hof- initials(ts)such that- h*p - rlies in the ideal generated by- ts.
- headReduced?: % -> Boolean
- headReduced?(ts)returns- trueiff the head of every element of- tsis reduced- w.- r.- tto any other element of- ts.
- headReduced?: (P, %) -> Boolean
- headReduced?(p, ts)returns- trueiff the head of- pis reduced- w.- r.- t.- ts.
- headRemainder: (P, %) -> Record(num: P, den: R)
- from PolynomialSetCategory(R, E, V, P) 
- iexactQuo: (R, R) -> R
- from PolynomialSetCategory(R, E, V, P) 
- infRittWu?: (%, %) -> Boolean
- infRittWu?(ts1, ts2)returns- trueiff- ts2has higher rank than- ts1in Wu Wen Tsun sense.
- initiallyReduce: (P, %) -> P
- initiallyReduce(p, ts)returns a polynomial- rsuch that- initiallyReduced?(r, ts)holds and there exists some product- hof- initials(ts)such that- h*p - rlies in the ideal generated by- ts.
- initiallyReduced?: % -> Boolean
- initiallyReduced?(ts)returns- trueiff for every element- pof- ts- pand all its iterated initials are reduced- w.- r.- t. to the other elements of- tswith the same main variable.
- initiallyReduced?: (P, %) -> Boolean
- initiallyReduced?(p, ts)returns- trueiff- pand all its iterated initials are reduced- w.- r.- t. to the elements of- tswith the same main variable.
- initials: % -> List P
- initials(ts)returns the list of the non-constant initials of the members of- ts.
- last: % -> Union(P, failed)
- last(ts)returns the polynomial of- tswith smallest main variable if- tsis not empty, otherwise returns- "failed".
- latex: % -> String
- from SetCategory 
- less?: (%, NonNegativeInteger) -> Boolean
- from Aggregate 
- mainVariable?: (V, %) -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- mainVariables: % -> List V
- from PolynomialSetCategory(R, E, V, P) 
- map!: (P -> P, %) -> %
- from HomogeneousAggregate P 
- map: (P -> P, %) -> %
- from HomogeneousAggregate P 
- max: % -> P if P has OrderedSet
- from HomogeneousAggregate P 
- max: ((P, P) -> Boolean, %) -> P
- from HomogeneousAggregate P 
- member?: (P, %) -> Boolean
- from HomogeneousAggregate P 
- members: % -> List P
- from HomogeneousAggregate P 
- min: % -> P if P has OrderedSet
- from HomogeneousAggregate P 
- more?: (%, NonNegativeInteger) -> Boolean
- from Aggregate 
- mvar: % -> V
- from PolynomialSetCategory(R, E, V, P) 
- normalized?: % -> Boolean
- normalized?(ts)returns- trueiff for every- pin- tswe have- normalized?(p, us)where- usis- collectUnder(ts, mvar(p)).
- normalized?: (P, %) -> Boolean
- normalized?(p, ts)returns- trueiff- pand all its iterated initials have degree zero- w.- r.- t. the main variables of the polynomials of- ts
- parts: % -> List P
- from HomogeneousAggregate P 
- quasiComponent: % -> Record(close: List P, open: List P)
- quasiComponent(ts)returns- [lp, lq]where- lpis the list of the members of- tsand- lqis- initials(ts).
- reduce: ((P, P) -> P, %) -> P
- from Collection P 
- reduce: ((P, P) -> P, %, P) -> P
- from Collection P 
- reduce: ((P, P) -> P, %, P, P) -> P
- from Collection P 
- reduce: (P, %, (P, P) -> P, (P, P) -> Boolean) -> P
- reduce(p, ts, redOp, redOp?)returns a polynomial- rsuch that- redOp?(r, p)holds for every- pof- tsand there exists some product- hof the initials of the members of- tssuch that- h*p - rlies in the ideal generated by- ts. The operation- redOpmust satisfy the following conditions. For every- pand- qwe have- redOp?(redOp(p, q), q)and there exists an integer- eand a polynomial- fsuch that- init(q)^e*p = f*q + redOp(p, q).
- reduceByQuasiMonic: (P, %) -> P
- reduceByQuasiMonic(p, ts)returns the same as- remainder(p, collectQuasiMonic(ts)).polnum.
- reduced?: (P, %, (P, P) -> Boolean) -> Boolean
- reduced?(p, ts, redOp?)returns- trueiff- pis reduced- w.- r.- t. in the sense of the operation- redOp?, that is if for every- tin- ts- redOp?(p, t)holds.
- remainder: (P, %) -> Record(rnum: R, polnum: P, den: R)
- from PolynomialSetCategory(R, E, V, P) 
- remove: (P -> Boolean, %) -> %
- from Collection P 
- remove: (P, %) -> %
- from Collection P 
- removeDuplicates: % -> %
- from Collection P 
- removeZero: (P, %) -> P
- removeZero(p, ts)returns- 0if- preduces to- 0by pseudo-division- w.- r.- t- tsotherwise returns a polynomial- qcomputed from- pby removing any coefficient in- preducing to- 0.
- rest: % -> Union(%, failed)
- rest(ts)returns the polynomials of- tswith smaller main variable than- mvar(ts)if- tsis not empty, otherwise returns “failed”
- retract: List P -> %
- from RetractableFrom List P 
- retractIfCan: List P -> Union(%, failed)
- from RetractableFrom List P 
- rewriteIdealWithHeadRemainder: (List P, %) -> List P
- from PolynomialSetCategory(R, E, V, P) 
- rewriteIdealWithRemainder: (List P, %) -> List P
- from PolynomialSetCategory(R, E, V, P) 
- rewriteSetWithReduction: (List P, %, (P, P) -> P, (P, P) -> Boolean) -> List P
- rewriteSetWithReduction(lp, ts, redOp, redOp?)returns a list- lqof polynomials such that- [reduce(p, ts, redOp, redOp?) for p in lp]and- lphave the same zeros inside the regular zero set of- ts. Moreover, for every polynomial- qin- lqand every polynomial- tin- ts- redOp?(q, t)holds and there exists a polynomial- pin the ideal generated by- lpand a product- hof- initials(ts)such that- h*p - rlies in the ideal generated by- ts. The operation- redOpmust satisfy the following conditions. For every- pand- qwe have- redOp?(redOp(p, q), q)and there exists an integer- eand a polynomial- fsuch that- init(q)^e*p = f*q + redOp(p, q).
- roughBase?: % -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- roughEqualIdeals?: (%, %) -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- roughSubIdeal?: (%, %) -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- roughUnitIdeal?: % -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- select: (%, V) -> Union(P, failed)
- select(ts, v)returns the polynomial of- tswith- vas main variable, if any.
- select: (P -> Boolean, %) -> %
- from Collection P 
- size?: (%, NonNegativeInteger) -> Boolean
- from Aggregate 
- sort: (%, V) -> Record(under: %, floor: %, upper: %)
- from PolynomialSetCategory(R, E, V, P) 
- stronglyReduce: (P, %) -> P
- stronglyReduce(p, ts)returns a polynomial- rsuch that- stronglyReduced?(r, ts)holds and there exists some product- hof- initials(ts)such that- h*p - rlies in the ideal generated by- ts.
- stronglyReduced?: % -> Boolean
- stronglyReduced?(ts)returns- trueiff every element of- tsis reduced- w.- r.- tto any other element of- ts.
- stronglyReduced?: (P, %) -> Boolean
- stronglyReduced?(p, ts)returns- trueiff- pis reduced- w.- r.- t.- ts.
- triangular?: % -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- trivialIdeal?: % -> Boolean
- from PolynomialSetCategory(R, E, V, P) 
- variables: % -> List V
- from PolynomialSetCategory(R, E, V, P) 
- zeroSetSplit: List P -> List %
- zeroSetSplit(lp)returns a list- ltsof triangular sets such that the zero set of- lpis the union of the closures of the regular zero sets of the members of- lts.
- zeroSetSplitIntoTriangularSystems: List P -> List Record(close: %, open: List P)
- zeroSetSplitIntoTriangularSystems(lp)returns a list of triangular systems- [[ts1, qs1], ..., [tsn, qsn]]such that the zero set of- lpis the union of the closures of the- W_iwhere- W_iconsists of the zeros of- tswhich do not cancel any polynomial in- qsi.
Evalable P if P has Evalable P
InnerEvalable(P, P) if P has Evalable P
PolynomialSetCategory(R, E, V, P)