CoCoA:HilbertSeriesShifts

HilbertSeriesShifts

the Hilbert-Poincare series

Description

This function computes the Hilbert-Poincare series of a

The input, M, must be homogeneous (with respect the weights list). In the standard case, i.e. the weights of all indeterminates are 1, the result is simplified so that the power appearing in the denominator is the dimension of M.

The function <ttref>PoincareShifts</ttref> is exacly the same as

<ttref>HilbertSeriesShifts</ttref>.

NOTES:

(i) the coefficient ring must be a field.

(ii) these functions produce tagged objects: they cannot safely be

```    (non-)equality to other values.
```

For more information, see the article: A.M. Bigatti, Computations of Hilbert-Poincare Series, J. Pure Appl. Algebra, 119/3 (1997), 237--253.

Example

```  Use P ::= Q[x,y,z];
M := Module([x,y^3], [x-z,0]);
HilbertSeriesShifts(M, [2,0]);  -- HilbertPoincare series of a shifted module
(2x^3) / (1-x)^3
-------------------------------
PoincareShifts(P^2/M, [3,1]);   -- HP series of a shifted quotient module
(x + x^2 + 2x^3) / (1-x)^2
-------------------------------
```

Syntax

```HilbertSeriesShifts(M: Module, ShiftsList: LIST):TAGGED(<quotes>\$hp.PSeries</quotes>)
HilbertSeriesShifts(M: TAGGED(<quotes>Quotient</quotes>), ShiftsList: LIST)
:TAGGED(<quotes>\$hp.PSeries</quotes>)
```

```   <type>groebner</type>
<type>groebner-basic</type>
<type>hilbert</type>
<type>quotient</type>
<type>ring</type>
```