NO FRAMES

Class IloNumToAnySetStepFunction

Definition file: ilconcert/ilosetfunc.h

An instance of IloNumToAnySetStepFunction represents a step function that associates sets with intervals. It is defined everywhere on an interval [xMin,xMax). Each interval [x1,x2) on which the function has the same set is called a step.

Note that if n is the number of steps of the function, the random access to a given step (see the member functions IloNumToAnySetStepFunction::add, IloNumToAnySetStepFunction::alwaysIntersects, IloNumToAnySetStepFunction::contains, IloNumToAnySetStepFunction::empty, IloNumToAnySetStepFunction::everContains, IloNumToAnySetStepFunction::everIntersects, IloNumToAnySetStepFunction::fill, IloNumToAnySetStepFunction::getComplementSet, IloNumToAnySetStepFunction::getSet, IloNumToAnySetStepFunction::intersects, IloNumToAnySetStepFunction::isEmpty, IloNumToAnySetStepFunction::isFull, IloNumToAnySetStepFunction::remove, IloNumToAnySetStepFunction::set, and IloNumToAnySetStepFunction::setIntersection) has a worst-case complexity of O(log(n)).

Complementary Representation of Values

IloNumToAnySetStepFunction allows the implicit representation of infinite sets through the representation of the complement of the actual set value. This, for example, allows you to completely fill a set (using the IloNumToAnySetStepFunction::fill member function) and then specify the elements that are not in the set. Under normal circumstances, it is not necessary to know if the value of the step function at a particular point is represented by the set or its complement: all the member functions that manipulate the step function value will correctly adapt to either representation. The only case where it is necessary to know the internal representation is if you want to directly access the set that represents a value (using the IloNumToAnySetStepFunction::getSet or IloNumToAnySetStepFunction::getComplementSet member functions). In that circumstance only, it is necessary to use the IloNumToAnySetStepFunction::usesComplementaryRepresentation member function to determine the internal representation, and then use either IloNumToAnySetStepFunction::getSet or IloNumToAnySetStepFunction::getComplementSet depending on the return value of IloNumToAnySetStepFunction::usesComplementaryRepresentation. Note that IloNumToAnySetStepFunction::getSet will raise an error if it is used to access a set that is represented as a complement set. IloNumToAnySetStepFunction::getComplementSet will raise an error if it is used to access a set that is directly represented.

See Also:

Constructor Summary
public IloNumToAnySetStepFunction(const IloEnv, IloNum, IloNum, const char *)
public IloNumToAnySetStepFunction(const IloEnv, IloNum, IloNum, const IloAnySet, const char *)
Method Summary
public voidadd(const IloNumToAnySetStepFunction)
public voidadd(IloNum, IloNum, IloAny)
public voidadd(IloNum, IloNum, const IloAnySet, IloBool)
public IloBoolalwaysContains(const IloNumToAnySetStepFunction)
public IloBoolalwaysContains(IloNum, IloNum, const IloAnySet)
public IloBoolalwaysContains(IloNum, IloNum, IloAny)
public IloBoolalwaysIntersects(const IloNumToAnySetStepFunction)
public IloBoolalwaysIntersects(IloNum, IloNum, const IloAnySet)
public IloBoolcontains(IloNum, const IloAnySet)
public IloBoolcontains(IloNum, IloAny)
public voiddilate(IloNum)
public voidempty(IloNum, IloNum)
public IloBooleverContains(const IloNumToAnySetStepFunction)
public IloBooleverContains(IloNum, IloNum, const IloAnySet)
public IloBooleverContains(IloNum, IloNum, IloAny)
public IloBooleverIntersects(const IloNumToAnySetStepFunction)
public IloBooleverIntersects(IloNum, IloNum, const IloAnySet)
public voidfill(IloNum, IloNum)
public IloAnySetgetComplementSet(IloNum)
public IloNumgetDefinitionIntervalMax()
public IloNumgetDefinitionIntervalMin()
public IloAnySetgetSet(IloNum)
public IloBoolintersects(IloNum, const IloAnySet)
public IloBoolisEmpty(IloNum)
public IloBoolisFull(IloNum)
public voidremove(const IloNumToAnySetStepFunction)
public voidremove(IloNum, IloNum, IloAny)
public voidremove(IloNum, IloNum, const IloAnySet, IloBool)
public voidset(IloNum, IloNum, IloAny)
public voidset(IloNum, IloNum, const IloAnySet, IloBool)
public voidsetIntersection(const IloNumToAnySetStepFunction)
public voidsetIntersection(IloNum, IloNum, IloAny)
public voidsetIntersection(IloNum, IloNum, const IloAnySet, IloBool)
public voidsetPeriodic(const IloNumToAnySetStepFunction, IloNum, IloNum, const IloAnySet)
public voidshift(IloNum, const IloAnySet)
public IloBoolusesComplementaryRepresentation(IloNum)
Constructor Detail

