Groebner
HilbertSeries
compute Hilbert series
HilbertPolynomial
compute Hilbert polynomial
Calling Sequence
Parameters
Description
Examples
HilbertSeries(J, X, s, characteristic=p)
HilbertPolynomial(J, X, s, characteristic=p)
J
-
a list or set of polynomials or a PolynomialIdeal
X
(optional) a list or set of variables, a ShortMonomialOrder, or a MonomialOrder
s
(optional) a variable to use for the series or polynomial
p
(optional) characteristic
The HilbertSeries command computes the Hilbert series of the ideal generated by J, which is defined as ∑n=0∞cn−cn−1sn where cn is the dimension of the vector space of normal forms (with respect to J) of polynomials of degree less than or equal to n. The output is a rational function of the form Hs=Ps1−sd where d is the HilbertDimension of J. The Hilbert polynomial is defined as the polynomial asymptotically equal to cn−cn−1.
In the case of skew polynomials, the invariants that are returned are those of the left ideal generated by J.
The variables of the system can be specified using an optional second argument X. If X is a ShortMonomialOrder then a Groebner basis of J with respect to X is computed. Be aware that if X is not a graded monomial order (that is, tdeg or grlex) then the result may be incorrect. By default, X is the set of all indeterminates not appearing inside a RootOf or radical when J is a list or set, or PolynomialIdeals[IdealInfo][Variables](J) if J is an ideal.
The variable for the Hilbert series or polynomial can be specified with an optional third argument s. If this is omitted, the global name 'Z' is used.
The optional argument characteristic=p specifies the ring characteristic when J is a list or set. This option has no effect when J is a PolynomialIdeal or when X is a MonomialOrder.
The algorithms for HilbertSeries and HilbertPolynomial use the leading monomials of a total degree Groebner basis for J. To access this functionality directly (as part of a program), make J the list or set of leading monomials. The commands will detect this case and execute their algorithms with minimal overhead.
Note that the hilbertseries and hilbertpoly commands are deprecated. They may not be supported in a future Maple release.
withGroebner:
F≔x31−x6−x−y,x8−z,x10−t
h≔HilbertSeriesF,t,x,y,z,s
h≔s6−2s5−11s4−9s3−6s2−3s−1−1+s
HilbertPolynomialF,t,x,y,z,n
31
seriesh,s=0,10
1+4s+10s2+19s3+30s4+32s5+31s6+31s7+31s8+31s9+Os10
The system below is not holonomic, in the sense that the Hilbert dimension is greater than the number of polynomial variables (x and y).
withOre_algebra:
A≔diff_algebraDx,x,Dy,y,polynom=x,y:
T≔MonomialOrderA,tdegDx,Dy,x,y:
p≔x2−x+y:
F≔pDx+diffp,x,pDy+diffp,y
F≔x2−x+yDx+2x−1,x2−x+yDy+1
G≔BasisF,T
G≔Dyx2−Dyx+Dyy+1,Dxx2−Dxx+Dxy+2x−1
HilbertDimensionF,T
3
p≔HilbertPolynomialF,T,n
p≔n2+3n
h≔HilbertSeriesF,T,s
h≔s3−s2−s−1−1+s3
seriesh,s
1+4s+10s2+18s3+28s4+40s5+Os6
seriesaddevalp,n=i,i=0..6,s
154
Neither x nor y can be eliminated.
removehas,BasisF,MonomialOrderA,lexdegx,Dx,Dy,y,x
removehas,BasisF,MonomialOrderA,lexdegy,Dx,Dy,x,y
f≔1p
f≔1n2+3n
x2−x+ydifff,x,y+22x−1difff,y
0
The system becomes holonomic when we add the polynomial above. The Hilbert dimension is now 2 and both x and y can be eliminated.
F2≔opF,x2−x+yDxDy+22x−1Dy
F2≔x2−x+yDx+2x−1,x2−x+yDy+1,x2−x+yDxDy+22x−1Dy
HilbertDimensionF2,T
2
HilbertPolynomialF2,T,n
4n
h≔HilbertSeriesF2,T,s
h≔s2+2s+1−1+s2
seriesh,s=0
1+4s+8s2+12s3+16s4+20s5+Os6
removehas,BasisF2,MonomialOrderA,lexdegx,Dx,Dy,y,x
4yDy2+Dx2−Dy2+6Dy
removehas,BasisF2,MonomialOrderA,lexdegy,Dx,Dy,x,y
2xDy−Dx−Dy
See Also
Basis
HilbertDimension
MonomialOrder
Ore_algebra
PolynomialIdeal
series
Download Help Document