Public Types | |
typedef void | output_function_type (std::ostream &s, const Variable &v) |
Type of output functions. | |
Public Member Functions | |
Variable (dimension_type i) | |
Builds the variable corresponding to the Cartesian axis of index i . | |
dimension_type | id () const |
Returns the index of the Cartesian axis associated to the variable. | |
dimension_type | space_dimension () const |
Returns the dimension of the vector space enclosing *this . | |
memory_size_type | total_memory_in_bytes () const |
Returns the total size in bytes of the memory occupied by *this . | |
memory_size_type | external_memory_in_bytes () const |
Returns the size in bytes of the memory managed by *this . | |
bool | OK () const |
Checks if all the invariants are satisfied. | |
Static Public Member Functions | |
static dimension_type | max_space_dimension () |
Returns the maximum space dimension a Variable can handle. | |
static void | set_output_function (output_function_type *p) |
Sets the output function to be used for printing Variable objects. | |
static output_function_type * | get_output_function () |
Returns the pointer to the current output function. | |
Friends | |
std::ostream & | operator<< (std::ostream &s, const Variable &v) |
Output operator. | |
Related Functions | |
(Note that these are not member functions.) | |
bool | less (Variable v, Variable w) |
Defines a total ordering on variables. | |
Classes | |
struct | Compare |
Binary predicate defining the total ordering on variables. More... |
An object of the class Variable represents a dimension of the space, that is one of the Cartesian axes. Variables are used as basic blocks in order to build more complex linear expressions. Each variable is identified by a non-negative integer, representing the index of the corresponding Cartesian axis (the first axis has index 0). The space dimension of a variable is the dimension of the vector space made by all the Cartesian axes having an index less than or equal to that of the considered variable; thus, if a variable has index , its space dimension is
.
Note that the ``meaning'' of an object of the class Variable is completely specified by the integer index provided to its constructor: be careful not to be mislead by C++ language variable names. For instance, in the following example the linear expressions e1
and e2
are equivalent, since the two variables x
and z
denote the same Cartesian axis.
Variable x(0); Variable y(1); Variable z(0); Linear_Expression e1 = x + y; Linear_Expression e2 = y + z;
Parma_Polyhedra_Library::Variable::Variable | ( | dimension_type | i | ) | [inline, explicit] |
Builds the variable corresponding to the Cartesian axis of index i
.
std::length_error | Thrown if the i+1 exceeds Variable::max_space_dimension() . |
dimension_type Parma_Polyhedra_Library::Variable::space_dimension | ( | ) | const [inline] |
Returns the dimension of the vector space enclosing *this
.
The returned value is id()+1
.