IloNumToAnySetStepFunction

public IloNumToAnySetStepFunction(const IloEnv env, IloNum xmin, IloNum xmax, const char * name)

This constructor creates a step function defined everywhere on the interval [xMin, xMax) with empty set as the value.


IloNumToAnySetStepFunction

public IloNumToAnySetStepFunction(const IloEnv env, IloNum xmin, IloNum xmax, const IloAnySet dval, const char * name)

This constructor creates a step function defined everywhere on the interval [xMin, xMax) with the same set dval.


Method Detail

add

public void add(const IloNumToAnySetStepFunction f)

This member function adds the value of f at point x to the value of the invoking step function at point x, for all points x in the definition interval of the invoking step function. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


add

public void add(IloNum xMin, IloNum xMax, IloAny elt)

This member function adds elt to the value of the invoking step function on the interval [xMin, xMax).


add

public void add(IloNum xMin, IloNum xMax, const IloAnySet elts, IloBool complt)

This member function adds the elements of elts to the value of the invoking step function on the interval [xMin, xMax).


alwaysContains

public IloBool alwaysContains(const IloNumToAnySetStepFunction f)

This member function returns IloTrue if for all points x on the definition interval of the invoking step function, the value of f at point x is a subset of the value of the invoking step function at point x. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


alwaysContains

public IloBool alwaysContains(IloNum xMin, IloNum xMax, const IloAnySet elts)

This member function returns IloTrue if elts is a subset of the value of the invoking step function at all points on the interval [xMin, xMax).


alwaysContains

public IloBool alwaysContains(IloNum xMin, IloNum xMax, IloAny elt)

This member function returns IloTrue if at all points on the interval [xMin, xMax) the value of the invoking step function contains elt.


alwaysIntersects

public IloBool alwaysIntersects(const IloNumToAnySetStepFunction f)

This member function returns IloTrue if for all points x in the definition interval of the invoking step function, the intersection of f and the invoking step function is not empty. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


alwaysIntersects

public IloBool alwaysIntersects(IloNum xMin, IloNum xMax, const IloAnySet elts)

This member function returns IloTrue if for all x on the interval [xMin, xMax) the intersection of elts and the value of the invoking step function at point x is not empty.


contains

public IloBool contains(IloNum x, const IloAnySet elts)

This member function returns IloTrue if elts is a subset of the value of the invoking step function at point x.


contains

public IloBool contains(IloNum x, IloAny elt)

This member function returns IloTrue if the invoking step function contains element elt at point x.


dilate

public void dilate(IloNum k)

This member function multiplies by k the scale of x for the invoking step function. k must be a non-negative numerical value. More precisely, if the invoking step function was defined over an interval [xMin, xMax), it will be redefined over the interval [k*xMin, k*xMax) and the value at x will be the former value at x/k.


empty

public void empty(IloNum xMin, IloNum xMax)

This member function sets the value of the invoking step function on the interval [xMin, xMax) to be the empty set.


everContains

public IloBool everContains(const IloNumToAnySetStepFunction f)

This member function returns IloTrue if at any point x in the definition interval of the invoking step function, f at point x is a subset of the invoking step function at point x. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


everContains

public IloBool everContains(IloNum xMin, IloNum xMax, const IloAnySet elts)

This member function returns IloTrue if at any point on the interval [xMin, xMax)elts is a subset of the value of the invoking step function.


everContains

public IloBool everContains(IloNum xMin, IloNum xMax, IloAny elt)

This member function returns IloTrue if at any point on the interval [xMin, xMax) the value of the invoking step function contains elt.


everIntersects

public IloBool everIntersects(const IloNumToAnySetStepFunction f)

This member function returns IloTrue if at some point x in the definition interval of the invoking step function, the intersection of f and the invoking step function is not empty. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


everIntersects

public IloBool everIntersects(IloNum xMin, IloNum xMax, const IloAnySet elts)

