Difference between revisions of "ApCoCoA-1:Num.SubABM"
m (replaced <quotes> tag by real quotes) |
|||
(12 intermediate revisions by 5 users not shown) | |||
Line 1: | Line 1: | ||
− | <command> | + | {{Version|1}} |
+ | <command> | ||
<title>Num.SubABM</title> | <title>Num.SubABM</title> | ||
− | <short_description>Computes a border basis of an almost vanishing sub-ideal for a set of points and ideal.</short_description> | + | <short_description>Computes a border basis of an almost vanishing sub-ideal for a set of points and an ideal using the <ref>ApCoCoA-1:Num.ABM|Num.ABM</ref> algorithm.</short_description> |
<syntax> | <syntax> | ||
− | Num.SubABM(Points:MAT, | + | Num.SubABM(Points:MAT, Epsilon:RAT, Basis:LIST):Object |
− | Num.SubABM(Points:MAT, | + | Num.SubABM(Points:MAT, Epsilon:RAT, Basis:LIST, Delta:RAT, ForbiddenMonomials:List, NormalizeType:INT):Object |
</syntax> | </syntax> | ||
<description> | <description> | ||
<em>Please note:</em> The function(s) explained on this page is/are using the <em>ApCoCoAServer</em>. You will have to start the ApCoCoAServer in order to use it/them. | <em>Please note:</em> The function(s) explained on this page is/are using the <em>ApCoCoAServer</em>. You will have to start the ApCoCoAServer in order to use it/them. | ||
<par/> | <par/> | ||
− | This command computes a border basis of an almost vanishing sub-ideal for a set of points and ideal. | + | This command computes a border basis of an almost vanishing sub-ideal for a set of points and an ideal using the <ref>ApCoCoA-1:Num.ABM|Num.ABM</ref> algorithm. |
<par/> | <par/> | ||
− | The current ring has to be a ring over the | + | The current ring has to be a ring over the rational numbers with a standard-degree |
− | compatible term-ordering. | + | compatible term-ordering. Each row in the matrix <tt>Points</tt> represents one point, so the number of columns must equal the |
− | |||
number of indeterminates in the current ring. | number of indeterminates in the current ring. | ||
Line 19: | Line 19: | ||
<item>@param <em>Points</em> The points for which a border basis is computed.</item> | <item>@param <em>Points</em> The points for which a border basis is computed.</item> | ||
− | <item>@param <em> | + | <item>@param <em>Epsilon</em> A positive rational number describing the maximal admissible least squares error for a polynomial. (Bigger values for <tt>Epsilon</tt> lead to bigger errors of the polynomials evaluated at the point set). <tt>Epsilon</tt> should be in the interval (0,1). As a rule of thumb, <tt>Epsilon</tt> is the expected percentage of error on the input points. </item> |
− | <item>@param <em> | + | <item>@param <em>Basis</em> A set of polynomials in the current ring. This basis defines the ideal in which we compute the basis of the approximate vanishing ideal.</item> |
<item>@return A list of two results. First the border basis as a list of polynomials, second the vector space basis of P/I as a list of terms.</item> | <item>@return A list of two results. First the border basis as a list of polynomials, second the vector space basis of P/I as a list of terms.</item> | ||
Line 29: | Line 29: | ||
The following parameters are optional: | The following parameters are optional: | ||
<itemize> | <itemize> | ||
− | <item>@param <em>Delta</em> A | + | <item>@param <em>Delta</em> A positive rational number which describes the computing precision. In different steps, it is crucial, if a value is 0 or not. The algorithm assumes every value in <tt>[-Delta, Delta]</tt> to be 0. The default value for <tt>Delta</tt> is 0.00000000001.</item> |
− | <item>@param <em>NormalizeType</em> A integer of the | + | <item>@param <em>ForbiddenTerms</em> A list containing the terms which are not allowed to show up in the order ideal.</item> |
+ | |||
+ | <item>@param <em>NormalizeType</em> A integer of the set <tt>{1,2,3,4}</tt>. The default value is 2. This parameter describes, if and where required the input points are normalized. If <tt>NormalizeType</tt> equals 1, each coordinate of a point is divided by the maximal absolute value of all coordinates of this point. This ensures that all coordinates of the points are within <tt>[-1,1]</tt>. With <tt>NormalizeType=2</tt> no normalization is done at all. <tt>NormalizeType=3</tt> shifts each coordinate to <tt>[-1,1]</tt>, i.e. the minimal coordinate of a point is mapped to -1 and the maximal coordinate to 1, which describes a unique affine mapping. The last option is <tt>NormalizeType=4</tt>. In this case, each point is normalized by its euclidean norm. Although <tt>NormalizeType=3</tt> is in most cases a better choice, the default value is due to backward compatibility 1.</item> | ||
</itemize> | </itemize> | ||
Line 39: | Line 41: | ||
Points := Mat([[2/3,0,0],[0,1,0],[0,0,1/3]]); | Points := Mat([[2/3,0,0],[0,1,0],[0,0,1/3]]); | ||
− | R:=Num.SubABM(Points, 0.1, [ | + | R:=Num.SubABM(Points, 0.1, [x]); |
Dec(R[1],2); | Dec(R[1],2); | ||
R[2]; | R[2]; | ||
− | -- CoCoAServer: computing Cpu Time = 0 | + | -- CoCoAServer: computing Cpu Time = 0 |
------------------------------- | ------------------------------- | ||
− | [ | + | ["1 xz ", "1 xy ", "1 x^2 -0.66 x "] |
------------------------------- | ------------------------------- | ||
− | [ | + | [x] |
------------------------------- | ------------------------------- | ||
</example> | </example> | ||
</description> | </description> | ||
<seealso> | <seealso> | ||
− | <see>Introduction to CoCoAServer</see> | + | <see>ApCoCoA-1:Introduction to CoCoAServer|Introduction to CoCoAServer</see> |
− | <see>Num.ABM</see> | + | <see>ApCoCoA-1:Num.ABM|Num.ABM</see> |
</seealso> | </seealso> | ||
<types> | <types> | ||
Line 63: | Line 65: | ||
<key>num.SubABM</key> | <key>num.SubABM</key> | ||
<key>numerical.subabm</key> | <key>numerical.subabm</key> | ||
− | <wiki-category>Package_numerical</wiki-category> | + | <wiki-category>ApCoCoA-1:Package_numerical</wiki-category> |
</command> | </command> |
Latest revision as of 13:48, 29 October 2020
This article is about a function from ApCoCoA-1. |
Num.SubABM
Computes a border basis of an almost vanishing sub-ideal for a set of points and an ideal using the Num.ABM algorithm.
Syntax
Num.SubABM(Points:MAT, Epsilon:RAT, Basis:LIST):Object Num.SubABM(Points:MAT, Epsilon:RAT, Basis:LIST, Delta:RAT, ForbiddenMonomials:List, NormalizeType:INT):Object
Description
Please note: The function(s) explained on this page is/are using the ApCoCoAServer. You will have to start the ApCoCoAServer in order to use it/them.
This command computes a border basis of an almost vanishing sub-ideal for a set of points and an ideal using the Num.ABM algorithm.
The current ring has to be a ring over the rational numbers with a standard-degree
compatible term-ordering. Each row in the matrix Points represents one point, so the number of columns must equal the
number of indeterminates in the current ring.
@param Points The points for which a border basis is computed.
@param Epsilon A positive rational number describing the maximal admissible least squares error for a polynomial. (Bigger values for Epsilon lead to bigger errors of the polynomials evaluated at the point set). Epsilon should be in the interval (0,1). As a rule of thumb, Epsilon is the expected percentage of error on the input points.
@param Basis A set of polynomials in the current ring. This basis defines the ideal in which we compute the basis of the approximate vanishing ideal.
@return A list of two results. First the border basis as a list of polynomials, second the vector space basis of P/I as a list of terms.
The following parameters are optional:
@param Delta A positive rational number which describes the computing precision. In different steps, it is crucial, if a value is 0 or not. The algorithm assumes every value in [-Delta, Delta] to be 0. The default value for Delta is 0.00000000001.
@param ForbiddenTerms A list containing the terms which are not allowed to show up in the order ideal.
@param NormalizeType A integer of the set {1,2,3,4}. The default value is 2. This parameter describes, if and where required the input points are normalized. If NormalizeType equals 1, each coordinate of a point is divided by the maximal absolute value of all coordinates of this point. This ensures that all coordinates of the points are within [-1,1]. With NormalizeType=2 no normalization is done at all. NormalizeType=3 shifts each coordinate to [-1,1], i.e. the minimal coordinate of a point is mapped to -1 and the maximal coordinate to 1, which describes a unique affine mapping. The last option is NormalizeType=4. In this case, each point is normalized by its euclidean norm. Although NormalizeType=3 is in most cases a better choice, the default value is due to backward compatibility 1.
Example
Use P::=QQ[x,y,z]; Points := Mat([[2/3,0,0],[0,1,0],[0,0,1/3]]); R:=Num.SubABM(Points, 0.1, [x]); Dec(R[1],2); R[2]; -- CoCoAServer: computing Cpu Time = 0 ------------------------------- ["1 xz ", "1 xy ", "1 x^2 -0.66 x "] ------------------------------- [x] -------------------------------
See also