Difference between revisions of "Package zerodim"
Line 193: | Line 193: | ||
=== Examples for computations === | === Examples for computations === | ||
− | Now let us apply the <code>zerodim</code> package to some concrete examples. | + | Now let us apply the <code>zerodim</code> package to some concrete examples. Recall that the alias of the package is <code>ZD</code>, and so to call a function from this package in computation one use [[/ZD.<functions-name>/]]. |
− | + | Consider the following example. | |
− | |||
− | |||
− | |||
<pre> | <pre> | ||
Use P ::= QQ[x,y,z]; | Use P ::= QQ[x,y,z]; | ||
Line 210: | Line 207: | ||
While this is only a simple example, the second code is much faster. At the time this is written, the second computation is approximately two times as fast as the first one. | While this is only a simple example, the second code is much faster. At the time this is written, the second computation is approximately two times as fast as the first one. | ||
− | [[Category:Package | + | [[Category:Package zerodim]] |
[[Category:ApCoCoA Packages]] | [[Category:ApCoCoA Packages]] |
Revision as of 20:53, 17 November 2022
This article is about a function from ApCoCoA-2. If you are looking for the ApCoCoA-1 version of it, see Category:ApCoCoA-1:Package ZeroDim. |
This page describes the zerodim package. The package contains various functions for computing algebraic invariants of zero-dimensional schemes and related computations. For a complete list of functions, see Category:Package zerodim.
Algebraic Invariants
Let be a field, let be the polynomial ring over in indeterminates, and let be a 0-dimensional ideal of and . Then defines a 0-dimensional scheme in the affine -space. Consider the canonical multiplication map
and its kernel . Then is a finitely generated -module and is an ideal of the enveloping algebra .
- The ideal is called the Noether different of the algebra .
- The -module is called the module of Kaehler differential 1-forms of the algebra .
- The -linear map , is called the universal derivation of the algebra .
- For , the exterior power is called the module of Kaehler differential m-forms of the algebra .
- For the -th Fitting ideal of the module of Kaehler differential 1-forms is called the Kaehler different of the algebra .
More generally, for any -algebra , we can define the Noether different, module of Kaehler differential m-forms, Kaehler different of analogously. In particular, if is graded, then all these invariants are also graded.
Now let us embed the scheme in the projective -space via , where is a new indeterminate. Set and equip with the standard grading. The homogeneous vanishing ideal of is the homogenization of with respect to and denoted by , and the homogeneous coordinate ring of is the graded 1-dimensional ring . In this case is the Noetherian normalization of , and hence we can define the above invariants for the graded algebra . Moreover, we have the following further invariants.
- The graded -module is called the canonical module of the algebra .
- The graded locolization of at is called the homogeneous ring of quotients of .
- When the scheme is reduced (more general, locally Gorenstein), there is an injection and the inverse of in is called the Dedekind different of .
Many interesting properties of the scheme are reflexed by the algebraic structure of the above invariants.
Package Description
The zerodim
package provides functions for computing the introduced invariants of zero-dimensional schemes. In the graded case the package also provides functions for computations of the Hilbert functions of these invariants. Alias of the package is ZD
.
List of main functions
MinQuotIdeal(P, I, J): computes a min. homog. system of generators of homog. ideal (I+J)/I. input: P=K[x[1..N]], I and J homog. ideals of P output: list of polys
AffineNoetherDiff(P, I): computes a generating system"; of the Noether different of algebra R/K, R=P/I"; input: P=K[x[1..N]], I an ideal of P"; output: list of polys";
NoetherDifferent(P, I): computes a min.homog. gen. system of the Noether different of algebra R/K, R=P/I. input: P=K[x[1..N]], I an homog. ideal of P output: list of polys
NoetherDifferentRel(P, Ix): computes a min.homog. gen. system of the Noether different of R/K[x[0]], R=P/Ix. input: P=K[x[0..N]], Ix vanishing ideal of a 0-dim scheme X in P^n_K such that intersect(X,Z(x[0])) is empty output: list of polys
HilbertNoetherDiff(P, I): computes the Hilbert function of the Noether different of R/K, R=P/I. input: P=K[x[1..N]], I an homog. ideal of P output: the Hilbert function
HilbertNoetherDiffRel(P, Ix): computes the Hilbert function of the Noether different of R/K[x[0]], R=P/Ix. input: P=K[x[0..N]], Ix vanishing ideal of a 0-dim scheme X in P^n_K such that intersect(X,Z(x[0])) is empty output: the Hilbert function
AffineKaehlerDiff(P,I,m): computes a generating system of the m-th Kaehler different of algebra R/K, R=P/I. input: P=K[x[1..N]], I an ideal of P, m non-neg integer output: list of polys
KaehlerDifferent(P,I,m): computes a min.homog.gen. system of the m-th Kaehler different of algebra R/K, R=P/I. input: P=K[x[1..N]], I an homog. ideal, m non-neg integer output: list of polys
KaehlerDifferentRel(P, Ix): computes a min. homog.gen. system of the Kaehler different of R/K[x[0]], R=P/Ix. input: P=K[x[0..N]], Ix vanishing ideal of a 0-dim scheme X in P^n_K such that intersect(X,Z(x[0])) is empty output: list of polys
HilbertKaehlerDiff(P,I,m): computes the Hilbert function of the m-th Kaehler different of R/K, R=P/I. input: P=K[x[1..N]], I an homog. ideal, m non-neg integer output: the Hilbert function
HilbertKaehlerDiffRel(P, Ix): computes the Hilbert function of the Kaehler different of R/K[x[0]], R=P/Ix. input: P=K[x[0..N]], Ix vanishing ideal of a 0-dim scheme X in P^n_K such that intersect(X,Z(x[0])) is empty output: the Hilbert function
AffBMAlgo(LX,O): computes a list [GBasis,OrderIdeal,Separators] for a 0-dim ideal with its primary components LX. input: P=K[x[1..N]], LX list of 0-dim primary ideals q_j associated to a 0-dim ideal of P O list of K-bases of P/q_j output: [GBasis,OrderIdeal,Separators] of P/intersection(q_j)
DedekindDifferentRel(P,Points): computes a min.homog.gen. system of the Dedekind different of R/K[x[0]], where R=P/Ix and Ix is the vanishing ideal of Points. input: P=K[x[0..N]], Points=list of points in P^n_K not in Z(x[0]) output: list of polys
HilbertDedekindDiffRel(P,Points): computes the Hilbert function of the Dedekind different of R/K[x[0]], where R=P/Ix and Ix is the vanishing ideal of Points. input: P=K[x[0..N]], Points=list of points in P^n_K not in Z(x[0]) output: the Hilbert function
KaehlerDiffModule(P, Ix, m): computes a submodule U of P^t such that the module of Kaehler differential m-form has Omega^m(R/K)=P^t/U, R=P/Ix, t=binom{n}{m}. input: P=K[x[1..N]], Ix a non-zero ideal, m non-neg integer output: submodule with generators
HilbertKDM(P, Ix, m): computes the Hilbert function of the module of Kaehler differential m-form. input: P=K[x[1..N]], Ix a non-zero homog. ideal, 0<m<n+1 output: HF of Omega^m(R/K)
KDMOfPoints(P,Points,m): computes a submodule U of P^t such that the module of Kaehler differential m-form has Omega^m(R/K)=P^t/U, R=P/I_Points, t=binom{n}{m}. input: P=K[x[1..N]], Points=list of points, m non-neg integer output: submodule with generators
KDMOfProjectivePoints(P,Points,m): computes a submodule U of P^t such that the module of Kaehler differential m-form has Omega^m(R/K)=P^t/U, R=P/I_Points, t=binom{n}{m}. input: P=K[x[1..N]], Points=list of projective points, m non-neg integer output: submodule with generators
KDMRel(P, Ix, m): computes a submodule U of P^t such that the module of Kaehler differential m-form of R/K[x[0]] has Omega^m(R/K[x[0]])=P^t/U, R=P/Ix, t=binom{n}{m}. input: P=K[x[0..N]], Ix a non-zero homog. ideal such that K[x[0]] is the Noetherian normalization of R, m non-neg integer output: submodule with generators
HilbertKDMRel(P, Ix, m): computes the Hilbert function of the module of Kaehler differential m-form of R/K[x[0]]. input: P=K[x[0..N]], Ix a non-zero homog. ideal such that K[x[0]] is the Noetherian normalization of R, m non-neg integer"; output: HF of Omega^m(R/K[x_0])
Examples for computations
Now let us apply the zerodim
package to some concrete examples. Recall that the alias of the package is ZD
, and so to call a function from this package in computation one use [[/ZD.<functions-name>/]].
Consider the following example.
Use P ::= QQ[x,y,z]; G := [x^2 -z^2, x*y +z^2, y^2 -2*z^2]; L := SB.SAGBI(G); f := x^10*y^2 +x^6*y^6 -2*x^10*z^2 -5*x^8*y^2*z^2 +6*x^5*y^5*z^2 +10*x^8*z^4 +10*x^6*y^2*z^4 +15*x^4*y^4*z^4 -20*x^6*z^6 -10*x^4*y^2*z^6 +20*x^3*y^3*z^6 +20*x^4*z^8 +20*x^2*y^2*z^8 -10*x^2*z^10 +6*x*y*z^10 -y^2*z^10 +3*z^12; b := SB.IsInSubalgebra(f,G); h := SB.SubalgebraHS(G);
While this is only a simple example, the second code is much faster. At the time this is written, the second computation is approximately two times as fast as the first one.