|
Calling Sequence
|
|
IntersectionMultiplicity(P, F, V, options)
IntersectionMultiplicity(P, rc1, R, options)
IntersectionMultiplicity(rc2, F, R, options)
|
|
Parameters
|
|
P
|
-
|
list of algebraic numbers; the point
|
F
|
-
|
list of polynomials with algebraic number coefficients in variables
|
V
|
-
|
list of names; the variables
|
rc1,rc2
|
-
|
regular chains of dimension zero
|
R
|
-
|
polynomial ring of characteristic zero
|
options
|
-
|
sequence of optional equations of the form keyword=value, where keyword is maxdepth, maxshift, or method
|
|
|
|
|
Returns
|
|
•
|
The calling sequence IntersectionMultiplicity(P, F, V) returns either the intersection multiplicity of at as a nonnegative integer, or if the algorithm cannot determine the intersection multiplicity.
|
•
|
The calling sequence IntersectionMultiplicity(P, rc1, R) returns the intersection multiplicity of the regular chain at .
|
•
|
The calling sequence IntersectionMultiplicity(rc2, F, R) returns a list of pairs, , such that is either the intersection multiplicity of all points in the vanishing set of the regular chain , or . Moreover, the regular chains, , contained in the output list, form a triangular decomposition of the zero set of .
|
|
|
Assumptions
|
|
•
|
The system is square. That is, when the first argument is a point and the second is a list, is required. When the second argument is a regular chain, must have as many elements as there are variables in . When the first argument is a regular chain, must have as many equations as there are variables in .
|
•
|
For the calling sequence IntersectionMultiplicity(P, F, V) it is assumed is a regular sequence in the local ring at .
|
•
|
For the calling sequence IntersectionMultiplicity(rc2, F, R) it is assumed is a regular sequence in the local ring at all points encoded by .
|
•
|
The local ring at a point is the set of all polynomial fractions defined at .
|
•
|
Let be elements in the local ring at some point . We say is a regular sequence in the local ring at , or a regular sequence for short, when no is zero or a zero-divisor modulo the ideal generated by any subset of the remaining elements of . Moreover, we require generates a proper ideal in the local ring at .
|
•
|
When the elements of do not generate a proper ideal, i.e. the ideal generated contains 1, the intersection multiplicity is trivially zero. Hence, the assumption that is a regular sequence is only required when the intersection multiplicity at is positive.
|
|
|
Options
|
|
The behavior of IntersectionMultiplicity differs depending on whether it is used to compute the intersection multiplicity at a point or a regular chain. The different optional arguments reflect this change in behavior.
For the calling sequence where the second argument is a regular chain, all optional arguments are ignored.
•
|
method : either fulton, tangentcone, or hybrid (default); specifies the method used to compute intersection multiplicities. This option is ignored when the first argument is a point.
|
–
|
When the first argument is a regular chain, IntersectionMultiplicity calls up to two partial algorithms. Each of these algorithms can be accessed individually using the keyword method, in which case IntersectionMultiplicity would invoke only the algorithm corresponding to the value of the keyword method.
|
–
|
The first partial algorithm, described in [3], uses a generalization of Fulton's bivariate intersection multiplicity algorithm to more than variables. This algorithm is also the one used by IntersectionMultiplicity when the first argument is a point. When the first argument is a regular chain this algorithm can be invoked directly by specifying method=fulton.
|
–
|
The second partial algorithm, described in [1,2], uses a criterion based on tangent cones to reduce to Fulton's bivariate intersection multiplicity algorithm. This algorithm can be invoked directly using method=tangentcone. Additionally, when method=tangentcone is given and the algorithm does not succeed in computing the intersection multiplicity at every point in , an error is returned rather then a list of pairs.
|
–
|
When method=hybrid, IntersectionMultiplicity first calls the algorithm described in [3], and if it did not succeed in computing the intersection multiplicity at every point in , the algorithm described in [1,2] will be called as well. If neither algorithm succeeds in computing the intersection multiplicity at every point in , the output of the first algorithm is returned, namely, a list of pairs (which may contain ).
|
–
|
For strict backwards compatibility with Maple versions 2021 and earlier, method=tangentcone can be used.
|
•
|
maxshift : nonnegative integer; maximum number of variable reorderings to be applied
|
–
|
The algorithm described in [3] and its generalization for regular chains assign an arbitrary variable ordering to the input. This can be changed manually by giving the variables in or in a different order. When this occurs, the corresponding point or regular chain must also be reordered accordingly.
|
–
|
It is possible the algorithm described in [3] fails for one ordering but succeeds for another. Moreover, it is impractical to try all possible variable orderings. Upon detecting a failure, IntersectionMultiplicity will apply a left, circular shift to the variables, when written in decreasing order, up to maxshift many times. The user can also reorder variables manually to work past a failure.
|
–
|
When the first argument is a point, maxshift is set to by default. When the first argument is a regular chain, maxshift is set to as default.
|
•
|
maxdepth : nonnegative integer,pos_infinity; the maximum number of recursive calls
|
–
|
When is not a regular sequence, IntersectionMultiplicity may not always terminate. In this case the maxdepth option can be used to control the maximum allowable amount of recursive calls made by IntersectionMultiplicity.
|
–
|
The default value of maxdepth is proportional to the number of variables times the product of the total degree of all polynomials in . When the number of recursive calls made exceeds maxdepth it is likely that is not a regular sequence, and hence an error is returned.
|
–
|
When this error occurs there are several ways to proceed. This error suggests it is likely is not a regular sequence, and hence this constraint should be checked. Alternatively, if is believed to be a regular sequence, one could try increasing the value of maxdepth.
|
–
|
Setting maxdepth=infinity disables this option, removing the limit on the number of allowable recursive calls. This may be desirable for long computations. When maxdepth is set to , or when maxdepth is much lower than the stacklimit kernel option, an error may occur if the number of recursive calls made exceeds the stacklimit. In this case, if kernelopts(stacklimit) is less than the hard limit set by Maple, one can try increasing kernelopts(stacklimit).
|
–
|
To check whether is a regular sequence in the local ring at , compute the primary decomposition of each in and remove any primary components which do not vanish on . If any two share a primary component through , is not a regular sequence in the local ring at .
|
–
|
When the first argument is a regular chain, this must be repeated for each point encoded in the regular chain.
|
•
|
Both the maxdepth and maxshift options are ignored when method=tangentcone is specified.
|
|
|
Description
|
|
•
|
The IntersectionMultiplicity command computes the intersection multiplicity of a system of equations at a point or at a group of points encoded by a zero-dimensional regular chain. See the references for a formal definition of the intersection multiplicity.
|
•
|
Unless or the second argument is a regular chain, the underlying algorithms to the IntersectionMultiplicity command may fail, in which case is returned.
|
•
|
This command is part of the RegularChains[AlgebraicGeometryTools] package, so it can be used in the form IntersectionMultiplicity(..) only after executing the command with(RegularChains[AlgebraicGeometryTools]). However, it can always be accessed through the long form of the command by using RegularChains[AlgebraicGeometryTools][IntersectionMultiplicity](..).
|
|
|
Examples
|
|
>
|
|
>
|
|
>
|
|
Compute the intersection multiplicity of four polynomials in four variables at the origin.
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
The point at which we compute the intersection multiplicity need not be the origin.
>
|
|
>
|
|
When the first argument is a point, we can also use algebraic number coefficients and coordinates, specified by RootOfs.
>
|
|
>
|
|
| (9) |
>
|
|
| (10) |
>
|
|
When the intersection multiplicity is non-zero, it is required that forms a regular sequence in the local ring at for the algorithm to succeed. When a non-regular sequence is detected, an error will be thrown.
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
The IntersectionMultiplicity command cannot always detect non-regular sequences. Often, a non-regular sequence which is not detected will lead to excessive recursive calls. When this is so, the IntersectionMultiplicity command will return an error which warns the input received may not be a regular sequence.
This bound on the recursive calls can be controlled by the maxdepth option. The default for maxdepth is proportional to the both the number of variables and total degrees of the input polynomials. Moreover, the default is set quite high to mitigate the risk of this warning being given when the input is indeed a regular sequence.
>
|
|
>
|
|
When this error occurs it is likely the input is not a regular sequence. This can be checked by using primary decomposition and considering only those components in the maximal ideal of the local ring.
>
|
|
>
|
|
| (12) |
>
|
|
| (13) |
>
|
|
Here we can see that is contained in a prime component of the ideal generated by and in the local ring at , which proves that is not a regular sequence.
Sometimes, it may be desirable to disable the maxdepth option by setting maxdepth=infinity. In this case, it is possible that IntersectionMultiplicity exceeds the maximum amount of recursive calls set by kernelopts(stacklimit). In some cases, it can therefore help to increase kernelopts(stacklimit) to avoid this error.
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
>
|
|
The underlying algorithm used to compute intersection multiplicities is a partial algorithm, and hence, may not always succeed. In such a case, is returned to indicate the procedure was not successful. See the references for more details.
>
|
|
>
|
|
>
|
|
Often, reordering the variables can help to work around a failure. This can be done manually by changing the order of variables in or by using the maxshift option. Note in this case is the origin so we do not need to reorder .
>
|
|
Setting maxshift=2 is equivalent to calling IntersectionMultiplicity with , then , then , where is the ordering which succeeds.
>
|
|
When the system of polynomials is in fact given by a regular chain, the intersection multiplicity can always be computed.
>
|
|
>
|
|
>
|
|
IntersectionMultiplicity can also be used to compute the intersection multiplicity at a group of points encoded by a zero-dimensional regular chain.
When the regular chain, , encodes just one point, the IntersectionMultiplicity command behaves analogously to when the first argument is a point. Here encodes just the origin.
>
|
|
>
|
|
>
|
|
| (21) |
| (22) |
>
|
|
| (23) |
| (24) |
>
|
|
| (25) |
| (26) |
>
|
|
| (27) |
| (28) |
>
|
|
| (29) |
| (30) |
>
|
|
| (31) |
| (32) |
Often, a regular chain will encode several points with different intersection multiplicities, in which case several regular chains, and the intersection multiplicity corresponding to every point encoded in each regular chain, will be returned.
>
|
|
>
|
|
>
|
|
>
|
|
| (33) |
| (34) |
Here, calling IntersectionMultiplicity returns 3 regular chains, encoding 5 points, and the intersection multiplicity corresponding to all points in encoded in each regular chain. The first regular chain encodes the points and , which both have intersection multiplicity . The second regular chain encodes the points and which have intersection multiplicity 1. Finally, the origin, encoded by the last regular chain, has intersection multiplicity .
When the first argument is a regular chain, the method option can be used to control which partial algorithm IntersectionMultiplicity should invoke.
Here the algorithm described in [3] succeeds whereas the criterion described in [1,2] does not apply.
>
|
|
>
|
|
>
|
|
| (35) |
Similarly, the algorithm described in [1,2] can be used to compute some examples the algorithm described in [3] cannot. Here, the algorithm described in [3] fails for the given variable ordering but the algorithm described in [1,2] succeeds.
>
|
|
>
|
|
>
|
|
| (37) |
>
|
|
| (38) |
As was the case previously, the underlying algorithm used to compute intersection multiplicities is a partial algorithm, and hence, may not always succeed. When method=hybrid or method=fulton is given, a failure in the branch denoted by the regular chain , will be represented by the pair in the output list.
Here we see a failure occur in the regular chain encoding the origin.
>
|
|
>
|
|
>
|
|
| (39) |
| (40) |
When method=tangentcone, the algorithm will instead return an error when it cannot compute the intersection multiplicity of every point in the regular chain .
>
|
|
>
|
|
>
|
|
|
|
References
|
|
|
[1] Steffen Marcus, Marc Moreno Maza, Paul Vrbik, On Fulton's Algorithm for Computing Intersection Multiplicities. Computer Algebra in Scientific Computing (CASC 2012), Lecture Notes in Computer Science 7442, (2012), 198-211.
|
|
[2] Parisa Alvandi, Marc Moreno Maza, Eric Schost, Paul Vrbik, A Standard Basis Free Algorithm for Computing the Tangent Cones of a Space Curve. Computer Algebra in Scientific Computing (CASC 2015), Lecture Notes in Computer Science 9301, (2015), 45-60.
|
|
[3] M. Moreno Maza and R. Sandford. Towards Extending Fulton's Intersection Multiplicity Algorithm Beyond the Bivariate Case. Computer Algebra in Scientific Computing (CASC 2021), Lecture Notes in Computer Science 12865, (2021), 232-251.
|
|
|
Compatibility
|
|
•
|
The method=tangentcone corresponds to the algorithm in Maple 2020 and 2021.
|
•
|
The RegularChains:-AlgebraicGeometryTools:-IntersectionMultiplicity command was introduced in Maple 2020.
|
•
|
The RegularChains:-AlgebraicGeometryTools:-IntersectionMultiplicity command was updated in Maple 2022.
|
•
|
The P parameter was introduced in Maple 2022.
|
•
|
The method, maxshift and maxdepth options were introduced in Maple 2022.
|
|
|
|