|
PPL
1.2
|
A generic Cast Floating Point Expression. More...
#include <Cast_Floating_Point_Expression_defs.hh>


Public Types | |
| typedef Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Linear_Form | FP_Linear_Form |
| Alias for the Linear_Form<FP_Interval_Type> from Floating_Point_Expression. More... | |
| typedef Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Interval_Abstract_Store | FP_Interval_Abstract_Store |
| Alias for the Box<FP_Interval_Type> from Floating_Point_Expression. More... | |
| typedef Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Linear_Form_Abstract_Store | FP_Linear_Form_Abstract_Store |
| Alias for the std::map<dimension_type, FP_Linear_Form> from Floating_Point_Expression. More... | |
Public Types inherited from Parma_Polyhedra_Library::Floating_Point_Expression< FP_Interval_Type, FP_Format > | |
| typedef Linear_Form< FP_Interval_Type > | FP_Linear_Form |
Alias for a linear form with template argument FP_Interval_Type. More... | |
| typedef Box< FP_Interval_Type > | FP_Interval_Abstract_Store |
| Alias for a map that associates a variable index to an interval. More... | |
| typedef std::map< dimension_type, FP_Linear_Form > | FP_Linear_Form_Abstract_Store |
| Alias for a map that associates a variable index to a linear form. More... | |
| typedef FP_Interval_Type::boundary_type | boundary_type |
| The floating point format used by the analyzer. More... | |
| typedef FP_Interval_Type::info_type | info_type |
The interval policy used by FP_Interval_Type. More... | |
Public Member Functions | |
| bool | linearize (const FP_Interval_Abstract_Store &int_store, const FP_Linear_Form_Abstract_Store &lf_store, FP_Linear_Form &result) const |
| Linearizes the expression in a given astract store. More... | |
| void | m_swap (Cast_Floating_Point_Expression &y) |
Swaps *this with y. More... | |
Constructors and Destructor | |
| Cast_Floating_Point_Expression (Floating_Point_Expression< FP_Interval_Type, FP_Format > *const expr) | |
Builds a cast floating point expression with the value expressed by expr. More... | |
| ~Cast_Floating_Point_Expression () | |
| Destructor. More... | |
Public Member Functions inherited from Parma_Polyhedra_Library::Floating_Point_Expression< FP_Interval_Type, FP_Format > | |
| virtual | ~Floating_Point_Expression () |
| Destructor. More... | |
Private Member Functions | |
| Cast_Floating_Point_Expression (const Cast_Floating_Point_Expression &y) | |
| Inhibited copy constructor. More... | |
| Cast_Floating_Point_Expression & | operator= (const Cast_Floating_Point_Expression &y) |
| Inhibited assignment operator. More... | |
Private Attributes | |
| Floating_Point_Expression< FP_Interval_Type, FP_Format > * | expr |
| Pointer to the casted expression. More... | |
Related Functions | |
(Note that these are not member functions.) | |
| template<typename FP_Interval_Type , typename FP_Format > | |
| void | swap (Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format > &x, Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format > &y) |
Swaps x with y. More... | |
| template<typename FP_Interval_Type , typename FP_Format > | |
| void | swap (Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format > &x, Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format > &y) |
Additional Inherited Members | |
Static Public Member Functions inherited from Parma_Polyhedra_Library::Floating_Point_Expression< FP_Interval_Type, FP_Format > | |
| static bool | overflows (const FP_Linear_Form &lf) |
| Verifies if a given linear form overflows. More... | |
| static void | relative_error (const FP_Linear_Form &lf, FP_Linear_Form &result) |
| Computes the relative error of a given linear form. More... | |
| static void | intervalize (const FP_Linear_Form &lf, const FP_Interval_Abstract_Store &store, FP_Interval_Type &result) |
Makes result become an interval that overapproximates all the possible values of lf in the interval abstract store store. More... | |
Static Public Attributes inherited from Parma_Polyhedra_Library::Floating_Point_Expression< FP_Interval_Type, FP_Format > | |
| static FP_Interval_Type | absolute_error = compute_absolute_error() |
| Absolute error. More... | |
A generic Cast Floating Point Expression.
FP_Interval_Type represents the type of the intervals used in the abstract domain.FP_Format represents the floating point format used in the concrete domain.Let
and
be two linear forms and
a sound abstract operator on linear forms such that:
Given a floating point expression
and a composite abstract store
, we construct the interval linear form
as follows:
where
is the linear form computed by calling method Floating_Point_Expression::relative_error on
and
is a rounding error defined in Floating_Point_Expression::absolute_error.
Definition at line 90 of file Cast_Floating_Point_Expression_defs.hh.
| typedef Floating_Point_Expression<FP_Interval_Type, FP_Format>:: FP_Interval_Abstract_Store Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Interval_Abstract_Store |
Alias for the Box<FP_Interval_Type> from Floating_Point_Expression.
Definition at line 109 of file Cast_Floating_Point_Expression_defs.hh.
| typedef Floating_Point_Expression<FP_Interval_Type, FP_Format>:: FP_Linear_Form Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Linear_Form |
Alias for the Linear_Form<FP_Interval_Type> from Floating_Point_Expression.
Definition at line 101 of file Cast_Floating_Point_Expression_defs.hh.
| typedef Floating_Point_Expression<FP_Interval_Type, FP_Format>:: FP_Linear_Form_Abstract_Store Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::FP_Linear_Form_Abstract_Store |
Alias for the std::map<dimension_type, FP_Linear_Form> from Floating_Point_Expression.
Definition at line 117 of file Cast_Floating_Point_Expression_defs.hh.
|
inline |
Builds a cast floating point expression with the value expressed by expr.
Definition at line 34 of file Cast_Floating_Point_Expression_inlines.hh.
|
inline |
Destructor.
Definition at line 43 of file Cast_Floating_Point_Expression_inlines.hh.
|
private |
Inhibited copy constructor.
|
virtual |
Linearizes the expression in a given astract store.
Makes result become the linearization of *this in the given composite abstract store.
| int_store | The interval abstract store. |
| lf_store | The linear form abstract store. |
| result | The modified linear form. |
true if the linearization succeeded, false otherwise.See the class description for an explanation of how result is computed.
Implements Parma_Polyhedra_Library::Floating_Point_Expression< FP_Interval_Type, FP_Format >.
Definition at line 32 of file Cast_Floating_Point_Expression_templates.hh.
|
inline |
Swaps *this with y.
Definition at line 50 of file Cast_Floating_Point_Expression_inlines.hh.
References Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::expr, and Parma_Polyhedra_Library::swap().
Referenced by Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::swap().
|
private |
Inhibited assignment operator.
|
related |
Swaps x with y.
|
related |
Definition at line 57 of file Cast_Floating_Point_Expression_inlines.hh.
References Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::m_swap().
|
private |
Pointer to the casted expression.
Definition at line 158 of file Cast_Floating_Point_Expression_defs.hh.
Referenced by Parma_Polyhedra_Library::Cast_Floating_Point_Expression< FP_Interval_Type, FP_Format >::m_swap().