This member function returns IloTrue if at any point x on the interval [xMin, xMax) the intersection of elts and the value of the invoking step function at point x is not empty.


fill

public void fill(IloNum xMin, IloNum xMax)

This member function sets the value of the invoking step function on the interval [xMin, xMax) to be the full set.


getComplementSet

public IloAnySet getComplementSet(IloNum x)

This member function returns the complement of the value of the invoking step function at point x. An instance of IloException is thrown if the invoking step function at point x does not use the complementary representation. See Complementary Representation of Values for more information.


getDefinitionIntervalMax

public IloNum getDefinitionIntervalMax()

This member function returns the right-most point of the definition interval of the invoking step function.


getDefinitionIntervalMin

public IloNum getDefinitionIntervalMin()

This member function returns the left-most point of the definition interval of the invoking step function.


getSet

public IloAnySet getSet(IloNum x)

This member function returns the value of the invoking step function at point x. An instance of IloException is thrown if the invoking step function at point x uses the complementary representation. See Complementary Representation of Values for more information.


intersects

public IloBool intersects(IloNum x, const IloAnySet elts)

This member function returns IloTrue if the intersection of elts and the value of the invoking step function at point x is not empty.


isEmpty

public IloBool isEmpty(IloNum x)

This member function returns IloTrue if the function is empty at point x. In other words, a return of IloTrue means that the member function IloNumToAnySetStepFunction::empty has been applied to point x and no elements have been subsequently added to the value of the invoking step function at point x.


isFull

public IloBool isFull(IloNum x)

This member function returns IloTrue if the function is full at point x. In other words, a return of IloTrue means that the member function IloNumToAnySetStepFunction::fill has been applied to point x and no elements have been subsequently removed from the value of the invoking step function at point x.


remove

public void remove(const IloNumToAnySetStepFunction f)

This member function removes the value of f from the value of the invoking step function at all points on the definition interval of the invoking step function. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


remove

public void remove(IloNum xMin, IloNum xMax, IloAny elt)

This member function removes elt from the value of the invoking step function on the interval [xMin, xMax).


remove

public void remove(IloNum xMin, IloNum xMax, const IloAnySet elts, IloBool complt)

This member function removes all the elements in elts from the value of the invoking step function on the interval [xMin, xMax).


set

public void set(IloNum xMin, IloNum xMax, IloAny elt)

This member function sets the value of the invoking step function to be elt on the interval [xMin, xMax).


set

public void set(IloNum xMin, IloNum xMax, const IloAnySet elts, IloBool complt)

This member function sets the value of the invoking step function to be elts on the interval [xMin, xMax).


setIntersection

public void setIntersection(const IloNumToAnySetStepFunction f)

This member function assigns the value of the invoking step function at all points x on the definition interval of the invoking step function to be the intersection of the value of f at point x and the value of the invoking step function at point x. An instance of IloException is thrown if the definition interval of f is not equal to the definition interval of the invoking step function.


setIntersection

public void setIntersection(IloNum xMin, IloNum xMax, IloAny elt)

This member function assigns the value of the invoking step function at all points x on the interval [xMin, xMax) to be the intersection of the set containing elt and the value of the invoking set function at point x.


setIntersection

public void setIntersection(IloNum xMin, IloNum xMax, const IloAnySet elts, IloBool complt)

This member function assigns the value of the invoking step function at all points x on the interval [xMin, xMax) to be the intersection of elts and the value of the invoking set function at point x.


setPeriodic

public void setPeriodic(const IloNumToAnySetStepFunction f, IloNum x0, IloNum n, const IloAnySet dval)

This member function initializes the invoking step function as a function that repeats the step function f, n times after x0. More precisely, if f is defined on [xfpMin,xfpMax) and if the invoking step function is defined on [xMin,xMax), the value of the invoking step function will be:


shift

public void shift(IloNum dx, const IloAnySet dval)

This member function shifts the invoking step function from dx to the right if dx > 0, or from -dx to the left if dx < 0. It has no effect if dx = 0. More precisely, if the invoking step function is defined on [xMin,xMax) and dx > 0, the new value of the invoking step function is:

If dx < 0, the new value of the invoking step function is:


usesComplementaryRepresentation

public IloBool usesComplementaryRepresentation(IloNum x)

This member function returns IloTrue if the value of the invoking function at point x is represented by a complementary set, rather than by directly representing the value as a set itself. See Complementary Representation of Values for more information.