CBMC
constant_abstract_value.cpp
Go to the documentation of this file.
1 /*******************************************************************\
2 
3  Module: analyses variable-sensitivity
4 
5  Author: Thomas Kiley, thomas.kiley@diffblue.com
6 
7 \*******************************************************************/
8 
10 
11 #include <util/interval.h>
12 #include <util/std_expr.h>
13 
16 
19 
21 {
22 public:
23  explicit constant_index_ranget(const exprt &val)
25  {
26  }
27 
29  {
31  }
32 };
33 
36 {
37  return util_make_unique<constant_index_ranget>(val);
38 }
39 
41  : abstract_value_objectt(t), value()
42 {
43 }
44 
46  : abstract_value_objectt(e.type(), false, false), value(e)
47 {
48 }
49 
51  const typet &t,
52  bool tp,
53  bool bttm)
54  : abstract_value_objectt(t, tp, bttm), value()
55 {
56 }
57 
59  const exprt &e,
60  const abstract_environmentt &environment,
61  const namespacet &ns)
62  : abstract_value_objectt(e.type(), false, false), value(e)
63 {
64 }
65 
68 {
69  exprt val = to_constant();
70  if(!val.is_constant())
72 
73  return make_constant_index_range(val);
74 }
75 
78 {
79  return make_single_value_range(shared_from_this());
80 }
81 
83 {
84  if(!is_top() && !is_bottom())
85  {
86  return this->value;
87  }
88  else
89  {
91  }
92 }
93 
95 {
97 }
98 
100  std::ostream &out,
101  const ai_baset &ai,
102  const namespacet &ns) const
103 {
104  if(!is_top() && !is_bottom())
105  {
107  }
108  else
109  {
110  abstract_objectt::output(out, ai, ns);
111  }
112 }
113 
115  const abstract_value_pointert &other,
116  const widen_modet &widen_mode) const
117 {
118  auto other_expr = other->to_constant();
119  if(is_bottom() && other_expr.is_constant())
120  return std::make_shared<constant_abstract_valuet>(other_expr);
121 
122  if(value == other_expr) // Can we actually merge these value
123  return shared_from_this();
124 
125  return abstract_objectt::merge(other, widen_mode);
126 }
127 
129  const abstract_value_pointert &other) const
130 {
131  auto value_as_interval = constant_interval_exprt(value, value);
132  auto other_interval = other->to_interval();
133 
134  if(other_interval.contains(value_as_interval)) // Do they actually meet
135  return shared_from_this();
136 
137  return abstract_objectt::meet(other);
138 }
139 
141  const exprt &lower,
142  const exprt &upper) const
143 {
144  return as_value(mutable_clone());
145 }
146 
148 {
149  return equal_exprt(name, value);
150 }
151 
153  abstract_object_statisticst &statistics,
154  abstract_object_visitedt &visited,
155  const abstract_environmentt &env,
156  const namespacet &ns) const
157 {
158  abstract_objectt::get_statistics(statistics, visited, env, ns);
159  ++statistics.number_of_constants;
160  statistics.objects_memory_usage += memory_sizet::from_bytes(sizeof(*this));
161 }
widen_modet
widen_modet
Definition: abstract_environment.h:32
single_value_index_ranget
Definition: abstract_value_object.h:109
abstract_object_pointert
sharing_ptrt< class abstract_objectt > abstract_object_pointert
Definition: abstract_object.h:69
abstract_objectt::is_top
virtual bool is_top() const
Find out if the abstract object is top.
Definition: abstract_object.cpp:155
abstract_objectt::output
virtual void output(std::ostream &out, const class ai_baset &ai, const namespacet &ns) const
Print the value of the abstract object.
Definition: abstract_object.cpp:190
constant_abstract_valuet::to_constant
exprt to_constant() const override
Converts to a constant expression if possible.
Definition: constant_abstract_value.cpp:82
typet
The type of an expression, extends irept.
Definition: type.h:28
constant_abstract_valuet::merge_with_value
abstract_object_pointert merge_with_value(const abstract_value_pointert &other, const widen_modet &widen_mode) const override
Merges another abstract value into this one.
Definition: constant_abstract_value.cpp:114
abstract_environmentt
Definition: abstract_environment.h:40
exprt
Base class for all expressions.
Definition: expr.h:55
single_value_index_ranget::value
const exprt value
Definition: abstract_value_object.h:119
abstract_objectt::get_statistics
virtual void get_statistics(abstract_object_statisticst &statistics, abstract_object_visitedt &visited, const abstract_environmentt &env, const namespacet &ns) const
Definition: abstract_object.cpp:310
interval.h
equal_exprt
Equality.
Definition: std_expr.h:1305
constant_abstract_valuet::value
exprt value
Definition: constant_abstract_value.h:87
constant_interval_exprt
Represents an interval of values.
Definition: interval.h:47
value_range_implementation_ptrt
std::unique_ptr< value_range_implementationt > value_range_implementation_ptrt
Definition: abstract_value_object.h:131
constant_abstract_valuet::constrain
abstract_value_pointert constrain(const exprt &lower, const exprt &upper) const override
Definition: constant_abstract_value.cpp:140
namespacet
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
Definition: namespace.h:90
constant_abstract_valuet::value_range_implementation
value_range_implementation_ptrt value_range_implementation() const override
Definition: constant_abstract_value.cpp:77
constant_abstract_valuet::to_predicate_internal
exprt to_predicate_internal(const exprt &name) const override
to_predicate implementation - derived classes will override
Definition: constant_abstract_value.cpp:147
constant_index_ranget
Definition: constant_abstract_value.cpp:20
abstract_objectt::merge
static combine_result merge(const abstract_object_pointert &op1, const abstract_object_pointert &op2, const locationt &merge_location, const widen_modet &widen_mode)
Definition: abstract_object.cpp:209
constant_abstract_valuet::output
void output(std::ostream &out, const class ai_baset &ai, const class namespacet &ns) const override
Definition: constant_abstract_value.cpp:99
abstract_object_statisticst
Definition: abstract_object_statistics.h:18
abstract_value_objectt
Definition: abstract_value_object.h:239
language_util.h
abstract_objectt::to_constant
virtual exprt to_constant() const
Converts to a constant expression if possible.
Definition: abstract_object.cpp:170
abstract_value_objectt::as_value
sharing_ptrt< const abstract_value_objectt > as_value(const abstract_object_pointert &obj) const
Definition: abstract_value_object.cpp:697
abstract_object_visitedt
std::set< abstract_object_pointert > abstract_object_visitedt
Definition: abstract_object.h:70
constant_abstract_valuet::constant_abstract_valuet
constant_abstract_valuet(const typet &t)
Definition: constant_abstract_value.cpp:40
constant_index_ranget::constant_index_ranget
constant_index_ranget(const exprt &val)
Definition: constant_abstract_value.cpp:23
abstract_objectt::meet
static combine_result meet(const abstract_object_pointert &op1, const abstract_object_pointert &op2)
Interface method for the meet operation.
Definition: abstract_object.cpp:241
make_single_value_range
value_range_implementation_ptrt make_single_value_range(const abstract_object_pointert &value)
Definition: abstract_value_object.cpp:115
abstract_object_statistics.h
exprt::is_constant
bool is_constant() const
Return whether the expression is a constant.
Definition: expr.cpp:27
abstract_object_statisticst::objects_memory_usage
memory_sizet objects_memory_usage
An underestimation of the memory usage of the abstract objects.
Definition: abstract_object_statistics.h:28
ai_baset
This is the basic interface of the abstract interpreter with default implementations of the core func...
Definition: ai.h:118
abstract_object_statisticst::number_of_constants
std::size_t number_of_constants
Definition: abstract_object_statistics.h:25
make_constant_index_range
static index_range_implementation_ptrt make_constant_index_range(const exprt &val)
Definition: constant_abstract_value.cpp:35
constant_abstract_valuet::get_statistics
void get_statistics(abstract_object_statisticst &statistics, abstract_object_visitedt &visited, const abstract_environmentt &env, const namespacet &ns) const override
Definition: constant_abstract_value.cpp:152
index_range_implementation_ptrt
std::unique_ptr< index_range_implementationt > index_range_implementation_ptrt
Definition: abstract_value_object.h:26
constant_abstract_valuet::meet_with_value
abstract_object_pointert meet_with_value(const abstract_value_pointert &other) const override
Definition: constant_abstract_value.cpp:128
abstract_value_objectt::abstract_value_pointert
sharing_ptrt< const abstract_value_objectt > abstract_value_pointert
Definition: abstract_value_object.h:302
constant_index_ranget::reset
index_range_implementation_ptrt reset() const override
Definition: constant_abstract_value.cpp:28
abstract_objectt::is_bottom
virtual bool is_bottom() const
Find out if the abstract object is bottom.
Definition: abstract_object.cpp:160
constant_abstract_valuet::to_interval
constant_interval_exprt to_interval() const override
Definition: constant_abstract_value.cpp:94
std_expr.h
memory_sizet::from_bytes
static memory_sizet from_bytes(std::size_t bytes)
Definition: memory_units.cpp:38
constant_abstract_valuet::mutable_clone
internal_abstract_object_pointert mutable_clone() const override
Definition: constant_abstract_value.h:67
from_expr
std::string from_expr(const namespacet &ns, const irep_idt &identifier, const exprt &expr)
Definition: language_util.cpp:38
make_indeterminate_index_range
index_range_implementation_ptrt make_indeterminate_index_range()
Definition: abstract_value_object.cpp:81
constant_abstract_valuet::index_range_implementation
index_range_implementation_ptrt index_range_implementation(const namespacet &ns) const override
Definition: constant_abstract_value.cpp:67
constant_abstract_value.h
to_constant_expr
const constant_exprt & to_constant_expr(const exprt &expr)
Cast an exprt to a constant_exprt.
Definition: std_expr.h:2992