|  |  3.3.2 General syntax of a ring declaration 
  Rings 
Syntax:
ringname=(coefficients),(names_of_ring_variables),(ordering);or
 ringname=cring[names_of_ring_variables]Default:
(ZZ/32003)[x,y,z];Purpose:
declares a ring and sets it as the current basering.
The second form sets the ordering to (dp,C).cringstands currently forQQ(the rationals),ZZ(the integers)
or(ZZ/m)(the field (m prime and <2147483648) resp. ring of the integers modulo m). 
The coefficients (for the first form) are given by one of the following:
 
a cringas given above
a non-negative int_expression less than 2147483648 (2^31).
The int_expression should either be 0, specifying the field of
rational numbers Q, or a prime number p, specifying the finite field
with p elements.  If it is not a prime number, int_expression is
converted to the next lower prime number.
 
an expression_list of an int_expression and one or more names.
The int_expression specifies the characteristic of the coefficient
field as described above. The names are used as parameters in
transcendental or algebraic extensions of the coefficient
field. Algebraic extensions are implemented for one parameter only. In
this case, a minimal polynomial has to be defined by an assignment to
 minpoly. See  minpoly.
an expression_list of an int_expression and a name.
The int_expression has to be a prime number p to the power of a
positive integer n. This defines the Galois field
  with  elements, where  has to be less than or equal to  .The given name refers to a primitive element of  generating the multiplicative group.  Due to a different internal
representation, the arithmetic operations in these coefficient fields
are faster than arithmetic operations in algebraic extensions as
described above. 
an expression_list of the name realand two optional int_expressions
determining the precision in decimal digits and
the size for the stabilizing rest. The default for the rest is the same size
as for the representation.
An exeption is the namerealwithout any integers.
These numbers are implemented as machine floating point numbers
of single precision.
Note that computations over all these fields are not exact.
an expression_list of the name complex,
two optional int_expression and a name.
This specifies the field of complex numbers represented by floating point
numbers with a precision similar toreal. An expression_list
without int_expression defines a precision and rest with length 6.
The name of the imaginary unit is given by the last parameter.
Note that computations over these fields are not exact.
an expression_list with the name integer. This specifies the ring of integers.
an expression_list with the name integerand one subsequent int_expression.
This specifies the ring of integers modulo the given int_expression.
an expression_list with the name integerand two int_expressionsbande.
This specifies the ring of integers modulo b^e. Ifb = 2ande < int_bit_sizean optimized implementation is used.
 
'names_of_ring_variables' is a list of names or indexed names.
 
'ordering' is a list of block orderings where each block ordering is either
 
 
lp,dp,Dp,ls,ds, orDsoptionally followed by a size parameter in parentheses.
wp,Wp,ws,Ws, orafollowed by a
weight vector given as an intvec_expression in parentheses.
Mfollowed by an intmat_expression in parentheses.
corC. 
For the definition of the orderings, see  Monomial orderings.
 
If one of coefficients, names_of_ring_variables, and ordering
consists of only one entry, the parentheses around this entry may be
omitted.
 
  Quotient rings 
Syntax:
qringname=ideal_expression;Default:
none
Purpose:
declares a quotient ring as the basering modulo ideal_expression, and sets
it as current basering.
 
ideal_expression has to be represented by a standard basis.
 
The most convenient way to map objects from a ring to its quotient ring
and vice versa is to use the fetchfunction (see  fetch). 
SINGULAR computes in a quotient ring as long as possible with the
given representative of a polynomial, say, f.  I.e., it usually
does not reducefw.r.t. the quotient ideal.  This is only done
when necessary
during standard bases computations or by an explicit reduction using
the commandreduce(f, std(0))(see  reduce). 
Operations based on standard bases (e.g. std,groebner, etc.,reduce) and functions which require a standard basis (e.g.dim,hilb, etc.) operated with the residue classes; all others on the polynomial objects. 
Example:
 |  |   // defintion and usage:
  ring r=(ZZ/32003)[x,y];
  poly f=x3+yx2+3y+4;
  qring q=std(maxideal(2));
  basering;
==> // coefficients: ZZ/32003
==> // number of vars : 2
==> //        block   1 : ordering dp
==> //                  : names    x y
==> //        block   2 : ordering C
==> // quotient ring from ideal
==> _[1]=y2
==> _[2]=xy
==> _[3]=x2
  poly g=fetch(r, f);
  g;
==> x3+x2y+3y+4
  reduce(g,std(0));
==> 3y+4
  // polynomial and residue class:
  ring R=QQ[x,y];
  qring Q=std(y);
  poly p1=x;
  poly p2=x+y;
  // comparing polynomial objects:
  p1==p2;
==> 0
  // comparing residue classes:
  reduce(p1,std(0))==reduce(p2,std(0));
==> 1
 | 
 
 |