diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 0000000..e69de29 diff --git a/doxygen/annotated.html b/doxygen/annotated.html new file mode 100644 index 0000000..73947b3 --- /dev/null +++ b/doxygen/annotated.html @@ -0,0 +1,131 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Class List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
Class List
+
+
+
Here are the classes, structs, unions and interfaces with brief descriptions:
+
+
+ + + + diff --git a/doxygen/annotated_dup.js b/doxygen/annotated_dup.js new file mode 100644 index 0000000..3ef69d4 --- /dev/null +++ b/doxygen/annotated_dup.js @@ -0,0 +1,25 @@ +var annotated_dup = +[ + [ "ans_trait", "structans__trait.html", null ], + [ "ans_trait< MaxMinSemiring< double > >", "structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html", null ], + [ "ans_trait< MaxMinSemiring< int > >", "structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html", null ], + [ "ans_trait< MinPlusSemiring< double > >", "structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html", null ], + [ "ans_trait< MinPlusSemiring< int > >", "structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html", null ], + [ "BooleanSemiring", "classBooleanSemiring.html", "classBooleanSemiring" ], + [ "BoostTAState", "structBoostTAState.html", "structBoostTAState" ], + [ "BoostTATransition", "structBoostTATransition.html", "structBoostTATransition" ], + [ "BoostZoneGraphState", "structBoostZoneGraphState.html", "structBoostZoneGraphState" ], + [ "Constraint", "structConstraint.html", "structConstraint" ], + [ "ConstraintMaker", "classConstraintMaker.html", "classConstraintMaker" ], + [ "DBM", "structDBM.html", "structDBM" ], + [ "MaxMinSemiring", "classMaxMinSemiring.html", "classMaxMinSemiring" ], + [ "MaxPlusSemiring", "classMaxPlusSemiring.html", "classMaxPlusSemiring" ], + [ "MinPlusSemiring", "classMinPlusSemiring.html", "classMinPlusSemiring" ], + [ "num_type_trait", "structnum__type__trait.html", "structnum__type__trait" ], + [ "num_type_trait< signed char >", "structnum__type__trait_3_01signed_01char_01_4.html", "structnum__type__trait_3_01signed_01char_01_4" ], + [ "num_type_trait< unsigned char >", "structnum__type__trait_3_01unsigned_01char_01_4.html", "structnum__type__trait_3_01unsigned_01char_01_4" ], + [ "QuantitativeTimedPatternMatching", "classQuantitativeTimedPatternMatching.html", "classQuantitativeTimedPatternMatching" ], + [ "ResetVars", "structResetVars.html", "structResetVars" ], + [ "weight_label_writer", "structweight__label__writer.html", "structweight__label__writer" ], + [ "ZoneGraphLabelWriter", "structZoneGraphLabelWriter.html", "structZoneGraphLabelWriter" ] +]; \ No newline at end of file diff --git a/doxygen/bc_s.png b/doxygen/bc_s.png new file mode 100644 index 0000000..224b29a Binary files /dev/null and b/doxygen/bc_s.png differ diff --git a/doxygen/bdwn.png b/doxygen/bdwn.png new file mode 100644 index 0000000..940a0b9 Binary files /dev/null and b/doxygen/bdwn.png differ diff --git a/doxygen/bellman__ford_8hh_source.html b/doxygen/bellman__ford_8hh_source.html new file mode 100644 index 0000000..0f6559d --- /dev/null +++ b/doxygen/bellman__ford_8hh_source.html @@ -0,0 +1,145 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/bellman_ford.hh Source File + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
bellman_ford.hh
+
+
+
1 #include <unordered_map>
+
2 
+
3 #include "weighted_graph.hh"
+
4 
+
11 template<typename Queue, typename WeightedGraph>
+
12 void bellman_ford(const WeightedGraph &G,
+
13  const std::unordered_map<typename WeightedGraph::vertex_descriptor, typename WeightedGraph::edge_property_type::value_type> &init,
+
14  std::unordered_map<typename WeightedGraph::vertex_descriptor, typename WeightedGraph::edge_property_type::value_type> &distance) {
+
15  std::unordered_map<typename WeightedGraph::vertex_descriptor, typename WeightedGraph::edge_property_type::value_type> r;
+
16  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
+
17  auto i = *range.first;
+
18  distance[i] = WeightedGraph::edge_property_type::value_type::zero();
+
19  r[i] = WeightedGraph::edge_property_type::value_type::zero();
+
20  }
+
21  Queue Q;
+
22  for (const auto &q: init) {
+
23  distance[q.first] = q.second;
+
24  r[q.first] = q.second;
+
25  Q.push(q.first);
+
26  }
+
27 
+
28  auto edgeWeightMap = get(boost::edge_weight, G);
+
29 
+
30  while (!Q.empty()) {
+
31  auto q = Q.front();
+
32  Q.pop();
+
33  const auto currentR = r[q];
+
34  r[q] = WeightedGraph::edge_property_type::value_type::zero();
+
35 
+
36  for (auto range = boost::out_edges(q, G); range.first != range.second; range.first++) {
+
37  auto e = *range.first;
+
38  if (distance[target(e, G)] != distance[target(e, G)] + (currentR * edgeWeightMap[e])) {
+
39  distance[target(e, G)] += (currentR * edgeWeightMap[e]);
+
40  r[target(e, G)] += (currentR * edgeWeightMap[e]);
+
41  Q.push(target(e, G));
+
42  }
+
43  }
+
44  }
+
45 }
+
+
+ + + + diff --git a/doxygen/citelist.html b/doxygen/citelist.html new file mode 100644 index 0000000..a4f64ae --- /dev/null +++ b/doxygen/citelist.html @@ -0,0 +1,106 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Bibliography + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
Bibliography
+
+
+
+
+
+ + + + diff --git a/doxygen/classBooleanSemiring-members.html b/doxygen/classBooleanSemiring-members.html new file mode 100644 index 0000000..a349309 --- /dev/null +++ b/doxygen/classBooleanSemiring-members.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
BooleanSemiring Member List
+
+
+ +

This is the complete list of members for BooleanSemiring, including all inherited members.

+ + + + + + + + + + + + +
BooleanSemiring(bool data=false) (defined in BooleanSemiring)BooleanSemiringinline
data (defined in BooleanSemiring)BooleanSemiring
one() (defined in BooleanSemiring)BooleanSemiringinlinestatic
operator!=(const BooleanSemiring &x) const (defined in BooleanSemiring)BooleanSemiringinline
operator*(const BooleanSemiring &x) const (defined in BooleanSemiring)BooleanSemiringinline
operator*=(const BooleanSemiring &x) (defined in BooleanSemiring)BooleanSemiringinline
operator+(const BooleanSemiring &x) const (defined in BooleanSemiring)BooleanSemiringinline
operator+=(const BooleanSemiring &x) (defined in BooleanSemiring)BooleanSemiringinline
operator==(const BooleanSemiring &x) const (defined in BooleanSemiring)BooleanSemiringinline
star() const (defined in BooleanSemiring)BooleanSemiringinline
zero() (defined in BooleanSemiring)BooleanSemiringinlinestatic
+
+ + + + diff --git a/doxygen/classBooleanSemiring.html b/doxygen/classBooleanSemiring.html new file mode 100644 index 0000000..ceecf39 --- /dev/null +++ b/doxygen/classBooleanSemiring.html @@ -0,0 +1,157 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: BooleanSemiring Class Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
BooleanSemiring Class Reference
+
+
+ + + + + + + + + + + + + + + + + + +

+Public Member Functions

BooleanSemiring (bool data=false)
 
+BooleanSemiring operator+ (const BooleanSemiring &x) const
 
+void operator+= (const BooleanSemiring &x)
 
+BooleanSemiring operator* (const BooleanSemiring &x) const
 
+void operator*= (const BooleanSemiring &x)
 
+bool operator!= (const BooleanSemiring &x) const
 
+bool operator== (const BooleanSemiring &x) const
 
+BooleanSemiring star () const
 
+ + + + + +

+Static Public Member Functions

+static BooleanSemiring zero ()
 
+static BooleanSemiring one ()
 
+ + + +

+Public Attributes

+bool data
 
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classBooleanSemiring.js b/doxygen/classBooleanSemiring.js new file mode 100644 index 0000000..20a1b2c --- /dev/null +++ b/doxygen/classBooleanSemiring.js @@ -0,0 +1,12 @@ +var classBooleanSemiring = +[ + [ "BooleanSemiring", "classBooleanSemiring.html#a767ebd314eb27ef099577c40ee3ce70f", null ], + [ "operator!=", "classBooleanSemiring.html#a4213e5d0fc25b59b9c6d4909390d6696", null ], + [ "operator*", "classBooleanSemiring.html#ae09230a7597517d7f460787a823b133d", null ], + [ "operator*=", "classBooleanSemiring.html#a8f3526c7714f4497d6db7e87ebe5efe9", null ], + [ "operator+", "classBooleanSemiring.html#a6482192c33a7739b63c32c2cbbfe5e0c", null ], + [ "operator+=", "classBooleanSemiring.html#a50100cf48e88305445adc950142bd8d9", null ], + [ "operator==", "classBooleanSemiring.html#a30c30e651ef05c47dac6d1bb3412cf27", null ], + [ "star", "classBooleanSemiring.html#a75ba41e86ef3aa74dc1b297b354cf5e2", null ], + [ "data", "classBooleanSemiring.html#a8b9a4dd35d6dbf459ece99a4d68ff715", null ] +]; \ No newline at end of file diff --git a/doxygen/classConstraintMaker-members.html b/doxygen/classConstraintMaker-members.html new file mode 100644 index 0000000..95298e6 --- /dev/null +++ b/doxygen/classConstraintMaker-members.html @@ -0,0 +1,113 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
ConstraintMaker< ClockVariables > Member List
+
+
+ +

This is the complete list of members for ConstraintMaker< ClockVariables >, including all inherited members.

+ + + + + + +
ConstraintMaker(ClockVariables x) (defined in ConstraintMaker< ClockVariables >)ConstraintMaker< ClockVariables >inline
operator<(int c) (defined in ConstraintMaker< ClockVariables >)ConstraintMaker< ClockVariables >inline
operator<=(int c) (defined in ConstraintMaker< ClockVariables >)ConstraintMaker< ClockVariables >inline
operator>(int c) (defined in ConstraintMaker< ClockVariables >)ConstraintMaker< ClockVariables >inline
operator>=(int c) (defined in ConstraintMaker< ClockVariables >)ConstraintMaker< ClockVariables >inline
+
+ + + + diff --git a/doxygen/classConstraintMaker.html b/doxygen/classConstraintMaker.html new file mode 100644 index 0000000..afba0f0 --- /dev/null +++ b/doxygen/classConstraintMaker.html @@ -0,0 +1,131 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ConstraintMaker< ClockVariables > Class Template Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
ConstraintMaker< ClockVariables > Class Template Reference
+
+
+ + + + + + + + + + + + +

+Public Member Functions

ConstraintMaker (ClockVariables x)
 
+Constraint< ClockVariables > operator< (int c)
 
+Constraint< ClockVariables > operator<= (int c)
 
+Constraint< ClockVariables > operator> (int c)
 
+Constraint< ClockVariables > operator>= (int c)
 
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classConstraintMaker.js b/doxygen/classConstraintMaker.js new file mode 100644 index 0000000..b7e5aae --- /dev/null +++ b/doxygen/classConstraintMaker.js @@ -0,0 +1,8 @@ +var classConstraintMaker = +[ + [ "ConstraintMaker", "classConstraintMaker.html#a3e48d98c8c6dc39e1a20ba3f0a73861a", null ], + [ "operator<", "classConstraintMaker.html#ae03b04765ba599a1275bfd1f8e9a0309", null ], + [ "operator<=", "classConstraintMaker.html#aa750688dcacced80cb95d92461f46a3a", null ], + [ "operator>", "classConstraintMaker.html#afb50bb8c4f9cf16f1badab2deeb20b5e", null ], + [ "operator>=", "classConstraintMaker.html#ae6765b0b11946ec9666ebd68a763e0fc", null ] +]; \ No newline at end of file diff --git a/doxygen/classMaxMinSemiring-members.html b/doxygen/classMaxMinSemiring-members.html new file mode 100644 index 0000000..75bdf6a --- /dev/null +++ b/doxygen/classMaxMinSemiring-members.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
MaxMinSemiring< Base > Member List
+
+
+ +

This is the complete list of members for MaxMinSemiring< Base >, including all inherited members.

+ + + + + + + + + + + + +
data (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >
MaxMinSemiring(Base data=std::numeric_limits< Base >::infinity()) (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
one() (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inlinestatic
operator!=(const MaxMinSemiring &x) const (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
operator*(const MaxMinSemiring &x) const (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
operator*=(const MaxMinSemiring &x) (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
operator+(const MaxMinSemiring &x) const (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
operator+=(const MaxMinSemiring &x) (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
operator==(const MaxMinSemiring &x) const (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
star() const (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inline
zero() (defined in MaxMinSemiring< Base >)MaxMinSemiring< Base >inlinestatic
+
+ + + + diff --git a/doxygen/classMaxMinSemiring.html b/doxygen/classMaxMinSemiring.html new file mode 100644 index 0000000..c40c830 --- /dev/null +++ b/doxygen/classMaxMinSemiring.html @@ -0,0 +1,157 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: MaxMinSemiring< Base > Class Template Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
MaxMinSemiring< Base > Class Template Reference
+
+
+ + + + + + + + + + + + + + + + + + +

+Public Member Functions

MaxMinSemiring (Base data=std::numeric_limits< Base >::infinity())
 
+MaxMinSemiring operator+ (const MaxMinSemiring &x) const
 
+void operator+= (const MaxMinSemiring &x)
 
+MaxMinSemiring operator* (const MaxMinSemiring &x) const
 
+void operator*= (const MaxMinSemiring &x)
 
+bool operator!= (const MaxMinSemiring &x) const
 
+bool operator== (const MaxMinSemiring &x) const
 
+MaxMinSemiring star () const
 
+ + + + + +

+Static Public Member Functions

+static MaxMinSemiring one ()
 
+static MaxMinSemiring zero ()
 
+ + + +

+Public Attributes

+Base data
 
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classMaxMinSemiring.js b/doxygen/classMaxMinSemiring.js new file mode 100644 index 0000000..fc6ec85 --- /dev/null +++ b/doxygen/classMaxMinSemiring.js @@ -0,0 +1,12 @@ +var classMaxMinSemiring = +[ + [ "MaxMinSemiring", "classMaxMinSemiring.html#a810fe016e29cff6252871fedd865ad94", null ], + [ "operator!=", "classMaxMinSemiring.html#a82342b8f9fae79baf06573ba1e84e3b4", null ], + [ "operator*", "classMaxMinSemiring.html#a4ea3c78748668a8386e48223447fadf4", null ], + [ "operator*=", "classMaxMinSemiring.html#a201a867c83a5135295ac2f22deee126e", null ], + [ "operator+", "classMaxMinSemiring.html#ab6864710d18389712abf838f9e0b741c", null ], + [ "operator+=", "classMaxMinSemiring.html#a448e8237de3906c59a8b43ced5f9342f", null ], + [ "operator==", "classMaxMinSemiring.html#abffb8979203092b6dfd857369e9ee226", null ], + [ "star", "classMaxMinSemiring.html#ae5cc95a5e1f6abb4f69cae866c4130ca", null ], + [ "data", "classMaxMinSemiring.html#aa59907e4b86ed9eed43c6247ef01d3fb", null ] +]; \ No newline at end of file diff --git a/doxygen/classMaxPlusSemiring-members.html b/doxygen/classMaxPlusSemiring-members.html new file mode 100644 index 0000000..371da70 --- /dev/null +++ b/doxygen/classMaxPlusSemiring-members.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
MaxPlusSemiring< Base > Member List
+
+
+ +

This is the complete list of members for MaxPlusSemiring< Base >, including all inherited members.

+ + + + + + + + + + + + +
data (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >
MaxPlusSemiring(Base data=0) (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
one() (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inlinestatic
operator!=(const MaxPlusSemiring &x) const (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
operator*(const MaxPlusSemiring &x) const (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
operator*=(const MaxPlusSemiring &x) (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
operator+(const MaxPlusSemiring &x) const (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
operator+=(const MaxPlusSemiring &x) (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
operator==(const MaxPlusSemiring &x) const (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
star() const (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inline
zero() (defined in MaxPlusSemiring< Base >)MaxPlusSemiring< Base >inlinestatic
+
+ + + + diff --git a/doxygen/classMaxPlusSemiring.html b/doxygen/classMaxPlusSemiring.html new file mode 100644 index 0000000..de130ad --- /dev/null +++ b/doxygen/classMaxPlusSemiring.html @@ -0,0 +1,157 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: MaxPlusSemiring< Base > Class Template Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
MaxPlusSemiring< Base > Class Template Reference
+
+
+ + + + + + + + + + + + + + + + + + +

+Public Member Functions

MaxPlusSemiring (Base data=0)
 
+MaxPlusSemiring operator+ (const MaxPlusSemiring &x) const
 
+void operator+= (const MaxPlusSemiring &x)
 
+MaxPlusSemiring operator* (const MaxPlusSemiring &x) const
 
+void operator*= (const MaxPlusSemiring &x)
 
+bool operator!= (const MaxPlusSemiring &x) const
 
+bool operator== (const MaxPlusSemiring &x) const
 
+MaxPlusSemiring star () const
 
+ + + + + +

+Static Public Member Functions

+static MaxPlusSemiring zero ()
 
+static MaxPlusSemiring one ()
 
+ + + +

+Public Attributes

+Base data
 
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classMaxPlusSemiring.js b/doxygen/classMaxPlusSemiring.js new file mode 100644 index 0000000..b0ae3a8 --- /dev/null +++ b/doxygen/classMaxPlusSemiring.js @@ -0,0 +1,12 @@ +var classMaxPlusSemiring = +[ + [ "MaxPlusSemiring", "classMaxPlusSemiring.html#a81bbc6f451ca2a716f4c3a34b759f201", null ], + [ "operator!=", "classMaxPlusSemiring.html#ab5e87c7ed55f0503eefe503a2f85899a", null ], + [ "operator*", "classMaxPlusSemiring.html#ae994bf6ca8bce850a4c3c649bdf2875f", null ], + [ "operator*=", "classMaxPlusSemiring.html#afbfa52d8237b0a00f3e018720a79baf7", null ], + [ "operator+", "classMaxPlusSemiring.html#ab21f6a4cdfad53a9c6ca9bd0f047312c", null ], + [ "operator+=", "classMaxPlusSemiring.html#a87351ae713b3202a95c5290bee34b809", null ], + [ "operator==", "classMaxPlusSemiring.html#a8793c2ad5f35f60f51f080f83c8ab0af", null ], + [ "star", "classMaxPlusSemiring.html#a984d68500725cdb171d7f6095bdc8a8a", null ], + [ "data", "classMaxPlusSemiring.html#a67c080ee2c777d71c9ceeab50db77904", null ] +]; \ No newline at end of file diff --git a/doxygen/classMinPlusSemiring-members.html b/doxygen/classMinPlusSemiring-members.html new file mode 100644 index 0000000..a55db2a --- /dev/null +++ b/doxygen/classMinPlusSemiring-members.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
MinPlusSemiring< Base > Member List
+
+
+ +

This is the complete list of members for MinPlusSemiring< Base >, including all inherited members.

+ + + + + + + + + + + + +
data (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >
MinPlusSemiring(Base data=0) (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
one() (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inlinestatic
operator!=(const MinPlusSemiring &x) const (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
operator*(const MinPlusSemiring &x) const (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
operator*=(const MinPlusSemiring &x) (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
operator+(const MinPlusSemiring &x) const (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
operator+=(const MinPlusSemiring &x) (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
operator==(const MinPlusSemiring &x) const (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
star() const (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inline
zero() (defined in MinPlusSemiring< Base >)MinPlusSemiring< Base >inlinestatic
+
+ + + + diff --git a/doxygen/classMinPlusSemiring.html b/doxygen/classMinPlusSemiring.html new file mode 100644 index 0000000..8350603 --- /dev/null +++ b/doxygen/classMinPlusSemiring.html @@ -0,0 +1,157 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: MinPlusSemiring< Base > Class Template Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
MinPlusSemiring< Base > Class Template Reference
+
+
+ + + + + + + + + + + + + + + + + + +

+Public Member Functions

MinPlusSemiring (Base data=0)
 
+MinPlusSemiring operator+ (const MinPlusSemiring &x) const
 
+void operator+= (const MinPlusSemiring &x)
 
+MinPlusSemiring operator* (const MinPlusSemiring &x) const
 
+void operator*= (const MinPlusSemiring &x)
 
+bool operator!= (const MinPlusSemiring &x) const
 
+bool operator== (const MinPlusSemiring &x) const
 
+MinPlusSemiring star () const
 
+ + + + + +

+Static Public Member Functions

+static MinPlusSemiring zero ()
 
+static MinPlusSemiring one ()
 
+ + + +

+Public Attributes

+Base data
 
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classMinPlusSemiring.js b/doxygen/classMinPlusSemiring.js new file mode 100644 index 0000000..282a081 --- /dev/null +++ b/doxygen/classMinPlusSemiring.js @@ -0,0 +1,12 @@ +var classMinPlusSemiring = +[ + [ "MinPlusSemiring", "classMinPlusSemiring.html#a31b6f2dc9cfc60bfe47097a67fc84535", null ], + [ "operator!=", "classMinPlusSemiring.html#a2d6b37195e4bb34a07a7ff9b7e60832a", null ], + [ "operator*", "classMinPlusSemiring.html#ace23a4149646d8d36d80bae898d94b65", null ], + [ "operator*=", "classMinPlusSemiring.html#a25652dee7534abfdf228a7c8123ffd7d", null ], + [ "operator+", "classMinPlusSemiring.html#af3fdaa681f66fe452006e6e2d6e16f28", null ], + [ "operator+=", "classMinPlusSemiring.html#a113aa2a89686cca56e86d5de90ac9ff1", null ], + [ "operator==", "classMinPlusSemiring.html#a863fcb6f9b56642d4498f1e8e782c500", null ], + [ "star", "classMinPlusSemiring.html#a6415fb3f676a7363fd5ba7788a272182", null ], + [ "data", "classMinPlusSemiring.html#ac9cdf0b7347c4bcaed62d36ec9d72564", null ] +]; \ No newline at end of file diff --git a/doxygen/classQuantitativeTimedPatternMatching-members.html b/doxygen/classQuantitativeTimedPatternMatching-members.html new file mode 100644 index 0000000..0895f8d --- /dev/null +++ b/doxygen/classQuantitativeTimedPatternMatching-members.html @@ -0,0 +1,113 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value > Member List
+
+
+ +

This is the complete list of members for QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >, including all inherited members.

+ + + + + + +
feed(const std::vector< Value > &valuation, const double duration)QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >inline
getResult(boost::unordered_map< ResultMatrix, Weight > &v) const (defined in QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >)QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >inline
getResultRef() (defined in QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >)QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >inline
QuantitativeTimedPatternMatching(const TimedAutomaton &TA, const std::vector< TAState > &initStates, const std::function< Weight(const std::vector< Constraint< ClockVariables >> &, const std::vector< std::vector< Value >> &)> &cost, const bool ignoreZero=false) (defined in QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >)QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >inline
ResultMatrix typedef (defined in QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >)QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >
+
+ + + + diff --git a/doxygen/classQuantitativeTimedPatternMatching.html b/doxygen/classQuantitativeTimedPatternMatching.html new file mode 100644 index 0000000..48344cf --- /dev/null +++ b/doxygen/classQuantitativeTimedPatternMatching.html @@ -0,0 +1,228 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value > Class Template Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+ +
+
QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value > Class Template Reference
+
+
+ +

A class to execute quantitative timed pattern matching. + More...

+ +

#include <quantitative_timed_pattern_matching.hh>

+ + + + +

+Public Types

+using ResultMatrix = std::array< Bounds, 6 >
 
+ + + + + + + + + + +

+Public Member Functions

QuantitativeTimedPatternMatching (const TimedAutomaton &TA, const std::vector< TAState > &initStates, const std::function< Weight(const std::vector< Constraint< ClockVariables >> &, const std::vector< std::vector< Value >> &)> &cost, const bool ignoreZero=false)
 
void feed (const std::vector< Value > &valuation, const double duration)
 feed one valuation with dwell time More...
 
+void getResult (boost::unordered_map< ResultMatrix, Weight > &v) const
 
+boost::unordered_map< ResultMatrix, Weight > & getResultRef ()
 
+

Detailed Description

+

template<class SignalVariables, class ClockVariables, class Weight, class Value>
+class QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >

+ +

A class to execute quantitative timed pattern matching.

+
Note
This class works in an incremental way.
+

+Outline of the Automata-Based Algorithm for Quantitative Timed Pattern Matching

+

The following shows the outline of the algorithm for quantitative timed pattern matching:

+
    +
  1. A piece \((u_i, \tau_i)\) of the monitored piecewise constant signal is given to feed.
  2. +
  3. The configurations corresponding to the matching begging from the current piece are added to the "pool" of the current configurations.
  4. +
  5. The zone graph of duration \(\tau_i\) with values \(u_i\) is constructed.
  6. +
  7. For each node of the zone graph, we compute the shortest distance to it by the generalized Bellman-Ford algorithm [Mohri09].
  8. +
  9. By forcing the dwell time, we construct the configuration just after the current piece.
  10. +
  11. For the configurations reaching accepting states, we put the resulting matching to this->result.
  12. +
+

We use the zone graph for generalized reachability analysis since the transition and the switching of the signal values are asynchronous.

+

+On the Usage of DBM in Quantitative Timed Pattern Matching

+

The usage of each element in the DBM is as follows.

+
    +
  • 0: x0 == 0
      +
    • i.e., the special element showing the constant 0.
    • +
    +
  • +
  • 1-N: x (usual variables)
  • +
  • N+1: the duration from the actual start
      +
    • i.e., \( \mathrm{NOW} - t \), where \( t \) is the beginning of the matching
    • +
    +
  • +
  • N+2: the dwell time
      +
    • i.e., \( \mathrm{NOW} - \tau_i \)
    • +
    • should be released at first
    • +
    • THIS SHOULD NOT RESET in zone construction
    • +
    +
  • +
+

Member Function Documentation

+ +

◆ feed()

+ +
+
+
+template<class SignalVariables , class ClockVariables , class Weight , class Value >
+ + + + + +
+ + + + + + + + + + + + + + + + + + +
void QuantitativeTimedPatternMatching< SignalVariables, ClockVariables, Weight, Value >::feed (const std::vector< Value > & valuation,
const double duration 
)
+
+inline
+
+ +

feed one valuation with dwell time

+

In this function, a piece of the entire piecewise constant function is fed and the matching ending in this piece is added to this->result. See Outline of the Automata-Based Algorithm for Quantitative Timed Pattern Matching for the outline of the algorithm.

+
Parameters
+ + + +
[in]valuationThe new signal valuation
[in]durationThe duration of the given signal valuation
+
+
+
Note
It is not a problem to give the same valuation consecutively.
+ +
+
+
The documentation for this class was generated from the following file: +
+
+ + + + diff --git a/doxygen/classQuantitativeTimedPatternMatching.js b/doxygen/classQuantitativeTimedPatternMatching.js new file mode 100644 index 0000000..7d10d27 --- /dev/null +++ b/doxygen/classQuantitativeTimedPatternMatching.js @@ -0,0 +1,8 @@ +var classQuantitativeTimedPatternMatching = +[ + [ "ResultMatrix", "classQuantitativeTimedPatternMatching.html#a995c220022c0ed5da5a4fc92fb39b49d", null ], + [ "QuantitativeTimedPatternMatching", "classQuantitativeTimedPatternMatching.html#a55e7b70f130f275fd4a909c74586f21f", null ], + [ "feed", "classQuantitativeTimedPatternMatching.html#a69c30442b09757c7588f3e81adf6330a", null ], + [ "getResult", "classQuantitativeTimedPatternMatching.html#a2205a2c9a42806ec3d84408c6e615294", null ], + [ "getResultRef", "classQuantitativeTimedPatternMatching.html#afab3c88f5616aa943412a0dd260825d0", null ] +]; \ No newline at end of file diff --git a/doxygen/classes.html b/doxygen/classes.html new file mode 100644 index 0000000..692bc11 --- /dev/null +++ b/doxygen/classes.html @@ -0,0 +1,138 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Class Index + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
Class Index
+
+
+
A | B | C | D | M | N | Q | R | W | Z
+ +
+
+ + + + diff --git a/doxygen/closed.png b/doxygen/closed.png new file mode 100644 index 0000000..98cc2c9 Binary files /dev/null and b/doxygen/closed.png differ diff --git a/doxygen/constraint_8hh_source.html b/doxygen/constraint_8hh_source.html new file mode 100644 index 0000000..5219da9 --- /dev/null +++ b/doxygen/constraint_8hh_source.html @@ -0,0 +1,183 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/constraint.hh Source File + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
constraint.hh
+
+
+
1 #pragma once
+
2 
+
3 #include <cstdint>
+
4 #include <vector>
+
5 #include <algorithm>
+
6 
+
8 enum class Order {
+
9  LT, EQ, GT
+
10 };
+
11 
+
12 inline static bool toBool (Order odr) {
+
13  return odr == Order::EQ;
+
14 }
+
15 
+
17 template<class ClockVariables>
+
18 struct Constraint {
+
19  enum class Order {
+
20  lt,le,ge,gt
+
21  };
+
22 
+
23  ClockVariables x;
+
24  Order odr;
+
25  int c;
+
26 
+
27  bool satisfy (double d) const {
+
28  switch (odr) {
+
29  case Order::lt:
+
30  return d < c;
+
31  case Order::le:
+
32  return d <= c;
+
33  case Order::gt:
+
34  return d > c;
+
35  case Order::ge:
+
36  return d >= c;
+
37  }
+
38  return false;
+
39  }
+
40  using Interpretation = std::vector<double>;
+
41  ::Order operator() (Interpretation val) const {
+
42  if (satisfy (val.at (x))) {
+
43  return ::Order::EQ;
+
44  } else if (odr == Order::lt || odr == Order::le) {
+
45  return ::Order::GT;
+
46  } else {
+
47  return ::Order::LT;
+
48  }
+
49  }
+
50 };
+
51 
+
52 // An interface to write an inequality constrait easily
+
53 template<class ClockVariables>
+ +
55  ClockVariables x;
+
56 public:
+
57  ConstraintMaker(ClockVariables x) : x(x) {}
+
58  Constraint<ClockVariables> operator<(int c) {
+ +
60  }
+
61  Constraint<ClockVariables> operator<=(int c) {
+ +
63  }
+
64  Constraint<ClockVariables> operator>(int c) {
+ +
66  }
+
67  Constraint<ClockVariables> operator>=(int c) {
+ +
69  }
+
70 };
+
71 
+
75 template<class ClockVariables>
+
76 static inline void widen(std::vector<Constraint<ClockVariables>> &guard) {
+
77  guard.erase(std::remove_if(guard.begin(), guard.end(), [](Constraint<ClockVariables> g) {
+
78  return g.odr == Constraint<ClockVariables>::Order::ge || g.odr == Constraint<ClockVariables>::Order::gt;
+
79  }), guard.end());
+
80 }
+
Definition: constraint.hh:54
+
A constraint in a guard of transitions.
Definition: constraint.hh:18
+
+
+ + + + diff --git a/doxygen/dbm_8hh_source.html b/doxygen/dbm_8hh_source.html new file mode 100644 index 0000000..717e4d5 --- /dev/null +++ b/doxygen/dbm_8hh_source.html @@ -0,0 +1,390 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/dbm.hh Source File + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
dbm.hh
+
+
+
1 #pragma once
+
2 // (setq flycheck-clang-language-standard "c++14")
+
3 #include <iostream>
+
4 #include <cmath>
+
5 #include <limits>
+
6 #include <algorithm>
+
7 #include <boost/unordered_map.hpp>
+
8 
+
9 #include "constraint.hh"
+
10 
+
11 using Bounds = std::pair<double, bool>;
+
12 static inline Bounds
+
13 operator+ (const Bounds &a,const Bounds &b) {
+
14  return Bounds(a.first + b.first, a.second && b.second);
+
15 }
+
16 static inline Bounds
+
17 operator- (const Bounds &a,const Bounds &b) {
+
18  return Bounds(a.first - b.first, a.second && b.second);
+
19 }
+
20 static inline void
+
21 operator+= (Bounds &a, const Bounds b) {
+
22  a.first += b.first;
+
23  a.second = a.second && b.second;
+
24 }
+
25 namespace std {
+
26  static inline std::ostream &operator<<(std::ostream &os, const Bounds &b) {
+
27  os << "(" << b.first << ", " << b.second << ")";
+
28  return os;
+
29  }
+
30 }
+
31 static inline Bounds
+
32 operator+ (Bounds a, const double b) {
+
33  a.first += b;
+
34  return a;
+
35 }
+
36 static inline Bounds
+
37 operator- (Bounds a, const double b) {
+
38  a.first -= b;
+
39  return a;
+
40 }
+
41 
+
42 
+
43 #include <eigen3/Eigen/Core>
+
45 
+
52 struct DBM {
+
53  using Tuple = std::tuple<std::vector<Bounds>,Bounds>;
+
55  Eigen::Matrix<Bounds, Eigen::Dynamic, Eigen::Dynamic> value;
+
57  Bounds M;
+
58 
+
63  inline std::size_t getNumOfVar() const {
+
64  return value.cols() - 1;
+
65  }
+
66 
+
67  inline void cutVars (std::shared_ptr<DBM> &out,std::size_t from,std::size_t to) const {
+
68  out = std::make_shared<DBM>();
+
69  out->value.resize(to - from + 2, to - from + 2);
+
70  out->value.block(0,0,1,1) << Bounds(0,true);
+
71  out->value.block(1, 1, to - from + 1, to - from + 1) = value.block(from + 1, from + 1, to - from + 1,to - from + 1);
+
72  out->value.block(1, 0, to - from + 1, 1) = value.block(from + 1, 0, to - from + 1, 1);
+
73  out->value.block(0, 1, 1, to - from + 1) = value.block(0, from + 1, 1, to - from + 1);
+
74  out->M = M;
+
75  }
+
76 
+
77 
+
79  static DBM zero(int size) {
+
80  static DBM zeroZone;
+
81  if (zeroZone.value.cols() == size) {
+
82  return zeroZone;
+
83  }
+
84  zeroZone.value.resize(size, size);
+
85  zeroZone.value.fill(Bounds(0, true));
+
86  return zeroZone;
+
87  }
+
88 
+
89 
+
91  std::tuple<std::vector<Bounds>,Bounds> toTuple() const {
+
92  // omit (0,0)
+
93  return std::tuple<std::vector<Bounds>,Bounds>(std::vector<Bounds>(value.data() + 1, value.data() + value.size()),M);
+
94  }
+
95 
+
98  void tightenWithoutClose(uint8_t x, uint8_t y, Bounds c) {
+
99  x++;
+
100  y++;
+
101  value(x,y) = std::min(value(x, y), c);
+
102  }
+
103 
+
105  void tighten(uint8_t x, uint8_t y, Bounds c) {
+
106  x++;
+
107  y++;
+
108  value(x,y) = std::min(value(x, y), c);
+
109  close1(x);
+
110  close1(y);
+
111  }
+
112 
+
113  void close1(uint8_t x) {
+
114  for (int i = 0; i < value.rows(); i++) {
+
115  value.row(i) = value.row(i).array().min(value.row(x).array() + value(i, x));
+
116  // for (int j = 0; j < value.cols(); j++) {
+
117  // value(i, j) = std::min(value(i, j), value(i, x) + value(x, j));
+
118  // }
+
119  }
+
120  }
+
121 
+
122  // The reset value is always (0, \le)
+
123  void reset(uint8_t x) {
+
124  // DBM orig = *this;
+
125  // 0 is the special varibale here
+
126  x++;
+
127  value(0,x) = Bounds(0, true);
+
128  value(x,0) = Bounds(0, true);
+
129  value.col(x).tail(value.rows() - 1) = value.col(0).tail(value.rows() - 1);
+
130  value.row(x).tail(value.cols() - 1) = value.row(0).tail(value.cols() - 1);
+
131  // This close is necessary to keep canonized.
+
132  close1(x);
+
133  // if (orig.isCanonized()) {
+
134  // assert(isCanonized());
+
135  // }
+
136  }
+
137 
+
139  void release(uint8_t x) {
+
140  static constexpr Bounds infinity = Bounds(std::numeric_limits<double>::infinity(), false);
+
141  // 0 is the special varibale here
+
142  x++;
+
143  value.col(x).fill(infinity);
+
144  value.row(x).fill(infinity);
+
145  value(0,x) = Bounds(0, true);
+
146  value(x,0) = infinity;
+
147  }
+
148 
+
154  void elapse() {
+
155  // DBM orig = *this;
+
156  static constexpr Bounds infinity = Bounds(std::numeric_limits<double>::infinity(), false);
+
157  value.col(0).fill(infinity);
+
158  for (int i = 0; i < value.row(0).size(); ++i) {
+
159  value.row(0)[i].second = false;
+
160  }
+
161  // if (orig.isCanonized()) {
+
162  // assert(isCanonized());
+
163  // }
+
164  }
+
165 
+
169  void canonize() {
+
170  for (int k = 0; k < value.cols(); k++) {
+
171  close1(k);
+
172  }
+
173  }
+
174 
+
180  inline bool isSatisfiableWithoutCanonize() const {
+
181  return (value + value.transpose()).minCoeff() >= Bounds(0.0, true);
+
182  }
+
183 
+
187  bool isSatisfiable() {
+
188  canonize();
+ +
190  }
+
191 
+
195  void abstractize() {
+
196  static constexpr Bounds infinity = Bounds(std::numeric_limits<double>::infinity(), false);
+
197  for (auto it = value.data(); it < value.data() + value.size(); it++) {
+
198  if (*it >= M) {
+
199  *it = infinity;
+
200  }
+
201  }
+
202  }
+
203 
+
207  void makeUnsat() {
+
208  value(0, 0) = Bounds(-std::numeric_limits<double>::infinity(), false);
+
209  }
+
210 
+
211  bool operator== (DBM z) const {
+
212  z.value(0,0) = value(0,0);
+
213  return value == z.value;
+
214  }
+
215 
+
216  void operator&=(const DBM &z) {
+
217  value.array() = value.array().min(z.value.array());
+
218  canonize();
+
219  }
+
220 
+
221  bool operator>(const DBM &z) const {
+
222  return (value.array() > z.value.array()).all();
+
223  }
+
224 
+
225  bool operator<=(const DBM &z) const {
+
226  return !isSatisfiableWithoutCanonize() || (value.array() <= z.value.array()).all();
+
227  }
+
228 
+
239  void convexUnion(const DBM &z, DBM &dest) const {
+
240  dest.value.array() = value.array().max(z.value.array());
+
241  }
+
242 
+
252  bool merge(const DBM &z) {
+
253  // When *this is included by z
+
254  if (*this <= z) {
+
255  value = std::move(z.value);
+
256  return true;
+
257  }
+
258  // When z is included by *this
+
259  if (z <= *this) {
+
260  return true;
+
261  }
+
262 
+
263  // Take the convex union
+
264  DBM convex = DBM::zero(getNumOfVar()+ 1);
+
265  convexUnion(z, convex);
+
266 
+
267  // Check if convex is the union of *this and z
+
268  const std::size_t N = value.cols();
+
269  for (std::size_t i = 0; i < N; i++) {
+
270  for (std::size_t j = 0; j < N; j++) {
+
271  // we do not have to look at the diags
+
272  if (i == j) {
+
273  continue;
+
274  }
+
275  // Exclude the values in *this and check if it is included to z
+
276  const Bounds rev = {-value(j,i).first, !value(j,i).second};
+
277  // When we do not have to tighten, we skip
+
278  if (convex.value(i,j) <= rev) {
+
279  continue;
+
280  }
+
281  DBM c = convex;
+
282  c.value(i,j) = rev;
+
283  c.close1(i);
+
284  c.close1(j);
+
285  if (!(c <= z)) {
+
286  return false;
+
287  }
+
288  }
+
289  }
+
290 
+
291  value = std::move(convex.value);
+
292  return true;
+
293  }
+
294 
+
295  bool isCanonized() const {
+
296  DBM tmp = *this;
+
297  tmp.canonize();
+
298  return !tmp.isSatisfiableWithoutCanonize() || value == tmp.value;
+
299  }
+
300 };
+
301 
+
302 // struct ZoneAutomaton : public AbstractionAutomaton<DBM> {
+
303 // struct TAEdge {
+
304 // State source;
+
305 // State target;
+
306 // Alphabet c;
+
307 // std::vector<Alphabet> resetVars;
+
308 // std::vector<Constraint> guard;
+
309 // };
+
310 
+
311 // boost::unordered_map<std::tuple<State, State, Alphabet>, TAEdge> edgeMap;
+
312 // boost::unordered_map<std::pair<TAState, typename DBM::Tuple>, RAState> zones_in_za;
+
313 // int numOfVariables;
+
314 // };
+
315 
+
316 // static inline std::ostream& operator << (std::ostream& os, const DBM& z) {
+
317 // for (int i = 0; i < z.value.rows();i++) {
+
318 // for (int j = 0; j < z.value.cols();j++) {
+
319 // os << z.value(i,j);
+
320 // }
+
321 // os << "\n";
+
322 // }
+
323 // os << std::endl;
+
324 // return os;
+
325 // }
+
326 
+
327 
+
Implementation of a zone with DBM DBM For the detail of DBMs, see for example .
Definition: dbm.hh:52
+
void convexUnion(const DBM &z, DBM &dest) const
Make the convex union of two DBMs.
Definition: dbm.hh:239
+
bool isSatisfiableWithoutCanonize() const
check if the zone is satisfiable
Definition: dbm.hh:180
+
void canonize()
make the zone canonical
Definition: dbm.hh:169
+
std::tuple< std::vector< Bounds >, Bounds > toTuple() const
Return the tuple representation of the DBM.
Definition: dbm.hh:91
+
std::size_t getNumOfVar() const
Returns the number of the variables represented by this zone.
Definition: dbm.hh:63
+
void release(uint8_t x)
Definition: dbm.hh:139
+
void tightenWithoutClose(uint8_t x, uint8_t y, Bounds c)
add the constraint x - y <= (c,s) but does not close.
Definition: dbm.hh:98
+
bool isSatisfiable()
check if the zone is satisfiable
Definition: dbm.hh:187
+
void tighten(uint8_t x, uint8_t y, Bounds c)
add the constraint
Definition: dbm.hh:105
+
bool merge(const DBM &z)
Try to merge the given DBM to this DBM.
Definition: dbm.hh:252
+
void abstractize()
truncate the constraints compared with a constant greater than or equal to M
Definition: dbm.hh:195
+
static DBM zero(int size)
Make the zone of size size such that all the values are zero.
Definition: dbm.hh:79
+
Bounds M
The threshold for the normalization.
Definition: dbm.hh:57
+
void elapse()
Assign the strongest post-condition of the delay.
Definition: dbm.hh:154
+
void makeUnsat()
make the zone unsatisfiable
Definition: dbm.hh:207
+
Eigen::Matrix< Bounds, Eigen::Dynamic, Eigen::Dynamic > value
The matrix representing the DBM.
Definition: dbm.hh:55
+
+
+ + + + diff --git a/doxygen/dir_13e138d54eb8818da29c3992edef070a.html b/doxygen/dir_13e138d54eb8818da29c3992edef070a.html new file mode 100644 index 0000000..c4e8b45 --- /dev/null +++ b/doxygen/dir_13e138d54eb8818da29c3992edef070a.html @@ -0,0 +1,106 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: test Directory Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
test Directory Reference
+
+
+
+
+ + + + diff --git a/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.html b/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.html new file mode 100644 index 0000000..15bf82a --- /dev/null +++ b/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.html @@ -0,0 +1,106 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src Directory Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
src Directory Reference
+
+
+
+
+ + + + diff --git a/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.js b/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.js new file mode 100644 index 0000000..5e26640 --- /dev/null +++ b/doxygen/dir_68267d1309a1af8e8297ef4c3efbcdba.js @@ -0,0 +1,12 @@ +var dir_68267d1309a1af8e8297ef4c3efbcdba = +[ + [ "bellman_ford.hh", "bellman__ford_8hh_source.html", null ], + [ "constraint.hh", "constraint_8hh_source.html", null ], + [ "dbm.hh", "dbm_8hh_source.html", null ], + [ "quantitative_timed_pattern_matching.hh", "quantitative__timed__pattern__matching_8hh_source.html", null ], + [ "robustness.hh", "robustness_8hh_source.html", null ], + [ "timed_automaton.hh", "timed__automaton_8hh_source.html", null ], + [ "warshall_froid.hh", "warshall__froid_8hh_source.html", null ], + [ "weighted_graph.hh", "weighted__graph_8hh_source.html", null ], + [ "zone_graph.hh", "zone__graph_8hh_source.html", null ] +]; \ No newline at end of file diff --git a/doxygen/dir_e68e8157741866f444e17edd764ebbae.html b/doxygen/dir_e68e8157741866f444e17edd764ebbae.html new file mode 100644 index 0000000..d02cc8d --- /dev/null +++ b/doxygen/dir_e68e8157741866f444e17edd764ebbae.html @@ -0,0 +1,106 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: doc Directory Reference + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
doc Directory Reference
+
+
+
+
+ + + + diff --git a/doxygen/doc.png b/doxygen/doc.png new file mode 100644 index 0000000..17edabf Binary files /dev/null and b/doxygen/doc.png differ diff --git a/doxygen/doxygen.css b/doxygen/doxygen.css new file mode 100644 index 0000000..ffbff02 --- /dev/null +++ b/doxygen/doxygen.css @@ -0,0 +1,1793 @@ +/* The standard CSS for doxygen 1.9.1 */ + +body, table, div, p, dl { + font: 400 14px/22px Roboto,sans-serif; +} + +p.reference, p.definition { + font: 400 14px/22px Roboto,sans-serif; +} + +/* @group Heading Levels */ + +h1.groupheader { + font-size: 150%; +} + +.title { + font: 400 14px/28px Roboto,sans-serif; + font-size: 150%; + font-weight: bold; + margin: 10px 2px; +} + +h2.groupheader { + border-bottom: 1px solid #879ECB; + color: #354C7B; + font-size: 150%; + font-weight: normal; + margin-top: 1.75em; + padding-top: 8px; + padding-bottom: 4px; + width: 100%; +} + +h3.groupheader { + font-size: 100%; +} + +h1, h2, h3, h4, h5, h6 { + -webkit-transition: text-shadow 0.5s linear; + -moz-transition: text-shadow 0.5s linear; + -ms-transition: text-shadow 0.5s linear; + -o-transition: text-shadow 0.5s linear; + transition: text-shadow 0.5s linear; + margin-right: 15px; +} + +h1.glow, h2.glow, h3.glow, h4.glow, h5.glow, h6.glow { + text-shadow: 0 0 15px cyan; +} + +dt { + font-weight: bold; +} + +ul.multicol { + -moz-column-gap: 1em; + -webkit-column-gap: 1em; + column-gap: 1em; + -moz-column-count: 3; + -webkit-column-count: 3; + column-count: 3; +} + +p.startli, p.startdd { + margin-top: 2px; +} + +th p.starttd, th p.intertd, th p.endtd { + font-size: 100%; + font-weight: 700; +} + +p.starttd { + margin-top: 0px; +} + +p.endli { + margin-bottom: 0px; +} + +p.enddd { + margin-bottom: 4px; +} + +p.endtd { + margin-bottom: 2px; +} + +p.interli { +} + +p.interdd { +} + +p.intertd { +} + +/* @end */ + +caption { + font-weight: bold; +} + +span.legend { + font-size: 70%; + text-align: center; +} + +h3.version { + font-size: 90%; + text-align: center; +} + +div.navtab { + border-right: 1px solid #A3B4D7; + padding-right: 15px; + text-align: right; + line-height: 110%; +} + +div.navtab table { + border-spacing: 0; +} + +td.navtab { + padding-right: 6px; + padding-left: 6px; +} +td.navtabHL { + background-image: url('tab_a.png'); + background-repeat:repeat-x; + padding-right: 6px; + padding-left: 6px; +} + +td.navtabHL a, td.navtabHL a:visited { + color: #fff; + text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +} + +a.navtab { + font-weight: bold; +} + +div.qindex{ + text-align: center; + width: 100%; + line-height: 140%; + font-size: 130%; + color: #A0A0A0; +} + +dt.alphachar{ + font-size: 180%; + font-weight: bold; +} + +.alphachar a{ + color: black; +} + +.alphachar a:hover, .alphachar a:visited{ + text-decoration: none; +} + +.classindex dl { + padding: 25px; + column-count:1 +} + +.classindex dd { + display:inline-block; + margin-left: 50px; + width: 90%; + line-height: 1.15em; +} + +.classindex dl.odd { + background-color: #F8F9FC; +} + +@media(min-width: 1120px) { + .classindex dl { + column-count:2 + } +} + +@media(min-width: 1320px) { + .classindex dl { + column-count:3 + } +} + + +/* @group Link Styling */ + +a { + color: #3D578C; + font-weight: normal; + text-decoration: none; +} + +.contents a:visited { + color: #4665A2; +} + +a:hover { + text-decoration: underline; +} + +.contents a.qindexHL:visited { + color: #FFFFFF; +} + +a.el { + font-weight: bold; +} + +a.elRef { +} + +a.code, a.code:visited, a.line, a.line:visited { + color: #4665A2; +} + +a.codeRef, a.codeRef:visited, a.lineRef, a.lineRef:visited { + color: #4665A2; +} + +/* @end */ + +dl.el { + margin-left: -1cm; +} + +ul { + overflow: hidden; /*Fixed: list item bullets overlap floating elements*/ +} + +#side-nav ul { + overflow: visible; /* reset ul rule for scroll bar in GENERATE_TREEVIEW window */ +} + +#main-nav ul { + overflow: visible; /* reset ul rule for the navigation bar drop down lists */ +} + +.fragment { + text-align: left; + direction: ltr; + overflow-x: auto; /*Fixed: fragment lines overlap floating elements*/ + overflow-y: hidden; +} + +pre.fragment { + border: 1px solid #C4CFE5; + background-color: #FBFCFD; + padding: 4px 6px; + margin: 4px 8px 4px 2px; + overflow: auto; + word-wrap: break-word; + font-size: 9pt; + line-height: 125%; + font-family: monospace, fixed; + font-size: 105%; +} + +div.fragment { + padding: 0 0 1px 0; /*Fixed: last line underline overlap border*/ + margin: 4px 8px 4px 2px; + background-color: #FBFCFD; + border: 1px solid #C4CFE5; +} + +div.line { + font-family: monospace, fixed; + font-size: 13px; + min-height: 13px; + line-height: 1.0; + text-wrap: unrestricted; + white-space: -moz-pre-wrap; /* Moz */ + white-space: -pre-wrap; /* Opera 4-6 */ + white-space: -o-pre-wrap; /* Opera 7 */ + white-space: pre-wrap; /* CSS3 */ + word-wrap: break-word; /* IE 5.5+ */ + text-indent: -53px; + padding-left: 53px; + padding-bottom: 0px; + margin: 0px; + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +div.line:after { + content:"\000A"; + white-space: pre; +} + +div.line.glow { + background-color: cyan; + box-shadow: 0 0 10px cyan; +} + + +span.lineno { + padding-right: 4px; + text-align: right; + border-right: 2px solid #0F0; + background-color: #E8E8E8; + white-space: pre; +} +span.lineno a { + background-color: #D8D8D8; +} + +span.lineno a:hover { + background-color: #C8C8C8; +} + +.lineno { + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +div.ah, span.ah { + background-color: black; + font-weight: bold; + color: #FFFFFF; + margin-bottom: 3px; + margin-top: 3px; + padding: 0.2em; + border: solid thin #333; + border-radius: 0.5em; + -webkit-border-radius: .5em; + -moz-border-radius: .5em; + box-shadow: 2px 2px 3px #999; + -webkit-box-shadow: 2px 2px 3px #999; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + background-image: -webkit-gradient(linear, left top, left bottom, from(#eee), to(#000),color-stop(0.3, #444)); + background-image: -moz-linear-gradient(center top, #eee 0%, #444 40%, #000 110%); +} + +div.classindex ul { + list-style: none; + padding-left: 0; +} + +div.classindex span.ai { + display: inline-block; +} + +div.groupHeader { + margin-left: 16px; + margin-top: 12px; + font-weight: bold; +} + +div.groupText { + margin-left: 16px; + font-style: italic; +} + +body { + background-color: white; + color: black; + margin: 0; +} + +div.contents { + margin-top: 10px; + margin-left: 12px; + margin-right: 8px; +} + +td.indexkey { + background-color: #EBEFF6; + font-weight: bold; + border: 1px solid #C4CFE5; + margin: 2px 0px 2px 0; + padding: 2px 10px; + white-space: nowrap; + vertical-align: top; +} + +td.indexvalue { + background-color: #EBEFF6; + border: 1px solid #C4CFE5; + padding: 2px 10px; + margin: 2px 0px; +} + +tr.memlist { + background-color: #EEF1F7; +} + +p.formulaDsp { + text-align: center; +} + +img.formulaDsp { + +} + +img.formulaInl, img.inline { + vertical-align: middle; +} + +div.center { + text-align: center; + margin-top: 0px; + margin-bottom: 0px; + padding: 0px; +} + +div.center img { + border: 0px; +} + +address.footer { + text-align: right; + padding-right: 12px; +} + +img.footer { + border: 0px; + vertical-align: middle; +} + +/* @group Code Colorization */ + +span.keyword { + color: #008000 +} + +span.keywordtype { + color: #604020 +} + +span.keywordflow { + color: #e08000 +} + +span.comment { + color: #800000 +} + +span.preprocessor { + color: #806020 +} + +span.stringliteral { + color: #002080 +} + +span.charliteral { + color: #008080 +} + +span.vhdldigit { + color: #ff00ff +} + +span.vhdlchar { + color: #000000 +} + +span.vhdlkeyword { + color: #700070 +} + +span.vhdllogic { + color: #ff0000 +} + +blockquote { + background-color: #F7F8FB; + border-left: 2px solid #9CAFD4; + margin: 0 24px 0 4px; + padding: 0 12px 0 16px; +} + +blockquote.DocNodeRTL { + border-left: 0; + border-right: 2px solid #9CAFD4; + margin: 0 4px 0 24px; + padding: 0 16px 0 12px; +} + +/* @end */ + +/* +.search { + color: #003399; + font-weight: bold; +} + +form.search { + margin-bottom: 0px; + margin-top: 0px; +} + +input.search { + font-size: 75%; + color: #000080; + font-weight: normal; + background-color: #e8eef2; +} +*/ + +td.tiny { + font-size: 75%; +} + +.dirtab { + padding: 4px; + border-collapse: collapse; + border: 1px solid #A3B4D7; +} + +th.dirtab { + background: #EBEFF6; + font-weight: bold; +} + +hr { + height: 0px; + border: none; + border-top: 1px solid #4A6AAA; +} + +hr.footer { + height: 1px; +} + +/* @group Member Descriptions */ + +table.memberdecls { + border-spacing: 0px; + padding: 0px; +} + +.memberdecls td, .fieldtable tr { + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +.memberdecls td.glow, .fieldtable tr.glow { + background-color: cyan; + box-shadow: 0 0 15px cyan; +} + +.mdescLeft, .mdescRight, +.memItemLeft, .memItemRight, +.memTemplItemLeft, .memTemplItemRight, .memTemplParams { + background-color: #F9FAFC; + border: none; + margin: 4px; + padding: 1px 0 0 8px; +} + +.mdescLeft, .mdescRight { + padding: 0px 8px 4px 8px; + color: #555; +} + +.memSeparator { + border-bottom: 1px solid #DEE4F0; + line-height: 1px; + margin: 0px; + padding: 0px; +} + +.memItemLeft, .memTemplItemLeft { + white-space: nowrap; +} + +.memItemRight, .memTemplItemRight { + width: 100%; +} + +.memTemplParams { + color: #4665A2; + white-space: nowrap; + font-size: 80%; +} + +/* @end */ + +/* @group Member Details */ + +/* Styles for detailed member documentation */ + +.memtitle { + padding: 8px; + border-top: 1px solid #A8B8D9; + border-left: 1px solid #A8B8D9; + border-right: 1px solid #A8B8D9; + border-top-right-radius: 4px; + border-top-left-radius: 4px; + margin-bottom: -1px; + background-image: url('nav_f.png'); + background-repeat: repeat-x; + background-color: #E2E8F2; + line-height: 1.25; + font-weight: 300; + float:left; +} + +.permalink +{ + font-size: 65%; + display: inline-block; + vertical-align: middle; +} + +.memtemplate { + font-size: 80%; + color: #4665A2; + font-weight: normal; + margin-left: 9px; +} + +.memnav { + background-color: #EBEFF6; + border: 1px solid #A3B4D7; + text-align: center; + margin: 2px; + margin-right: 15px; + padding: 2px; +} + +.mempage { + width: 100%; +} + +.memitem { + padding: 0; + margin-bottom: 10px; + margin-right: 5px; + -webkit-transition: box-shadow 0.5s linear; + -moz-transition: box-shadow 0.5s linear; + -ms-transition: box-shadow 0.5s linear; + -o-transition: box-shadow 0.5s linear; + transition: box-shadow 0.5s linear; + display: table !important; + width: 100%; +} + +.memitem.glow { + box-shadow: 0 0 15px cyan; +} + +.memname { + font-weight: 400; + margin-left: 6px; +} + +.memname td { + vertical-align: bottom; +} + +.memproto, dl.reflist dt { + border-top: 1px solid #A8B8D9; + border-left: 1px solid #A8B8D9; + border-right: 1px solid #A8B8D9; + padding: 6px 0px 6px 0px; + color: #253555; + font-weight: bold; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + background-color: #DFE5F1; + /* opera specific markup */ + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + border-top-right-radius: 4px; + /* firefox specific markup */ + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + -moz-border-radius-topright: 4px; + /* webkit specific markup */ + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + -webkit-border-top-right-radius: 4px; + +} + +.overload { + font-family: "courier new",courier,monospace; + font-size: 65%; +} + +.memdoc, dl.reflist dd { + border-bottom: 1px solid #A8B8D9; + border-left: 1px solid #A8B8D9; + border-right: 1px solid #A8B8D9; + padding: 6px 10px 2px 10px; + background-color: #FBFCFD; + border-top-width: 0; + background-image:url('nav_g.png'); + background-repeat:repeat-x; + background-color: #FFFFFF; + /* opera specific markup */ + border-bottom-left-radius: 4px; + border-bottom-right-radius: 4px; + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + /* firefox specific markup */ + -moz-border-radius-bottomleft: 4px; + -moz-border-radius-bottomright: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + /* webkit specific markup */ + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +dl.reflist dt { + padding: 5px; +} + +dl.reflist dd { + margin: 0px 0px 10px 0px; + padding: 5px; +} + +.paramkey { + text-align: right; +} + +.paramtype { + white-space: nowrap; +} + +.paramname { + color: #602020; + white-space: nowrap; +} +.paramname em { + font-style: normal; +} +.paramname code { + line-height: 14px; +} + +.params, .retval, .exception, .tparams { + margin-left: 0px; + padding-left: 0px; +} + +.params .paramname, .retval .paramname, .tparams .paramname, .exception .paramname { + font-weight: bold; + vertical-align: top; +} + +.params .paramtype, .tparams .paramtype { + font-style: italic; + vertical-align: top; +} + +.params .paramdir, .tparams .paramdir { + font-family: "courier new",courier,monospace; + vertical-align: top; +} + +table.mlabels { + border-spacing: 0px; +} + +td.mlabels-left { + width: 100%; + padding: 0px; +} + +td.mlabels-right { + vertical-align: bottom; + padding: 0px; + white-space: nowrap; +} + +span.mlabels { + margin-left: 8px; +} + +span.mlabel { + background-color: #728DC1; + border-top:1px solid #5373B4; + border-left:1px solid #5373B4; + border-right:1px solid #C4CFE5; + border-bottom:1px solid #C4CFE5; + text-shadow: none; + color: white; + margin-right: 4px; + padding: 2px 3px; + border-radius: 3px; + font-size: 7pt; + white-space: nowrap; + vertical-align: middle; +} + + + +/* @end */ + +/* these are for tree view inside a (index) page */ + +div.directory { + margin: 10px 0px; + border-top: 1px solid #9CAFD4; + border-bottom: 1px solid #9CAFD4; + width: 100%; +} + +.directory table { + border-collapse:collapse; +} + +.directory td { + margin: 0px; + padding: 0px; + vertical-align: top; +} + +.directory td.entry { + white-space: nowrap; + padding-right: 6px; + padding-top: 3px; +} + +.directory td.entry a { + outline:none; +} + +.directory td.entry a img { + border: none; +} + +.directory td.desc { + width: 100%; + padding-left: 6px; + padding-right: 6px; + padding-top: 3px; + border-left: 1px solid rgba(0,0,0,0.05); +} + +.directory tr.even { + padding-left: 6px; + background-color: #F7F8FB; +} + +.directory img { + vertical-align: -30%; +} + +.directory .levels { + white-space: nowrap; + width: 100%; + text-align: right; + font-size: 9pt; +} + +.directory .levels span { + cursor: pointer; + padding-left: 2px; + padding-right: 2px; + color: #3D578C; +} + +.arrow { + color: #9CAFD4; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: pointer; + font-size: 80%; + display: inline-block; + width: 16px; + height: 22px; +} + +.icon { + font-family: Arial, Helvetica; + font-weight: bold; + font-size: 12px; + height: 14px; + width: 16px; + display: inline-block; + background-color: #728DC1; + color: white; + text-align: center; + border-radius: 4px; + margin-left: 2px; + margin-right: 2px; +} + +.icona { + width: 24px; + height: 22px; + display: inline-block; +} + +.iconfopen { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:url('folderopen.png'); + background-position: 0px -4px; + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +.iconfclosed { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:url('folderclosed.png'); + background-position: 0px -4px; + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +.icondoc { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:url('doc.png'); + background-position: 0px -4px; + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +table.directory { + font: 400 14px Roboto,sans-serif; +} + +/* @end */ + +div.dynheader { + margin-top: 8px; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +address { + font-style: normal; + color: #2A3D61; +} + +table.doxtable caption { + caption-side: top; +} + +table.doxtable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.doxtable td, table.doxtable th { + border: 1px solid #2D4068; + padding: 3px 7px 2px; +} + +table.doxtable th { + background-color: #374F7F; + color: #FFFFFF; + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +table.fieldtable { + /*width: 100%;*/ + margin-bottom: 10px; + border: 1px solid #A8B8D9; + border-spacing: 0px; + -moz-border-radius: 4px; + -webkit-border-radius: 4px; + border-radius: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px; + -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); + box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); +} + +.fieldtable td, .fieldtable th { + padding: 3px 7px 2px; +} + +.fieldtable td.fieldtype, .fieldtable td.fieldname { + white-space: nowrap; + border-right: 1px solid #A8B8D9; + border-bottom: 1px solid #A8B8D9; + vertical-align: top; +} + +.fieldtable td.fieldname { + padding-top: 3px; +} + +.fieldtable td.fielddoc { + border-bottom: 1px solid #A8B8D9; + /*width: 100%;*/ +} + +.fieldtable td.fielddoc p:first-child { + margin-top: 0px; +} + +.fieldtable td.fielddoc p:last-child { + margin-bottom: 2px; +} + +.fieldtable tr:last-child td { + border-bottom: none; +} + +.fieldtable th { + background-image:url('nav_f.png'); + background-repeat:repeat-x; + background-color: #E2E8F2; + font-size: 90%; + color: #253555; + padding-bottom: 4px; + padding-top: 5px; + text-align:left; + font-weight: 400; + -moz-border-radius-topleft: 4px; + -moz-border-radius-topright: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + border-top-left-radius: 4px; + border-top-right-radius: 4px; + border-bottom: 1px solid #A8B8D9; +} + + +.tabsearch { + top: 0px; + left: 10px; + height: 36px; + background-image: url('tab_b.png'); + z-index: 101; + overflow: hidden; + font-size: 13px; +} + +.navpath ul +{ + font-size: 11px; + background-image:url('tab_b.png'); + background-repeat:repeat-x; + background-position: 0 -5px; + height:30px; + line-height:30px; + color:#8AA0CC; + border:solid 1px #C2CDE4; + overflow:hidden; + margin:0px; + padding:0px; +} + +.navpath li +{ + list-style-type:none; + float:left; + padding-left:10px; + padding-right:15px; + background-image:url('bc_s.png'); + background-repeat:no-repeat; + background-position:right; + color:#364D7C; +} + +.navpath li.navelem a +{ + height:32px; + display:block; + text-decoration: none; + outline: none; + color: #283A5D; + font-family: 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; + text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); + text-decoration: none; +} + +.navpath li.navelem a:hover +{ + color:#6884BD; +} + +.navpath li.footer +{ + list-style-type:none; + float:right; + padding-left:10px; + padding-right:15px; + background-image:none; + background-repeat:no-repeat; + background-position:right; + color:#364D7C; + font-size: 8pt; +} + + +div.summary +{ + float: right; + font-size: 8pt; + padding-right: 5px; + width: 50%; + text-align: right; +} + +div.summary a +{ + white-space: nowrap; +} + +table.classindex +{ + margin: 10px; + white-space: nowrap; + margin-left: 3%; + margin-right: 3%; + width: 94%; + border: 0; + border-spacing: 0; + padding: 0; +} + +div.ingroups +{ + font-size: 8pt; + width: 50%; + text-align: left; +} + +div.ingroups a +{ + white-space: nowrap; +} + +div.header +{ + background-image:url('nav_h.png'); + background-repeat:repeat-x; + background-color: #F9FAFC; + margin: 0px; + border-bottom: 1px solid #C4CFE5; +} + +div.headertitle +{ + padding: 5px 5px 5px 10px; +} + +.PageDocRTL-title div.headertitle { + text-align: right; + direction: rtl; +} + +dl { + padding: 0 0 0 0; +} + +/* dl.note, dl.warning, dl.attention, dl.pre, dl.post, dl.invariant, dl.deprecated, dl.todo, dl.test, dl.bug, dl.examples */ +dl.section { + margin-left: 0px; + padding-left: 0px; +} + +dl.section.DocNodeRTL { + margin-right: 0px; + padding-right: 0px; +} + +dl.note { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #D0C000; +} + +dl.note.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #D0C000; +} + +dl.warning, dl.attention { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #FF0000; +} + +dl.warning.DocNodeRTL, dl.attention.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #FF0000; +} + +dl.pre, dl.post, dl.invariant { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #00D000; +} + +dl.pre.DocNodeRTL, dl.post.DocNodeRTL, dl.invariant.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #00D000; +} + +dl.deprecated { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #505050; +} + +dl.deprecated.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #505050; +} + +dl.todo { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #00C0E0; +} + +dl.todo.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #00C0E0; +} + +dl.test { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #3030E0; +} + +dl.test.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #3030E0; +} + +dl.bug { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #C08050; +} + +dl.bug.DocNodeRTL { + margin-left: 0; + padding-left: 0; + border-left: 0; + margin-right: -7px; + padding-right: 3px; + border-right: 4px solid; + border-color: #C08050; +} + +dl.section dd { + margin-bottom: 6px; +} + + +#projectlogo +{ + text-align: center; + vertical-align: bottom; + border-collapse: separate; +} + +#projectlogo img +{ + border: 0px none; +} + +#projectalign +{ + vertical-align: middle; +} + +#projectname +{ + font: 300% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 2px 0px; +} + +#projectbrief +{ + font: 120% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#projectnumber +{ + font: 50% Tahoma, Arial,sans-serif; + margin: 0px; + padding: 0px; +} + +#titlearea +{ + padding: 0px; + margin: 0px; + width: 100%; + border-bottom: 1px solid #5373B4; +} + +.image +{ + text-align: center; +} + +.dotgraph +{ + text-align: center; +} + +.mscgraph +{ + text-align: center; +} + +.plantumlgraph +{ + text-align: center; +} + +.diagraph +{ + text-align: center; +} + +.caption +{ + font-weight: bold; +} + +div.zoom +{ + border: 1px solid #90A5CE; +} + +dl.citelist { + margin-bottom:50px; +} + +dl.citelist dt { + color:#334975; + float:left; + font-weight:bold; + margin-right:10px; + padding:5px; + text-align:right; + width:52px; +} + +dl.citelist dd { + margin:2px 0 2px 72px; + padding:5px 0; +} + +div.toc { + padding: 14px 25px; + background-color: #F4F6FA; + border: 1px solid #D8DFEE; + border-radius: 7px 7px 7px 7px; + float: right; + height: auto; + margin: 0 8px 10px 10px; + width: 200px; +} + +.PageDocRTL-title div.toc { + float: left !important; + text-align: right; +} + +div.toc li { + background: url("bdwn.png") no-repeat scroll 0 5px transparent; + font: 10px/1.2 Verdana,DejaVu Sans,Geneva,sans-serif; + margin-top: 5px; + padding-left: 10px; + padding-top: 2px; +} + +.PageDocRTL-title div.toc li { + background-position-x: right !important; + padding-left: 0 !important; + padding-right: 10px; +} + +div.toc h3 { + font: bold 12px/1.2 Arial,FreeSans,sans-serif; + color: #4665A2; + border-bottom: 0 none; + margin: 0; +} + +div.toc ul { + list-style: none outside none; + border: medium none; + padding: 0px; +} + +div.toc li.level1 { + margin-left: 0px; +} + +div.toc li.level2 { + margin-left: 15px; +} + +div.toc li.level3 { + margin-left: 30px; +} + +div.toc li.level4 { + margin-left: 45px; +} + +span.emoji { + /* font family used at the site: https://unicode.org/emoji/charts/full-emoji-list.html + * font-family: "Noto Color Emoji", "Apple Color Emoji", "Segoe UI Emoji", Times, Symbola, Aegyptus, Code2000, Code2001, Code2002, Musica, serif, LastResort; + */ +} + +.PageDocRTL-title div.toc li.level1 { + margin-left: 0 !important; + margin-right: 0; +} + +.PageDocRTL-title div.toc li.level2 { + margin-left: 0 !important; + margin-right: 15px; +} + +.PageDocRTL-title div.toc li.level3 { + margin-left: 0 !important; + margin-right: 30px; +} + +.PageDocRTL-title div.toc li.level4 { + margin-left: 0 !important; + margin-right: 45px; +} + +.inherit_header { + font-weight: bold; + color: gray; + cursor: pointer; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.inherit_header td { + padding: 6px 0px 2px 5px; +} + +.inherit { + display: none; +} + +tr.heading h2 { + margin-top: 12px; + margin-bottom: 4px; +} + +/* tooltip related style info */ + +.ttc { + position: absolute; + display: none; +} + +#powerTip { + cursor: default; + white-space: nowrap; + background-color: white; + border: 1px solid gray; + border-radius: 4px 4px 4px 4px; + box-shadow: 1px 1px 7px gray; + display: none; + font-size: smaller; + max-width: 80%; + opacity: 0.9; + padding: 1ex 1em 1em; + position: absolute; + z-index: 2147483647; +} + +#powerTip div.ttdoc { + color: grey; + font-style: italic; +} + +#powerTip div.ttname a { + font-weight: bold; +} + +#powerTip div.ttname { + font-weight: bold; +} + +#powerTip div.ttdeci { + color: #006318; +} + +#powerTip div { + margin: 0px; + padding: 0px; + font: 12px/16px Roboto,sans-serif; +} + +#powerTip:before, #powerTip:after { + content: ""; + position: absolute; + margin: 0px; +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.s:after, #powerTip.s:before, +#powerTip.w:after, #powerTip.w:before, +#powerTip.e:after, #powerTip.e:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.nw:after, #powerTip.nw:before, +#powerTip.sw:after, #powerTip.sw:before { + border: solid transparent; + content: " "; + height: 0; + width: 0; + position: absolute; +} + +#powerTip.n:after, #powerTip.s:after, +#powerTip.w:after, #powerTip.e:after, +#powerTip.nw:after, #powerTip.ne:after, +#powerTip.sw:after, #powerTip.se:after { + border-color: rgba(255, 255, 255, 0); +} + +#powerTip.n:before, #powerTip.s:before, +#powerTip.w:before, #powerTip.e:before, +#powerTip.nw:before, #powerTip.ne:before, +#powerTip.sw:before, #powerTip.se:before { + border-color: rgba(128, 128, 128, 0); +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.nw:after, #powerTip.nw:before { + top: 100%; +} + +#powerTip.n:after, #powerTip.ne:after, #powerTip.nw:after { + border-top-color: #FFFFFF; + border-width: 10px; + margin: 0px -10px; +} +#powerTip.n:before { + border-top-color: #808080; + border-width: 11px; + margin: 0px -11px; +} +#powerTip.n:after, #powerTip.n:before { + left: 50%; +} + +#powerTip.nw:after, #powerTip.nw:before { + right: 14px; +} + +#powerTip.ne:after, #powerTip.ne:before { + left: 14px; +} + +#powerTip.s:after, #powerTip.s:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.sw:after, #powerTip.sw:before { + bottom: 100%; +} + +#powerTip.s:after, #powerTip.se:after, #powerTip.sw:after { + border-bottom-color: #FFFFFF; + border-width: 10px; + margin: 0px -10px; +} + +#powerTip.s:before, #powerTip.se:before, #powerTip.sw:before { + border-bottom-color: #808080; + border-width: 11px; + margin: 0px -11px; +} + +#powerTip.s:after, #powerTip.s:before { + left: 50%; +} + +#powerTip.sw:after, #powerTip.sw:before { + right: 14px; +} + +#powerTip.se:after, #powerTip.se:before { + left: 14px; +} + +#powerTip.e:after, #powerTip.e:before { + left: 100%; +} +#powerTip.e:after { + border-left-color: #FFFFFF; + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.e:before { + border-left-color: #808080; + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +#powerTip.w:after, #powerTip.w:before { + right: 100%; +} +#powerTip.w:after { + border-right-color: #FFFFFF; + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.w:before { + border-right-color: #808080; + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +@media print +{ + #top { display: none; } + #side-nav { display: none; } + #nav-path { display: none; } + body { overflow:visible; } + h1, h2, h3, h4, h5, h6 { page-break-after: avoid; } + .summary { display: none; } + .memitem { page-break-inside: avoid; } + #doc-content + { + margin-left:0 !important; + height:auto !important; + width:auto !important; + overflow:inherit; + display:inline; + } +} + +/* @group Markdown */ + +table.markdownTable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.markdownTable td, table.markdownTable th { + border: 1px solid #2D4068; + padding: 3px 7px 2px; +} + +table.markdownTable tr { +} + +th.markdownTableHeadLeft, th.markdownTableHeadRight, th.markdownTableHeadCenter, th.markdownTableHeadNone { + background-color: #374F7F; + color: #FFFFFF; + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +th.markdownTableHeadLeft, td.markdownTableBodyLeft { + text-align: left +} + +th.markdownTableHeadRight, td.markdownTableBodyRight { + text-align: right +} + +th.markdownTableHeadCenter, td.markdownTableBodyCenter { + text-align: center +} + +.DocNodeRTL { + text-align: right; + direction: rtl; +} + +.DocNodeLTR { + text-align: left; + direction: ltr; +} + +table.DocNodeRTL { + width: auto; + margin-right: 0; + margin-left: auto; +} + +table.DocNodeLTR { + width: auto; + margin-right: auto; + margin-left: 0; +} + +tt, code, kbd, samp +{ + display: inline-block; + direction:ltr; +} +/* @end */ + +u { + text-decoration: underline; +} + diff --git a/doxygen/doxygen.svg b/doxygen/doxygen.svg new file mode 100644 index 0000000..d42dad5 --- /dev/null +++ b/doxygen/doxygen.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/doxygen/dynsections.js b/doxygen/dynsections.js new file mode 100644 index 0000000..3174bd7 --- /dev/null +++ b/doxygen/dynsections.js @@ -0,0 +1,121 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +function toggleVisibility(linkObj) +{ + var base = $(linkObj).attr('id'); + var summary = $('#'+base+'-summary'); + var content = $('#'+base+'-content'); + var trigger = $('#'+base+'-trigger'); + var src=$(trigger).attr('src'); + if (content.is(':visible')===true) { + content.hide(); + summary.show(); + $(linkObj).addClass('closed').removeClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-8)+'closed.png'); + } else { + content.show(); + summary.hide(); + $(linkObj).removeClass('closed').addClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-10)+'open.png'); + } + return false; +} + +function updateStripes() +{ + $('table.directory tr'). + removeClass('even').filter(':visible:even').addClass('even'); +} + +function toggleLevel(level) +{ + $('table.directory tr').each(function() { + var l = this.id.split('_').length-1; + var i = $('#img'+this.id.substring(3)); + var a = $('#arr'+this.id.substring(3)); + if (l + + + + + + +Quantitative Timed Pattern Matching Developers Manual: File List + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
File List
+
+
+
Here is a list of all documented files with brief descriptions:
+
[detail level 12]
+ + + + + + + + + + +
  src
 bellman_ford.hh
 constraint.hh
 dbm.hh
 quantitative_timed_pattern_matching.hh
 robustness.hh
 timed_automaton.hh
 warshall_froid.hh
 weighted_graph.hh
 zone_graph.hh
+
+
+
+ + + + diff --git a/doxygen/files_dup.js b/doxygen/files_dup.js new file mode 100644 index 0000000..c3b39c4 --- /dev/null +++ b/doxygen/files_dup.js @@ -0,0 +1,4 @@ +var files_dup = +[ + [ "src", "dir_68267d1309a1af8e8297ef4c3efbcdba.html", "dir_68267d1309a1af8e8297ef4c3efbcdba" ] +]; \ No newline at end of file diff --git a/doxygen/folderclosed.png b/doxygen/folderclosed.png new file mode 100644 index 0000000..bb8ab35 Binary files /dev/null and b/doxygen/folderclosed.png differ diff --git a/doxygen/folderopen.png b/doxygen/folderopen.png new file mode 100644 index 0000000..d6c7f67 Binary files /dev/null and b/doxygen/folderopen.png differ diff --git a/doxygen/functions.html b/doxygen/functions.html new file mode 100644 index 0000000..30e5e1b --- /dev/null +++ b/doxygen/functions.html @@ -0,0 +1,169 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Class Members + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
Here is a list of all documented class members with links to the class documentation for each member:
+
+
+ + + + diff --git a/doxygen/functions_func.html b/doxygen/functions_func.html new file mode 100644 index 0000000..ff8fc1b --- /dev/null +++ b/doxygen/functions_func.html @@ -0,0 +1,148 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Class Members - Functions + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
+ + + + diff --git a/doxygen/functions_vars.html b/doxygen/functions_vars.html new file mode 100644 index 0000000..be3324b --- /dev/null +++ b/doxygen/functions_vars.html @@ -0,0 +1,124 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Class Members - Variables + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ + +
+ + + + diff --git a/doxygen/graph_legend.html b/doxygen/graph_legend.html new file mode 100644 index 0000000..07f688c --- /dev/null +++ b/doxygen/graph_legend.html @@ -0,0 +1,165 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Graph Legend + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
Graph Legend
+
+
+

This page explains how to interpret the graphs that are generated by doxygen.

+

Consider the following example:

/*! Invisible class because of truncation */
+
class Invisible { };
+
+
/*! Truncated class, inheritance relation is hidden */
+
class Truncated : public Invisible { };
+
+
/* Class not documented with doxygen comments */
+
class Undocumented { };
+
+
/*! Class that is inherited using public inheritance */
+
class PublicBase : public Truncated { };
+
+
/*! A template class */
+
template<class T> class Templ { };
+
+
/*! Class that is inherited using protected inheritance */
+
class ProtectedBase { };
+
+
/*! Class that is inherited using private inheritance */
+
class PrivateBase { };
+
+
/*! Class that is used by the Inherited class */
+
class Used { };
+
+
/*! Super class that inherits a number of other classes */
+
class Inherited : public PublicBase,
+
protected ProtectedBase,
+
private PrivateBase,
+
public Undocumented,
+
public Templ<int>
+
{
+
private:
+
Used *m_usedClass;
+
};
+

This will result in the following graph:

+

The boxes in the above graph have the following meaning:

+
    +
  • +A filled gray box represents the struct or class for which the graph is generated.
  • +
  • +A box with a black border denotes a documented struct or class.
  • +
  • +A box with a gray border denotes an undocumented struct or class.
  • +
  • +A box with a red border denotes a documented struct or class forwhich not all inheritance/containment relations are shown. A graph is truncated if it does not fit within the specified boundaries.
  • +
+

The arrows have the following meaning:

+
    +
  • +A dark blue arrow is used to visualize a public inheritance relation between two classes.
  • +
  • +A dark green arrow is used for protected inheritance.
  • +
  • +A dark red arrow is used for private inheritance.
  • +
  • +A purple dashed arrow is used if a class is contained or used by another class. The arrow is labelled with the variable(s) through which the pointed class or struct is accessible.
  • +
  • +A yellow dashed arrow denotes a relation between a template instance and the template class it was instantiated from. The arrow is labelled with the template parameters of the instance.
  • +
+
+
+ + + + diff --git a/doxygen/graph_legend.md5 b/doxygen/graph_legend.md5 new file mode 100644 index 0000000..8fcdccd --- /dev/null +++ b/doxygen/graph_legend.md5 @@ -0,0 +1 @@ +f51bf6e9a10430aafef59831b08dcbfe \ No newline at end of file diff --git a/doxygen/graph_legend.png b/doxygen/graph_legend.png new file mode 100644 index 0000000..7e2cbcf Binary files /dev/null and b/doxygen/graph_legend.png differ diff --git a/doxygen/index.html b/doxygen/index.html new file mode 100644 index 0000000..96e10b3 --- /dev/null +++ b/doxygen/index.html @@ -0,0 +1,108 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Overview + + + + + + + + + + + + + + + +
+
+ + + + + + +
+
Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
+
+
+ + + + + + + +
+
+ +
+
+
+ +
+ +
+
+ + +
+ +
+ +
+
+
Overview
+
+
+

+

This is the documentation for developers of QTPM. The readers are supposed to be familiar with the concepts and the algorithm in [Waga19].

+
+
+
+ + + + diff --git a/doxygen/jquery.js b/doxygen/jquery.js new file mode 100644 index 0000000..103c32d --- /dev/null +++ b/doxygen/jquery.js @@ -0,0 +1,35 @@ +/*! jQuery v3.4.1 | (c) JS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],E=C.document,r=Object.getPrototypeOf,s=t.slice,g=t.concat,u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.4.1",k=function(e,t){return new k.fn.init(e,t)},p=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;function d(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp($),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+$),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ne=function(e,t,n){var r="0x"+t-65536;return r!=r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(m.childNodes),m.childNodes),t[m.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&((e?e.ownerDocument||e:m)!==C&&T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!A[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&U.test(t)){(s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=k),o=(l=h(t)).length;while(o--)l[o]="#"+s+" "+xe(l[o]);c=l.join(","),f=ee.test(t)&&ye(e.parentNode)||e}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){A(t,!0)}finally{s===k&&e.removeAttribute("id")}}}return g(t.replace(B,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[k]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:m;return r!==C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),m!==C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=k,!C.getElementsByName||!C.getElementsByName(k).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){a.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+k+"-]").length||v.push("~="),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+k+"+*").length||v.push(".#.+[+~]")}),ce(function(e){e.innerHTML="";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",$)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e===C||e.ownerDocument===m&&y(m,e)?-1:t===C||t.ownerDocument===m&&y(m,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===C?-1:t===C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]===m?-1:s[r]===m?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if((e.ownerDocument||e)!==C&&T(e),d.matchesSelector&&E&&!A[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){A(t,!0)}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=p[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&p(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?k.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?k.grep(e,function(e){return e===n!==r}):"string"!=typeof n?k.grep(e,function(e){return-1)[^>]*|#([\w-]+))$/;(k.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:L.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof k?t[0]:t,k.merge(this,k.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),D.test(r[1])&&k.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(k):k.makeArray(e,this)}).prototype=k.fn,q=k(E);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}k.fn.extend({has:function(e){var t=k(e,this),n=t.length;return this.filter(function(){for(var e=0;e\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?k.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;nx",y.noCloneChecked=!!me.cloneNode(!0).lastChild.defaultValue;var Te=/^key/,Ce=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ee=/^([^.]*)(?:\.(.+)|)/;function ke(){return!0}function Se(){return!1}function Ne(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ae(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ae(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Se;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return k().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=k.guid++)),e.each(function(){k.event.add(this,t,i,r,n)})}function De(e,i,o){o?(Q.set(e,i,!1),k.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Q.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(k.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Q.set(this,i,r),t=o(this,i),this[i](),r!==(n=Q.get(this,i))||t?Q.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Q.set(this,i,{value:k.event.trigger(k.extend(r[0],k.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Q.get(e,i)&&k.event.add(e,i,ke)}k.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Q.get(t);if(v){n.handler&&(n=(o=n).handler,i=o.selector),i&&k.find.matchesSelector(ie,i),n.guid||(n.guid=k.guid++),(u=v.events)||(u=v.events={}),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof k&&k.event.triggered!==e.type?k.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(R)||[""]).length;while(l--)d=g=(s=Ee.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=k.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=k.event.special[d]||{},c=k.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&k.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),k.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Q.hasData(e)&&Q.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(R)||[""]).length;while(l--)if(d=g=(s=Ee.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=k.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||k.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)k.event.remove(e,d+t[l],n,r,!0);k.isEmptyObject(u)&&Q.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=k.event.fix(e),u=new Array(arguments.length),l=(Q.get(this,"events")||{})[s.type]||[],c=k.event.special[s.type]||{};for(u[0]=s,t=1;t\x20\t\r\n\f]*)[^>]*)\/>/gi,qe=/\s*$/g;function Oe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&k(e).children("tbody")[0]||e}function Pe(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function Re(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Me(e,t){var n,r,i,o,a,s,u,l;if(1===t.nodeType){if(Q.hasData(e)&&(o=Q.access(e),a=Q.set(t,o),l=o.events))for(i in delete a.handle,a.events={},l)for(n=0,r=l[i].length;n")},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=oe(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||k.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Vt,Gt=[],Yt=/(=)\?(?=&|$)|\?\?/;k.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Gt.pop()||k.expando+"_"+kt++;return this[e]=!0,e}}),k.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Yt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Yt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Yt,"$1"+r):!1!==e.jsonp&&(e.url+=(St.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||k.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?k(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Gt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Vt=E.implementation.createHTMLDocument("").body).innerHTML="
",2===Vt.childNodes.length),k.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=D.exec(e))?[t.createElement(i[1])]:(i=we([e],t,o),o&&o.length&&k(o).remove(),k.merge([],i.childNodes)));var r,i,o},k.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1").append(k.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},k.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){k.fn[t]=function(e){return this.on(t,e)}}),k.expr.pseudos.animated=function(t){return k.grep(k.timers,function(e){return t===e.elem}).length},k.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=k.css(e,"position"),c=k(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=k.css(e,"top"),u=k.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,k.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},k.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){k.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===k.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===k.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=k(e).offset()).top+=k.css(e,"borderTopWidth",!0),i.left+=k.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-k.css(r,"marginTop",!0),left:t.left-i.left-k.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===k.css(e,"position"))e=e.offsetParent;return e||ie})}}),k.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;k.fn[t]=function(e){return _(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),k.each(["top","left"],function(e,n){k.cssHooks[n]=ze(y.pixelPosition,function(e,t){if(t)return t=_e(e,n),$e.test(t)?k(e).position()[n]+"px":t})}),k.each({Height:"height",Width:"width"},function(a,s){k.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){k.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return _(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?k.css(e,t,i):k.style(e,t,n,i)},s,n?e:void 0,n)}})}),k.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){k.fn[n]=function(e,t){return 0a;a++)for(i in o[a])n=o[a][i],o[a].hasOwnProperty(i)&&void 0!==n&&(e[i]=t.isPlainObject(n)?t.isPlainObject(e[i])?t.widget.extend({},e[i],n):t.widget.extend({},n):n);return e},t.widget.bridge=function(e,i){var n=i.prototype.widgetFullName||e;t.fn[e]=function(o){var a="string"==typeof o,r=s.call(arguments,1),h=this;return a?this.length||"instance"!==o?this.each(function(){var i,s=t.data(this,n);return"instance"===o?(h=s,!1):s?t.isFunction(s[o])&&"_"!==o.charAt(0)?(i=s[o].apply(s,r),i!==s&&void 0!==i?(h=i&&i.jquery?h.pushStack(i.get()):i,!1):void 0):t.error("no such method '"+o+"' for "+e+" widget instance"):t.error("cannot call methods on "+e+" prior to initialization; "+"attempted to call method '"+o+"'")}):h=void 0:(r.length&&(o=t.widget.extend.apply(null,[o].concat(r))),this.each(function(){var e=t.data(this,n);e?(e.option(o||{}),e._init&&e._init()):t.data(this,n,new i(o,this))})),h}},t.Widget=function(){},t.Widget._childConstructors=[],t.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",defaultElement:"
",options:{classes:{},disabled:!1,create:null},_createWidget:function(e,s){s=t(s||this.defaultElement||this)[0],this.element=t(s),this.uuid=i++,this.eventNamespace="."+this.widgetName+this.uuid,this.bindings=t(),this.hoverable=t(),this.focusable=t(),this.classesElementLookup={},s!==this&&(t.data(s,this.widgetFullName,this),this._on(!0,this.element,{remove:function(t){t.target===s&&this.destroy()}}),this.document=t(s.style?s.ownerDocument:s.document||s),this.window=t(this.document[0].defaultView||this.document[0].parentWindow)),this.options=t.widget.extend({},this.options,this._getCreateOptions(),e),this._create(),this.options.disabled&&this._setOptionDisabled(this.options.disabled),this._trigger("create",null,this._getCreateEventData()),this._init()},_getCreateOptions:function(){return{}},_getCreateEventData:t.noop,_create:t.noop,_init:t.noop,destroy:function(){var e=this;this._destroy(),t.each(this.classesElementLookup,function(t,i){e._removeClass(i,t)}),this.element.off(this.eventNamespace).removeData(this.widgetFullName),this.widget().off(this.eventNamespace).removeAttr("aria-disabled"),this.bindings.off(this.eventNamespace)},_destroy:t.noop,widget:function(){return this.element},option:function(e,i){var s,n,o,a=e;if(0===arguments.length)return t.widget.extend({},this.options);if("string"==typeof e)if(a={},s=e.split("."),e=s.shift(),s.length){for(n=a[e]=t.widget.extend({},this.options[e]),o=0;s.length-1>o;o++)n[s[o]]=n[s[o]]||{},n=n[s[o]];if(e=s.pop(),1===arguments.length)return void 0===n[e]?null:n[e];n[e]=i}else{if(1===arguments.length)return void 0===this.options[e]?null:this.options[e];a[e]=i}return this._setOptions(a),this},_setOptions:function(t){var e;for(e in t)this._setOption(e,t[e]);return this},_setOption:function(t,e){return"classes"===t&&this._setOptionClasses(e),this.options[t]=e,"disabled"===t&&this._setOptionDisabled(e),this},_setOptionClasses:function(e){var i,s,n;for(i in e)n=this.classesElementLookup[i],e[i]!==this.options.classes[i]&&n&&n.length&&(s=t(n.get()),this._removeClass(n,i),s.addClass(this._classes({element:s,keys:i,classes:e,add:!0})))},_setOptionDisabled:function(t){this._toggleClass(this.widget(),this.widgetFullName+"-disabled",null,!!t),t&&(this._removeClass(this.hoverable,null,"ui-state-hover"),this._removeClass(this.focusable,null,"ui-state-focus"))},enable:function(){return this._setOptions({disabled:!1})},disable:function(){return this._setOptions({disabled:!0})},_classes:function(e){function i(i,o){var a,r;for(r=0;i.length>r;r++)a=n.classesElementLookup[i[r]]||t(),a=e.add?t(t.unique(a.get().concat(e.element.get()))):t(a.not(e.element).get()),n.classesElementLookup[i[r]]=a,s.push(i[r]),o&&e.classes[i[r]]&&s.push(e.classes[i[r]])}var s=[],n=this;return e=t.extend({element:this.element,classes:this.options.classes||{}},e),this._on(e.element,{remove:"_untrackClassesElement"}),e.keys&&i(e.keys.match(/\S+/g)||[],!0),e.extra&&i(e.extra.match(/\S+/g)||[]),s.join(" ")},_untrackClassesElement:function(e){var i=this;t.each(i.classesElementLookup,function(s,n){-1!==t.inArray(e.target,n)&&(i.classesElementLookup[s]=t(n.not(e.target).get()))})},_removeClass:function(t,e,i){return this._toggleClass(t,e,i,!1)},_addClass:function(t,e,i){return this._toggleClass(t,e,i,!0)},_toggleClass:function(t,e,i,s){s="boolean"==typeof s?s:i;var n="string"==typeof t||null===t,o={extra:n?e:i,keys:n?t:e,element:n?this.element:t,add:s};return o.element.toggleClass(this._classes(o),s),this},_on:function(e,i,s){var n,o=this;"boolean"!=typeof e&&(s=i,i=e,e=!1),s?(i=n=t(i),this.bindings=this.bindings.add(i)):(s=i,i=this.element,n=this.widget()),t.each(s,function(s,a){function r(){return e||o.options.disabled!==!0&&!t(this).hasClass("ui-state-disabled")?("string"==typeof a?o[a]:a).apply(o,arguments):void 0}"string"!=typeof a&&(r.guid=a.guid=a.guid||r.guid||t.guid++);var h=s.match(/^([\w:-]*)\s*(.*)$/),l=h[1]+o.eventNamespace,c=h[2];c?n.on(l,c,r):i.on(l,r)})},_off:function(e,i){i=(i||"").split(" ").join(this.eventNamespace+" ")+this.eventNamespace,e.off(i).off(i),this.bindings=t(this.bindings.not(e).get()),this.focusable=t(this.focusable.not(e).get()),this.hoverable=t(this.hoverable.not(e).get())},_delay:function(t,e){function i(){return("string"==typeof t?s[t]:t).apply(s,arguments)}var s=this;return setTimeout(i,e||0)},_hoverable:function(e){this.hoverable=this.hoverable.add(e),this._on(e,{mouseenter:function(e){this._addClass(t(e.currentTarget),null,"ui-state-hover")},mouseleave:function(e){this._removeClass(t(e.currentTarget),null,"ui-state-hover")}})},_focusable:function(e){this.focusable=this.focusable.add(e),this._on(e,{focusin:function(e){this._addClass(t(e.currentTarget),null,"ui-state-focus")},focusout:function(e){this._removeClass(t(e.currentTarget),null,"ui-state-focus")}})},_trigger:function(e,i,s){var n,o,a=this.options[e];if(s=s||{},i=t.Event(i),i.type=(e===this.widgetEventPrefix?e:this.widgetEventPrefix+e).toLowerCase(),i.target=this.element[0],o=i.originalEvent)for(n in o)n in i||(i[n]=o[n]);return this.element.trigger(i,s),!(t.isFunction(a)&&a.apply(this.element[0],[i].concat(s))===!1||i.isDefaultPrevented())}},t.each({show:"fadeIn",hide:"fadeOut"},function(e,i){t.Widget.prototype["_"+e]=function(s,n,o){"string"==typeof n&&(n={effect:n});var a,r=n?n===!0||"number"==typeof n?i:n.effect||i:e;n=n||{},"number"==typeof n&&(n={duration:n}),a=!t.isEmptyObject(n),n.complete=o,n.delay&&s.delay(n.delay),a&&t.effects&&t.effects.effect[r]?s[e](n):r!==e&&s[r]?s[r](n.duration,n.easing,o):s.queue(function(i){t(this)[e](),o&&o.call(s[0]),i()})}}),t.widget,function(){function e(t,e,i){return[parseFloat(t[0])*(u.test(t[0])?e/100:1),parseFloat(t[1])*(u.test(t[1])?i/100:1)]}function i(e,i){return parseInt(t.css(e,i),10)||0}function s(e){var i=e[0];return 9===i.nodeType?{width:e.width(),height:e.height(),offset:{top:0,left:0}}:t.isWindow(i)?{width:e.width(),height:e.height(),offset:{top:e.scrollTop(),left:e.scrollLeft()}}:i.preventDefault?{width:0,height:0,offset:{top:i.pageY,left:i.pageX}}:{width:e.outerWidth(),height:e.outerHeight(),offset:e.offset()}}var n,o=Math.max,a=Math.abs,r=/left|center|right/,h=/top|center|bottom/,l=/[\+\-]\d+(\.[\d]+)?%?/,c=/^\w+/,u=/%$/,d=t.fn.position;t.position={scrollbarWidth:function(){if(void 0!==n)return n;var e,i,s=t("
"),o=s.children()[0];return t("body").append(s),e=o.offsetWidth,s.css("overflow","scroll"),i=o.offsetWidth,e===i&&(i=s[0].clientWidth),s.remove(),n=e-i},getScrollInfo:function(e){var i=e.isWindow||e.isDocument?"":e.element.css("overflow-x"),s=e.isWindow||e.isDocument?"":e.element.css("overflow-y"),n="scroll"===i||"auto"===i&&e.widthi?"left":e>0?"right":"center",vertical:0>r?"top":s>0?"bottom":"middle"};l>p&&p>a(e+i)&&(u.horizontal="center"),c>f&&f>a(s+r)&&(u.vertical="middle"),u.important=o(a(e),a(i))>o(a(s),a(r))?"horizontal":"vertical",n.using.call(this,t,u)}),h.offset(t.extend(D,{using:r}))})},t.ui.position={fit:{left:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollLeft:s.offset.left,a=s.width,r=t.left-e.collisionPosition.marginLeft,h=n-r,l=r+e.collisionWidth-a-n;e.collisionWidth>a?h>0&&0>=l?(i=t.left+h+e.collisionWidth-a-n,t.left+=h-i):t.left=l>0&&0>=h?n:h>l?n+a-e.collisionWidth:n:h>0?t.left+=h:l>0?t.left-=l:t.left=o(t.left-r,t.left)},top:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollTop:s.offset.top,a=e.within.height,r=t.top-e.collisionPosition.marginTop,h=n-r,l=r+e.collisionHeight-a-n;e.collisionHeight>a?h>0&&0>=l?(i=t.top+h+e.collisionHeight-a-n,t.top+=h-i):t.top=l>0&&0>=h?n:h>l?n+a-e.collisionHeight:n:h>0?t.top+=h:l>0?t.top-=l:t.top=o(t.top-r,t.top)}},flip:{left:function(t,e){var i,s,n=e.within,o=n.offset.left+n.scrollLeft,r=n.width,h=n.isWindow?n.scrollLeft:n.offset.left,l=t.left-e.collisionPosition.marginLeft,c=l-h,u=l+e.collisionWidth-r-h,d="left"===e.my[0]?-e.elemWidth:"right"===e.my[0]?e.elemWidth:0,p="left"===e.at[0]?e.targetWidth:"right"===e.at[0]?-e.targetWidth:0,f=-2*e.offset[0];0>c?(i=t.left+d+p+f+e.collisionWidth-r-o,(0>i||a(c)>i)&&(t.left+=d+p+f)):u>0&&(s=t.left-e.collisionPosition.marginLeft+d+p+f-h,(s>0||u>a(s))&&(t.left+=d+p+f))},top:function(t,e){var i,s,n=e.within,o=n.offset.top+n.scrollTop,r=n.height,h=n.isWindow?n.scrollTop:n.offset.top,l=t.top-e.collisionPosition.marginTop,c=l-h,u=l+e.collisionHeight-r-h,d="top"===e.my[1],p=d?-e.elemHeight:"bottom"===e.my[1]?e.elemHeight:0,f="top"===e.at[1]?e.targetHeight:"bottom"===e.at[1]?-e.targetHeight:0,m=-2*e.offset[1];0>c?(s=t.top+p+f+m+e.collisionHeight-r-o,(0>s||a(c)>s)&&(t.top+=p+f+m)):u>0&&(i=t.top-e.collisionPosition.marginTop+p+f+m-h,(i>0||u>a(i))&&(t.top+=p+f+m))}},flipfit:{left:function(){t.ui.position.flip.left.apply(this,arguments),t.ui.position.fit.left.apply(this,arguments)},top:function(){t.ui.position.flip.top.apply(this,arguments),t.ui.position.fit.top.apply(this,arguments)}}}}(),t.ui.position,t.extend(t.expr[":"],{data:t.expr.createPseudo?t.expr.createPseudo(function(e){return function(i){return!!t.data(i,e)}}):function(e,i,s){return!!t.data(e,s[3])}}),t.fn.extend({disableSelection:function(){var t="onselectstart"in document.createElement("div")?"selectstart":"mousedown";return function(){return this.on(t+".ui-disableSelection",function(t){t.preventDefault()})}}(),enableSelection:function(){return this.off(".ui-disableSelection")}}),t.ui.focusable=function(i,s){var n,o,a,r,h,l=i.nodeName.toLowerCase();return"area"===l?(n=i.parentNode,o=n.name,i.href&&o&&"map"===n.nodeName.toLowerCase()?(a=t("img[usemap='#"+o+"']"),a.length>0&&a.is(":visible")):!1):(/^(input|select|textarea|button|object)$/.test(l)?(r=!i.disabled,r&&(h=t(i).closest("fieldset")[0],h&&(r=!h.disabled))):r="a"===l?i.href||s:s,r&&t(i).is(":visible")&&e(t(i)))},t.extend(t.expr[":"],{focusable:function(e){return t.ui.focusable(e,null!=t.attr(e,"tabindex"))}}),t.ui.focusable,t.fn.form=function(){return"string"==typeof this[0].form?this.closest("form"):t(this[0].form)},t.ui.formResetMixin={_formResetHandler:function(){var e=t(this);setTimeout(function(){var i=e.data("ui-form-reset-instances");t.each(i,function(){this.refresh()})})},_bindFormResetHandler:function(){if(this.form=this.element.form(),this.form.length){var t=this.form.data("ui-form-reset-instances")||[];t.length||this.form.on("reset.ui-form-reset",this._formResetHandler),t.push(this),this.form.data("ui-form-reset-instances",t)}},_unbindFormResetHandler:function(){if(this.form.length){var e=this.form.data("ui-form-reset-instances");e.splice(t.inArray(this,e),1),e.length?this.form.data("ui-form-reset-instances",e):this.form.removeData("ui-form-reset-instances").off("reset.ui-form-reset")}}},"1.7"===t.fn.jquery.substring(0,3)&&(t.each(["Width","Height"],function(e,i){function s(e,i,s,o){return t.each(n,function(){i-=parseFloat(t.css(e,"padding"+this))||0,s&&(i-=parseFloat(t.css(e,"border"+this+"Width"))||0),o&&(i-=parseFloat(t.css(e,"margin"+this))||0)}),i}var n="Width"===i?["Left","Right"]:["Top","Bottom"],o=i.toLowerCase(),a={innerWidth:t.fn.innerWidth,innerHeight:t.fn.innerHeight,outerWidth:t.fn.outerWidth,outerHeight:t.fn.outerHeight};t.fn["inner"+i]=function(e){return void 0===e?a["inner"+i].call(this):this.each(function(){t(this).css(o,s(this,e)+"px")})},t.fn["outer"+i]=function(e,n){return"number"!=typeof e?a["outer"+i].call(this,e):this.each(function(){t(this).css(o,s(this,e,!0,n)+"px")})}}),t.fn.addBack=function(t){return this.add(null==t?this.prevObject:this.prevObject.filter(t))}),t.ui.keyCode={BACKSPACE:8,COMMA:188,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,LEFT:37,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SPACE:32,TAB:9,UP:38},t.ui.escapeSelector=function(){var t=/([!"#$%&'()*+,./:;<=>?@[\]^`{|}~])/g;return function(e){return e.replace(t,"\\$1")}}(),t.fn.labels=function(){var e,i,s,n,o;return this[0].labels&&this[0].labels.length?this.pushStack(this[0].labels):(n=this.eq(0).parents("label"),s=this.attr("id"),s&&(e=this.eq(0).parents().last(),o=e.add(e.length?e.siblings():this.siblings()),i="label[for='"+t.ui.escapeSelector(s)+"']",n=n.add(o.find(i).addBack(i))),this.pushStack(n))},t.fn.scrollParent=function(e){var i=this.css("position"),s="absolute"===i,n=e?/(auto|scroll|hidden)/:/(auto|scroll)/,o=this.parents().filter(function(){var e=t(this);return s&&"static"===e.css("position")?!1:n.test(e.css("overflow")+e.css("overflow-y")+e.css("overflow-x"))}).eq(0);return"fixed"!==i&&o.length?o:t(this[0].ownerDocument||document)},t.extend(t.expr[":"],{tabbable:function(e){var i=t.attr(e,"tabindex"),s=null!=i;return(!s||i>=0)&&t.ui.focusable(e,s)}}),t.fn.extend({uniqueId:function(){var t=0;return function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++t)})}}(),removeUniqueId:function(){return this.each(function(){/^ui-id-\d+$/.test(this.id)&&t(this).removeAttr("id")})}}),t.ui.ie=!!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase());var n=!1;t(document).on("mouseup",function(){n=!1}),t.widget("ui.mouse",{version:"1.12.1",options:{cancel:"input, textarea, button, select, option",distance:1,delay:0},_mouseInit:function(){var e=this;this.element.on("mousedown."+this.widgetName,function(t){return e._mouseDown(t)}).on("click."+this.widgetName,function(i){return!0===t.data(i.target,e.widgetName+".preventClickEvent")?(t.removeData(i.target,e.widgetName+".preventClickEvent"),i.stopImmediatePropagation(),!1):void 0}),this.started=!1},_mouseDestroy:function(){this.element.off("."+this.widgetName),this._mouseMoveDelegate&&this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate)},_mouseDown:function(e){if(!n){this._mouseMoved=!1,this._mouseStarted&&this._mouseUp(e),this._mouseDownEvent=e;var i=this,s=1===e.which,o="string"==typeof this.options.cancel&&e.target.nodeName?t(e.target).closest(this.options.cancel).length:!1;return s&&!o&&this._mouseCapture(e)?(this.mouseDelayMet=!this.options.delay,this.mouseDelayMet||(this._mouseDelayTimer=setTimeout(function(){i.mouseDelayMet=!0},this.options.delay)),this._mouseDistanceMet(e)&&this._mouseDelayMet(e)&&(this._mouseStarted=this._mouseStart(e)!==!1,!this._mouseStarted)?(e.preventDefault(),!0):(!0===t.data(e.target,this.widgetName+".preventClickEvent")&&t.removeData(e.target,this.widgetName+".preventClickEvent"),this._mouseMoveDelegate=function(t){return i._mouseMove(t)},this._mouseUpDelegate=function(t){return i._mouseUp(t)},this.document.on("mousemove."+this.widgetName,this._mouseMoveDelegate).on("mouseup."+this.widgetName,this._mouseUpDelegate),e.preventDefault(),n=!0,!0)):!0}},_mouseMove:function(e){if(this._mouseMoved){if(t.ui.ie&&(!document.documentMode||9>document.documentMode)&&!e.button)return this._mouseUp(e);if(!e.which)if(e.originalEvent.altKey||e.originalEvent.ctrlKey||e.originalEvent.metaKey||e.originalEvent.shiftKey)this.ignoreMissingWhich=!0;else if(!this.ignoreMissingWhich)return this._mouseUp(e)}return(e.which||e.button)&&(this._mouseMoved=!0),this._mouseStarted?(this._mouseDrag(e),e.preventDefault()):(this._mouseDistanceMet(e)&&this._mouseDelayMet(e)&&(this._mouseStarted=this._mouseStart(this._mouseDownEvent,e)!==!1,this._mouseStarted?this._mouseDrag(e):this._mouseUp(e)),!this._mouseStarted)},_mouseUp:function(e){this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate),this._mouseStarted&&(this._mouseStarted=!1,e.target===this._mouseDownEvent.target&&t.data(e.target,this.widgetName+".preventClickEvent",!0),this._mouseStop(e)),this._mouseDelayTimer&&(clearTimeout(this._mouseDelayTimer),delete this._mouseDelayTimer),this.ignoreMissingWhich=!1,n=!1,e.preventDefault()},_mouseDistanceMet:function(t){return Math.max(Math.abs(this._mouseDownEvent.pageX-t.pageX),Math.abs(this._mouseDownEvent.pageY-t.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return!0}}),t.ui.plugin={add:function(e,i,s){var n,o=t.ui[e].prototype;for(n in s)o.plugins[n]=o.plugins[n]||[],o.plugins[n].push([i,s[n]])},call:function(t,e,i,s){var n,o=t.plugins[e];if(o&&(s||t.element[0].parentNode&&11!==t.element[0].parentNode.nodeType))for(n=0;o.length>n;n++)t.options[o[n][0]]&&o[n][1].apply(t.element,i)}},t.widget("ui.resizable",t.ui.mouse,{version:"1.12.1",widgetEventPrefix:"resize",options:{alsoResize:!1,animate:!1,animateDuration:"slow",animateEasing:"swing",aspectRatio:!1,autoHide:!1,classes:{"ui-resizable-se":"ui-icon ui-icon-gripsmall-diagonal-se"},containment:!1,ghost:!1,grid:!1,handles:"e,s,se",helper:!1,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:90,resize:null,start:null,stop:null},_num:function(t){return parseFloat(t)||0},_isNumber:function(t){return!isNaN(parseFloat(t))},_hasScroll:function(e,i){if("hidden"===t(e).css("overflow"))return!1;var s=i&&"left"===i?"scrollLeft":"scrollTop",n=!1;return e[s]>0?!0:(e[s]=1,n=e[s]>0,e[s]=0,n)},_create:function(){var e,i=this.options,s=this;this._addClass("ui-resizable"),t.extend(this,{_aspectRatio:!!i.aspectRatio,aspectRatio:i.aspectRatio,originalElement:this.element,_proportionallyResizeElements:[],_helper:i.helper||i.ghost||i.animate?i.helper||"ui-resizable-helper":null}),this.element[0].nodeName.match(/^(canvas|textarea|input|select|button|img)$/i)&&(this.element.wrap(t("
").css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),top:this.element.css("top"),left:this.element.css("left")})),this.element=this.element.parent().data("ui-resizable",this.element.resizable("instance")),this.elementIsWrapper=!0,e={marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom"),marginLeft:this.originalElement.css("marginLeft")},this.element.css(e),this.originalElement.css("margin",0),this.originalResizeStyle=this.originalElement.css("resize"),this.originalElement.css("resize","none"),this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"})),this.originalElement.css(e),this._proportionallyResize()),this._setupHandles(),i.autoHide&&t(this.element).on("mouseenter",function(){i.disabled||(s._removeClass("ui-resizable-autohide"),s._handles.show())}).on("mouseleave",function(){i.disabled||s.resizing||(s._addClass("ui-resizable-autohide"),s._handles.hide())}),this._mouseInit()},_destroy:function(){this._mouseDestroy();var e,i=function(e){t(e).removeData("resizable").removeData("ui-resizable").off(".resizable").find(".ui-resizable-handle").remove()};return this.elementIsWrapper&&(i(this.element),e=this.element,this.originalElement.css({position:e.css("position"),width:e.outerWidth(),height:e.outerHeight(),top:e.css("top"),left:e.css("left")}).insertAfter(e),e.remove()),this.originalElement.css("resize",this.originalResizeStyle),i(this.originalElement),this},_setOption:function(t,e){switch(this._super(t,e),t){case"handles":this._removeHandles(),this._setupHandles();break;default:}},_setupHandles:function(){var e,i,s,n,o,a=this.options,r=this;if(this.handles=a.handles||(t(".ui-resizable-handle",this.element).length?{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",nw:".ui-resizable-nw"}:"e,s,se"),this._handles=t(),this.handles.constructor===String)for("all"===this.handles&&(this.handles="n,e,s,w,se,sw,ne,nw"),s=this.handles.split(","),this.handles={},i=0;s.length>i;i++)e=t.trim(s[i]),n="ui-resizable-"+e,o=t("
"),this._addClass(o,"ui-resizable-handle "+n),o.css({zIndex:a.zIndex}),this.handles[e]=".ui-resizable-"+e,this.element.append(o);this._renderAxis=function(e){var i,s,n,o;e=e||this.element;for(i in this.handles)this.handles[i].constructor===String?this.handles[i]=this.element.children(this.handles[i]).first().show():(this.handles[i].jquery||this.handles[i].nodeType)&&(this.handles[i]=t(this.handles[i]),this._on(this.handles[i],{mousedown:r._mouseDown})),this.elementIsWrapper&&this.originalElement[0].nodeName.match(/^(textarea|input|select|button)$/i)&&(s=t(this.handles[i],this.element),o=/sw|ne|nw|se|n|s/.test(i)?s.outerHeight():s.outerWidth(),n=["padding",/ne|nw|n/.test(i)?"Top":/se|sw|s/.test(i)?"Bottom":/^e$/.test(i)?"Right":"Left"].join(""),e.css(n,o),this._proportionallyResize()),this._handles=this._handles.add(this.handles[i])},this._renderAxis(this.element),this._handles=this._handles.add(this.element.find(".ui-resizable-handle")),this._handles.disableSelection(),this._handles.on("mouseover",function(){r.resizing||(this.className&&(o=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i)),r.axis=o&&o[1]?o[1]:"se")}),a.autoHide&&(this._handles.hide(),this._addClass("ui-resizable-autohide"))},_removeHandles:function(){this._handles.remove()},_mouseCapture:function(e){var i,s,n=!1;for(i in this.handles)s=t(this.handles[i])[0],(s===e.target||t.contains(s,e.target))&&(n=!0);return!this.options.disabled&&n},_mouseStart:function(e){var i,s,n,o=this.options,a=this.element;return this.resizing=!0,this._renderProxy(),i=this._num(this.helper.css("left")),s=this._num(this.helper.css("top")),o.containment&&(i+=t(o.containment).scrollLeft()||0,s+=t(o.containment).scrollTop()||0),this.offset=this.helper.offset(),this.position={left:i,top:s},this.size=this._helper?{width:this.helper.width(),height:this.helper.height()}:{width:a.width(),height:a.height()},this.originalSize=this._helper?{width:a.outerWidth(),height:a.outerHeight()}:{width:a.width(),height:a.height()},this.sizeDiff={width:a.outerWidth()-a.width(),height:a.outerHeight()-a.height()},this.originalPosition={left:i,top:s},this.originalMousePosition={left:e.pageX,top:e.pageY},this.aspectRatio="number"==typeof o.aspectRatio?o.aspectRatio:this.originalSize.width/this.originalSize.height||1,n=t(".ui-resizable-"+this.axis).css("cursor"),t("body").css("cursor","auto"===n?this.axis+"-resize":n),this._addClass("ui-resizable-resizing"),this._propagate("start",e),!0},_mouseDrag:function(e){var i,s,n=this.originalMousePosition,o=this.axis,a=e.pageX-n.left||0,r=e.pageY-n.top||0,h=this._change[o];return this._updatePrevProperties(),h?(i=h.apply(this,[e,a,r]),this._updateVirtualBoundaries(e.shiftKey),(this._aspectRatio||e.shiftKey)&&(i=this._updateRatio(i,e)),i=this._respectSize(i,e),this._updateCache(i),this._propagate("resize",e),s=this._applyChanges(),!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize(),t.isEmptyObject(s)||(this._updatePrevProperties(),this._trigger("resize",e,this.ui()),this._applyChanges()),!1):!1},_mouseStop:function(e){this.resizing=!1;var i,s,n,o,a,r,h,l=this.options,c=this;return this._helper&&(i=this._proportionallyResizeElements,s=i.length&&/textarea/i.test(i[0].nodeName),n=s&&this._hasScroll(i[0],"left")?0:c.sizeDiff.height,o=s?0:c.sizeDiff.width,a={width:c.helper.width()-o,height:c.helper.height()-n},r=parseFloat(c.element.css("left"))+(c.position.left-c.originalPosition.left)||null,h=parseFloat(c.element.css("top"))+(c.position.top-c.originalPosition.top)||null,l.animate||this.element.css(t.extend(a,{top:h,left:r})),c.helper.height(c.size.height),c.helper.width(c.size.width),this._helper&&!l.animate&&this._proportionallyResize()),t("body").css("cursor","auto"),this._removeClass("ui-resizable-resizing"),this._propagate("stop",e),this._helper&&this.helper.remove(),!1},_updatePrevProperties:function(){this.prevPosition={top:this.position.top,left:this.position.left},this.prevSize={width:this.size.width,height:this.size.height}},_applyChanges:function(){var t={};return this.position.top!==this.prevPosition.top&&(t.top=this.position.top+"px"),this.position.left!==this.prevPosition.left&&(t.left=this.position.left+"px"),this.size.width!==this.prevSize.width&&(t.width=this.size.width+"px"),this.size.height!==this.prevSize.height&&(t.height=this.size.height+"px"),this.helper.css(t),t},_updateVirtualBoundaries:function(t){var e,i,s,n,o,a=this.options;o={minWidth:this._isNumber(a.minWidth)?a.minWidth:0,maxWidth:this._isNumber(a.maxWidth)?a.maxWidth:1/0,minHeight:this._isNumber(a.minHeight)?a.minHeight:0,maxHeight:this._isNumber(a.maxHeight)?a.maxHeight:1/0},(this._aspectRatio||t)&&(e=o.minHeight*this.aspectRatio,s=o.minWidth/this.aspectRatio,i=o.maxHeight*this.aspectRatio,n=o.maxWidth/this.aspectRatio,e>o.minWidth&&(o.minWidth=e),s>o.minHeight&&(o.minHeight=s),o.maxWidth>i&&(o.maxWidth=i),o.maxHeight>n&&(o.maxHeight=n)),this._vBoundaries=o},_updateCache:function(t){this.offset=this.helper.offset(),this._isNumber(t.left)&&(this.position.left=t.left),this._isNumber(t.top)&&(this.position.top=t.top),this._isNumber(t.height)&&(this.size.height=t.height),this._isNumber(t.width)&&(this.size.width=t.width)},_updateRatio:function(t){var e=this.position,i=this.size,s=this.axis;return this._isNumber(t.height)?t.width=t.height*this.aspectRatio:this._isNumber(t.width)&&(t.height=t.width/this.aspectRatio),"sw"===s&&(t.left=e.left+(i.width-t.width),t.top=null),"nw"===s&&(t.top=e.top+(i.height-t.height),t.left=e.left+(i.width-t.width)),t},_respectSize:function(t){var e=this._vBoundaries,i=this.axis,s=this._isNumber(t.width)&&e.maxWidth&&e.maxWidtht.width,a=this._isNumber(t.height)&&e.minHeight&&e.minHeight>t.height,r=this.originalPosition.left+this.originalSize.width,h=this.originalPosition.top+this.originalSize.height,l=/sw|nw|w/.test(i),c=/nw|ne|n/.test(i);return o&&(t.width=e.minWidth),a&&(t.height=e.minHeight),s&&(t.width=e.maxWidth),n&&(t.height=e.maxHeight),o&&l&&(t.left=r-e.minWidth),s&&l&&(t.left=r-e.maxWidth),a&&c&&(t.top=h-e.minHeight),n&&c&&(t.top=h-e.maxHeight),t.width||t.height||t.left||!t.top?t.width||t.height||t.top||!t.left||(t.left=null):t.top=null,t},_getPaddingPlusBorderDimensions:function(t){for(var e=0,i=[],s=[t.css("borderTopWidth"),t.css("borderRightWidth"),t.css("borderBottomWidth"),t.css("borderLeftWidth")],n=[t.css("paddingTop"),t.css("paddingRight"),t.css("paddingBottom"),t.css("paddingLeft")];4>e;e++)i[e]=parseFloat(s[e])||0,i[e]+=parseFloat(n[e])||0;return{height:i[0]+i[2],width:i[1]+i[3]}},_proportionallyResize:function(){if(this._proportionallyResizeElements.length)for(var t,e=0,i=this.helper||this.element;this._proportionallyResizeElements.length>e;e++)t=this._proportionallyResizeElements[e],this.outerDimensions||(this.outerDimensions=this._getPaddingPlusBorderDimensions(t)),t.css({height:i.height()-this.outerDimensions.height||0,width:i.width()-this.outerDimensions.width||0})},_renderProxy:function(){var e=this.element,i=this.options;this.elementOffset=e.offset(),this._helper?(this.helper=this.helper||t("
"),this._addClass(this.helper,this._helper),this.helper.css({width:this.element.outerWidth(),height:this.element.outerHeight(),position:"absolute",left:this.elementOffset.left+"px",top:this.elementOffset.top+"px",zIndex:++i.zIndex}),this.helper.appendTo("body").disableSelection()):this.helper=this.element +},_change:{e:function(t,e){return{width:this.originalSize.width+e}},w:function(t,e){var i=this.originalSize,s=this.originalPosition;return{left:s.left+e,width:i.width-e}},n:function(t,e,i){var s=this.originalSize,n=this.originalPosition;return{top:n.top+i,height:s.height-i}},s:function(t,e,i){return{height:this.originalSize.height+i}},se:function(e,i,s){return t.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[e,i,s]))},sw:function(e,i,s){return t.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[e,i,s]))},ne:function(e,i,s){return t.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[e,i,s]))},nw:function(e,i,s){return t.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[e,i,s]))}},_propagate:function(e,i){t.ui.plugin.call(this,e,[i,this.ui()]),"resize"!==e&&this._trigger(e,i,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,originalPosition:this.originalPosition}}}),t.ui.plugin.add("resizable","animate",{stop:function(e){var i=t(this).resizable("instance"),s=i.options,n=i._proportionallyResizeElements,o=n.length&&/textarea/i.test(n[0].nodeName),a=o&&i._hasScroll(n[0],"left")?0:i.sizeDiff.height,r=o?0:i.sizeDiff.width,h={width:i.size.width-r,height:i.size.height-a},l=parseFloat(i.element.css("left"))+(i.position.left-i.originalPosition.left)||null,c=parseFloat(i.element.css("top"))+(i.position.top-i.originalPosition.top)||null;i.element.animate(t.extend(h,c&&l?{top:c,left:l}:{}),{duration:s.animateDuration,easing:s.animateEasing,step:function(){var s={width:parseFloat(i.element.css("width")),height:parseFloat(i.element.css("height")),top:parseFloat(i.element.css("top")),left:parseFloat(i.element.css("left"))};n&&n.length&&t(n[0]).css({width:s.width,height:s.height}),i._updateCache(s),i._propagate("resize",e)}})}}),t.ui.plugin.add("resizable","containment",{start:function(){var e,i,s,n,o,a,r,h=t(this).resizable("instance"),l=h.options,c=h.element,u=l.containment,d=u instanceof t?u.get(0):/parent/.test(u)?c.parent().get(0):u;d&&(h.containerElement=t(d),/document/.test(u)||u===document?(h.containerOffset={left:0,top:0},h.containerPosition={left:0,top:0},h.parentData={element:t(document),left:0,top:0,width:t(document).width(),height:t(document).height()||document.body.parentNode.scrollHeight}):(e=t(d),i=[],t(["Top","Right","Left","Bottom"]).each(function(t,s){i[t]=h._num(e.css("padding"+s))}),h.containerOffset=e.offset(),h.containerPosition=e.position(),h.containerSize={height:e.innerHeight()-i[3],width:e.innerWidth()-i[1]},s=h.containerOffset,n=h.containerSize.height,o=h.containerSize.width,a=h._hasScroll(d,"left")?d.scrollWidth:o,r=h._hasScroll(d)?d.scrollHeight:n,h.parentData={element:d,left:s.left,top:s.top,width:a,height:r}))},resize:function(e){var i,s,n,o,a=t(this).resizable("instance"),r=a.options,h=a.containerOffset,l=a.position,c=a._aspectRatio||e.shiftKey,u={top:0,left:0},d=a.containerElement,p=!0;d[0]!==document&&/static/.test(d.css("position"))&&(u=h),l.left<(a._helper?h.left:0)&&(a.size.width=a.size.width+(a._helper?a.position.left-h.left:a.position.left-u.left),c&&(a.size.height=a.size.width/a.aspectRatio,p=!1),a.position.left=r.helper?h.left:0),l.top<(a._helper?h.top:0)&&(a.size.height=a.size.height+(a._helper?a.position.top-h.top:a.position.top),c&&(a.size.width=a.size.height*a.aspectRatio,p=!1),a.position.top=a._helper?h.top:0),n=a.containerElement.get(0)===a.element.parent().get(0),o=/relative|absolute/.test(a.containerElement.css("position")),n&&o?(a.offset.left=a.parentData.left+a.position.left,a.offset.top=a.parentData.top+a.position.top):(a.offset.left=a.element.offset().left,a.offset.top=a.element.offset().top),i=Math.abs(a.sizeDiff.width+(a._helper?a.offset.left-u.left:a.offset.left-h.left)),s=Math.abs(a.sizeDiff.height+(a._helper?a.offset.top-u.top:a.offset.top-h.top)),i+a.size.width>=a.parentData.width&&(a.size.width=a.parentData.width-i,c&&(a.size.height=a.size.width/a.aspectRatio,p=!1)),s+a.size.height>=a.parentData.height&&(a.size.height=a.parentData.height-s,c&&(a.size.width=a.size.height*a.aspectRatio,p=!1)),p||(a.position.left=a.prevPosition.left,a.position.top=a.prevPosition.top,a.size.width=a.prevSize.width,a.size.height=a.prevSize.height)},stop:function(){var e=t(this).resizable("instance"),i=e.options,s=e.containerOffset,n=e.containerPosition,o=e.containerElement,a=t(e.helper),r=a.offset(),h=a.outerWidth()-e.sizeDiff.width,l=a.outerHeight()-e.sizeDiff.height;e._helper&&!i.animate&&/relative/.test(o.css("position"))&&t(this).css({left:r.left-n.left-s.left,width:h,height:l}),e._helper&&!i.animate&&/static/.test(o.css("position"))&&t(this).css({left:r.left-n.left-s.left,width:h,height:l})}}),t.ui.plugin.add("resizable","alsoResize",{start:function(){var e=t(this).resizable("instance"),i=e.options;t(i.alsoResize).each(function(){var e=t(this);e.data("ui-resizable-alsoresize",{width:parseFloat(e.width()),height:parseFloat(e.height()),left:parseFloat(e.css("left")),top:parseFloat(e.css("top"))})})},resize:function(e,i){var s=t(this).resizable("instance"),n=s.options,o=s.originalSize,a=s.originalPosition,r={height:s.size.height-o.height||0,width:s.size.width-o.width||0,top:s.position.top-a.top||0,left:s.position.left-a.left||0};t(n.alsoResize).each(function(){var e=t(this),s=t(this).data("ui-resizable-alsoresize"),n={},o=e.parents(i.originalElement[0]).length?["width","height"]:["width","height","top","left"];t.each(o,function(t,e){var i=(s[e]||0)+(r[e]||0);i&&i>=0&&(n[e]=i||null)}),e.css(n)})},stop:function(){t(this).removeData("ui-resizable-alsoresize")}}),t.ui.plugin.add("resizable","ghost",{start:function(){var e=t(this).resizable("instance"),i=e.size;e.ghost=e.originalElement.clone(),e.ghost.css({opacity:.25,display:"block",position:"relative",height:i.height,width:i.width,margin:0,left:0,top:0}),e._addClass(e.ghost,"ui-resizable-ghost"),t.uiBackCompat!==!1&&"string"==typeof e.options.ghost&&e.ghost.addClass(this.options.ghost),e.ghost.appendTo(e.helper)},resize:function(){var e=t(this).resizable("instance");e.ghost&&e.ghost.css({position:"relative",height:e.size.height,width:e.size.width})},stop:function(){var e=t(this).resizable("instance");e.ghost&&e.helper&&e.helper.get(0).removeChild(e.ghost.get(0))}}),t.ui.plugin.add("resizable","grid",{resize:function(){var e,i=t(this).resizable("instance"),s=i.options,n=i.size,o=i.originalSize,a=i.originalPosition,r=i.axis,h="number"==typeof s.grid?[s.grid,s.grid]:s.grid,l=h[0]||1,c=h[1]||1,u=Math.round((n.width-o.width)/l)*l,d=Math.round((n.height-o.height)/c)*c,p=o.width+u,f=o.height+d,m=s.maxWidth&&p>s.maxWidth,g=s.maxHeight&&f>s.maxHeight,_=s.minWidth&&s.minWidth>p,v=s.minHeight&&s.minHeight>f;s.grid=h,_&&(p+=l),v&&(f+=c),m&&(p-=l),g&&(f-=c),/^(se|s|e)$/.test(r)?(i.size.width=p,i.size.height=f):/^(ne)$/.test(r)?(i.size.width=p,i.size.height=f,i.position.top=a.top-d):/^(sw)$/.test(r)?(i.size.width=p,i.size.height=f,i.position.left=a.left-u):((0>=f-c||0>=p-l)&&(e=i._getPaddingPlusBorderDimensions(this)),f-c>0?(i.size.height=f,i.position.top=a.top-d):(f=c-e.height,i.size.height=f,i.position.top=a.top+o.height-f),p-l>0?(i.size.width=p,i.position.left=a.left-u):(p=l-e.width,i.size.width=p,i.position.left=a.left+o.width-p))}}),t.ui.resizable});/** + * Copyright (c) 2007 Ariel Flesler - aflesler ○ gmail • com | https://github.com/flesler + * Licensed under MIT + * @author Ariel Flesler + * @version 2.1.2 + */ +;(function(f){"use strict";"function"===typeof define&&define.amd?define(["jquery"],f):"undefined"!==typeof module&&module.exports?module.exports=f(require("jquery")):f(jQuery)})(function($){"use strict";function n(a){return!a.nodeName||-1!==$.inArray(a.nodeName.toLowerCase(),["iframe","#document","html","body"])}function h(a){return $.isFunction(a)||$.isPlainObject(a)?a:{top:a,left:a}}var p=$.scrollTo=function(a,d,b){return $(window).scrollTo(a,d,b)};p.defaults={axis:"xy",duration:0,limit:!0};$.fn.scrollTo=function(a,d,b){"object"=== typeof d&&(b=d,d=0);"function"===typeof b&&(b={onAfter:b});"max"===a&&(a=9E9);b=$.extend({},p.defaults,b);d=d||b.duration;var u=b.queue&&1=f[g]?0:Math.min(f[g],n));!a&&1-1){targetElements.on(evt+EVENT_NAMESPACE,function elementToggle(event){$.powerTip.toggle(this,event)})}else{targetElements.on(evt+EVENT_NAMESPACE,function elementOpen(event){$.powerTip.show(this,event)})}});$.each(options.closeEvents,function(idx,evt){if($.inArray(evt,options.openEvents)<0){targetElements.on(evt+EVENT_NAMESPACE,function elementClose(event){$.powerTip.hide(this,!isMouseEvent(event))})}});targetElements.on("keydown"+EVENT_NAMESPACE,function elementKeyDown(event){if(event.keyCode===27){$.powerTip.hide(this,true)}})}return targetElements};$.fn.powerTip.defaults={fadeInTime:200,fadeOutTime:100,followMouse:false,popupId:"powerTip",popupClass:null,intentSensitivity:7,intentPollInterval:100,closeDelay:100,placement:"n",smartPlacement:false,offset:10,mouseOnToPopup:false,manual:false,openEvents:["mouseenter","focus"],closeEvents:["mouseleave","blur"]};$.fn.powerTip.smartPlacementLists={n:["n","ne","nw","s"],e:["e","ne","se","w","nw","sw","n","s","e"],s:["s","se","sw","n"],w:["w","nw","sw","e","ne","se","n","s","w"],nw:["nw","w","sw","n","s","se","nw"],ne:["ne","e","se","n","s","sw","ne"],sw:["sw","w","nw","s","n","ne","sw"],se:["se","e","ne","s","n","nw","se"],"nw-alt":["nw-alt","n","ne-alt","sw-alt","s","se-alt","w","e"],"ne-alt":["ne-alt","n","nw-alt","se-alt","s","sw-alt","e","w"],"sw-alt":["sw-alt","s","se-alt","nw-alt","n","ne-alt","w","e"],"se-alt":["se-alt","s","sw-alt","ne-alt","n","nw-alt","e","w"]};$.powerTip={show:function apiShowTip(element,event){if(isMouseEvent(event)){trackMouse(event);session.previousX=event.pageX;session.previousY=event.pageY;$(element).data(DATA_DISPLAYCONTROLLER).show()}else{$(element).first().data(DATA_DISPLAYCONTROLLER).show(true,true)}return element},reposition:function apiResetPosition(element){$(element).first().data(DATA_DISPLAYCONTROLLER).resetPosition();return element},hide:function apiCloseTip(element,immediate){var displayController;immediate=element?immediate:true;if(element){displayController=$(element).first().data(DATA_DISPLAYCONTROLLER)}else if(session.activeHover){displayController=session.activeHover.data(DATA_DISPLAYCONTROLLER)}if(displayController){displayController.hide(immediate)}return element},toggle:function apiToggle(element,event){if(session.activeHover&&session.activeHover.is(element)){$.powerTip.hide(element,!isMouseEvent(event))}else{$.powerTip.show(element,event)}return element}};$.powerTip.showTip=$.powerTip.show;$.powerTip.closeTip=$.powerTip.hide;function CSSCoordinates(){var me=this;me.top="auto";me.left="auto";me.right="auto";me.bottom="auto";me.set=function(property,value){if($.isNumeric(value)){me[property]=Math.round(value)}}}function DisplayController(element,options,tipController){var hoverTimer=null,myCloseDelay=null;function openTooltip(immediate,forceOpen){cancelTimer();if(!element.data(DATA_HASACTIVEHOVER)){if(!immediate){session.tipOpenImminent=true;hoverTimer=setTimeout(function intentDelay(){hoverTimer=null;checkForIntent()},options.intentPollInterval)}else{if(forceOpen){element.data(DATA_FORCEDOPEN,true)}closeAnyDelayed();tipController.showTip(element)}}else{cancelClose()}}function closeTooltip(disableDelay){if(myCloseDelay){myCloseDelay=session.closeDelayTimeout=clearTimeout(myCloseDelay);session.delayInProgress=false}cancelTimer();session.tipOpenImminent=false;if(element.data(DATA_HASACTIVEHOVER)){element.data(DATA_FORCEDOPEN,false);if(!disableDelay){session.delayInProgress=true;session.closeDelayTimeout=setTimeout(function closeDelay(){session.closeDelayTimeout=null;tipController.hideTip(element);session.delayInProgress=false;myCloseDelay=null},options.closeDelay);myCloseDelay=session.closeDelayTimeout}else{tipController.hideTip(element)}}}function checkForIntent(){var xDifference=Math.abs(session.previousX-session.currentX),yDifference=Math.abs(session.previousY-session.currentY),totalDifference=xDifference+yDifference;if(totalDifference",{id:options.popupId});if($body.length===0){$body=$("body")}$body.append(tipElement);session.tooltips=session.tooltips?session.tooltips.add(tipElement):tipElement}if(options.followMouse){if(!tipElement.data(DATA_HASMOUSEMOVE)){$document.on("mousemove"+EVENT_NAMESPACE,positionTipOnCursor);$window.on("scroll"+EVENT_NAMESPACE,positionTipOnCursor);tipElement.data(DATA_HASMOUSEMOVE,true)}}function beginShowTip(element){element.data(DATA_HASACTIVEHOVER,true);tipElement.queue(function queueTipInit(next){showTip(element);next()})}function showTip(element){var tipContent;if(!element.data(DATA_HASACTIVEHOVER)){return}if(session.isTipOpen){if(!session.isClosing){hideTip(session.activeHover)}tipElement.delay(100).queue(function queueTipAgain(next){showTip(element);next()});return}element.trigger("powerTipPreRender");tipContent=getTooltipContent(element);if(tipContent){tipElement.empty().append(tipContent)}else{return}element.trigger("powerTipRender");session.activeHover=element;session.isTipOpen=true;tipElement.data(DATA_MOUSEONTOTIP,options.mouseOnToPopup);tipElement.addClass(options.popupClass);if(!options.followMouse||element.data(DATA_FORCEDOPEN)){positionTipOnElement(element);session.isFixedTipOpen=true}else{positionTipOnCursor()}if(!element.data(DATA_FORCEDOPEN)&&!options.followMouse){$document.on("click"+EVENT_NAMESPACE,function documentClick(event){var target=event.target;if(target!==element[0]){if(options.mouseOnToPopup){if(target!==tipElement[0]&&!$.contains(tipElement[0],target)){$.powerTip.hide()}}else{$.powerTip.hide()}}})}if(options.mouseOnToPopup&&!options.manual){tipElement.on("mouseenter"+EVENT_NAMESPACE,function tipMouseEnter(){if(session.activeHover){session.activeHover.data(DATA_DISPLAYCONTROLLER).cancel()}});tipElement.on("mouseleave"+EVENT_NAMESPACE,function tipMouseLeave(){if(session.activeHover){session.activeHover.data(DATA_DISPLAYCONTROLLER).hide()}})}tipElement.fadeIn(options.fadeInTime,function fadeInCallback(){if(!session.desyncTimeout){session.desyncTimeout=setInterval(closeDesyncedTip,500)}element.trigger("powerTipOpen")})}function hideTip(element){session.isClosing=true;session.isTipOpen=false;session.desyncTimeout=clearInterval(session.desyncTimeout);element.data(DATA_HASACTIVEHOVER,false);element.data(DATA_FORCEDOPEN,false);$document.off("click"+EVENT_NAMESPACE);tipElement.off(EVENT_NAMESPACE);tipElement.fadeOut(options.fadeOutTime,function fadeOutCallback(){var coords=new CSSCoordinates;session.activeHover=null;session.isClosing=false;session.isFixedTipOpen=false;tipElement.removeClass();coords.set("top",session.currentY+options.offset);coords.set("left",session.currentX+options.offset);tipElement.css(coords);element.trigger("powerTipClose")})}function positionTipOnCursor(){var tipWidth,tipHeight,coords,collisions,collisionCount;if(!session.isFixedTipOpen&&(session.isTipOpen||session.tipOpenImminent&&tipElement.data(DATA_HASMOUSEMOVE))){tipWidth=tipElement.outerWidth();tipHeight=tipElement.outerHeight();coords=new CSSCoordinates;coords.set("top",session.currentY+options.offset);coords.set("left",session.currentX+options.offset);collisions=getViewportCollisions(coords,tipWidth,tipHeight);if(collisions!==Collision.none){collisionCount=countFlags(collisions);if(collisionCount===1){if(collisions===Collision.right){coords.set("left",session.scrollLeft+session.windowWidth-tipWidth)}else if(collisions===Collision.bottom){coords.set("top",session.scrollTop+session.windowHeight-tipHeight)}}else{coords.set("left",session.currentX-tipWidth-options.offset);coords.set("top",session.currentY-tipHeight-options.offset)}}tipElement.css(coords)}}function positionTipOnElement(element){var priorityList,finalPlacement;if(options.smartPlacement||options.followMouse&&element.data(DATA_FORCEDOPEN)){priorityList=$.fn.powerTip.smartPlacementLists[options.placement];$.each(priorityList,function(idx,pos){var collisions=getViewportCollisions(placeTooltip(element,pos),tipElement.outerWidth(),tipElement.outerHeight());finalPlacement=pos;return collisions!==Collision.none})}else{placeTooltip(element,options.placement);finalPlacement=options.placement}tipElement.removeClass("w nw sw e ne se n s w se-alt sw-alt ne-alt nw-alt");tipElement.addClass(finalPlacement)}function placeTooltip(element,placement){var iterationCount=0,tipWidth,tipHeight,coords=new CSSCoordinates;coords.set("top",0);coords.set("left",0);tipElement.css(coords);do{tipWidth=tipElement.outerWidth();tipHeight=tipElement.outerHeight();coords=placementCalculator.compute(element,placement,tipWidth,tipHeight,options.offset);tipElement.css(coords)}while(++iterationCount<=5&&(tipWidth!==tipElement.outerWidth()||tipHeight!==tipElement.outerHeight()));return coords}function closeDesyncedTip(){var isDesynced=false,hasDesyncableCloseEvent=$.grep(["mouseleave","mouseout","blur","focusout"],function(eventType){return $.inArray(eventType,options.closeEvents)!==-1}).length>0;if(session.isTipOpen&&!session.isClosing&&!session.delayInProgress&&hasDesyncableCloseEvent){if(session.activeHover.data(DATA_HASACTIVEHOVER)===false||session.activeHover.is(":disabled")){isDesynced=true}else if(!isMouseOver(session.activeHover)&&!session.activeHover.is(":focus")&&!session.activeHover.data(DATA_FORCEDOPEN)){if(tipElement.data(DATA_MOUSEONTOTIP)){if(!isMouseOver(tipElement)){isDesynced=true}}else{isDesynced=true}}if(isDesynced){hideTip(session.activeHover)}}}this.showTip=beginShowTip;this.hideTip=hideTip;this.resetPosition=positionTipOnElement}function isSvgElement(element){return Boolean(window.SVGElement&&element[0]instanceof SVGElement)}function isMouseEvent(event){return Boolean(event&&$.inArray(event.type,MOUSE_EVENTS)>-1&&typeof event.pageX==="number")}function initTracking(){if(!session.mouseTrackingActive){session.mouseTrackingActive=true;getViewportDimensions();$(getViewportDimensions);$document.on("mousemove"+EVENT_NAMESPACE,trackMouse);$window.on("resize"+EVENT_NAMESPACE,trackResize);$window.on("scroll"+EVENT_NAMESPACE,trackScroll)}}function getViewportDimensions(){session.scrollLeft=$window.scrollLeft();session.scrollTop=$window.scrollTop();session.windowWidth=$window.width();session.windowHeight=$window.height()}function trackResize(){session.windowWidth=$window.width();session.windowHeight=$window.height()}function trackScroll(){var x=$window.scrollLeft(),y=$window.scrollTop();if(x!==session.scrollLeft){session.currentX+=x-session.scrollLeft;session.scrollLeft=x}if(y!==session.scrollTop){session.currentY+=y-session.scrollTop;session.scrollTop=y}}function trackMouse(event){session.currentX=event.pageX;session.currentY=event.pageY}function isMouseOver(element){var elementPosition=element.offset(),elementBox=element[0].getBoundingClientRect(),elementWidth=elementBox.right-elementBox.left,elementHeight=elementBox.bottom-elementBox.top;return session.currentX>=elementPosition.left&&session.currentX<=elementPosition.left+elementWidth&&session.currentY>=elementPosition.top&&session.currentY<=elementPosition.top+elementHeight}function getTooltipContent(element){var tipText=element.data(DATA_POWERTIP),tipObject=element.data(DATA_POWERTIPJQ),tipTarget=element.data(DATA_POWERTIPTARGET),targetElement,content;if(tipText){if($.isFunction(tipText)){tipText=tipText.call(element[0])}content=tipText}else if(tipObject){if($.isFunction(tipObject)){tipObject=tipObject.call(element[0])}if(tipObject.length>0){content=tipObject.clone(true,true)}}else if(tipTarget){targetElement=$("#"+tipTarget);if(targetElement.length>0){content=targetElement.html()}}return content}function getViewportCollisions(coords,elementWidth,elementHeight){var viewportTop=session.scrollTop,viewportLeft=session.scrollLeft,viewportBottom=viewportTop+session.windowHeight,viewportRight=viewportLeft+session.windowWidth,collisions=Collision.none;if(coords.topviewportBottom||Math.abs(coords.bottom-session.windowHeight)>viewportBottom){collisions|=Collision.bottom}if(coords.leftviewportRight){collisions|=Collision.left}if(coords.left+elementWidth>viewportRight||coords.right1)){a.preventDefault();var c=a.originalEvent.changedTouches[0],d=document.createEvent("MouseEvents");d.initMouseEvent(b,!0,!0,window,1,c.screenX,c.screenY,c.clientX,c.clientY,!1,!1,!1,!1,0,null),a.target.dispatchEvent(d)}}if(a.support.touch="ontouchend"in document,a.support.touch){var e,b=a.ui.mouse.prototype,c=b._mouseInit,d=b._mouseDestroy;b._touchStart=function(a){var b=this;!e&&b._mouseCapture(a.originalEvent.changedTouches[0])&&(e=!0,b._touchMoved=!1,f(a,"mouseover"),f(a,"mousemove"),f(a,"mousedown"))},b._touchMove=function(a){e&&(this._touchMoved=!0,f(a,"mousemove"))},b._touchEnd=function(a){e&&(f(a,"mouseup"),f(a,"mouseout"),this._touchMoved||f(a,"click"),e=!1)},b._mouseInit=function(){var b=this;b.element.bind({touchstart:a.proxy(b,"_touchStart"),touchmove:a.proxy(b,"_touchMove"),touchend:a.proxy(b,"_touchEnd")}),c.call(b)},b._mouseDestroy=function(){var b=this;b.element.unbind({touchstart:a.proxy(b,"_touchStart"),touchmove:a.proxy(b,"_touchMove"),touchend:a.proxy(b,"_touchEnd")}),d.call(b)}}}(jQuery);/*! SmartMenus jQuery Plugin - v1.1.0 - September 17, 2017 + * http://www.smartmenus.org/ + * Copyright Vasil Dinkov, Vadikom Web Ltd. http://vadikom.com; Licensed MIT */(function(t){"function"==typeof define&&define.amd?define(["jquery"],t):"object"==typeof module&&"object"==typeof module.exports?module.exports=t(require("jquery")):t(jQuery)})(function($){function initMouseDetection(t){var e=".smartmenus_mouse";if(mouseDetectionEnabled||t)mouseDetectionEnabled&&t&&($(document).off(e),mouseDetectionEnabled=!1);else{var i=!0,s=null,o={mousemove:function(t){var e={x:t.pageX,y:t.pageY,timeStamp:(new Date).getTime()};if(s){var o=Math.abs(s.x-e.x),a=Math.abs(s.y-e.y);if((o>0||a>0)&&2>=o&&2>=a&&300>=e.timeStamp-s.timeStamp&&(mouse=!0,i)){var n=$(t.target).closest("a");n.is("a")&&$.each(menuTrees,function(){return $.contains(this.$root[0],n[0])?(this.itemEnter({currentTarget:n[0]}),!1):void 0}),i=!1}}s=e}};o[touchEvents?"touchstart":"pointerover pointermove pointerout MSPointerOver MSPointerMove MSPointerOut"]=function(t){isTouchEvent(t.originalEvent)&&(mouse=!1)},$(document).on(getEventsNS(o,e)),mouseDetectionEnabled=!0}}function isTouchEvent(t){return!/^(4|mouse)$/.test(t.pointerType)}function getEventsNS(t,e){e||(e="");var i={};for(var s in t)i[s.split(" ").join(e+" ")+e]=t[s];return i}var menuTrees=[],mouse=!1,touchEvents="ontouchstart"in window,mouseDetectionEnabled=!1,requestAnimationFrame=window.requestAnimationFrame||function(t){return setTimeout(t,1e3/60)},cancelAnimationFrame=window.cancelAnimationFrame||function(t){clearTimeout(t)},canAnimate=!!$.fn.animate;return $.SmartMenus=function(t,e){this.$root=$(t),this.opts=e,this.rootId="",this.accessIdPrefix="",this.$subArrow=null,this.activatedItems=[],this.visibleSubMenus=[],this.showTimeout=0,this.hideTimeout=0,this.scrollTimeout=0,this.clickActivated=!1,this.focusActivated=!1,this.zIndexInc=0,this.idInc=0,this.$firstLink=null,this.$firstSub=null,this.disabled=!1,this.$disableOverlay=null,this.$touchScrollingSub=null,this.cssTransforms3d="perspective"in t.style||"webkitPerspective"in t.style,this.wasCollapsible=!1,this.init()},$.extend($.SmartMenus,{hideAll:function(){$.each(menuTrees,function(){this.menuHideAll()})},destroy:function(){for(;menuTrees.length;)menuTrees[0].destroy();initMouseDetection(!0)},prototype:{init:function(t){var e=this;if(!t){menuTrees.push(this),this.rootId=((new Date).getTime()+Math.random()+"").replace(/\D/g,""),this.accessIdPrefix="sm-"+this.rootId+"-",this.$root.hasClass("sm-rtl")&&(this.opts.rightToLeftSubMenus=!0);var i=".smartmenus";this.$root.data("smartmenus",this).attr("data-smartmenus-id",this.rootId).dataSM("level",1).on(getEventsNS({"mouseover focusin":$.proxy(this.rootOver,this),"mouseout focusout":$.proxy(this.rootOut,this),keydown:$.proxy(this.rootKeyDown,this)},i)).on(getEventsNS({mouseenter:$.proxy(this.itemEnter,this),mouseleave:$.proxy(this.itemLeave,this),mousedown:$.proxy(this.itemDown,this),focus:$.proxy(this.itemFocus,this),blur:$.proxy(this.itemBlur,this),click:$.proxy(this.itemClick,this)},i),"a"),i+=this.rootId,this.opts.hideOnClick&&$(document).on(getEventsNS({touchstart:$.proxy(this.docTouchStart,this),touchmove:$.proxy(this.docTouchMove,this),touchend:$.proxy(this.docTouchEnd,this),click:$.proxy(this.docClick,this)},i)),$(window).on(getEventsNS({"resize orientationchange":$.proxy(this.winResize,this)},i)),this.opts.subIndicators&&(this.$subArrow=$("").addClass("sub-arrow"),this.opts.subIndicatorsText&&this.$subArrow.html(this.opts.subIndicatorsText)),initMouseDetection()}if(this.$firstSub=this.$root.find("ul").each(function(){e.menuInit($(this))}).eq(0),this.$firstLink=this.$root.find("a").eq(0),this.opts.markCurrentItem){var s=/(index|default)\.[^#\?\/]*/i,o=/#.*/,a=window.location.href.replace(s,""),n=a.replace(o,"");this.$root.find("a").each(function(){var t=this.href.replace(s,""),i=$(this);(t==a||t==n)&&(i.addClass("current"),e.opts.markCurrentTree&&i.parentsUntil("[data-smartmenus-id]","ul").each(function(){$(this).dataSM("parent-a").addClass("current")}))})}this.wasCollapsible=this.isCollapsible()},destroy:function(t){if(!t){var e=".smartmenus";this.$root.removeData("smartmenus").removeAttr("data-smartmenus-id").removeDataSM("level").off(e),e+=this.rootId,$(document).off(e),$(window).off(e),this.opts.subIndicators&&(this.$subArrow=null)}this.menuHideAll();var i=this;this.$root.find("ul").each(function(){var t=$(this);t.dataSM("scroll-arrows")&&t.dataSM("scroll-arrows").remove(),t.dataSM("shown-before")&&((i.opts.subMenusMinWidth||i.opts.subMenusMaxWidth)&&t.css({width:"",minWidth:"",maxWidth:""}).removeClass("sm-nowrap"),t.dataSM("scroll-arrows")&&t.dataSM("scroll-arrows").remove(),t.css({zIndex:"",top:"",left:"",marginLeft:"",marginTop:"",display:""})),0==(t.attr("id")||"").indexOf(i.accessIdPrefix)&&t.removeAttr("id")}).removeDataSM("in-mega").removeDataSM("shown-before").removeDataSM("scroll-arrows").removeDataSM("parent-a").removeDataSM("level").removeDataSM("beforefirstshowfired").removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby").removeAttr("aria-expanded"),this.$root.find("a.has-submenu").each(function(){var t=$(this);0==t.attr("id").indexOf(i.accessIdPrefix)&&t.removeAttr("id")}).removeClass("has-submenu").removeDataSM("sub").removeAttr("aria-haspopup").removeAttr("aria-controls").removeAttr("aria-expanded").closest("li").removeDataSM("sub"),this.opts.subIndicators&&this.$root.find("span.sub-arrow").remove(),this.opts.markCurrentItem&&this.$root.find("a.current").removeClass("current"),t||(this.$root=null,this.$firstLink=null,this.$firstSub=null,this.$disableOverlay&&(this.$disableOverlay.remove(),this.$disableOverlay=null),menuTrees.splice($.inArray(this,menuTrees),1))},disable:function(t){if(!this.disabled){if(this.menuHideAll(),!t&&!this.opts.isPopup&&this.$root.is(":visible")){var e=this.$root.offset();this.$disableOverlay=$('
').css({position:"absolute",top:e.top,left:e.left,width:this.$root.outerWidth(),height:this.$root.outerHeight(),zIndex:this.getStartZIndex(!0),opacity:0}).appendTo(document.body)}this.disabled=!0}},docClick:function(t){return this.$touchScrollingSub?(this.$touchScrollingSub=null,void 0):((this.visibleSubMenus.length&&!$.contains(this.$root[0],t.target)||$(t.target).closest("a").length)&&this.menuHideAll(),void 0)},docTouchEnd:function(){if(this.lastTouch){if(!(!this.visibleSubMenus.length||void 0!==this.lastTouch.x2&&this.lastTouch.x1!=this.lastTouch.x2||void 0!==this.lastTouch.y2&&this.lastTouch.y1!=this.lastTouch.y2||this.lastTouch.target&&$.contains(this.$root[0],this.lastTouch.target))){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0);var t=this;this.hideTimeout=setTimeout(function(){t.menuHideAll()},350)}this.lastTouch=null}},docTouchMove:function(t){if(this.lastTouch){var e=t.originalEvent.touches[0];this.lastTouch.x2=e.pageX,this.lastTouch.y2=e.pageY}},docTouchStart:function(t){var e=t.originalEvent.touches[0];this.lastTouch={x1:e.pageX,y1:e.pageY,target:e.target}},enable:function(){this.disabled&&(this.$disableOverlay&&(this.$disableOverlay.remove(),this.$disableOverlay=null),this.disabled=!1)},getClosestMenu:function(t){for(var e=$(t).closest("ul");e.dataSM("in-mega");)e=e.parent().closest("ul");return e[0]||null},getHeight:function(t){return this.getOffset(t,!0)},getOffset:function(t,e){var i;"none"==t.css("display")&&(i={position:t[0].style.position,visibility:t[0].style.visibility},t.css({position:"absolute",visibility:"hidden"}).show());var s=t[0].getBoundingClientRect&&t[0].getBoundingClientRect(),o=s&&(e?s.height||s.bottom-s.top:s.width||s.right-s.left);return o||0===o||(o=e?t[0].offsetHeight:t[0].offsetWidth),i&&t.hide().css(i),o},getStartZIndex:function(t){var e=parseInt(this[t?"$root":"$firstSub"].css("z-index"));return!t&&isNaN(e)&&(e=parseInt(this.$root.css("z-index"))),isNaN(e)?1:e},getTouchPoint:function(t){return t.touches&&t.touches[0]||t.changedTouches&&t.changedTouches[0]||t},getViewport:function(t){var e=t?"Height":"Width",i=document.documentElement["client"+e],s=window["inner"+e];return s&&(i=Math.min(i,s)),i},getViewportHeight:function(){return this.getViewport(!0)},getViewportWidth:function(){return this.getViewport()},getWidth:function(t){return this.getOffset(t)},handleEvents:function(){return!this.disabled&&this.isCSSOn()},handleItemEvents:function(t){return this.handleEvents()&&!this.isLinkInMegaMenu(t)},isCollapsible:function(){return"static"==this.$firstSub.css("position")},isCSSOn:function(){return"inline"!=this.$firstLink.css("display")},isFixed:function(){var t="fixed"==this.$root.css("position");return t||this.$root.parentsUntil("body").each(function(){return"fixed"==$(this).css("position")?(t=!0,!1):void 0}),t},isLinkInMegaMenu:function(t){return $(this.getClosestMenu(t[0])).hasClass("mega-menu")},isTouchMode:function(){return!mouse||this.opts.noMouseOver||this.isCollapsible()},itemActivate:function(t,e){var i=t.closest("ul"),s=i.dataSM("level");if(s>1&&(!this.activatedItems[s-2]||this.activatedItems[s-2][0]!=i.dataSM("parent-a")[0])){var o=this;$(i.parentsUntil("[data-smartmenus-id]","ul").get().reverse()).add(i).each(function(){o.itemActivate($(this).dataSM("parent-a"))})}if((!this.isCollapsible()||e)&&this.menuHideSubMenus(this.activatedItems[s-1]&&this.activatedItems[s-1][0]==t[0]?s:s-1),this.activatedItems[s-1]=t,this.$root.triggerHandler("activate.smapi",t[0])!==!1){var a=t.dataSM("sub");a&&(this.isTouchMode()||!this.opts.showOnClick||this.clickActivated)&&this.menuShow(a)}},itemBlur:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&this.$root.triggerHandler("blur.smapi",e[0])},itemClick:function(t){var e=$(t.currentTarget);if(this.handleItemEvents(e)){if(this.$touchScrollingSub&&this.$touchScrollingSub[0]==e.closest("ul")[0])return this.$touchScrollingSub=null,t.stopPropagation(),!1;if(this.$root.triggerHandler("click.smapi",e[0])===!1)return!1;var i=$(t.target).is(".sub-arrow"),s=e.dataSM("sub"),o=s?2==s.dataSM("level"):!1,a=this.isCollapsible(),n=/toggle$/.test(this.opts.collapsibleBehavior),r=/link$/.test(this.opts.collapsibleBehavior),h=/^accordion/.test(this.opts.collapsibleBehavior);if(s&&!s.is(":visible")){if((!r||!a||i)&&(this.opts.showOnClick&&o&&(this.clickActivated=!0),this.itemActivate(e,h),s.is(":visible")))return this.focusActivated=!0,!1}else if(a&&(n||i))return this.itemActivate(e,h),this.menuHide(s),n&&(this.focusActivated=!1),!1;return this.opts.showOnClick&&o||e.hasClass("disabled")||this.$root.triggerHandler("select.smapi",e[0])===!1?!1:void 0}},itemDown:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&e.dataSM("mousedown",!0)},itemEnter:function(t){var e=$(t.currentTarget);if(this.handleItemEvents(e)){if(!this.isTouchMode()){this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0);var i=this;this.showTimeout=setTimeout(function(){i.itemActivate(e)},this.opts.showOnClick&&1==e.closest("ul").dataSM("level")?1:this.opts.showTimeout)}this.$root.triggerHandler("mouseenter.smapi",e[0])}},itemFocus:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&(!this.focusActivated||this.isTouchMode()&&e.dataSM("mousedown")||this.activatedItems.length&&this.activatedItems[this.activatedItems.length-1][0]==e[0]||this.itemActivate(e,!0),this.$root.triggerHandler("focus.smapi",e[0]))},itemLeave:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&(this.isTouchMode()||(e[0].blur(),this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0)),e.removeDataSM("mousedown"),this.$root.triggerHandler("mouseleave.smapi",e[0]))},menuHide:function(t){if(this.$root.triggerHandler("beforehide.smapi",t[0])!==!1&&(canAnimate&&t.stop(!0,!0),"none"!=t.css("display"))){var e=function(){t.css("z-index","")};this.isCollapsible()?canAnimate&&this.opts.collapsibleHideFunction?this.opts.collapsibleHideFunction.call(this,t,e):t.hide(this.opts.collapsibleHideDuration,e):canAnimate&&this.opts.hideFunction?this.opts.hideFunction.call(this,t,e):t.hide(this.opts.hideDuration,e),t.dataSM("scroll")&&(this.menuScrollStop(t),t.css({"touch-action":"","-ms-touch-action":"","-webkit-transform":"",transform:""}).off(".smartmenus_scroll").removeDataSM("scroll").dataSM("scroll-arrows").hide()),t.dataSM("parent-a").removeClass("highlighted").attr("aria-expanded","false"),t.attr({"aria-expanded":"false","aria-hidden":"true"});var i=t.dataSM("level");this.activatedItems.splice(i-1,1),this.visibleSubMenus.splice($.inArray(t,this.visibleSubMenus),1),this.$root.triggerHandler("hide.smapi",t[0])}},menuHideAll:function(){this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0);for(var t=this.opts.isPopup?1:0,e=this.visibleSubMenus.length-1;e>=t;e--)this.menuHide(this.visibleSubMenus[e]);this.opts.isPopup&&(canAnimate&&this.$root.stop(!0,!0),this.$root.is(":visible")&&(canAnimate&&this.opts.hideFunction?this.opts.hideFunction.call(this,this.$root):this.$root.hide(this.opts.hideDuration))),this.activatedItems=[],this.visibleSubMenus=[],this.clickActivated=!1,this.focusActivated=!1,this.zIndexInc=0,this.$root.triggerHandler("hideAll.smapi")},menuHideSubMenus:function(t){for(var e=this.activatedItems.length-1;e>=t;e--){var i=this.activatedItems[e].dataSM("sub");i&&this.menuHide(i)}},menuInit:function(t){if(!t.dataSM("in-mega")){t.hasClass("mega-menu")&&t.find("ul").dataSM("in-mega",!0);for(var e=2,i=t[0];(i=i.parentNode.parentNode)!=this.$root[0];)e++;var s=t.prevAll("a").eq(-1);s.length||(s=t.prevAll().find("a").eq(-1)),s.addClass("has-submenu").dataSM("sub",t),t.dataSM("parent-a",s).dataSM("level",e).parent().dataSM("sub",t);var o=s.attr("id")||this.accessIdPrefix+ ++this.idInc,a=t.attr("id")||this.accessIdPrefix+ ++this.idInc;s.attr({id:o,"aria-haspopup":"true","aria-controls":a,"aria-expanded":"false"}),t.attr({id:a,role:"group","aria-hidden":"true","aria-labelledby":o,"aria-expanded":"false"}),this.opts.subIndicators&&s[this.opts.subIndicatorsPos](this.$subArrow.clone())}},menuPosition:function(t){var e,i,s=t.dataSM("parent-a"),o=s.closest("li"),a=o.parent(),n=t.dataSM("level"),r=this.getWidth(t),h=this.getHeight(t),u=s.offset(),l=u.left,c=u.top,d=this.getWidth(s),m=this.getHeight(s),p=$(window),f=p.scrollLeft(),v=p.scrollTop(),b=this.getViewportWidth(),S=this.getViewportHeight(),g=a.parent().is("[data-sm-horizontal-sub]")||2==n&&!a.hasClass("sm-vertical"),M=this.opts.rightToLeftSubMenus&&!o.is("[data-sm-reverse]")||!this.opts.rightToLeftSubMenus&&o.is("[data-sm-reverse]"),w=2==n?this.opts.mainMenuSubOffsetX:this.opts.subMenusSubOffsetX,T=2==n?this.opts.mainMenuSubOffsetY:this.opts.subMenusSubOffsetY;if(g?(e=M?d-r-w:w,i=this.opts.bottomToTopSubMenus?-h-T:m+T):(e=M?w-r:d-w,i=this.opts.bottomToTopSubMenus?m-T-h:T),this.opts.keepInViewport){var y=l+e,I=c+i;if(M&&f>y?e=g?f-y+e:d-w:!M&&y+r>f+b&&(e=g?f+b-r-y+e:w-r),g||(S>h&&I+h>v+S?i+=v+S-h-I:(h>=S||v>I)&&(i+=v-I)),g&&(I+h>v+S+.49||v>I)||!g&&h>S+.49){var x=this;t.dataSM("scroll-arrows")||t.dataSM("scroll-arrows",$([$('')[0],$('')[0]]).on({mouseenter:function(){t.dataSM("scroll").up=$(this).hasClass("scroll-up"),x.menuScroll(t)},mouseleave:function(e){x.menuScrollStop(t),x.menuScrollOut(t,e)},"mousewheel DOMMouseScroll":function(t){t.preventDefault()}}).insertAfter(t));var A=".smartmenus_scroll";if(t.dataSM("scroll",{y:this.cssTransforms3d?0:i-m,step:1,itemH:m,subH:h,arrowDownH:this.getHeight(t.dataSM("scroll-arrows").eq(1))}).on(getEventsNS({mouseover:function(e){x.menuScrollOver(t,e)},mouseout:function(e){x.menuScrollOut(t,e)},"mousewheel DOMMouseScroll":function(e){x.menuScrollMousewheel(t,e)}},A)).dataSM("scroll-arrows").css({top:"auto",left:"0",marginLeft:e+(parseInt(t.css("border-left-width"))||0),width:r-(parseInt(t.css("border-left-width"))||0)-(parseInt(t.css("border-right-width"))||0),zIndex:t.css("z-index")}).eq(g&&this.opts.bottomToTopSubMenus?0:1).show(),this.isFixed()){var C={};C[touchEvents?"touchstart touchmove touchend":"pointerdown pointermove pointerup MSPointerDown MSPointerMove MSPointerUp"]=function(e){x.menuScrollTouch(t,e)},t.css({"touch-action":"none","-ms-touch-action":"none"}).on(getEventsNS(C,A))}}}t.css({top:"auto",left:"0",marginLeft:e,marginTop:i-m})},menuScroll:function(t,e,i){var s,o=t.dataSM("scroll"),a=t.dataSM("scroll-arrows"),n=o.up?o.upEnd:o.downEnd;if(!e&&o.momentum){if(o.momentum*=.92,s=o.momentum,.5>s)return this.menuScrollStop(t),void 0}else s=i||(e||!this.opts.scrollAccelerate?this.opts.scrollStep:Math.floor(o.step));var r=t.dataSM("level");if(this.activatedItems[r-1]&&this.activatedItems[r-1].dataSM("sub")&&this.activatedItems[r-1].dataSM("sub").is(":visible")&&this.menuHideSubMenus(r-1),o.y=o.up&&o.y>=n||!o.up&&n>=o.y?o.y:Math.abs(n-o.y)>s?o.y+(o.up?s:-s):n,t.css(this.cssTransforms3d?{"-webkit-transform":"translate3d(0, "+o.y+"px, 0)",transform:"translate3d(0, "+o.y+"px, 0)"}:{marginTop:o.y}),mouse&&(o.up&&o.y>o.downEnd||!o.up&&o.y0;t.dataSM("scroll-arrows").eq(i?0:1).is(":visible")&&(t.dataSM("scroll").up=i,this.menuScroll(t,!0))}e.preventDefault()},menuScrollOut:function(t,e){mouse&&(/^scroll-(up|down)/.test((e.relatedTarget||"").className)||(t[0]==e.relatedTarget||$.contains(t[0],e.relatedTarget))&&this.getClosestMenu(e.relatedTarget)==t[0]||t.dataSM("scroll-arrows").css("visibility","hidden"))},menuScrollOver:function(t,e){if(mouse&&!/^scroll-(up|down)/.test(e.target.className)&&this.getClosestMenu(e.target)==t[0]){this.menuScrollRefreshData(t);var i=t.dataSM("scroll"),s=$(window).scrollTop()-t.dataSM("parent-a").offset().top-i.itemH;t.dataSM("scroll-arrows").eq(0).css("margin-top",s).end().eq(1).css("margin-top",s+this.getViewportHeight()-i.arrowDownH).end().css("visibility","visible")}},menuScrollRefreshData:function(t){var e=t.dataSM("scroll"),i=$(window).scrollTop()-t.dataSM("parent-a").offset().top-e.itemH;this.cssTransforms3d&&(i=-(parseFloat(t.css("margin-top"))-i)),$.extend(e,{upEnd:i,downEnd:i+this.getViewportHeight()-e.subH})},menuScrollStop:function(t){return this.scrollTimeout?(cancelAnimationFrame(this.scrollTimeout),this.scrollTimeout=0,t.dataSM("scroll").step=1,!0):void 0},menuScrollTouch:function(t,e){if(e=e.originalEvent,isTouchEvent(e)){var i=this.getTouchPoint(e);if(this.getClosestMenu(i.target)==t[0]){var s=t.dataSM("scroll");if(/(start|down)$/i.test(e.type))this.menuScrollStop(t)?(e.preventDefault(),this.$touchScrollingSub=t):this.$touchScrollingSub=null,this.menuScrollRefreshData(t),$.extend(s,{touchStartY:i.pageY,touchStartTime:e.timeStamp});else if(/move$/i.test(e.type)){var o=void 0!==s.touchY?s.touchY:s.touchStartY;if(void 0!==o&&o!=i.pageY){this.$touchScrollingSub=t;var a=i.pageY>o;void 0!==s.up&&s.up!=a&&$.extend(s,{touchStartY:i.pageY,touchStartTime:e.timeStamp}),$.extend(s,{up:a,touchY:i.pageY}),this.menuScroll(t,!0,Math.abs(i.pageY-o))}e.preventDefault()}else void 0!==s.touchY&&((s.momentum=15*Math.pow(Math.abs(i.pageY-s.touchStartY)/(e.timeStamp-s.touchStartTime),2))&&(this.menuScrollStop(t),this.menuScroll(t),e.preventDefault()),delete s.touchY)}}},menuShow:function(t){if((t.dataSM("beforefirstshowfired")||(t.dataSM("beforefirstshowfired",!0),this.$root.triggerHandler("beforefirstshow.smapi",t[0])!==!1))&&this.$root.triggerHandler("beforeshow.smapi",t[0])!==!1&&(t.dataSM("shown-before",!0),canAnimate&&t.stop(!0,!0),!t.is(":visible"))){var e=t.dataSM("parent-a"),i=this.isCollapsible();if((this.opts.keepHighlighted||i)&&e.addClass("highlighted"),i)t.removeClass("sm-nowrap").css({zIndex:"",width:"auto",minWidth:"",maxWidth:"",top:"",left:"",marginLeft:"",marginTop:""});else{if(t.css("z-index",this.zIndexInc=(this.zIndexInc||this.getStartZIndex())+1),(this.opts.subMenusMinWidth||this.opts.subMenusMaxWidth)&&(t.css({width:"auto",minWidth:"",maxWidth:""}).addClass("sm-nowrap"),this.opts.subMenusMinWidth&&t.css("min-width",this.opts.subMenusMinWidth),this.opts.subMenusMaxWidth)){var s=this.getWidth(t);t.css("max-width",this.opts.subMenusMaxWidth),s>this.getWidth(t)&&t.removeClass("sm-nowrap").css("width",this.opts.subMenusMaxWidth)}this.menuPosition(t)}var o=function(){t.css("overflow","")};i?canAnimate&&this.opts.collapsibleShowFunction?this.opts.collapsibleShowFunction.call(this,t,o):t.show(this.opts.collapsibleShowDuration,o):canAnimate&&this.opts.showFunction?this.opts.showFunction.call(this,t,o):t.show(this.opts.showDuration,o),e.attr("aria-expanded","true"),t.attr({"aria-expanded":"true","aria-hidden":"false"}),this.visibleSubMenus.push(t),this.$root.triggerHandler("show.smapi",t[0])}},popupHide:function(t){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0);var e=this;this.hideTimeout=setTimeout(function(){e.menuHideAll()},t?1:this.opts.hideTimeout)},popupShow:function(t,e){if(!this.opts.isPopup)return alert('SmartMenus jQuery Error:\n\nIf you want to show this menu via the "popupShow" method, set the isPopup:true option.'),void 0;if(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0),this.$root.dataSM("shown-before",!0),canAnimate&&this.$root.stop(!0,!0),!this.$root.is(":visible")){this.$root.css({left:t,top:e});var i=this,s=function(){i.$root.css("overflow","")};canAnimate&&this.opts.showFunction?this.opts.showFunction.call(this,this.$root,s):this.$root.show(this.opts.showDuration,s),this.visibleSubMenus[0]=this.$root}},refresh:function(){this.destroy(!0),this.init(!0)},rootKeyDown:function(t){if(this.handleEvents())switch(t.keyCode){case 27:var e=this.activatedItems[0];if(e){this.menuHideAll(),e[0].focus();var i=e.dataSM("sub");i&&this.menuHide(i)}break;case 32:var s=$(t.target);if(s.is("a")&&this.handleItemEvents(s)){var i=s.dataSM("sub");i&&!i.is(":visible")&&(this.itemClick({currentTarget:t.target}),t.preventDefault())}}},rootOut:function(t){if(this.handleEvents()&&!this.isTouchMode()&&t.target!=this.$root[0]&&(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0),!this.opts.showOnClick||!this.opts.hideOnClick)){var e=this;this.hideTimeout=setTimeout(function(){e.menuHideAll()},this.opts.hideTimeout)}},rootOver:function(t){this.handleEvents()&&!this.isTouchMode()&&t.target!=this.$root[0]&&this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0)},winResize:function(t){if(this.handleEvents()){if(!("onorientationchange"in window)||"orientationchange"==t.type){var e=this.isCollapsible();this.wasCollapsible&&e||(this.activatedItems.length&&this.activatedItems[this.activatedItems.length-1][0].blur(),this.menuHideAll()),this.wasCollapsible=e}}else if(this.$disableOverlay){var i=this.$root.offset();this.$disableOverlay.css({top:i.top,left:i.left,width:this.$root.outerWidth(),height:this.$root.outerHeight()})}}}}),$.fn.dataSM=function(t,e){return e?this.data(t+"_smartmenus",e):this.data(t+"_smartmenus")},$.fn.removeDataSM=function(t){return this.removeData(t+"_smartmenus")},$.fn.smartmenus=function(options){if("string"==typeof options){var args=arguments,method=options;return Array.prototype.shift.call(args),this.each(function(){var t=$(this).data("smartmenus");t&&t[method]&&t[method].apply(t,args)})}return this.each(function(){var dataOpts=$(this).data("sm-options")||null;if(dataOpts)try{dataOpts=eval("("+dataOpts+")")}catch(e){dataOpts=null,alert('ERROR\n\nSmartMenus jQuery init:\nInvalid "data-sm-options" attribute value syntax.')}new $.SmartMenus(this,$.extend({},$.fn.smartmenus.defaults,options,dataOpts))})},$.fn.smartmenus.defaults={isPopup:!1,mainMenuSubOffsetX:0,mainMenuSubOffsetY:0,subMenusSubOffsetX:0,subMenusSubOffsetY:0,subMenusMinWidth:"10em",subMenusMaxWidth:"20em",subIndicators:!0,subIndicatorsPos:"append",subIndicatorsText:"",scrollStep:30,scrollAccelerate:!0,showTimeout:250,hideTimeout:500,showDuration:0,showFunction:null,hideDuration:0,hideFunction:function(t,e){t.fadeOut(200,e)},collapsibleShowDuration:0,collapsibleShowFunction:function(t,e){t.slideDown(200,e)},collapsibleHideDuration:0,collapsibleHideFunction:function(t,e){t.slideUp(200,e)},showOnClick:!1,hideOnClick:!0,noMouseOver:!1,keepInViewport:!0,keepHighlighted:!0,markCurrentItem:!1,markCurrentTree:!0,rightToLeftSubMenus:!1,bottomToTopSubMenus:!1,collapsibleBehavior:"default"},$}); \ No newline at end of file diff --git a/doxygen/menu.js b/doxygen/menu.js new file mode 100644 index 0000000..2fe2214 --- /dev/null +++ b/doxygen/menu.js @@ -0,0 +1,51 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +function initMenu(relPath,searchEnabled,serverSide,searchPage,search) { + function makeTree(data,relPath) { + var result=''; + if ('children' in data) { + result+=''; + } + return result; + } + + $('#main-nav').append(makeTree(menudata,relPath)); + $('#main-nav').children(':first').addClass('sm sm-dox').attr('id','main-menu'); + if (searchEnabled) { + if (serverSide) { + $('#main-menu').append('
  • '); + } else { + $('#main-menu').append('
  • '); + } + } + $('#main-menu').smartmenus(); +} +/* @license-end */ diff --git a/doxygen/menudata.js b/doxygen/menudata.js new file mode 100644 index 0000000..565fd82 --- /dev/null +++ b/doxygen/menudata.js @@ -0,0 +1,36 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file +*/ +var menudata={children:[ +{text:"Main Page",url:"index.html"}, +{text:"Related Pages",url:"pages.html"}, +{text:"Classes",url:"annotated.html",children:[ +{text:"Class List",url:"annotated.html"}, +{text:"Class Index",url:"classes.html"}, +{text:"Class Members",url:"functions.html",children:[ +{text:"All",url:"functions.html"}, +{text:"Functions",url:"functions_func.html"}, +{text:"Variables",url:"functions_vars.html"}]}]}, +{text:"Files",url:"files.html",children:[ +{text:"File List",url:"files.html"}]}]} diff --git a/doxygen/nav_f.png b/doxygen/nav_f.png new file mode 100644 index 0000000..72a58a5 Binary files /dev/null and b/doxygen/nav_f.png differ diff --git a/doxygen/nav_g.png b/doxygen/nav_g.png new file mode 100644 index 0000000..2093a23 Binary files /dev/null and b/doxygen/nav_g.png differ diff --git a/doxygen/nav_h.png b/doxygen/nav_h.png new file mode 100644 index 0000000..33389b1 Binary files /dev/null and b/doxygen/nav_h.png differ diff --git a/doxygen/navtree.css b/doxygen/navtree.css new file mode 100644 index 0000000..33341a6 --- /dev/null +++ b/doxygen/navtree.css @@ -0,0 +1,146 @@ +#nav-tree .children_ul { + margin:0; + padding:4px; +} + +#nav-tree ul { + list-style:none outside none; + margin:0px; + padding:0px; +} + +#nav-tree li { + white-space:nowrap; + margin:0px; + padding:0px; +} + +#nav-tree .plus { + margin:0px; +} + +#nav-tree .selected { + background-image: url('tab_a.png'); + background-repeat:repeat-x; + color: #fff; + text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +} + +#nav-tree img { + margin:0px; + padding:0px; + border:0px; + vertical-align: middle; +} + +#nav-tree a { + text-decoration:none; + padding:0px; + margin:0px; + outline:none; +} + +#nav-tree .label { + margin:0px; + padding:0px; + font: 12px 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; +} + +#nav-tree .label a { + padding:2px; +} + +#nav-tree .selected a { + text-decoration:none; + color:#fff; +} + +#nav-tree .children_ul { + margin:0px; + padding:0px; +} + +#nav-tree .item { + margin:0px; + padding:0px; +} + +#nav-tree { + padding: 0px 0px; + background-color: #FAFAFF; + font-size:14px; + overflow:auto; +} + +#doc-content { + overflow:auto; + display:block; + padding:0px; + margin:0px; + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#side-nav { + padding:0 6px 0 0; + margin: 0px; + display:block; + position: absolute; + left: 0px; + width: 250px; +} + +.ui-resizable .ui-resizable-handle { + display:block; +} + +.ui-resizable-e { + background-image:url("splitbar.png"); + background-size:100%; + background-repeat:repeat-y; + background-attachment: scroll; + cursor:ew-resize; + height:100%; + right:0; + top:0; + width:6px; +} + +.ui-resizable-handle { + display:none; + font-size:0.1px; + position:absolute; + z-index:1; +} + +#nav-tree-contents { + margin: 6px 0px 0px 0px; +} + +#nav-tree { + background-image:url('nav_h.png'); + background-repeat:repeat-x; + background-color: #F9FAFC; + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#nav-sync { + position:absolute; + top:5px; + right:24px; + z-index:0; +} + +#nav-sync img { + opacity:0.3; +} + +#nav-sync img:hover { + opacity:0.9; +} + +@media print +{ + #nav-tree { display: none; } + div.ui-resizable-handle { display: none; position: relative; } +} + diff --git a/doxygen/navtree.js b/doxygen/navtree.js new file mode 100644 index 0000000..1e272d3 --- /dev/null +++ b/doxygen/navtree.js @@ -0,0 +1,546 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +var navTreeSubIndices = new Array(); +var arrowDown = '▼'; +var arrowRight = '►'; + +function getData(varName) +{ + var i = varName.lastIndexOf('/'); + var n = i>=0 ? varName.substring(i+1) : varName; + return eval(n.replace(/\-/g,'_')); +} + +function stripPath(uri) +{ + return uri.substring(uri.lastIndexOf('/')+1); +} + +function stripPath2(uri) +{ + var i = uri.lastIndexOf('/'); + var s = uri.substring(i+1); + var m = uri.substring(0,i+1).match(/\/d\w\/d\w\w\/$/); + return m ? uri.substring(i-6) : s; +} + +function hashValue() +{ + return $(location).attr('hash').substring(1).replace(/[^\w\-]/g,''); +} + +function hashUrl() +{ + return '#'+hashValue(); +} + +function pathName() +{ + return $(location).attr('pathname').replace(/[^-A-Za-z0-9+&@#/%?=~_|!:,.;\(\)]/g, ''); +} + +function localStorageSupported() +{ + try { + return 'localStorage' in window && window['localStorage'] !== null && window.localStorage.getItem; + } + catch(e) { + return false; + } +} + +function storeLink(link) +{ + if (!$("#nav-sync").hasClass('sync') && localStorageSupported()) { + window.localStorage.setItem('navpath',link); + } +} + +function deleteLink() +{ + if (localStorageSupported()) { + window.localStorage.setItem('navpath',''); + } +} + +function cachedLink() +{ + if (localStorageSupported()) { + return window.localStorage.getItem('navpath'); + } else { + return ''; + } +} + +function getScript(scriptName,func,show) +{ + var head = document.getElementsByTagName("head")[0]; + var script = document.createElement('script'); + script.id = scriptName; + script.type = 'text/javascript'; + script.onload = func; + script.src = scriptName+'.js'; + head.appendChild(script); +} + +function createIndent(o,domNode,node,level) +{ + var level=-1; + var n = node; + while (n.parentNode) { level++; n=n.parentNode; } + if (node.childrenData) { + var imgNode = document.createElement("span"); + imgNode.className = 'arrow'; + imgNode.style.paddingLeft=(16*level).toString()+'px'; + imgNode.innerHTML=arrowRight; + node.plus_img = imgNode; + node.expandToggle = document.createElement("a"); + node.expandToggle.href = "javascript:void(0)"; + node.expandToggle.onclick = function() { + if (node.expanded) { + $(node.getChildrenUL()).slideUp("fast"); + node.plus_img.innerHTML=arrowRight; + node.expanded = false; + } else { + expandNode(o, node, false, false); + } + } + node.expandToggle.appendChild(imgNode); + domNode.appendChild(node.expandToggle); + } else { + var span = document.createElement("span"); + span.className = 'arrow'; + span.style.width = 16*(level+1)+'px'; + span.innerHTML = ' '; + domNode.appendChild(span); + } +} + +var animationInProgress = false; + +function gotoAnchor(anchor,aname,updateLocation) +{ + var pos, docContent = $('#doc-content'); + var ancParent = $(anchor.parent()); + if (ancParent.hasClass('memItemLeft') || + ancParent.hasClass('memtitle') || + ancParent.hasClass('fieldname') || + ancParent.hasClass('fieldtype') || + ancParent.is(':header')) + { + pos = ancParent.position().top; + } else if (anchor.position()) { + pos = anchor.position().top; + } + if (pos) { + var dist = Math.abs(Math.min( + pos-docContent.offset().top, + docContent[0].scrollHeight- + docContent.height()-docContent.scrollTop())); + animationInProgress=true; + docContent.animate({ + scrollTop: pos + docContent.scrollTop() - docContent.offset().top + },Math.max(50,Math.min(500,dist)),function(){ + if (updateLocation) window.location.href=aname; + animationInProgress=false; + }); + } +} + +function newNode(o, po, text, link, childrenData, lastNode) +{ + var node = new Object(); + node.children = Array(); + node.childrenData = childrenData; + node.depth = po.depth + 1; + node.relpath = po.relpath; + node.isLast = lastNode; + + node.li = document.createElement("li"); + po.getChildrenUL().appendChild(node.li); + node.parentNode = po; + + node.itemDiv = document.createElement("div"); + node.itemDiv.className = "item"; + + node.labelSpan = document.createElement("span"); + node.labelSpan.className = "label"; + + createIndent(o,node.itemDiv,node,0); + node.itemDiv.appendChild(node.labelSpan); + node.li.appendChild(node.itemDiv); + + var a = document.createElement("a"); + node.labelSpan.appendChild(a); + node.label = document.createTextNode(text); + node.expanded = false; + a.appendChild(node.label); + if (link) { + var url; + if (link.substring(0,1)=='^') { + url = link.substring(1); + link = url; + } else { + url = node.relpath+link; + } + a.className = stripPath(link.replace('#',':')); + if (link.indexOf('#')!=-1) { + var aname = '#'+link.split('#')[1]; + var srcPage = stripPath(pathName()); + var targetPage = stripPath(link.split('#')[0]); + a.href = srcPage!=targetPage ? url : "javascript:void(0)"; + a.onclick = function(){ + storeLink(link); + if (!$(a).parent().parent().hasClass('selected')) + { + $('.item').removeClass('selected'); + $('.item').removeAttr('id'); + $(a).parent().parent().addClass('selected'); + $(a).parent().parent().attr('id','selected'); + } + var anchor = $(aname); + gotoAnchor(anchor,aname,true); + }; + } else { + a.href = url; + a.onclick = function() { storeLink(link); } + } + } else { + if (childrenData != null) + { + a.className = "nolink"; + a.href = "javascript:void(0)"; + a.onclick = node.expandToggle.onclick; + } + } + + node.childrenUL = null; + node.getChildrenUL = function() { + if (!node.childrenUL) { + node.childrenUL = document.createElement("ul"); + node.childrenUL.className = "children_ul"; + node.childrenUL.style.display = "none"; + node.li.appendChild(node.childrenUL); + } + return node.childrenUL; + }; + + return node; +} + +function showRoot() +{ + var headerHeight = $("#top").height(); + var footerHeight = $("#nav-path").height(); + var windowHeight = $(window).height() - headerHeight - footerHeight; + (function (){ // retry until we can scroll to the selected item + try { + var navtree=$('#nav-tree'); + navtree.scrollTo('#selected',100,{offset:-windowHeight/2}); + } catch (err) { + setTimeout(arguments.callee, 0); + } + })(); +} + +function expandNode(o, node, imm, showRoot) +{ + if (node.childrenData && !node.expanded) { + if (typeof(node.childrenData)==='string') { + var varName = node.childrenData; + getScript(node.relpath+varName,function(){ + node.childrenData = getData(varName); + expandNode(o, node, imm, showRoot); + }, showRoot); + } else { + if (!node.childrenVisited) { + getNode(o, node); + } + $(node.getChildrenUL()).slideDown("fast"); + node.plus_img.innerHTML = arrowDown; + node.expanded = true; + } + } +} + +function glowEffect(n,duration) +{ + n.addClass('glow').delay(duration).queue(function(next){ + $(this).removeClass('glow');next(); + }); +} + +function highlightAnchor() +{ + var aname = hashUrl(); + var anchor = $(aname); + if (anchor.parent().attr('class')=='memItemLeft'){ + var rows = $('.memberdecls tr[class$="'+hashValue()+'"]'); + glowEffect(rows.children(),300); // member without details + } else if (anchor.parent().attr('class')=='fieldname'){ + glowEffect(anchor.parent().parent(),1000); // enum value + } else if (anchor.parent().attr('class')=='fieldtype'){ + glowEffect(anchor.parent().parent(),1000); // struct field + } else if (anchor.parent().is(":header")) { + glowEffect(anchor.parent(),1000); // section header + } else { + glowEffect(anchor.next(),1000); // normal member + } +} + +function selectAndHighlight(hash,n) +{ + var a; + if (hash) { + var link=stripPath(pathName())+':'+hash.substring(1); + a=$('.item a[class$="'+link+'"]'); + } + if (a && a.length) { + a.parent().parent().addClass('selected'); + a.parent().parent().attr('id','selected'); + highlightAnchor(); + } else if (n) { + $(n.itemDiv).addClass('selected'); + $(n.itemDiv).attr('id','selected'); + } + if ($('#nav-tree-contents .item:first').hasClass('selected')) { + $('#nav-sync').css('top','30px'); + } else { + $('#nav-sync').css('top','5px'); + } + showRoot(); +} + +function showNode(o, node, index, hash) +{ + if (node && node.childrenData) { + if (typeof(node.childrenData)==='string') { + var varName = node.childrenData; + getScript(node.relpath+varName,function(){ + node.childrenData = getData(varName); + showNode(o,node,index,hash); + },true); + } else { + if (!node.childrenVisited) { + getNode(o, node); + } + $(node.getChildrenUL()).css({'display':'block'}); + node.plus_img.innerHTML = arrowDown; + node.expanded = true; + var n = node.children[o.breadcrumbs[index]]; + if (index+11) hash = '#'+parts[1].replace(/[^\w\-]/g,''); + else hash=''; + } + if (hash.match(/^#l\d+$/)) { + var anchor=$('a[name='+hash.substring(1)+']'); + glowEffect(anchor.parent(),1000); // line number + hash=''; // strip line number anchors + } + var url=root+hash; + var i=-1; + while (NAVTREEINDEX[i+1]<=url) i++; + if (i==-1) { i=0; root=NAVTREE[0][1]; } // fallback: show index + if (navTreeSubIndices[i]) { + gotoNode(o,i,root,hash,relpath) + } else { + getScript(relpath+'navtreeindex'+i,function(){ + navTreeSubIndices[i] = eval('NAVTREEINDEX'+i); + if (navTreeSubIndices[i]) { + gotoNode(o,i,root,hash,relpath); + } + },true); + } +} + +function showSyncOff(n,relpath) +{ + n.html(''); +} + +function showSyncOn(n,relpath) +{ + n.html(''); +} + +function toggleSyncButton(relpath) +{ + var navSync = $('#nav-sync'); + if (navSync.hasClass('sync')) { + navSync.removeClass('sync'); + showSyncOff(navSync,relpath); + storeLink(stripPath2(pathName())+hashUrl()); + } else { + navSync.addClass('sync'); + showSyncOn(navSync,relpath); + deleteLink(); + } +} + +var loadTriggered = false; +var readyTriggered = false; +var loadObject,loadToRoot,loadUrl,loadRelPath; + +$(window).on('load',function(){ + if (readyTriggered) { // ready first + navTo(loadObject,loadToRoot,loadUrl,loadRelPath); + showRoot(); + } + loadTriggered=true; +}); + +function initNavTree(toroot,relpath) +{ + var o = new Object(); + o.toroot = toroot; + o.node = new Object(); + o.node.li = document.getElementById("nav-tree-contents"); + o.node.childrenData = NAVTREE; + o.node.children = new Array(); + o.node.childrenUL = document.createElement("ul"); + o.node.getChildrenUL = function() { return o.node.childrenUL; }; + o.node.li.appendChild(o.node.childrenUL); + o.node.depth = 0; + o.node.relpath = relpath; + o.node.expanded = false; + o.node.isLast = true; + o.node.plus_img = document.createElement("span"); + o.node.plus_img.className = 'arrow'; + o.node.plus_img.innerHTML = arrowRight; + + if (localStorageSupported()) { + var navSync = $('#nav-sync'); + if (cachedLink()) { + showSyncOff(navSync,relpath); + navSync.removeClass('sync'); + } else { + showSyncOn(navSync,relpath); + } + navSync.click(function(){ toggleSyncButton(relpath); }); + } + + if (loadTriggered) { // load before ready + navTo(o,toroot,hashUrl(),relpath); + showRoot(); + } else { // ready before load + loadObject = o; + loadToRoot = toroot; + loadUrl = hashUrl(); + loadRelPath = relpath; + readyTriggered=true; + } + + $(window).bind('hashchange', function(){ + if (window.location.hash && window.location.hash.length>1){ + var a; + if ($(location).attr('hash')){ + var clslink=stripPath(pathName())+':'+hashValue(); + a=$('.item a[class$="'+clslink.replace(/ + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Related Pages + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    Related Pages
    +
    +
    +
    Here is a list of all related documentation pages:
    + + + +
     Todo List
     Bibliography
    +
    +
    +
    + + + + diff --git a/doxygen/quantitative__timed__pattern__matching_8hh_source.html b/doxygen/quantitative__timed__pattern__matching_8hh_source.html new file mode 100644 index 0000000..2321766 --- /dev/null +++ b/doxygen/quantitative__timed__pattern__matching_8hh_source.html @@ -0,0 +1,301 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/quantitative_timed_pattern_matching.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    quantitative_timed_pattern_matching.hh
    +
    +
    +
    1 #pragma once
    +
    2 #include <vector>
    +
    3 #include <queue>
    +
    4 
    +
    5 #include "bellman_ford.hh"
    +
    6 #include "zone_graph.hh"
    +
    7 
    +
    41 template<class SignalVariables, class ClockVariables, class Weight, class Value>
    + +
    43 {
    +
    44 public:
    +
    45  using ResultMatrix = std::array<Bounds, 6>;
    +
    46 private:
    +
    47  //types
    +
    48 
    +
    49  using Conf_t = std::vector<std::pair<BoostZoneGraphState<SignalVariables, ClockVariables, Value>, Weight>>;
    +
    50  using TimedAutomaton = BoostTimedAutomaton<SignalVariables, ClockVariables>;
    +
    51  using TAState = typename TimedAutomaton::vertex_descriptor;
    +
    52  using ZoneGraph = BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>;
    +
    53  using ZGState = typename ZoneGraph::vertex_descriptor;
    +
    54 
    +
    55  using ConfTuple_t = std::tuple<TAState, bool, std::vector<std::vector<Value>>, Weight>;
    +
    56 
    +
    57  // constants
    +
    58 
    +
    59  const std::size_t numOfClockVariables;
    +
    60  const std::size_t dwellTimeClock;
    +
    61  DBM initialZone;
    +
    62  const TimedAutomaton TA;
    +
    63  const std::vector<TAState> initStates;
    +
    64  const std::function<Weight(const std::vector<Constraint<ClockVariables>> &,const std::vector<std::vector<Value>> &)> cost;
    +
    65 
    +
    66  // variables
    +
    67 
    +
    69  Conf_t configuration = {};
    +
    71  double absTime = 0;
    +
    76  boost::unordered_map<ResultMatrix, Weight> result = {};
    +
    77 
    +
    78 public:
    +
    79 
    +
    80  QuantitativeTimedPatternMatching(const TimedAutomaton &TA,
    +
    81  const std::vector<TAState> &initStates,
    +
    82  const std::function<Weight(const std::vector<Constraint<ClockVariables>> &,const std::vector<std::vector<Value>> &)> &cost,
    +
    83  const bool ignoreZero = false) : numOfClockVariables(boost::get_property(TA, boost::graph_num_of_vars)), dwellTimeClock(numOfClockVariables + 2), TA(TA), initStates(initStates), cost(cost) {
    +
    84  DBM z = DBM::zero(numOfClockVariables + 1 + 2);
    +
    85  // release Z(N+2)
    +
    86  z.M = Bounds(std::numeric_limits<double>::infinity(), false);
    +
    87  z.release(dwellTimeClock - 1);
    +
    88  z.tightenWithoutClose(-1, dwellTimeClock - 1, {0, true});
    +
    89  z.canonize();
    +
    90  initialZone = std::move(z);
    +
    91  }
    +
    92 
    +
    103  void feed(const std::vector<Value> &valuation, const double duration) {
    +
    104 
    +
    105  for (auto &c: configuration) {
    +
    106  // reset Z(N+2)
    +
    107  c.first.zone.reset(dwellTimeClock - 1);
    +
    108  // Check if the transition can fire at the beginning of the new piece of signal
    +
    109  if (c.first.jumpable) {
    +
    110  c.first.valuations.push_back(valuation);
    +
    111  c.first.zone.elapse();
    +
    112  }
    +
    113  }
    +
    114 
    +
    115  // Add new configurations from initial states for the matching beginning from this piece of signal
    +
    116  configuration.reserve(configuration.size() + initStates.size());
    +
    117  for(const auto &q0: initStates) {
    +
    118  configuration.emplace_back(BoostZoneGraphState<SignalVariables, ClockVariables, Value>{q0, false, initialZone, std::vector<std::vector<Value>>{}}, Weight::one());
    +
    119  }
    +
    120 
    +
    121  // Conduct zone construction for time bound `duration` for the current signal valuation
    +
    122  ZoneGraph ZG;
    +
    123  std::unordered_map<ZGState, Weight> initStatesZG;
    +
    124  zoneConstructionWithT(TA, configuration, cost, valuation, duration, ZG, initStatesZG);
    +
    125 #ifdef DEBUG
    +
    126  assert(std::none_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    127  return TA[ZG[p.first].vertex].isMatch;
    +
    128  }));
    +
    129 #endif
    +
    130 
    +
    131  // Compute the accumulated weights, i.e., the quantitative semantics using the generalized Bellman-Ford algorithm
    +
    132  std::unordered_map<ZGState, Weight> distance;
    +
    133  bellman_ford<std::queue<ZGState>>(ZG, initStatesZG, distance);
    +
    134  // This does not work when VerticesList is ListS. I do not know why.
    +
    135  // write_graphviz(std::cerr, ZG, makeZoneGraphLabelWriter(ZG, TA, distance),make_weight_label_writer(ZG));
    +
    136  configuration.clear();
    +
    137 
    +
    138  boost::unordered_map<ConfTuple_t, std::list<DBM>> confMap;
    +
    139 
    +
    140  // Construct the configuration just after the current piece
    +
    141  for (auto w: distance) {
    +
    142  // Ignore if the weight is already "zero"
    +
    143  if (w.second == Weight::zero()) {
    +
    144  continue;
    +
    145  }
    +
    146  // It is assumed that we do not have to use the configuration once we reach the accepting state.
    +
    147  // ZG[w.first].zone.value.cols() > 0 corresponds to the requirement that we have non-zero time elapse in the current piece.
    +
    148  if (!TA[ZG[w.first].vertex].isMatch && ZG[w.first].zone.value.cols() > 0) {
    +
    149  auto z = ZG[w.first].zone;
    +
    150  // Force dwellTimeClock == duration
    +
    151  z.tightenWithoutClose(-1, dwellTimeClock - 1, Bounds{-duration, true});
    +
    152  z.tightenWithoutClose(dwellTimeClock - 1, -1, Bounds{duration, true});
    +
    153  if (z.isSatisfiable()) {
    +
    154  auto it = confMap.find(std::make_tuple(ZG[w.first].vertex, ZG[w.first].jumpable, ZG[w.first].valuations, w.second));
    +
    155  if (it != confMap.end()) {
    +
    156  // Try to merge this zone to another zone at the same state
    +
    157  for (DBM &zz: it->second) {
    +
    158  if (zz.merge(z)) {
    +
    159  goto next;
    +
    160  }
    +
    161  }
    +
    162  // If the merging fails, we add this configuration
    +
    163  it->second.push_back(std::move(z));
    +
    164  } else {
    +
    165  confMap[std::make_tuple(ZG[w.first].vertex, ZG[w.first].jumpable, ZG[w.first].valuations ,w.second)].push_back(std::move(z));
    +
    166  }
    +
    167  }
    +
    168  }
    +
    169  next:;
    +
    170  }
    +
    171 
    +
    172  for (auto &c: confMap) {
    +
    173  if (c.second.size() == 1) {
    +
    174  configuration.emplace_back(BoostZoneGraphState<SignalVariables, ClockVariables, Value>{std::get<0>(c.first), std::get<1>(c.first), c.second.front(), std::get<2>(c.first)}, std::get<3>(c.first));
    +
    175 
    +
    176  } else {
    +
    177  bool removed = true;
    +
    178  while (removed) {
    +
    179  removed = false;
    +
    180  for (auto it = c.second.begin(); it != c.second.end(); it++) {
    +
    181  DBM tmp = *it;
    +
    182  auto jt = it;
    +
    183  for (jt++; jt != c.second.end();) {
    +
    184  if (it->merge(*jt)) {
    +
    185  jt = c.second.erase(jt);
    +
    186  removed = true;
    +
    187  } else {
    +
    188  jt++;
    +
    189  }
    +
    190  }
    +
    191  }
    +
    192  }
    +
    193  for (auto &z: c.second) {
    +
    194  // for the current check
    +
    195  configuration.emplace_back(BoostZoneGraphState<SignalVariables, ClockVariables, Value>{std::get<0>(c.first), std::get<1>(c.first), std::move(z), std::get<2>(c.first)}, std::get<3>(c.first));
    +
    196  }
    +
    197  }
    +
    198  }
    +
    199 
    +
    200  // Put the resulting matching to this->result
    +
    201  for (auto &w: distance) {
    +
    202  if (w.second == Weight::zero()) {
    +
    203  continue;
    +
    204  }
    +
    205  if (TA[ZG[w.first].vertex].isMatch && !ZG[w.first].jumpable && ZG[w.first].zone.value.cols() > 0) {
    +
    206  // assert(ZG[w.first].zone.isSatisfiable());
    +
    207  ResultMatrix mat = {{ZG[w.first].zone.value(numOfClockVariables + 2 - 1, numOfClockVariables + 2) - absTime,
    +
    208  ZG[w.first].zone.value(numOfClockVariables + 2, numOfClockVariables + 2 - 1) + absTime,
    +
    209  ZG[w.first].zone.value(0, numOfClockVariables + 2) - absTime,
    +
    210  ZG[w.first].zone.value(numOfClockVariables + 2, 0) + absTime,
    +
    211  ZG[w.first].zone.value(0, numOfClockVariables + 2 - 1),
    +
    212  ZG[w.first].zone.value(numOfClockVariables + 2 - 1, 0)}};
    +
    213 
    +
    214  if (result.find(mat) == result.end()) {
    +
    215  result[std::move(mat)] = std::move(w.second);
    +
    216  } else {
    +
    217  result[std::move(mat)] += std::move(w.second);
    +
    218  }
    +
    219  }
    +
    220  }
    +
    221 
    +
    222  // Update absTime to the end of the current piece
    +
    223  absTime += duration;
    +
    224  }
    +
    225 
    +
    226  void getResult(boost::unordered_map<ResultMatrix, Weight> &v) const {
    +
    227  v = result;
    +
    228  }
    +
    229  boost::unordered_map<ResultMatrix, Weight>& getResultRef() {
    +
    230  return result;
    +
    231  }
    +
    232 };
    +
    A class to execute quantitative timed pattern matching.
    Definition: quantitative_timed_pattern_matching.hh:43
    +
    void feed(const std::vector< Value > &valuation, const double duration)
    feed one valuation with dwell time
    Definition: quantitative_timed_pattern_matching.hh:103
    +
    Definition: zone_graph.hh:15
    +
    A constraint in a guard of transitions.
    Definition: constraint.hh:18
    +
    Implementation of a zone with DBM DBM For the detail of DBMs, see for example .
    Definition: dbm.hh:52
    +
    void canonize()
    make the zone canonical
    Definition: dbm.hh:169
    +
    void release(uint8_t x)
    Definition: dbm.hh:139
    +
    void tightenWithoutClose(uint8_t x, uint8_t y, Bounds c)
    add the constraint x - y <= (c,s) but does not close.
    Definition: dbm.hh:98
    +
    bool merge(const DBM &z)
    Try to merge the given DBM to this DBM.
    Definition: dbm.hh:252
    +
    static DBM zero(int size)
    Make the zone of size size such that all the values are zero.
    Definition: dbm.hh:79
    +
    Bounds M
    The threshold for the normalization.
    Definition: dbm.hh:57
    +
    Eigen::Matrix< Bounds, Eigen::Dynamic, Eigen::Dynamic > value
    The matrix representing the DBM.
    Definition: dbm.hh:55
    +
    +
    + + + + diff --git a/doxygen/resize.js b/doxygen/resize.js new file mode 100644 index 0000000..e1ad0fe --- /dev/null +++ b/doxygen/resize.js @@ -0,0 +1,140 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +function initResizable() +{ + var cookie_namespace = 'doxygen'; + var sidenav,navtree,content,header,collapsed,collapsedWidth=0,barWidth=6,desktop_vp=768,titleHeight; + + function readCookie(cookie) + { + var myCookie = cookie_namespace+"_"+cookie+"="; + if (document.cookie) { + var index = document.cookie.indexOf(myCookie); + if (index != -1) { + var valStart = index + myCookie.length; + var valEnd = document.cookie.indexOf(";", valStart); + if (valEnd == -1) { + valEnd = document.cookie.length; + } + var val = document.cookie.substring(valStart, valEnd); + return val; + } + } + return 0; + } + + function writeCookie(cookie, val, expiration) + { + if (val==undefined) return; + if (expiration == null) { + var date = new Date(); + date.setTime(date.getTime()+(10*365*24*60*60*1000)); // default expiration is one week + expiration = date.toGMTString(); + } + document.cookie = cookie_namespace + "_" + cookie + "=" + val + "; expires=" + expiration+"; path=/"; + } + + function resizeWidth() + { + var windowWidth = $(window).width() + "px"; + var sidenavWidth = $(sidenav).outerWidth(); + content.css({marginLeft:parseInt(sidenavWidth)+"px"}); + writeCookie('width',sidenavWidth-barWidth, null); + } + + function restoreWidth(navWidth) + { + var windowWidth = $(window).width() + "px"; + content.css({marginLeft:parseInt(navWidth)+barWidth+"px"}); + sidenav.css({width:navWidth + "px"}); + } + + function resizeHeight() + { + var headerHeight = header.outerHeight(); + var footerHeight = footer.outerHeight(); + var windowHeight = $(window).height() - headerHeight - footerHeight; + content.css({height:windowHeight + "px"}); + navtree.css({height:windowHeight + "px"}); + sidenav.css({height:windowHeight + "px"}); + var width=$(window).width(); + if (width!=collapsedWidth) { + if (width=desktop_vp) { + if (!collapsed) { + collapseExpand(); + } + } else if (width>desktop_vp && collapsedWidth0) { + restoreWidth(0); + collapsed=true; + } + else { + var width = readCookie('width'); + if (width>200 && width<$(window).width()) { restoreWidth(width); } else { restoreWidth(200); } + collapsed=false; + } + } + + header = $("#top"); + sidenav = $("#side-nav"); + content = $("#doc-content"); + navtree = $("#nav-tree"); + footer = $("#nav-path"); + $(".side-nav-resizable").resizable({resize: function(e, ui) { resizeWidth(); } }); + $(sidenav).resizable({ minWidth: 0 }); + $(window).resize(function() { resizeHeight(); }); + var device = navigator.userAgent.toLowerCase(); + var touch_device = device.match(/(iphone|ipod|ipad|android)/); + if (touch_device) { /* wider split bar for touch only devices */ + $(sidenav).css({ paddingRight:'20px' }); + $('.ui-resizable-e').css({ width:'20px' }); + $('#nav-sync').css({ right:'34px' }); + barWidth=20; + } + var width = readCookie('width'); + if (width) { restoreWidth(width); } else { resizeWidth(); } + resizeHeight(); + var url = location.href; + var i=url.indexOf("#"); + if (i>=0) window.location.hash=url.substr(i); + var _preventDefault = function(evt) { evt.preventDefault(); }; + $("#splitbar").bind("dragstart", _preventDefault).bind("selectstart", _preventDefault); + $(".ui-resizable-handle").dblclick(collapseExpand); + $(window).on('load',resizeHeight); +} +/* @license-end */ diff --git a/doxygen/robustness_8hh_source.html b/doxygen/robustness_8hh_source.html new file mode 100644 index 0000000..c63b7f4 --- /dev/null +++ b/doxygen/robustness_8hh_source.html @@ -0,0 +1,137 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/robustness.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    robustness.hh
    +
    +
    +
    1 #pragma once
    +
    2 
    +
    3 #include <vector>
    +
    4 #include <numeric>
    +
    5 #include "timed_automaton.hh"
    +
    6 
    +
    7 template<class Weight, class Value, class ClockVariables>
    +
    8 Weight singleSpaceRobustness(const std::vector<Constraint<ClockVariables>> &label, const std::vector<Value> &valuation) {
    +
    9  return std::accumulate(label.begin(), label.end(), Weight::one(), [&valuation] (Weight init, Constraint<ClockVariables> constraint) {
    +
    10  Weight w = Weight::zero();
    +
    11  switch (constraint.odr) {
    +
    12  case Constraint<ClockVariables>::Order::lt:
    +
    13  case Constraint<ClockVariables>::Order::le:
    +
    14  w = Weight(constraint.c - valuation[constraint.x]);
    +
    15  break;
    +
    16  case Constraint<ClockVariables>::Order::ge:
    +
    17  case Constraint<ClockVariables>::Order::gt:
    +
    18  w = Weight(valuation[constraint.x] - constraint.c);
    +
    19  break;
    +
    20  }
    +
    21  return init * w;
    +
    22  });
    +
    23 }
    +
    24 
    +
    25 template<class Weight, class Value, class ClockVariables>
    +
    26 Weight multipleSpaceRobustness(const std::vector<Constraint<ClockVariables>> &label, const std::vector<std::vector<Value>> &valuations) {
    +
    27  return std::accumulate(valuations.begin(), valuations.end(), Weight::one(), [&label](Weight init, const std::vector<Value> &valuation) {
    +
    28  return init * singleSpaceRobustness<Weight>(label, valuation);
    +
    29  });
    +
    30 }
    +
    A constraint in a guard of transitions.
    Definition: constraint.hh:18
    +
    +
    + + + + diff --git a/doxygen/search/all_0.html b/doxygen/search/all_0.html new file mode 100644 index 0000000..1ec5b2d --- /dev/null +++ b/doxygen/search/all_0.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_0.js b/doxygen/search/all_0.js new file mode 100644 index 0000000..e652964 --- /dev/null +++ b/doxygen/search/all_0.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['abstractize_0',['abstractize',['../structDBM.html#a9f69babfc8f06e5fc5f31c24ef807a96',1,'DBM']]], + ['ans_5ftrait_1',['ans_trait',['../structans__trait.html',1,'']]], + ['ans_5ftrait_3c_20maxminsemiring_3c_20double_20_3e_20_3e_2',['ans_trait< MaxMinSemiring< double > >',['../structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20maxminsemiring_3c_20int_20_3e_20_3e_3',['ans_trait< MaxMinSemiring< int > >',['../structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20minplussemiring_3c_20double_20_3e_20_3e_4',['ans_trait< MinPlusSemiring< double > >',['../structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20minplussemiring_3c_20int_20_3e_20_3e_5',['ans_trait< MinPlusSemiring< int > >',['../structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html',1,'']]] +]; diff --git a/doxygen/search/all_1.html b/doxygen/search/all_1.html new file mode 100644 index 0000000..9f80e90 --- /dev/null +++ b/doxygen/search/all_1.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_1.js b/doxygen/search/all_1.js new file mode 100644 index 0000000..5a401fd --- /dev/null +++ b/doxygen/search/all_1.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['bibliography_6',['Bibliography',['../citelist.html',1,'']]], + ['booleansemiring_7',['BooleanSemiring',['../classBooleanSemiring.html',1,'']]], + ['boosttastate_8',['BoostTAState',['../structBoostTAState.html',1,'']]], + ['boosttatransition_9',['BoostTATransition',['../structBoostTATransition.html',1,'']]], + ['boostzonegraphstate_10',['BoostZoneGraphState',['../structBoostZoneGraphState.html',1,'']]] +]; diff --git a/doxygen/search/all_10.html b/doxygen/search/all_10.html new file mode 100644 index 0000000..3bf1196 --- /dev/null +++ b/doxygen/search/all_10.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_10.js b/doxygen/search/all_10.js new file mode 100644 index 0000000..a9807c0 --- /dev/null +++ b/doxygen/search/all_10.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['weight_5flabel_5fwriter_43',['weight_label_writer',['../structweight__label__writer.html',1,'']]] +]; diff --git a/doxygen/search/all_11.html b/doxygen/search/all_11.html new file mode 100644 index 0000000..c9f79d2 --- /dev/null +++ b/doxygen/search/all_11.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_11.js b/doxygen/search/all_11.js new file mode 100644 index 0000000..d8d5b1e --- /dev/null +++ b/doxygen/search/all_11.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['zero_44',['zero',['../structDBM.html#ab0ab799402f785edc68b08f89d0d37e9',1,'DBM']]], + ['zone_45',['zone',['../structBoostZoneGraphState.html#a1ca35dd83d34170f76fc77aff6bc243a',1,'BoostZoneGraphState']]], + ['zonegraphlabelwriter_46',['ZoneGraphLabelWriter',['../structZoneGraphLabelWriter.html',1,'']]] +]; diff --git a/doxygen/search/all_2.html b/doxygen/search/all_2.html new file mode 100644 index 0000000..02cfffc --- /dev/null +++ b/doxygen/search/all_2.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_2.js b/doxygen/search/all_2.js new file mode 100644 index 0000000..e67044a --- /dev/null +++ b/doxygen/search/all_2.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['canonize_11',['canonize',['../structDBM.html#a13809878be1001a0b3fd9f26ca3e66af',1,'DBM']]], + ['constraint_12',['Constraint',['../structConstraint.html',1,'']]], + ['constraintmaker_13',['ConstraintMaker',['../classConstraintMaker.html',1,'']]], + ['convexunion_14',['convexUnion',['../structDBM.html#a067621af8e8fe77aa3dfc7de7982e56a',1,'DBM']]] +]; diff --git a/doxygen/search/all_3.html b/doxygen/search/all_3.html new file mode 100644 index 0000000..39767b8 --- /dev/null +++ b/doxygen/search/all_3.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_3.js b/doxygen/search/all_3.js new file mode 100644 index 0000000..522242a --- /dev/null +++ b/doxygen/search/all_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['dbm_15',['DBM',['../structDBM.html',1,'']]] +]; diff --git a/doxygen/search/all_4.html b/doxygen/search/all_4.html new file mode 100644 index 0000000..fc40463 --- /dev/null +++ b/doxygen/search/all_4.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_4.js b/doxygen/search/all_4.js new file mode 100644 index 0000000..81d1964 --- /dev/null +++ b/doxygen/search/all_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['elapse_16',['elapse',['../structDBM.html#ab595495aa58a1110043ad97e024cb024',1,'DBM']]] +]; diff --git a/doxygen/search/all_5.html b/doxygen/search/all_5.html new file mode 100644 index 0000000..9dd9344 --- /dev/null +++ b/doxygen/search/all_5.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_5.js b/doxygen/search/all_5.js new file mode 100644 index 0000000..86879e0 --- /dev/null +++ b/doxygen/search/all_5.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['feed_17',['feed',['../classQuantitativeTimedPatternMatching.html#a69c30442b09757c7588f3e81adf6330a',1,'QuantitativeTimedPatternMatching']]] +]; diff --git a/doxygen/search/all_6.html b/doxygen/search/all_6.html new file mode 100644 index 0000000..f1e516d --- /dev/null +++ b/doxygen/search/all_6.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_6.js b/doxygen/search/all_6.js new file mode 100644 index 0000000..42ef0a5 --- /dev/null +++ b/doxygen/search/all_6.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['getnumofvar_18',['getNumOfVar',['../structDBM.html#a3d1ef4d38ea09e0e91f2f3b6d8da0dfe',1,'DBM']]] +]; diff --git a/doxygen/search/all_7.html b/doxygen/search/all_7.html new file mode 100644 index 0000000..8ddbf6c --- /dev/null +++ b/doxygen/search/all_7.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_7.js b/doxygen/search/all_7.js new file mode 100644 index 0000000..2692a86 --- /dev/null +++ b/doxygen/search/all_7.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['issatisfiable_19',['isSatisfiable',['../structDBM.html#a773e3a1a233918f2eddbca7d4e1f069c',1,'DBM']]], + ['issatisfiablewithoutcanonize_20',['isSatisfiableWithoutCanonize',['../structDBM.html#a0a75308b3e3638c184afd80099b1de8c',1,'DBM']]] +]; diff --git a/doxygen/search/all_8.html b/doxygen/search/all_8.html new file mode 100644 index 0000000..83c55ae --- /dev/null +++ b/doxygen/search/all_8.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_8.js b/doxygen/search/all_8.js new file mode 100644 index 0000000..6c2d269 --- /dev/null +++ b/doxygen/search/all_8.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['jumpable_21',['jumpable',['../structBoostZoneGraphState.html#a7edb9e4e073abd170e09066f9197c345',1,'BoostZoneGraphState']]] +]; diff --git a/doxygen/search/all_9.html b/doxygen/search/all_9.html new file mode 100644 index 0000000..1e263c1 --- /dev/null +++ b/doxygen/search/all_9.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_9.js b/doxygen/search/all_9.js new file mode 100644 index 0000000..35258fc --- /dev/null +++ b/doxygen/search/all_9.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['m_22',['M',['../structDBM.html#ab15873102fc666864ab26d6da0d1f3f5',1,'DBM']]], + ['makeunsat_23',['makeUnsat',['../structDBM.html#ac2d18f66df21dac086500b2fb1f17716',1,'DBM']]], + ['maxminsemiring_24',['MaxMinSemiring',['../classMaxMinSemiring.html',1,'']]], + ['maxplussemiring_25',['MaxPlusSemiring',['../classMaxPlusSemiring.html',1,'']]], + ['merge_26',['merge',['../structDBM.html#a88e6232f8826db65ccdbb2ce59794f23',1,'DBM']]], + ['minplussemiring_27',['MinPlusSemiring',['../classMinPlusSemiring.html',1,'']]] +]; diff --git a/doxygen/search/all_a.html b/doxygen/search/all_a.html new file mode 100644 index 0000000..3a6cac1 --- /dev/null +++ b/doxygen/search/all_a.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_a.js b/doxygen/search/all_a.js new file mode 100644 index 0000000..06eec76 --- /dev/null +++ b/doxygen/search/all_a.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['num_5ftype_5ftrait_28',['num_type_trait',['../structnum__type__trait.html',1,'']]], + ['num_5ftype_5ftrait_3c_20signed_20char_20_3e_29',['num_type_trait< signed char >',['../structnum__type__trait_3_01signed_01char_01_4.html',1,'']]], + ['num_5ftype_5ftrait_3c_20unsigned_20char_20_3e_30',['num_type_trait< unsigned char >',['../structnum__type__trait_3_01unsigned_01char_01_4.html',1,'']]] +]; diff --git a/doxygen/search/all_b.html b/doxygen/search/all_b.html new file mode 100644 index 0000000..130deb4 --- /dev/null +++ b/doxygen/search/all_b.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_b.js b/doxygen/search/all_b.js new file mode 100644 index 0000000..119e213 --- /dev/null +++ b/doxygen/search/all_b.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['overview_31',['Overview',['../index.html',1,'']]] +]; diff --git a/doxygen/search/all_c.html b/doxygen/search/all_c.html new file mode 100644 index 0000000..3dd5af0 --- /dev/null +++ b/doxygen/search/all_c.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_c.js b/doxygen/search/all_c.js new file mode 100644 index 0000000..82fe68d --- /dev/null +++ b/doxygen/search/all_c.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['quantitativetimedpatternmatching_32',['QuantitativeTimedPatternMatching',['../classQuantitativeTimedPatternMatching.html',1,'']]] +]; diff --git a/doxygen/search/all_d.html b/doxygen/search/all_d.html new file mode 100644 index 0000000..af7f2f0 --- /dev/null +++ b/doxygen/search/all_d.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_d.js b/doxygen/search/all_d.js new file mode 100644 index 0000000..4f01f01 --- /dev/null +++ b/doxygen/search/all_d.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['release_33',['release',['../structDBM.html#a40935a242833cd89860c6f36d6d4fcb2',1,'DBM']]], + ['resetvars_34',['ResetVars',['../structResetVars.html',1,'']]], + ['resetvars_35',['resetVars',['../structBoostTATransition.html#a7e6eb098fad94231203a9399646b88b4',1,'BoostTATransition']]] +]; diff --git a/doxygen/search/all_e.html b/doxygen/search/all_e.html new file mode 100644 index 0000000..e25df42 --- /dev/null +++ b/doxygen/search/all_e.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_e.js b/doxygen/search/all_e.js new file mode 100644 index 0000000..fb6fe2d --- /dev/null +++ b/doxygen/search/all_e.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['tighten_36',['tighten',['../structDBM.html#a8745732472b31b4209b6f963d652bf83',1,'DBM']]], + ['tightenwithoutclose_37',['tightenWithoutClose',['../structDBM.html#a57ce698079c0feba068e58bc3831ce8e',1,'DBM']]], + ['todo_20list_38',['Todo List',['../todo.html',1,'']]], + ['totuple_39',['toTuple',['../structDBM.html#a353253430782322649e75f4eb53123e8',1,'DBM']]] +]; diff --git a/doxygen/search/all_f.html b/doxygen/search/all_f.html new file mode 100644 index 0000000..b23da6c --- /dev/null +++ b/doxygen/search/all_f.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/all_f.js b/doxygen/search/all_f.js new file mode 100644 index 0000000..b99cbc8 --- /dev/null +++ b/doxygen/search/all_f.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['valuations_40',['valuations',['../structBoostZoneGraphState.html#ae3f4a4503890f29733a59f49f02f98a3',1,'BoostZoneGraphState']]], + ['value_41',['value',['../structDBM.html#ae4e32630518e832b45e762c7cca44f2f',1,'DBM']]], + ['vertex_42',['vertex',['../structBoostZoneGraphState.html#aaea5a2c35dc515f898ce3327d7bbc755',1,'BoostZoneGraphState']]] +]; diff --git a/doxygen/search/classes_0.html b/doxygen/search/classes_0.html new file mode 100644 index 0000000..af8159e --- /dev/null +++ b/doxygen/search/classes_0.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_0.js b/doxygen/search/classes_0.js new file mode 100644 index 0000000..60572ee --- /dev/null +++ b/doxygen/search/classes_0.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['ans_5ftrait_47',['ans_trait',['../structans__trait.html',1,'']]], + ['ans_5ftrait_3c_20maxminsemiring_3c_20double_20_3e_20_3e_48',['ans_trait< MaxMinSemiring< double > >',['../structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20maxminsemiring_3c_20int_20_3e_20_3e_49',['ans_trait< MaxMinSemiring< int > >',['../structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20minplussemiring_3c_20double_20_3e_20_3e_50',['ans_trait< MinPlusSemiring< double > >',['../structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html',1,'']]], + ['ans_5ftrait_3c_20minplussemiring_3c_20int_20_3e_20_3e_51',['ans_trait< MinPlusSemiring< int > >',['../structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html',1,'']]] +]; diff --git a/doxygen/search/classes_1.html b/doxygen/search/classes_1.html new file mode 100644 index 0000000..576e916 --- /dev/null +++ b/doxygen/search/classes_1.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_1.js b/doxygen/search/classes_1.js new file mode 100644 index 0000000..a6ac8e3 --- /dev/null +++ b/doxygen/search/classes_1.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['booleansemiring_52',['BooleanSemiring',['../classBooleanSemiring.html',1,'']]], + ['boosttastate_53',['BoostTAState',['../structBoostTAState.html',1,'']]], + ['boosttatransition_54',['BoostTATransition',['../structBoostTATransition.html',1,'']]], + ['boostzonegraphstate_55',['BoostZoneGraphState',['../structBoostZoneGraphState.html',1,'']]] +]; diff --git a/doxygen/search/classes_2.html b/doxygen/search/classes_2.html new file mode 100644 index 0000000..956405e --- /dev/null +++ b/doxygen/search/classes_2.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_2.js b/doxygen/search/classes_2.js new file mode 100644 index 0000000..aec919a --- /dev/null +++ b/doxygen/search/classes_2.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['constraint_56',['Constraint',['../structConstraint.html',1,'']]], + ['constraintmaker_57',['ConstraintMaker',['../classConstraintMaker.html',1,'']]] +]; diff --git a/doxygen/search/classes_3.html b/doxygen/search/classes_3.html new file mode 100644 index 0000000..d33343b --- /dev/null +++ b/doxygen/search/classes_3.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_3.js b/doxygen/search/classes_3.js new file mode 100644 index 0000000..20bc930 --- /dev/null +++ b/doxygen/search/classes_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['dbm_58',['DBM',['../structDBM.html',1,'']]] +]; diff --git a/doxygen/search/classes_4.html b/doxygen/search/classes_4.html new file mode 100644 index 0000000..8430b07 --- /dev/null +++ b/doxygen/search/classes_4.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_4.js b/doxygen/search/classes_4.js new file mode 100644 index 0000000..05a5983 --- /dev/null +++ b/doxygen/search/classes_4.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['maxminsemiring_59',['MaxMinSemiring',['../classMaxMinSemiring.html',1,'']]], + ['maxplussemiring_60',['MaxPlusSemiring',['../classMaxPlusSemiring.html',1,'']]], + ['minplussemiring_61',['MinPlusSemiring',['../classMinPlusSemiring.html',1,'']]] +]; diff --git a/doxygen/search/classes_5.html b/doxygen/search/classes_5.html new file mode 100644 index 0000000..c2f1b76 --- /dev/null +++ b/doxygen/search/classes_5.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_5.js b/doxygen/search/classes_5.js new file mode 100644 index 0000000..5c3a5f0 --- /dev/null +++ b/doxygen/search/classes_5.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['num_5ftype_5ftrait_62',['num_type_trait',['../structnum__type__trait.html',1,'']]], + ['num_5ftype_5ftrait_3c_20signed_20char_20_3e_63',['num_type_trait< signed char >',['../structnum__type__trait_3_01signed_01char_01_4.html',1,'']]], + ['num_5ftype_5ftrait_3c_20unsigned_20char_20_3e_64',['num_type_trait< unsigned char >',['../structnum__type__trait_3_01unsigned_01char_01_4.html',1,'']]] +]; diff --git a/doxygen/search/classes_6.html b/doxygen/search/classes_6.html new file mode 100644 index 0000000..e39847c --- /dev/null +++ b/doxygen/search/classes_6.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_6.js b/doxygen/search/classes_6.js new file mode 100644 index 0000000..ef15a68 --- /dev/null +++ b/doxygen/search/classes_6.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['quantitativetimedpatternmatching_65',['QuantitativeTimedPatternMatching',['../classQuantitativeTimedPatternMatching.html',1,'']]] +]; diff --git a/doxygen/search/classes_7.html b/doxygen/search/classes_7.html new file mode 100644 index 0000000..a2c4d1a --- /dev/null +++ b/doxygen/search/classes_7.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_7.js b/doxygen/search/classes_7.js new file mode 100644 index 0000000..d6cd5a3 --- /dev/null +++ b/doxygen/search/classes_7.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['resetvars_66',['ResetVars',['../structResetVars.html',1,'']]] +]; diff --git a/doxygen/search/classes_8.html b/doxygen/search/classes_8.html new file mode 100644 index 0000000..17003e4 --- /dev/null +++ b/doxygen/search/classes_8.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_8.js b/doxygen/search/classes_8.js new file mode 100644 index 0000000..671679f --- /dev/null +++ b/doxygen/search/classes_8.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['weight_5flabel_5fwriter_67',['weight_label_writer',['../structweight__label__writer.html',1,'']]] +]; diff --git a/doxygen/search/classes_9.html b/doxygen/search/classes_9.html new file mode 100644 index 0000000..b8afa8c --- /dev/null +++ b/doxygen/search/classes_9.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/classes_9.js b/doxygen/search/classes_9.js new file mode 100644 index 0000000..e7bd0b4 --- /dev/null +++ b/doxygen/search/classes_9.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['zonegraphlabelwriter_68',['ZoneGraphLabelWriter',['../structZoneGraphLabelWriter.html',1,'']]] +]; diff --git a/doxygen/search/close.svg b/doxygen/search/close.svg new file mode 100644 index 0000000..a933eea --- /dev/null +++ b/doxygen/search/close.svg @@ -0,0 +1,31 @@ + + + + + + image/svg+xml + + + + + + + + diff --git a/doxygen/search/functions_0.html b/doxygen/search/functions_0.html new file mode 100644 index 0000000..eb4c501 --- /dev/null +++ b/doxygen/search/functions_0.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_0.js b/doxygen/search/functions_0.js new file mode 100644 index 0000000..0f3097b --- /dev/null +++ b/doxygen/search/functions_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['abstractize_69',['abstractize',['../structDBM.html#a9f69babfc8f06e5fc5f31c24ef807a96',1,'DBM']]] +]; diff --git a/doxygen/search/functions_1.html b/doxygen/search/functions_1.html new file mode 100644 index 0000000..ef4088b --- /dev/null +++ b/doxygen/search/functions_1.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_1.js b/doxygen/search/functions_1.js new file mode 100644 index 0000000..1678cf9 --- /dev/null +++ b/doxygen/search/functions_1.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['canonize_70',['canonize',['../structDBM.html#a13809878be1001a0b3fd9f26ca3e66af',1,'DBM']]], + ['convexunion_71',['convexUnion',['../structDBM.html#a067621af8e8fe77aa3dfc7de7982e56a',1,'DBM']]] +]; diff --git a/doxygen/search/functions_2.html b/doxygen/search/functions_2.html new file mode 100644 index 0000000..ca5aa10 --- /dev/null +++ b/doxygen/search/functions_2.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_2.js b/doxygen/search/functions_2.js new file mode 100644 index 0000000..efe302b --- /dev/null +++ b/doxygen/search/functions_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['elapse_72',['elapse',['../structDBM.html#ab595495aa58a1110043ad97e024cb024',1,'DBM']]] +]; diff --git a/doxygen/search/functions_3.html b/doxygen/search/functions_3.html new file mode 100644 index 0000000..d79f55b --- /dev/null +++ b/doxygen/search/functions_3.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_3.js b/doxygen/search/functions_3.js new file mode 100644 index 0000000..9bcd051 --- /dev/null +++ b/doxygen/search/functions_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['feed_73',['feed',['../classQuantitativeTimedPatternMatching.html#a69c30442b09757c7588f3e81adf6330a',1,'QuantitativeTimedPatternMatching']]] +]; diff --git a/doxygen/search/functions_4.html b/doxygen/search/functions_4.html new file mode 100644 index 0000000..1657cad --- /dev/null +++ b/doxygen/search/functions_4.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_4.js b/doxygen/search/functions_4.js new file mode 100644 index 0000000..c02b4a3 --- /dev/null +++ b/doxygen/search/functions_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['getnumofvar_74',['getNumOfVar',['../structDBM.html#a3d1ef4d38ea09e0e91f2f3b6d8da0dfe',1,'DBM']]] +]; diff --git a/doxygen/search/functions_5.html b/doxygen/search/functions_5.html new file mode 100644 index 0000000..9301d6b --- /dev/null +++ b/doxygen/search/functions_5.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_5.js b/doxygen/search/functions_5.js new file mode 100644 index 0000000..dc8423b --- /dev/null +++ b/doxygen/search/functions_5.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['issatisfiable_75',['isSatisfiable',['../structDBM.html#a773e3a1a233918f2eddbca7d4e1f069c',1,'DBM']]], + ['issatisfiablewithoutcanonize_76',['isSatisfiableWithoutCanonize',['../structDBM.html#a0a75308b3e3638c184afd80099b1de8c',1,'DBM']]] +]; diff --git a/doxygen/search/functions_6.html b/doxygen/search/functions_6.html new file mode 100644 index 0000000..9c4f5fc --- /dev/null +++ b/doxygen/search/functions_6.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_6.js b/doxygen/search/functions_6.js new file mode 100644 index 0000000..09b5675 --- /dev/null +++ b/doxygen/search/functions_6.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['makeunsat_77',['makeUnsat',['../structDBM.html#ac2d18f66df21dac086500b2fb1f17716',1,'DBM']]], + ['merge_78',['merge',['../structDBM.html#a88e6232f8826db65ccdbb2ce59794f23',1,'DBM']]] +]; diff --git a/doxygen/search/functions_7.html b/doxygen/search/functions_7.html new file mode 100644 index 0000000..46b5c0f --- /dev/null +++ b/doxygen/search/functions_7.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_7.js b/doxygen/search/functions_7.js new file mode 100644 index 0000000..6603f3e --- /dev/null +++ b/doxygen/search/functions_7.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['release_79',['release',['../structDBM.html#a40935a242833cd89860c6f36d6d4fcb2',1,'DBM']]] +]; diff --git a/doxygen/search/functions_8.html b/doxygen/search/functions_8.html new file mode 100644 index 0000000..31a1d95 --- /dev/null +++ b/doxygen/search/functions_8.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_8.js b/doxygen/search/functions_8.js new file mode 100644 index 0000000..452bb48 --- /dev/null +++ b/doxygen/search/functions_8.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['tighten_80',['tighten',['../structDBM.html#a8745732472b31b4209b6f963d652bf83',1,'DBM']]], + ['tightenwithoutclose_81',['tightenWithoutClose',['../structDBM.html#a57ce698079c0feba068e58bc3831ce8e',1,'DBM']]], + ['totuple_82',['toTuple',['../structDBM.html#a353253430782322649e75f4eb53123e8',1,'DBM']]] +]; diff --git a/doxygen/search/functions_9.html b/doxygen/search/functions_9.html new file mode 100644 index 0000000..9a8e429 --- /dev/null +++ b/doxygen/search/functions_9.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/functions_9.js b/doxygen/search/functions_9.js new file mode 100644 index 0000000..8a11e7a --- /dev/null +++ b/doxygen/search/functions_9.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['zero_83',['zero',['../structDBM.html#ab0ab799402f785edc68b08f89d0d37e9',1,'DBM']]] +]; diff --git a/doxygen/search/mag_sel.svg b/doxygen/search/mag_sel.svg new file mode 100644 index 0000000..03626f6 --- /dev/null +++ b/doxygen/search/mag_sel.svg @@ -0,0 +1,74 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/doxygen/search/nomatches.html b/doxygen/search/nomatches.html new file mode 100644 index 0000000..2b9360b --- /dev/null +++ b/doxygen/search/nomatches.html @@ -0,0 +1,13 @@ + + + + + + + + +
    +
    No Matches
    +
    + + diff --git a/doxygen/search/pages_0.html b/doxygen/search/pages_0.html new file mode 100644 index 0000000..8517b48 --- /dev/null +++ b/doxygen/search/pages_0.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/pages_0.js b/doxygen/search/pages_0.js new file mode 100644 index 0000000..e18ce66 --- /dev/null +++ b/doxygen/search/pages_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['bibliography_91',['Bibliography',['../citelist.html',1,'']]] +]; diff --git a/doxygen/search/pages_1.html b/doxygen/search/pages_1.html new file mode 100644 index 0000000..a0fb679 --- /dev/null +++ b/doxygen/search/pages_1.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/pages_1.js b/doxygen/search/pages_1.js new file mode 100644 index 0000000..6102596 --- /dev/null +++ b/doxygen/search/pages_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['overview_92',['Overview',['../index.html',1,'']]] +]; diff --git a/doxygen/search/pages_2.html b/doxygen/search/pages_2.html new file mode 100644 index 0000000..084edfd --- /dev/null +++ b/doxygen/search/pages_2.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/pages_2.js b/doxygen/search/pages_2.js new file mode 100644 index 0000000..09eaac8 --- /dev/null +++ b/doxygen/search/pages_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['todo_20list_93',['Todo List',['../todo.html',1,'']]] +]; diff --git a/doxygen/search/search.css b/doxygen/search/search.css new file mode 100644 index 0000000..9074198 --- /dev/null +++ b/doxygen/search/search.css @@ -0,0 +1,257 @@ +/*---------------- Search Box */ + +#MSearchBox { + white-space : nowrap; + background: white; + border-radius: 0.65em; + box-shadow: inset 0.5px 0.5px 3px 0px #555; + z-index: 102; +} + +#MSearchBox .left { + display: inline-block; + vertical-align: middle; + height: 1.4em; +} + +#MSearchSelect { + display: inline-block; + vertical-align: middle; + height: 1.4em; + padding: 0 0 0 0.3em; + margin: 0; +} + +#MSearchField { + display: inline-block; + vertical-align: middle; + width: 7.5em; + height: 1.1em; + margin: 0 0.15em; + padding: 0; + line-height: 1em; + border:none; + color: #909090; + outline: none; + font-family: Arial, Verdana, sans-serif; + -webkit-border-radius: 0px; + border-radius: 0px; + background: none; +} + + +#MSearchBox .right { + display: inline-block; + vertical-align: middle; + width: 1.4em; + height: 1.4em; +} + +#MSearchClose { + display: none; + font-size: inherit; + background : none; + border: none; + margin: 0; + padding: 0; + outline: none; + +} + +#MSearchCloseImg { + height: 1.4em; + padding: 0.3em; + margin: 0; +} + +.MSearchBoxActive #MSearchField { + color: #000000; +} + +#main-menu > li:last-child { + /* This
  • object is the parent of the search bar */ + display: flex; + justify-content: center; + align-items: center; + height: 36px; + margin-right: 1em; +} + +/*---------------- Search filter selection */ + +#MSearchSelectWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid #90A5CE; + background-color: #F9FAFC; + z-index: 10001; + padding-top: 4px; + padding-bottom: 4px; + -moz-border-radius: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +.SelectItem { + font: 8pt Arial, Verdana, sans-serif; + padding-left: 2px; + padding-right: 12px; + border: 0px; +} + +span.SelectionMark { + margin-right: 4px; + font-family: monospace; + outline-style: none; + text-decoration: none; +} + +a.SelectItem { + display: block; + outline-style: none; + color: #000000; + text-decoration: none; + padding-left: 6px; + padding-right: 12px; +} + +a.SelectItem:focus, +a.SelectItem:active { + color: #000000; + outline-style: none; + text-decoration: none; +} + +a.SelectItem:hover { + color: #FFFFFF; + background-color: #3D578C; + outline-style: none; + text-decoration: none; + cursor: pointer; + display: block; +} + +/*---------------- Search results window */ + +iframe#MSearchResults { + width: 60ex; + height: 15em; +} + +#MSearchResultsWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid #000; + background-color: #EEF1F7; + z-index:10000; +} + +/* ----------------------------------- */ + + +#SRIndex { + clear:both; + padding-bottom: 15px; +} + +.SREntry { + font-size: 10pt; + padding-left: 1ex; +} + +.SRPage .SREntry { + font-size: 8pt; + padding: 1px 5px; +} + +body.SRPage { + margin: 5px 2px; +} + +.SRChildren { + padding-left: 3ex; padding-bottom: .5em +} + +.SRPage .SRChildren { + display: none; +} + +.SRSymbol { + font-weight: bold; + color: #425E97; + font-family: Arial, Verdana, sans-serif; + text-decoration: none; + outline: none; +} + +a.SRScope { + display: block; + color: #425E97; + font-family: Arial, Verdana, sans-serif; + text-decoration: none; + outline: none; +} + +a.SRSymbol:focus, a.SRSymbol:active, +a.SRScope:focus, a.SRScope:active { + text-decoration: underline; +} + +span.SRScope { + padding-left: 4px; + font-family: Arial, Verdana, sans-serif; +} + +.SRPage .SRStatus { + padding: 2px 5px; + font-size: 8pt; + font-style: italic; + font-family: Arial, Verdana, sans-serif; +} + +.SRResult { + display: none; +} + +div.searchresults { + margin-left: 10px; + margin-right: 10px; +} + +/*---------------- External search page results */ + +.searchresult { + background-color: #F0F3F8; +} + +.pages b { + color: white; + padding: 5px 5px 3px 5px; + background-image: url("../tab_a.png"); + background-repeat: repeat-x; + text-shadow: 0 1px 1px #000000; +} + +.pages { + line-height: 17px; + margin-left: 4px; + text-decoration: none; +} + +.hl { + font-weight: bold; +} + +#searchresults { + margin-bottom: 20px; +} + +.searchpages { + margin-top: 10px; +} + diff --git a/doxygen/search/search.js b/doxygen/search/search.js new file mode 100644 index 0000000..fb226f7 --- /dev/null +++ b/doxygen/search/search.js @@ -0,0 +1,816 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +function convertToId(search) +{ + var result = ''; + for (i=0;i do a search + { + this.Search(); + } + } + + this.OnSearchSelectKey = function(evt) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==40 && this.searchIndex0) // Up + { + this.searchIndex--; + this.OnSelectItem(this.searchIndex); + } + else if (e.keyCode==13 || e.keyCode==27) + { + this.OnSelectItem(this.searchIndex); + this.CloseSelectionWindow(); + this.DOMSearchField().focus(); + } + return false; + } + + // --------- Actions + + // Closes the results window. + this.CloseResultsWindow = function() + { + this.DOMPopupSearchResultsWindow().style.display = 'none'; + this.DOMSearchClose().style.display = 'none'; + this.Activate(false); + } + + this.CloseSelectionWindow = function() + { + this.DOMSearchSelectWindow().style.display = 'none'; + } + + // Performs a search. + this.Search = function() + { + this.keyTimeout = 0; + + // strip leading whitespace + var searchValue = this.DOMSearchField().value.replace(/^ +/, ""); + + var code = searchValue.toLowerCase().charCodeAt(0); + var idxChar = searchValue.substr(0, 1).toLowerCase(); + if ( 0xD800 <= code && code <= 0xDBFF && searchValue > 1) // surrogate pair + { + idxChar = searchValue.substr(0, 2); + } + + var resultsPage; + var resultsPageWithSearch; + var hasResultsPage; + + var idx = indexSectionsWithContent[this.searchIndex].indexOf(idxChar); + if (idx!=-1) + { + var hexCode=idx.toString(16); + resultsPage = this.resultsPath + '/' + indexSectionNames[this.searchIndex] + '_' + hexCode + this.extension; + resultsPageWithSearch = resultsPage+'?'+escape(searchValue); + hasResultsPage = true; + } + else // nothing available for this search term + { + resultsPage = this.resultsPath + '/nomatches' + this.extension; + resultsPageWithSearch = resultsPage; + hasResultsPage = false; + } + + window.frames.MSearchResults.location = resultsPageWithSearch; + var domPopupSearchResultsWindow = this.DOMPopupSearchResultsWindow(); + + if (domPopupSearchResultsWindow.style.display!='block') + { + var domSearchBox = this.DOMSearchBox(); + this.DOMSearchClose().style.display = 'inline-block'; + if (this.insideFrame) + { + var domPopupSearchResults = this.DOMPopupSearchResults(); + domPopupSearchResultsWindow.style.position = 'relative'; + domPopupSearchResultsWindow.style.display = 'block'; + var width = document.body.clientWidth - 8; // the -8 is for IE :-( + domPopupSearchResultsWindow.style.width = width + 'px'; + domPopupSearchResults.style.width = width + 'px'; + } + else + { + var domPopupSearchResults = this.DOMPopupSearchResults(); + var left = getXPos(domSearchBox) + 150; // domSearchBox.offsetWidth; + var top = getYPos(domSearchBox) + 20; // domSearchBox.offsetHeight + 1; + domPopupSearchResultsWindow.style.display = 'block'; + left -= domPopupSearchResults.offsetWidth; + domPopupSearchResultsWindow.style.top = top + 'px'; + domPopupSearchResultsWindow.style.left = left + 'px'; + } + } + + this.lastSearchValue = searchValue; + this.lastResultsPage = resultsPage; + } + + // -------- Activation Functions + + // Activates or deactivates the search panel, resetting things to + // their default values if necessary. + this.Activate = function(isActive) + { + if (isActive || // open it + this.DOMPopupSearchResultsWindow().style.display == 'block' + ) + { + this.DOMSearchBox().className = 'MSearchBoxActive'; + + var searchField = this.DOMSearchField(); + + if (searchField.value == this.searchLabel) // clear "Search" term upon entry + { + searchField.value = ''; + this.searchActive = true; + } + } + else if (!isActive) // directly remove the panel + { + this.DOMSearchBox().className = 'MSearchBoxInactive'; + this.DOMSearchField().value = this.searchLabel; + this.searchActive = false; + this.lastSearchValue = '' + this.lastResultsPage = ''; + } + } +} + +// ----------------------------------------------------------------------- + +// The class that handles everything on the search results page. +function SearchResults(name) +{ + // The number of matches from the last run of . + this.lastMatchCount = 0; + this.lastKey = 0; + this.repeatOn = false; + + // Toggles the visibility of the passed element ID. + this.FindChildElement = function(id) + { + var parentElement = document.getElementById(id); + var element = parentElement.firstChild; + + while (element && element!=parentElement) + { + if (element.nodeName.toLowerCase() == 'div' && element.className == 'SRChildren') + { + return element; + } + + if (element.nodeName.toLowerCase() == 'div' && element.hasChildNodes()) + { + element = element.firstChild; + } + else if (element.nextSibling) + { + element = element.nextSibling; + } + else + { + do + { + element = element.parentNode; + } + while (element && element!=parentElement && !element.nextSibling); + + if (element && element!=parentElement) + { + element = element.nextSibling; + } + } + } + } + + this.Toggle = function(id) + { + var element = this.FindChildElement(id); + if (element) + { + if (element.style.display == 'block') + { + element.style.display = 'none'; + } + else + { + element.style.display = 'block'; + } + } + } + + // Searches for the passed string. If there is no parameter, + // it takes it from the URL query. + // + // Always returns true, since other documents may try to call it + // and that may or may not be possible. + this.Search = function(search) + { + if (!search) // get search word from URL + { + search = window.location.search; + search = search.substring(1); // Remove the leading '?' + search = unescape(search); + } + + search = search.replace(/^ +/, ""); // strip leading spaces + search = search.replace(/ +$/, ""); // strip trailing spaces + search = search.toLowerCase(); + search = convertToId(search); + + var resultRows = document.getElementsByTagName("div"); + var matches = 0; + + var i = 0; + while (i < resultRows.length) + { + var row = resultRows.item(i); + if (row.className == "SRResult") + { + var rowMatchName = row.id.toLowerCase(); + rowMatchName = rowMatchName.replace(/^sr\d*_/, ''); // strip 'sr123_' + + if (search.length<=rowMatchName.length && + rowMatchName.substr(0, search.length)==search) + { + row.style.display = 'block'; + matches++; + } + else + { + row.style.display = 'none'; + } + } + i++; + } + document.getElementById("Searching").style.display='none'; + if (matches == 0) // no results + { + document.getElementById("NoMatches").style.display='block'; + } + else // at least one result + { + document.getElementById("NoMatches").style.display='none'; + } + this.lastMatchCount = matches; + return true; + } + + // return the first item with index index or higher that is visible + this.NavNext = function(index) + { + var focusItem; + while (1) + { + var focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') + { + break; + } + else if (!focusItem) // last element + { + break; + } + focusItem=null; + index++; + } + return focusItem; + } + + this.NavPrev = function(index) + { + var focusItem; + while (1) + { + var focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') + { + break; + } + else if (!focusItem) // last element + { + break; + } + focusItem=null; + index--; + } + return focusItem; + } + + this.ProcessKeys = function(e) + { + if (e.type == "keydown") + { + this.repeatOn = false; + this.lastKey = e.keyCode; + } + else if (e.type == "keypress") + { + if (!this.repeatOn) + { + if (this.lastKey) this.repeatOn = true; + return false; // ignore first keypress after keydown + } + } + else if (e.type == "keyup") + { + this.lastKey = 0; + this.repeatOn = false; + } + return this.lastKey!=0; + } + + this.Nav = function(evt,itemIndex) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) // Up + { + var newIndex = itemIndex-1; + var focusItem = this.NavPrev(newIndex); + if (focusItem) + { + var child = this.FindChildElement(focusItem.parentNode.parentNode.id); + if (child && child.style.display == 'block') // children visible + { + var n=0; + var tmpElem; + while (1) // search for last child + { + tmpElem = document.getElementById('Item'+newIndex+'_c'+n); + if (tmpElem) + { + focusItem = tmpElem; + } + else // found it! + { + break; + } + n++; + } + } + } + if (focusItem) + { + focusItem.focus(); + } + else // return focus to search field + { + parent.document.getElementById("MSearchField").focus(); + } + } + else if (this.lastKey==40) // Down + { + var newIndex = itemIndex+1; + var focusItem; + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem && elem.style.display == 'block') // children visible + { + focusItem = document.getElementById('Item'+itemIndex+'_c0'); + } + if (!focusItem) focusItem = this.NavNext(newIndex); + if (focusItem) focusItem.focus(); + } + else if (this.lastKey==39) // Right + { + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'block'; + } + else if (this.lastKey==37) // Left + { + var item = document.getElementById('Item'+itemIndex); + var elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'none'; + } + else if (this.lastKey==27) // Escape + { + parent.searchBox.CloseResultsWindow(); + parent.document.getElementById("MSearchField").focus(); + } + else if (this.lastKey==13) // Enter + { + return true; + } + return false; + } + + this.NavChild = function(evt,itemIndex,childIndex) + { + var e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) // Up + { + if (childIndex>0) + { + var newIndex = childIndex-1; + document.getElementById('Item'+itemIndex+'_c'+newIndex).focus(); + } + else // already at first child, jump to parent + { + document.getElementById('Item'+itemIndex).focus(); + } + } + else if (this.lastKey==40) // Down + { + var newIndex = childIndex+1; + var elem = document.getElementById('Item'+itemIndex+'_c'+newIndex); + if (!elem) // last child, jump to parent next parent + { + elem = this.NavNext(itemIndex+1); + } + if (elem) + { + elem.focus(); + } + } + else if (this.lastKey==27) // Escape + { + parent.searchBox.CloseResultsWindow(); + parent.document.getElementById("MSearchField").focus(); + } + else if (this.lastKey==13) // Enter + { + return true; + } + return false; + } +} + +function setKeyActions(elem,action) +{ + elem.setAttribute('onkeydown',action); + elem.setAttribute('onkeypress',action); + elem.setAttribute('onkeyup',action); +} + +function setClassAttr(elem,attr) +{ + elem.setAttribute('class',attr); + elem.setAttribute('className',attr); +} + +function createResults() +{ + var results = document.getElementById("SRResults"); + for (var e=0; e + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/variables_0.js b/doxygen/search/variables_0.js new file mode 100644 index 0000000..614dec9 --- /dev/null +++ b/doxygen/search/variables_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['jumpable_84',['jumpable',['../structBoostZoneGraphState.html#a7edb9e4e073abd170e09066f9197c345',1,'BoostZoneGraphState']]] +]; diff --git a/doxygen/search/variables_1.html b/doxygen/search/variables_1.html new file mode 100644 index 0000000..ea73d9a --- /dev/null +++ b/doxygen/search/variables_1.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/variables_1.js b/doxygen/search/variables_1.js new file mode 100644 index 0000000..e1916a5 --- /dev/null +++ b/doxygen/search/variables_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['m_85',['M',['../structDBM.html#ab15873102fc666864ab26d6da0d1f3f5',1,'DBM']]] +]; diff --git a/doxygen/search/variables_2.html b/doxygen/search/variables_2.html new file mode 100644 index 0000000..0580462 --- /dev/null +++ b/doxygen/search/variables_2.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/variables_2.js b/doxygen/search/variables_2.js new file mode 100644 index 0000000..c4420cc --- /dev/null +++ b/doxygen/search/variables_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['resetvars_86',['resetVars',['../structBoostTATransition.html#a7e6eb098fad94231203a9399646b88b4',1,'BoostTATransition']]] +]; diff --git a/doxygen/search/variables_3.html b/doxygen/search/variables_3.html new file mode 100644 index 0000000..0d69e76 --- /dev/null +++ b/doxygen/search/variables_3.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/variables_3.js b/doxygen/search/variables_3.js new file mode 100644 index 0000000..c0e7313 --- /dev/null +++ b/doxygen/search/variables_3.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['valuations_87',['valuations',['../structBoostZoneGraphState.html#ae3f4a4503890f29733a59f49f02f98a3',1,'BoostZoneGraphState']]], + ['value_88',['value',['../structDBM.html#ae4e32630518e832b45e762c7cca44f2f',1,'DBM']]], + ['vertex_89',['vertex',['../structBoostZoneGraphState.html#aaea5a2c35dc515f898ce3327d7bbc755',1,'BoostZoneGraphState']]] +]; diff --git a/doxygen/search/variables_4.html b/doxygen/search/variables_4.html new file mode 100644 index 0000000..a4b6506 --- /dev/null +++ b/doxygen/search/variables_4.html @@ -0,0 +1,37 @@ + + + + + + + + + + +
    +
    Loading...
    +
    + +
    Searching...
    +
    No Matches
    + +
    + + diff --git a/doxygen/search/variables_4.js b/doxygen/search/variables_4.js new file mode 100644 index 0000000..ded8a71 --- /dev/null +++ b/doxygen/search/variables_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['zone_90',['zone',['../structBoostZoneGraphState.html#a1ca35dd83d34170f76fc77aff6bc243a',1,'BoostZoneGraphState']]] +]; diff --git a/doxygen/splitbar.png b/doxygen/splitbar.png new file mode 100644 index 0000000..fe895f2 Binary files /dev/null and b/doxygen/splitbar.png differ diff --git a/doxygen/structBoostTAState-members.html b/doxygen/structBoostTAState-members.html new file mode 100644 index 0000000..bfddd1a --- /dev/null +++ b/doxygen/structBoostTAState-members.html @@ -0,0 +1,111 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    BoostTAState< SignalVariables > Member List
    +
    +
    + +

    This is the complete list of members for BoostTAState< SignalVariables >, including all inherited members.

    + + + + +
    isInit (defined in BoostTAState< SignalVariables >)BoostTAState< SignalVariables >
    isMatch (defined in BoostTAState< SignalVariables >)BoostTAState< SignalVariables >
    label (defined in BoostTAState< SignalVariables >)BoostTAState< SignalVariables >
    +
    + + + + diff --git a/doxygen/structBoostTAState.html b/doxygen/structBoostTAState.html new file mode 100644 index 0000000..2c08131 --- /dev/null +++ b/doxygen/structBoostTAState.html @@ -0,0 +1,125 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: BoostTAState< SignalVariables > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    BoostTAState< SignalVariables > Struct Template Reference
    +
    +
    + + + + + + + + +

    +Public Attributes

    +bool isInit
     
    +bool isMatch
     
    +std::vector< Constraint< SignalVariables > > label
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structBoostTAState.js b/doxygen/structBoostTAState.js new file mode 100644 index 0000000..cf7f5a7 --- /dev/null +++ b/doxygen/structBoostTAState.js @@ -0,0 +1,6 @@ +var structBoostTAState = +[ + [ "isInit", "structBoostTAState.html#a0eec4635690aa0bf318a4e0b9593c2c1", null ], + [ "isMatch", "structBoostTAState.html#a136186786eb1dd5838fac815a9f1c04d", null ], + [ "label", "structBoostTAState.html#adf8aace291c6ffadc211f023d1c235f2", null ] +]; \ No newline at end of file diff --git a/doxygen/structBoostTATransition-members.html b/doxygen/structBoostTATransition-members.html new file mode 100644 index 0000000..2b9b88a --- /dev/null +++ b/doxygen/structBoostTATransition-members.html @@ -0,0 +1,110 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    BoostTATransition< ClockVariables > Member List
    +
    +
    + +

    This is the complete list of members for BoostTATransition< ClockVariables >, including all inherited members.

    + + + +
    guard (defined in BoostTATransition< ClockVariables >)BoostTATransition< ClockVariables >
    resetVarsBoostTATransition< ClockVariables >
    +
    + + + + diff --git a/doxygen/structBoostTATransition.html b/doxygen/structBoostTATransition.html new file mode 100644 index 0000000..a0cafb6 --- /dev/null +++ b/doxygen/structBoostTATransition.html @@ -0,0 +1,139 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: BoostTATransition< ClockVariables > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    BoostTATransition< ClockVariables > Struct Template Reference
    +
    +
    + + + + + + +

    +Public Attributes

    ResetVars< ClockVariables > resetVars
     
    +std::vector< Constraint< ClockVariables > > guard
     
    +

    Member Data Documentation

    + +

    ◆ resetVars

    + +
    +
    +
    +template<class ClockVariables >
    + + + + +
    ResetVars<ClockVariables> BoostTATransition< ClockVariables >::resetVars
    +
    +
    Note
    this structure is necessary because of some problem in boost graph
    + +
    +
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structBoostTATransition.js b/doxygen/structBoostTATransition.js new file mode 100644 index 0000000..b23141a --- /dev/null +++ b/doxygen/structBoostTATransition.js @@ -0,0 +1,5 @@ +var structBoostTATransition = +[ + [ "guard", "structBoostTATransition.html#afa83e2f227163b741435bc61fe376a63", null ], + [ "resetVars", "structBoostTATransition.html#a7e6eb098fad94231203a9399646b88b4", null ] +]; \ No newline at end of file diff --git a/doxygen/structBoostZoneGraphState-members.html b/doxygen/structBoostZoneGraphState-members.html new file mode 100644 index 0000000..e831623 --- /dev/null +++ b/doxygen/structBoostZoneGraphState-members.html @@ -0,0 +1,112 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + + + + + + diff --git a/doxygen/structBoostZoneGraphState.html b/doxygen/structBoostZoneGraphState.html new file mode 100644 index 0000000..47007fc --- /dev/null +++ b/doxygen/structBoostZoneGraphState.html @@ -0,0 +1,163 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: BoostZoneGraphState< SignalVariables, ClockVariables, Value > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    BoostZoneGraphState< SignalVariables, ClockVariables, Value > Struct Template Reference
    +
    +
    +
    +Collaboration diagram for BoostZoneGraphState< SignalVariables, ClockVariables, Value >:
    +
    +
    Collaboration graph
    + + + + +
    [legend]
    + + + + + + + + + + + + + + +

    +Public Attributes

    +BoostTimedAutomaton< SignalVariables, ClockVariables >::vertex_descriptor vertex
     The corresponding state in the TA.
     
    bool jumpable
     The flag showing if one can fire a (discrete) transition. This is used to forbid having multiple jumps at the same time. More...
     
    +DBM zone
     The corresponding zone.
     
    +std::vector< std::vector< Value > > valuations
     The signal valuations observed after the latest (discrete) transition.
     
    +

    Member Data Documentation

    + +

    ◆ jumpable

    + +
    +
    +
    +template<class SignalVariables , class ClockVariables , class Value >
    + + + + +
    bool BoostZoneGraphState< SignalVariables, ClockVariables, Value >::jumpable
    +
    + +

    The flag showing if one can fire a (discrete) transition. This is used to forbid having multiple jumps at the same time.

    +
    Note
    In the current implementation, this flag is unnecessary because we have the following:
    jumpable == !(valuations.empty())
    +
    bool jumpable
    The flag showing if one can fire a (discrete) transition. This is used to forbid having multiple jump...
    Definition: zone_graph.hh:25
    +
    std::vector< std::vector< Value > > valuations
    The signal valuations observed after the latest (discrete) transition.
    Definition: zone_graph.hh:29
    +
    + +
    +
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structBoostZoneGraphState.js b/doxygen/structBoostZoneGraphState.js new file mode 100644 index 0000000..9127b16 --- /dev/null +++ b/doxygen/structBoostZoneGraphState.js @@ -0,0 +1,7 @@ +var structBoostZoneGraphState = +[ + [ "jumpable", "structBoostZoneGraphState.html#a7edb9e4e073abd170e09066f9197c345", null ], + [ "valuations", "structBoostZoneGraphState.html#ae3f4a4503890f29733a59f49f02f98a3", null ], + [ "vertex", "structBoostZoneGraphState.html#aaea5a2c35dc515f898ce3327d7bbc755", null ], + [ "zone", "structBoostZoneGraphState.html#a1ca35dd83d34170f76fc77aff6bc243a", null ] +]; \ No newline at end of file diff --git a/doxygen/structBoostZoneGraphState__coll__graph.map b/doxygen/structBoostZoneGraphState__coll__graph.map new file mode 100644 index 0000000..de22420 --- /dev/null +++ b/doxygen/structBoostZoneGraphState__coll__graph.map @@ -0,0 +1,4 @@ + + + + diff --git a/doxygen/structBoostZoneGraphState__coll__graph.md5 b/doxygen/structBoostZoneGraphState__coll__graph.md5 new file mode 100644 index 0000000..48f8c30 --- /dev/null +++ b/doxygen/structBoostZoneGraphState__coll__graph.md5 @@ -0,0 +1 @@ +58b1210df82e01c63a930ed5bc999361 \ No newline at end of file diff --git a/doxygen/structBoostZoneGraphState__coll__graph.png b/doxygen/structBoostZoneGraphState__coll__graph.png new file mode 100644 index 0000000..7fd1b8e Binary files /dev/null and b/doxygen/structBoostZoneGraphState__coll__graph.png differ diff --git a/doxygen/structConstraint-members.html b/doxygen/structConstraint-members.html new file mode 100644 index 0000000..23bfb14 --- /dev/null +++ b/doxygen/structConstraint-members.html @@ -0,0 +1,115 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    Constraint< ClockVariables > Member List
    +
    +
    + +

    This is the complete list of members for Constraint< ClockVariables >, including all inherited members.

    + + + + + + + + +
    c (defined in Constraint< ClockVariables >)Constraint< ClockVariables >
    Interpretation typedef (defined in Constraint< ClockVariables >)Constraint< ClockVariables >
    odr (defined in Constraint< ClockVariables >)Constraint< ClockVariables >
    operator()(Interpretation val) const (defined in Constraint< ClockVariables >)Constraint< ClockVariables >inline
    Order enum name (defined in Constraint< ClockVariables >)Constraint< ClockVariables >
    satisfy(double d) const (defined in Constraint< ClockVariables >)Constraint< ClockVariables >inline
    x (defined in Constraint< ClockVariables >)Constraint< ClockVariables >
    +
    + + + + diff --git a/doxygen/structConstraint.html b/doxygen/structConstraint.html new file mode 100644 index 0000000..9da2643 --- /dev/null +++ b/doxygen/structConstraint.html @@ -0,0 +1,158 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Constraint< ClockVariables > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    Constraint< ClockVariables > Struct Template Reference
    +
    +
    + +

    A constraint in a guard of transitions. + More...

    + +

    #include <constraint.hh>

    + + + + + + +

    +Public Types

    enum class  Order { lt +, le +, ge +, gt + }
     
    +using Interpretation = std::vector< double >
     
    + + + + + +

    +Public Member Functions

    +bool satisfy (double d) const
     
    +::Order operator() (Interpretation val) const
     
    + + + + + + + +

    +Public Attributes

    +ClockVariables x
     
    +Order odr
     
    +int c
     
    +

    Detailed Description

    +

    template<class ClockVariables>
    +struct Constraint< ClockVariables >

    + +

    A constraint in a guard of transitions.

    +

    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structConstraint.js b/doxygen/structConstraint.js new file mode 100644 index 0000000..a6ed2d7 --- /dev/null +++ b/doxygen/structConstraint.js @@ -0,0 +1,15 @@ +var structConstraint = +[ + [ "Interpretation", "structConstraint.html#a4feb21e1c475415fc1699ef99ac0ea3a", null ], + [ "Order", "structConstraint.html#a557adb057f06215b0d275e3769e8ec97", [ + [ "lt", "structConstraint.html#a557adb057f06215b0d275e3769e8ec97ad91af6958918af87d6a057c1cdf5b225", null ], + [ "le", "structConstraint.html#a557adb057f06215b0d275e3769e8ec97ad9180594744f870aeefb086982e980bb", null ], + [ "ge", "structConstraint.html#a557adb057f06215b0d275e3769e8ec97a0ba64a0dea00947916dfb6a66866e1ca", null ], + [ "gt", "structConstraint.html#a557adb057f06215b0d275e3769e8ec97a1bfad22f0925978f310a37440bfdff43", null ] + ] ], + [ "operator()", "structConstraint.html#af2060781c7d3b6a0be78d69a85943353", null ], + [ "satisfy", "structConstraint.html#adc7155736ffd03e8f0bc1ab9b2e9cf19", null ], + [ "c", "structConstraint.html#a292c7823a74f321f123b6f6b11f250b4", null ], + [ "odr", "structConstraint.html#a2147dfba03590ccf31127e9b921feadc", null ], + [ "x", "structConstraint.html#a25534f1fe82e279895fa8ddb7a3e0402", null ] +]; \ No newline at end of file diff --git a/doxygen/structDBM-members.html b/doxygen/structDBM-members.html new file mode 100644 index 0000000..7e23b8a --- /dev/null +++ b/doxygen/structDBM-members.html @@ -0,0 +1,133 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    DBM Member List
    +
    +
    + +

    This is the complete list of members for DBM, including all inherited members.

    + + + + + + + + + + + + + + + + + + + + + + + + + + +
    abstractize()DBMinline
    canonize()DBMinline
    close1(uint8_t x) (defined in DBM)DBMinline
    convexUnion(const DBM &z, DBM &dest) constDBMinline
    cutVars(std::shared_ptr< DBM > &out, std::size_t from, std::size_t to) const (defined in DBM)DBMinline
    elapse()DBMinline
    getNumOfVar() constDBMinline
    isCanonized() const (defined in DBM)DBMinline
    isSatisfiable()DBMinline
    isSatisfiableWithoutCanonize() constDBMinline
    MDBM
    makeUnsat()DBMinline
    merge(const DBM &z)DBMinline
    operator&=(const DBM &z) (defined in DBM)DBMinline
    operator<=(const DBM &z) const (defined in DBM)DBMinline
    operator==(DBM z) const (defined in DBM)DBMinline
    operator>(const DBM &z) const (defined in DBM)DBMinline
    release(uint8_t x)DBMinline
    reset(uint8_t x) (defined in DBM)DBMinline
    tighten(uint8_t x, uint8_t y, Bounds c)DBMinline
    tightenWithoutClose(uint8_t x, uint8_t y, Bounds c)DBMinline
    toTuple() constDBMinline
    Tuple typedef (defined in DBM)DBM
    valueDBM
    zero(int size)DBMinlinestatic
    +
    + + + + diff --git a/doxygen/structDBM.html b/doxygen/structDBM.html new file mode 100644 index 0000000..fb52f3e --- /dev/null +++ b/doxygen/structDBM.html @@ -0,0 +1,466 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: DBM Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + + +
    + +

    Implementation of a zone with DBM DBM For the detail of DBMs, see for example [BY03]. + More...

    + +

    #include <dbm.hh>

    + + + + +

    +Public Types

    +using Tuple = std::tuple< std::vector< Bounds >, Bounds >
     
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

    +Public Member Functions

    std::size_t getNumOfVar () const
     Returns the number of the variables represented by this zone. More...
     
    +void cutVars (std::shared_ptr< DBM > &out, std::size_t from, std::size_t to) const
     
    +std::tuple< std::vector< Bounds >, Bounds > toTuple () const
     Return the tuple representation of the DBM.
     
    void tightenWithoutClose (uint8_t x, uint8_t y, Bounds c)
     add the constraint x - y <= (c,s) but does not close. More...
     
    +void tighten (uint8_t x, uint8_t y, Bounds c)
     add the constraint \(x - y \le (c,s)\)
     
    +void close1 (uint8_t x)
     
    +void reset (uint8_t x)
     
    void release (uint8_t x)
     
    void elapse ()
     Assign the strongest post-condition of the delay. More...
     
    +void canonize ()
     make the zone canonical
     
    bool isSatisfiableWithoutCanonize () const
     check if the zone is satisfiable More...
     
    +bool isSatisfiable ()
     check if the zone is satisfiable
     
    +void abstractize ()
     truncate the constraints compared with a constant greater than or equal to M
     
    +void makeUnsat ()
     make the zone unsatisfiable
     
    +bool operator== (DBM z) const
     
    +void operator&= (const DBM &z)
     
    +bool operator> (const DBM &z) const
     
    +bool operator<= (const DBM &z) const
     
    void convexUnion (const DBM &z, DBM &dest) const
     Make the convex union of two DBMs. More...
     
    bool merge (const DBM &z)
     Try to merge the given DBM to this DBM. More...
     
    +bool isCanonized () const
     
    + + + + +

    +Static Public Member Functions

    +static DBM zero (int size)
     Make the zone of size size such that all the values are zero.
     
    + + + + + + + +

    +Public Attributes

    +Eigen::Matrix< Bounds, Eigen::Dynamic, Eigen::Dynamic > value
     The matrix representing the DBM.
     
    +Bounds M
     The threshold for the normalization.
     
    +

    Detailed Description

    +

    Implementation of a zone with DBM DBM For the detail of DBMs, see for example [BY03].

    +
    Todo:
    configure include directory for eigen
    +
    Note
    Internally, the variable 0 is used for the constant while externally, the actual clock variable is 0 origin, i.e., the variable 0 for the user is the variable 1 internally. So, we need increment or decrement to fill the gap.
    +

    Member Function Documentation

    + +

    ◆ convexUnion()

    + +
    +
    + + + + + +
    + + + + + + + + + + + + + + + + + + +
    void DBM::convexUnion (const DBMz,
    DBMdest 
    ) const
    +
    +inline
    +
    + +

    Make the convex union of two DBMs.

    +

    The convex union is the smallest DBM containing the given DBMs.

    +
    Parameters
    + + + +
    [in]zThe DBM to take the convex union
    [out]destThe DBM to write the resulting convex union
    +
    +
    +
    Precondition
    getNumOfVar() == z.getNumOfVar() == dest.getNumOfVar()
    + +
    +
    + +

    ◆ elapse()

    + +
    +
    + + + + + +
    + + + + + + + +
    void DBM::elapse ()
    +
    +inline
    +
    + +

    Assign the strongest post-condition of the delay.

    +
    Note
    We do not allow time elapse of duration zero
    + +
    +
    + +

    ◆ getNumOfVar()

    + +
    +
    + + + + + +
    + + + + + + + +
    std::size_t DBM::getNumOfVar () const
    +
    +inline
    +
    + +

    Returns the number of the variables represented by this zone.

    +
    Returns
    The number of the variables
    + +
    +
    + +

    ◆ isSatisfiableWithoutCanonize()

    + +
    +
    + + + + + +
    + + + + + + + +
    bool DBM::isSatisfiableWithoutCanonize () const
    +
    +inline
    +
    + +

    check if the zone is satisfiable

    +
    Precondition
    The zone is canonical
    + +
    +
    + +

    ◆ merge()

    + +
    +
    + + + + + +
    + + + + + + + + +
    bool DBM::merge (const DBMz)
    +
    +inline
    +
    + +

    Try to merge the given DBM to this DBM.

    +

    *this is updated to the convex union of *this and z if it is the union of them. This happens if and only if one of them includes the other or two zones are adjacent.

    +
    Parameters
    + + +
    [in]zThe DBM to merge
    +
    +
    +
    Return values
    + + + +
    truewhen the convex union is the union
    falsewhen the convex union is not the union
    +
    +
    + +
    +
    + +

    ◆ release()

    + +
    +
    + + + + + +
    + + + + + + + + +
    void DBM::release (uint8_t x)
    +
    +inline
    +
    +
    Note
    the result is not canonized
    + +
    +
    + +

    ◆ tightenWithoutClose()

    + +
    +
    + + + + + +
    + + + + + + + + + + + + + + + + + + + + + + + + +
    void DBM::tightenWithoutClose (uint8_t x,
    uint8_t y,
    Bounds c 
    )
    +
    +inline
    +
    + +

    add the constraint x - y <= (c,s) but does not close.

    +
    Note
    The result is not canonized
    + +
    +
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structDBM.js b/doxygen/structDBM.js new file mode 100644 index 0000000..a5557b5 --- /dev/null +++ b/doxygen/structDBM.js @@ -0,0 +1,27 @@ +var structDBM = +[ + [ "Tuple", "structDBM.html#a0a0a1684f6c3aa2ff93caf3d11b67a81", null ], + [ "abstractize", "structDBM.html#a9f69babfc8f06e5fc5f31c24ef807a96", null ], + [ "canonize", "structDBM.html#a13809878be1001a0b3fd9f26ca3e66af", null ], + [ "close1", "structDBM.html#a99b4227581002ea2cefe11a153e28454", null ], + [ "convexUnion", "structDBM.html#a067621af8e8fe77aa3dfc7de7982e56a", null ], + [ "cutVars", "structDBM.html#a9831ddf876db1f5b0ed6a53259c3b01e", null ], + [ "elapse", "structDBM.html#ab595495aa58a1110043ad97e024cb024", null ], + [ "getNumOfVar", "structDBM.html#a3d1ef4d38ea09e0e91f2f3b6d8da0dfe", null ], + [ "isCanonized", "structDBM.html#aa473a4de9b2a14e97f92d4560dca5396", null ], + [ "isSatisfiable", "structDBM.html#a773e3a1a233918f2eddbca7d4e1f069c", null ], + [ "isSatisfiableWithoutCanonize", "structDBM.html#a0a75308b3e3638c184afd80099b1de8c", null ], + [ "makeUnsat", "structDBM.html#ac2d18f66df21dac086500b2fb1f17716", null ], + [ "merge", "structDBM.html#a88e6232f8826db65ccdbb2ce59794f23", null ], + [ "operator&=", "structDBM.html#a218dcd3d216987d9da76e5a960e2c86e", null ], + [ "operator<=", "structDBM.html#ae388dc5373df629f6a7c3aad6677cca2", null ], + [ "operator==", "structDBM.html#a4b74dcac92d62da6b543c7238d525976", null ], + [ "operator>", "structDBM.html#a8306b185e104232e69e435c6ed2e3495", null ], + [ "release", "structDBM.html#a40935a242833cd89860c6f36d6d4fcb2", null ], + [ "reset", "structDBM.html#aaeacedda089c9cc0b7d952b5f9b43291", null ], + [ "tighten", "structDBM.html#a8745732472b31b4209b6f963d652bf83", null ], + [ "tightenWithoutClose", "structDBM.html#a57ce698079c0feba068e58bc3831ce8e", null ], + [ "toTuple", "structDBM.html#a353253430782322649e75f4eb53123e8", null ], + [ "M", "structDBM.html#ab15873102fc666864ab26d6da0d1f3f5", null ], + [ "value", "structDBM.html#ae4e32630518e832b45e762c7cca44f2f", null ] +]; \ No newline at end of file diff --git a/doxygen/structResetVars-members.html b/doxygen/structResetVars-members.html new file mode 100644 index 0000000..8d17c38 --- /dev/null +++ b/doxygen/structResetVars-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ResetVars< ClockVariables > Member List
    +
    +
    + +

    This is the complete list of members for ResetVars< ClockVariables >, including all inherited members.

    + + +
    resetVars (defined in ResetVars< ClockVariables >)ResetVars< ClockVariables >
    +
    + + + + diff --git a/doxygen/structResetVars.html b/doxygen/structResetVars.html new file mode 100644 index 0000000..6c2f1b9 --- /dev/null +++ b/doxygen/structResetVars.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ResetVars< ClockVariables > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ResetVars< ClockVariables > Struct Template Reference
    +
    +
    + + + + +

    +Public Attributes

    +std::vector< ClockVariables > resetVars
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structResetVars.js b/doxygen/structResetVars.js new file mode 100644 index 0000000..bae3b44 --- /dev/null +++ b/doxygen/structResetVars.js @@ -0,0 +1,4 @@ +var structResetVars = +[ + [ "resetVars", "structResetVars.html#a887a7d07b7991fa705444dba15fbb586", null ] +]; \ No newline at end of file diff --git a/doxygen/structZoneGraphLabelWriter-members.html b/doxygen/structZoneGraphLabelWriter-members.html new file mode 100644 index 0000000..737bb83 --- /dev/null +++ b/doxygen/structZoneGraphLabelWriter-members.html @@ -0,0 +1,110 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight > Member List
    +
    +
    + +

    This is the complete list of members for ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight >, including all inherited members.

    + + + +
    operator()(std::ostream &out, const Vertex &vertex) const (defined in ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight >)ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight >inline
    ZoneGraphLabelWriter(const ZoneGraph &ZG, const TimedAutomaton &TA, const std::unordered_map< typename ZoneGraph::vertex_descriptor, Weight > &distance) (defined in ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight >)ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight >inline
    +
    + + + + diff --git a/doxygen/structZoneGraphLabelWriter.html b/doxygen/structZoneGraphLabelWriter.html new file mode 100644 index 0000000..6f90f11 --- /dev/null +++ b/doxygen/structZoneGraphLabelWriter.html @@ -0,0 +1,123 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ZoneGraphLabelWriter< ZoneGraph, TimedAutomaton, Weight > Struct Template Reference
    +
    +
    + + + + + + + +

    +Public Member Functions

    ZoneGraphLabelWriter (const ZoneGraph &ZG, const TimedAutomaton &TA, const std::unordered_map< typename ZoneGraph::vertex_descriptor, Weight > &distance)
     
    +template<class Vertex >
    void operator() (std::ostream &out, const Vertex &vertex) const
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structZoneGraphLabelWriter.js b/doxygen/structZoneGraphLabelWriter.js new file mode 100644 index 0000000..6d831d7 --- /dev/null +++ b/doxygen/structZoneGraphLabelWriter.js @@ -0,0 +1,5 @@ +var structZoneGraphLabelWriter = +[ + [ "ZoneGraphLabelWriter", "structZoneGraphLabelWriter.html#aa26b6c4fd8ed3e330dce89c97981a263", null ], + [ "operator()", "structZoneGraphLabelWriter.html#afa9010e4ccce8205d41d49b32c96eb8c", null ] +]; \ No newline at end of file diff --git a/doxygen/structans__trait.html b/doxygen/structans__trait.html new file mode 100644 index 0000000..e71cbc2 --- /dev/null +++ b/doxygen/structans__trait.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ans_trait< T > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ans_trait< T > Struct Template Reference
    +
    +
    +
    The documentation for this struct was generated from the following file:
      +
    • test/bellman_ford_test.cc
    • +
    +
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4-members.html b/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4-members.html new file mode 100644 index 0000000..18c3732 --- /dev/null +++ b/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ans_trait< MaxMinSemiring< double > > Member List
    +
    +
    + +

    This is the complete list of members for ans_trait< MaxMinSemiring< double > >, including all inherited members.

    + + +
    ans (defined in ans_trait< MaxMinSemiring< double > >)ans_trait< MaxMinSemiring< double > >static
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html b/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html new file mode 100644 index 0000000..df59925 --- /dev/null +++ b/doxygen/structans__trait_3_01MaxMinSemiring_3_01double_01_4_01_4.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ans_trait< MaxMinSemiring< double > > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ans_trait< MaxMinSemiring< double > > Struct Reference
    +
    +
    + + + + +

    +Static Public Attributes

    +constexpr static const double ans = 3.0
     
    +
    The documentation for this struct was generated from the following file:
      +
    • test/warshall_froid_test.cc
    • +
    +
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4-members.html b/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4-members.html new file mode 100644 index 0000000..a1644d4 --- /dev/null +++ b/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ans_trait< MaxMinSemiring< int > > Member List
    +
    +
    + +

    This is the complete list of members for ans_trait< MaxMinSemiring< int > >, including all inherited members.

    + + +
    ans (defined in ans_trait< MaxMinSemiring< int > >)ans_trait< MaxMinSemiring< int > >static
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html b/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html new file mode 100644 index 0000000..1e72714 --- /dev/null +++ b/doxygen/structans__trait_3_01MaxMinSemiring_3_01int_01_4_01_4.html @@ -0,0 +1,120 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ans_trait< MaxMinSemiring< int > > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ans_trait< MaxMinSemiring< int > > Struct Reference
    +
    +
    + + + + +

    +Static Public Attributes

    +static const int ans = 3
     
    +
    The documentation for this struct was generated from the following files:
      +
    • test/bellman_ford_test.cc
    • +
    • test/robustness_test.cc
    • +
    +
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4-members.html b/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4-members.html new file mode 100644 index 0000000..74333ac --- /dev/null +++ b/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4-members.html @@ -0,0 +1,110 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ans_trait< MinPlusSemiring< double > > Member List
    +
    +
    + +

    This is the complete list of members for ans_trait< MinPlusSemiring< double > >, including all inherited members.

    + + + +
    ans (defined in ans_trait< MinPlusSemiring< double > >)ans_trait< MinPlusSemiring< double > >static
    ans (defined in ans_trait< MinPlusSemiring< double > >)ans_trait< MinPlusSemiring< double > >static
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html b/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html new file mode 100644 index 0000000..6f598e2 --- /dev/null +++ b/doxygen/structans__trait_3_01MinPlusSemiring_3_01double_01_4_01_4.html @@ -0,0 +1,123 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ans_trait< MinPlusSemiring< double > > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ans_trait< MinPlusSemiring< double > > Struct Reference
    +
    +
    + + + + + + +

    +Static Public Attributes

    +static const int ans = 2
     
    +constexpr static const double ans = 2.0
     
    +
    The documentation for this struct was generated from the following files:
      +
    • test/bellman_ford_test.cc
    • +
    • test/warshall_froid_test.cc
    • +
    +
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4-members.html b/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4-members.html new file mode 100644 index 0000000..7a883a3 --- /dev/null +++ b/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    ans_trait< MinPlusSemiring< int > > Member List
    +
    +
    + +

    This is the complete list of members for ans_trait< MinPlusSemiring< int > >, including all inherited members.

    + + +
    ans (defined in ans_trait< MinPlusSemiring< int > >)ans_trait< MinPlusSemiring< int > >static
    +
    + + + + diff --git a/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html b/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html new file mode 100644 index 0000000..f13fce2 --- /dev/null +++ b/doxygen/structans__trait_3_01MinPlusSemiring_3_01int_01_4_01_4.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: ans_trait< MinPlusSemiring< int > > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    ans_trait< MinPlusSemiring< int > > Struct Reference
    +
    +
    + + + + +

    +Static Public Attributes

    +static const int ans = 40
     
    +
    The documentation for this struct was generated from the following file:
      +
    • test/robustness_test.cc
    • +
    +
    +
    + + + + diff --git a/doxygen/structnum__type__trait-members.html b/doxygen/structnum__type__trait-members.html new file mode 100644 index 0000000..4397b8f --- /dev/null +++ b/doxygen/structnum__type__trait-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    num_type_trait< U > Member List
    +
    +
    + +

    This is the complete list of members for num_type_trait< U >, including all inherited members.

    + + +
    num_type typedef (defined in num_type_trait< U >)num_type_trait< U >
    +
    + + + + diff --git a/doxygen/structnum__type__trait.html b/doxygen/structnum__type__trait.html new file mode 100644 index 0000000..d51a3c5 --- /dev/null +++ b/doxygen/structnum__type__trait.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: num_type_trait< U > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    num_type_trait< U > Struct Template Reference
    +
    +
    + + + + +

    +Public Types

    +using num_type = U
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structnum__type__trait.js b/doxygen/structnum__type__trait.js new file mode 100644 index 0000000..a8e1a5a --- /dev/null +++ b/doxygen/structnum__type__trait.js @@ -0,0 +1,4 @@ +var structnum__type__trait = +[ + [ "num_type", "structnum__type__trait.html#a00eeb7e6f6bdb757ff6de192c0a4f769", null ] +]; \ No newline at end of file diff --git a/doxygen/structnum__type__trait_3_01signed_01char_01_4-members.html b/doxygen/structnum__type__trait_3_01signed_01char_01_4-members.html new file mode 100644 index 0000000..fa0e924 --- /dev/null +++ b/doxygen/structnum__type__trait_3_01signed_01char_01_4-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    num_type_trait< signed char > Member List
    +
    +
    + +

    This is the complete list of members for num_type_trait< signed char >, including all inherited members.

    + + +
    num_type typedef (defined in num_type_trait< signed char >)num_type_trait< signed char >
    +
    + + + + diff --git a/doxygen/structnum__type__trait_3_01signed_01char_01_4.html b/doxygen/structnum__type__trait_3_01signed_01char_01_4.html new file mode 100644 index 0000000..1b818e6 --- /dev/null +++ b/doxygen/structnum__type__trait_3_01signed_01char_01_4.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: num_type_trait< signed char > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    num_type_trait< signed char > Struct Reference
    +
    +
    + + + + +

    +Public Types

    +using num_type = signed int
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structnum__type__trait_3_01signed_01char_01_4.js b/doxygen/structnum__type__trait_3_01signed_01char_01_4.js new file mode 100644 index 0000000..7989cd8 --- /dev/null +++ b/doxygen/structnum__type__trait_3_01signed_01char_01_4.js @@ -0,0 +1,4 @@ +var structnum__type__trait_3_01signed_01char_01_4 = +[ + [ "num_type", "structnum__type__trait_3_01signed_01char_01_4.html#a656ca0e799e4186799a6b8631cfd795d", null ] +]; \ No newline at end of file diff --git a/doxygen/structnum__type__trait_3_01unsigned_01char_01_4-members.html b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4-members.html new file mode 100644 index 0000000..2a149a4 --- /dev/null +++ b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4-members.html @@ -0,0 +1,109 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    num_type_trait< unsigned char > Member List
    +
    +
    + +

    This is the complete list of members for num_type_trait< unsigned char >, including all inherited members.

    + + +
    num_type typedef (defined in num_type_trait< unsigned char >)num_type_trait< unsigned char >
    +
    + + + + diff --git a/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.html b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.html new file mode 100644 index 0000000..4241d7f --- /dev/null +++ b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.html @@ -0,0 +1,119 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: num_type_trait< unsigned char > Struct Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    num_type_trait< unsigned char > Struct Reference
    +
    +
    + + + + +

    +Public Types

    +using num_type = unsigned int
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.js b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.js new file mode 100644 index 0000000..9a298e8 --- /dev/null +++ b/doxygen/structnum__type__trait_3_01unsigned_01char_01_4.js @@ -0,0 +1,4 @@ +var structnum__type__trait_3_01unsigned_01char_01_4 = +[ + [ "num_type", "structnum__type__trait_3_01unsigned_01char_01_4.html#a4ff6cf7bb333a48b78c48f94f4830901", null ] +]; \ No newline at end of file diff --git a/doxygen/structweight__label__writer-members.html b/doxygen/structweight__label__writer-members.html new file mode 100644 index 0000000..ca9cb02 --- /dev/null +++ b/doxygen/structweight__label__writer-members.html @@ -0,0 +1,110 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Member List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    weight_label_writer< Graph > Member List
    +
    +
    + +

    This is the complete list of members for weight_label_writer< Graph >, including all inherited members.

    + + + +
    operator()(std::ostream &out, const Edge &edge) const (defined in weight_label_writer< Graph >)weight_label_writer< Graph >inline
    weight_label_writer(const Graph &g) (defined in weight_label_writer< Graph >)weight_label_writer< Graph >inline
    +
    + + + + diff --git a/doxygen/structweight__label__writer.html b/doxygen/structweight__label__writer.html new file mode 100644 index 0000000..fcdf101 --- /dev/null +++ b/doxygen/structweight__label__writer.html @@ -0,0 +1,123 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: weight_label_writer< Graph > Struct Template Reference + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    + +
    +
    weight_label_writer< Graph > Struct Template Reference
    +
    +
    + + + + + + + +

    +Public Member Functions

    weight_label_writer (const Graph &g)
     
    +template<class Edge >
    void operator() (std::ostream &out, const Edge &edge) const
     
    +
    The documentation for this struct was generated from the following file: +
    +
    + + + + diff --git a/doxygen/structweight__label__writer.js b/doxygen/structweight__label__writer.js new file mode 100644 index 0000000..994a0d6 --- /dev/null +++ b/doxygen/structweight__label__writer.js @@ -0,0 +1,5 @@ +var structweight__label__writer = +[ + [ "weight_label_writer", "structweight__label__writer.html#a93de116bb1d1fa963afd9549edc54476", null ], + [ "operator()", "structweight__label__writer.html#a895b83fda0e800413d03d0db3f396a86", null ] +]; \ No newline at end of file diff --git a/doxygen/sync_off.png b/doxygen/sync_off.png new file mode 100644 index 0000000..3b443fc Binary files /dev/null and b/doxygen/sync_off.png differ diff --git a/doxygen/sync_on.png b/doxygen/sync_on.png new file mode 100644 index 0000000..e08320f Binary files /dev/null and b/doxygen/sync_on.png differ diff --git a/doxygen/tab_a.png b/doxygen/tab_a.png new file mode 100644 index 0000000..3b725c4 Binary files /dev/null and b/doxygen/tab_a.png differ diff --git a/doxygen/tab_b.png b/doxygen/tab_b.png new file mode 100644 index 0000000..e2b4a86 Binary files /dev/null and b/doxygen/tab_b.png differ diff --git a/doxygen/tab_h.png b/doxygen/tab_h.png new file mode 100644 index 0000000..fd5cb70 Binary files /dev/null and b/doxygen/tab_h.png differ diff --git a/doxygen/tab_s.png b/doxygen/tab_s.png new file mode 100644 index 0000000..ab478c9 Binary files /dev/null and b/doxygen/tab_s.png differ diff --git a/doxygen/tabs.css b/doxygen/tabs.css new file mode 100644 index 0000000..7d45d36 --- /dev/null +++ b/doxygen/tabs.css @@ -0,0 +1 @@ +.sm{position:relative;z-index:9999}.sm,.sm ul,.sm li{display:block;list-style:none;margin:0;padding:0;line-height:normal;direction:ltr;text-align:left;-webkit-tap-highlight-color:rgba(0,0,0,0)}.sm-rtl,.sm-rtl ul,.sm-rtl li{direction:rtl;text-align:right}.sm>li>h1,.sm>li>h2,.sm>li>h3,.sm>li>h4,.sm>li>h5,.sm>li>h6{margin:0;padding:0}.sm ul{display:none}.sm li,.sm a{position:relative}.sm a{display:block}.sm a.disabled{cursor:not-allowed}.sm:after{content:"\00a0";display:block;height:0;font:0px/0 serif;clear:both;visibility:hidden;overflow:hidden}.sm,.sm *,.sm *:before,.sm *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.sm-dox{background-image:url("tab_b.png")}.sm-dox a,.sm-dox a:focus,.sm-dox a:hover,.sm-dox a:active{padding:0px 12px;padding-right:43px;font-family:"Lucida Grande","Geneva","Helvetica",Arial,sans-serif;font-size:13px;font-weight:bold;line-height:36px;text-decoration:none;text-shadow:0px 1px 1px rgba(255,255,255,0.9);color:#283A5D;outline:none}.sm-dox a:hover{background-image:url("tab_a.png");background-repeat:repeat-x;color:#fff;text-shadow:0px 1px 1px #000}.sm-dox a.current{color:#D23600}.sm-dox a.disabled{color:#bbb}.sm-dox a span.sub-arrow{position:absolute;top:50%;margin-top:-14px;left:auto;right:3px;width:28px;height:28px;overflow:hidden;font:bold 12px/28px monospace !important;text-align:center;text-shadow:none;background:rgba(255,255,255,0.5);border-radius:5px}.sm-dox a.highlighted span.sub-arrow:before{display:block;content:'-'}.sm-dox>li:first-child>a,.sm-dox>li:first-child>:not(ul) a{border-radius:5px 5px 0 0}.sm-dox>li:last-child>a,.sm-dox>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul{border-radius:0 0 5px 5px}.sm-dox>li:last-child>a.highlighted,.sm-dox>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted{border-radius:0}.sm-dox ul{background:rgba(162,162,162,0.1)}.sm-dox ul a,.sm-dox ul a:focus,.sm-dox ul a:hover,.sm-dox ul a:active{font-size:12px;border-left:8px solid transparent;line-height:36px;text-shadow:none;background-color:white;background-image:none}.sm-dox ul a:hover{background-image:url("tab_a.png");background-repeat:repeat-x;color:#fff;text-shadow:0px 1px 1px #000}.sm-dox ul ul a,.sm-dox ul ul a:hover,.sm-dox ul ul a:focus,.sm-dox ul ul a:active{border-left:16px solid transparent}.sm-dox ul ul ul a,.sm-dox ul ul ul a:hover,.sm-dox ul ul ul a:focus,.sm-dox ul ul ul a:active{border-left:24px solid transparent}.sm-dox ul ul ul ul a,.sm-dox ul ul ul ul a:hover,.sm-dox ul ul ul ul a:focus,.sm-dox ul ul ul ul a:active{border-left:32px solid transparent}.sm-dox ul ul ul ul ul a,.sm-dox ul ul ul ul ul a:hover,.sm-dox ul ul ul ul ul a:focus,.sm-dox ul ul ul ul ul a:active{border-left:40px solid transparent}@media (min-width: 768px){.sm-dox ul{position:absolute;width:12em}.sm-dox li{float:left}.sm-dox.sm-rtl li{float:right}.sm-dox ul li,.sm-dox.sm-rtl ul li,.sm-dox.sm-vertical li{float:none}.sm-dox a{white-space:nowrap}.sm-dox ul a,.sm-dox.sm-vertical a{white-space:normal}.sm-dox .sm-nowrap>li>a,.sm-dox .sm-nowrap>li>:not(ul) a{white-space:nowrap}.sm-dox{padding:0 10px;background-image:url("tab_b.png");line-height:36px}.sm-dox a span.sub-arrow{top:50%;margin-top:-2px;right:12px;width:0;height:0;border-width:4px;border-style:solid dashed dashed dashed;border-color:#283A5D transparent transparent transparent;background:transparent;border-radius:0}.sm-dox a,.sm-dox a:focus,.sm-dox a:active,.sm-dox a:hover,.sm-dox a.highlighted{padding:0px 12px;background-image:url("tab_s.png");background-repeat:no-repeat;background-position:right;border-radius:0 !important}.sm-dox a:hover{background-image:url("tab_a.png");background-repeat:repeat-x;color:#fff;text-shadow:0px 1px 1px #000}.sm-dox a:hover span.sub-arrow{border-color:#fff transparent transparent transparent}.sm-dox a.has-submenu{padding-right:24px}.sm-dox li{border-top:0}.sm-dox>li>ul:before,.sm-dox>li>ul:after{content:'';position:absolute;top:-18px;left:30px;width:0;height:0;overflow:hidden;border-width:9px;border-style:dashed dashed solid dashed;border-color:transparent transparent #bbb transparent}.sm-dox>li>ul:after{top:-16px;left:31px;border-width:8px;border-color:transparent transparent #fff transparent}.sm-dox ul{border:1px solid #bbb;padding:5px 0;background:#fff;border-radius:5px !important;box-shadow:0 5px 9px rgba(0,0,0,0.2)}.sm-dox ul a span.sub-arrow{right:8px;top:50%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent #555;border-style:dashed dashed dashed solid}.sm-dox ul a,.sm-dox ul a:hover,.sm-dox ul a:focus,.sm-dox ul a:active,.sm-dox ul a.highlighted{color:#555;background-image:none;border:0 !important;color:#555;background-image:none}.sm-dox ul a:hover{background-image:url("tab_a.png");background-repeat:repeat-x;color:#fff;text-shadow:0px 1px 1px #000}.sm-dox ul a:hover span.sub-arrow{border-color:transparent transparent transparent #fff}.sm-dox span.scroll-up,.sm-dox span.scroll-down{position:absolute;display:none;visibility:hidden;overflow:hidden;background:#fff;height:36px}.sm-dox span.scroll-up:hover,.sm-dox span.scroll-down:hover{background:#eee}.sm-dox span.scroll-up:hover span.scroll-up-arrow,.sm-dox span.scroll-up:hover span.scroll-down-arrow{border-color:transparent transparent #D23600 transparent}.sm-dox span.scroll-down:hover span.scroll-down-arrow{border-color:#D23600 transparent transparent transparent}.sm-dox span.scroll-up-arrow,.sm-dox span.scroll-down-arrow{position:absolute;top:0;left:50%;margin-left:-6px;width:0;height:0;overflow:hidden;border-width:6px;border-style:dashed dashed solid dashed;border-color:transparent transparent #555 transparent}.sm-dox span.scroll-down-arrow{top:8px;border-style:solid dashed dashed dashed;border-color:#555 transparent transparent transparent}.sm-dox.sm-rtl a.has-submenu{padding-right:12px;padding-left:24px}.sm-dox.sm-rtl a span.sub-arrow{right:auto;left:12px}.sm-dox.sm-rtl.sm-vertical a.has-submenu{padding:10px 20px}.sm-dox.sm-rtl.sm-vertical a span.sub-arrow{right:auto;left:8px;border-style:dashed solid dashed dashed;border-color:transparent #555 transparent transparent}.sm-dox.sm-rtl>li>ul:before{left:auto;right:30px}.sm-dox.sm-rtl>li>ul:after{left:auto;right:31px}.sm-dox.sm-rtl ul a.has-submenu{padding:10px 20px !important}.sm-dox.sm-rtl ul a span.sub-arrow{right:auto;left:8px;border-style:dashed solid dashed dashed;border-color:transparent #555 transparent transparent}.sm-dox.sm-vertical{padding:10px 0;border-radius:5px}.sm-dox.sm-vertical a{padding:10px 20px}.sm-dox.sm-vertical a:hover,.sm-dox.sm-vertical a:focus,.sm-dox.sm-vertical a:active,.sm-dox.sm-vertical a.highlighted{background:#fff}.sm-dox.sm-vertical a.disabled{background-image:url("tab_b.png")}.sm-dox.sm-vertical a span.sub-arrow{right:8px;top:50%;margin-top:-5px;border-width:5px;border-style:dashed dashed dashed solid;border-color:transparent transparent transparent #555}.sm-dox.sm-vertical>li>ul:before,.sm-dox.sm-vertical>li>ul:after{display:none}.sm-dox.sm-vertical ul a{padding:10px 20px}.sm-dox.sm-vertical ul a:hover,.sm-dox.sm-vertical ul a:focus,.sm-dox.sm-vertical ul a:active,.sm-dox.sm-vertical ul a.highlighted{background:#eee}.sm-dox.sm-vertical ul a.disabled{background:#fff}} diff --git a/doxygen/timed__automaton_8hh_source.html b/doxygen/timed__automaton_8hh_source.html new file mode 100644 index 0000000..e317a11 --- /dev/null +++ b/doxygen/timed__automaton_8hh_source.html @@ -0,0 +1,410 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/timed_automaton.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    timed_automaton.hh
    +
    +
    +
    1 #pragma once
    +
    2 
    +
    3 #include <boost/graph/adjacency_list.hpp>
    +
    4 #include <boost/graph/graphviz.hpp>
    +
    5 #include <boost/optional.hpp>
    +
    6 #include <fstream>
    +
    7 #include <iostream>
    +
    8 #include <type_traits>
    +
    9 
    +
    10 #include "constraint.hh"
    +
    11 
    +
    12 template<class U>
    + +
    14  using num_type = U;
    +
    15 };
    +
    16 
    +
    17 template<>
    +
    18 struct num_type_trait<signed char> {
    +
    19  using num_type = signed int;
    +
    20 };
    +
    21 
    +
    22 template<>
    +
    23 struct num_type_trait<unsigned char> {
    +
    24  using num_type = unsigned int;
    +
    25 };
    +
    26 
    +
    27 namespace boost{
    +
    28  enum vertex_match_t {vertex_match};
    +
    29  enum edge_reset_t {edge_reset};
    +
    30  enum edge_guard_t {edge_guard};
    +
    31  enum graph_init_states_t {graph_init_states};
    +
    32  enum graph_num_of_vars_t {graph_num_of_vars};
    +
    33  enum graph_max_constraints_t {graph_max_constraints};
    +
    34 
    +
    35  BOOST_INSTALL_PROPERTY(vertex, match);
    +
    36  BOOST_INSTALL_PROPERTY(edge, reset);
    +
    37  BOOST_INSTALL_PROPERTY(edge, guard);
    +
    38  BOOST_INSTALL_PROPERTY(graph, init_states);
    +
    39  BOOST_INSTALL_PROPERTY(graph, num_of_vars);
    +
    40  BOOST_INSTALL_PROPERTY(graph, max_constraints);
    +
    41 }
    +
    42 
    +
    43 template<class ClockVariables>
    +
    44 static inline auto print(std::ostream& os, const typename Constraint<ClockVariables>::Order& odr)
    +
    45  -> typename std::conditional<true, std::ostream&, decltype(odr)>::type {
    +
    46  switch (odr) {
    + +
    48  os << "<";
    +
    49  break;
    + +
    51  os << "<=";
    +
    52  break;
    + +
    54  os << ">=";
    +
    55  break;
    + +
    57  os << ">";
    +
    58  break;
    +
    59  }
    +
    60  return os;
    +
    61 }
    +
    62 
    +
    63 template<class ClockVariables>
    +
    64 static inline auto operator<<(std::ostream& os, const Constraint<ClockVariables>& p)
    +
    65  -> typename std::conditional<true, std::ostream&, decltype(p)>::type
    +
    66 {
    +
    67  print<ClockVariables>(os << "x" << int(p.x) << " ", p.odr) << " " << p.c;
    +
    68  return os;
    +
    69 }
    +
    70 
    +
    71 template<class T>
    +
    72 static inline
    +
    73 auto operator<<(std::ostream& os, const std::vector<T>& guard)
    +
    74  -> typename std::conditional<true, std::ostream&, decltype(*guard.begin())>::type
    +
    75 {
    +
    76  bool first = true;
    +
    77  os << "{";
    +
    78  for (const auto &g: guard) {
    +
    79  if (!first) {
    +
    80  os << ", ";
    +
    81  }
    +
    82  first = false;
    +
    83  os << static_cast<typename num_type_trait<T>::num_type>(g);
    +
    84  }
    +
    85  os << "}";
    +
    86  return os;
    +
    87 }
    +
    88 
    +
    89 template<class ClockVariables>
    +
    90 static inline std::istream& operator>>(std::istream& is, Constraint<ClockVariables>& p)
    +
    91 {
    +
    92  if (is.get() != 'x') {
    +
    93  is.setstate(std::ios_base::failbit);
    +
    94  return is;
    +
    95  }
    +
    96  int x;
    +
    97  is >> x;
    +
    98  p.x = x;
    +
    99  if (!is) {
    +
    100  is.setstate(std::ios_base::failbit);
    +
    101  return is;
    +
    102  }
    +
    103 
    +
    104  if (is.get() != ' ') {
    +
    105  is.setstate(std::ios_base::failbit);
    +
    106  return is;
    +
    107  }
    +
    108 
    +
    109  char odr[2];
    +
    110  is >> odr[0] >> odr[1];
    +
    111 
    +
    112  switch (odr[0]) {
    +
    113  case '>':
    +
    114  if (odr[1] == '=') {
    + +
    116  if (is.get() != ' ') {
    +
    117  is.setstate(std::ios_base::failbit);
    +
    118  return is;
    +
    119  }
    +
    120  } else if (odr[1] == ' ') {
    + +
    122  } else {
    +
    123  is.setstate(std::ios_base::failbit);
    +
    124  return is;
    +
    125  }
    +
    126  break;
    +
    127  case '<':
    +
    128  if (odr[1] == '=') {
    + +
    130  if (is.get() != ' ') {
    +
    131  is.setstate(std::ios_base::failbit);
    +
    132  return is;
    +
    133  }
    +
    134  } else if (odr[1] == ' ') {
    + +
    136  } else {
    +
    137  is.setstate(std::ios_base::failbit);
    +
    138  return is;
    +
    139  }
    +
    140  break;
    +
    141  default:
    +
    142  is.setstate(std::ios_base::failbit);
    +
    143  return is;
    +
    144  }
    +
    145 
    +
    146  is >> p.c;
    +
    147  return is;
    +
    148 }
    +
    149 
    +
    150 template <class T>
    +
    151 static inline
    +
    152 std::istream& operator>>(std::istream& is, std::vector<T>& resetVars)
    +
    153 {
    +
    154 
    +
    155  resetVars.clear();
    +
    156  if (!is) {
    +
    157  is.setstate(std::ios_base::failbit);
    +
    158  return is;
    +
    159  }
    +
    160 
    +
    161  if (is.get() != '{') {
    +
    162  is.setstate(std::ios_base::failbit);
    +
    163  return is;
    +
    164  }
    +
    165 
    +
    166  if (!is) {
    +
    167  is.setstate(std::ios_base::failbit);
    +
    168  return is;
    +
    169  }
    +
    170 
    +
    171  while (true) {
    +
    172  typename num_type_trait<T>::num_type x;
    +
    173  is >> x;
    +
    174  resetVars.emplace_back(std::move(x));
    +
    175  if (!is) {
    +
    176  is.setstate(std::ios_base::failbit);
    +
    177  return is;
    +
    178  }
    +
    179  char c;
    +
    180  is >> c;
    +
    181  if (c == '}') {
    +
    182  break;
    +
    183  } else if (c == ',') {
    +
    184  is >> c;
    +
    185  if (c != ' ') {
    +
    186  is.setstate(std::ios_base::failbit);
    +
    187  return is;
    +
    188  }
    +
    189  } else {
    +
    190  is.setstate(std::ios_base::failbit);
    +
    191  return is;
    +
    192  }
    +
    193  }
    +
    194 
    +
    195  return is;
    +
    196 }
    +
    197 
    +
    198 namespace boost {
    +
    199  template <class T>
    +
    200  static inline
    +
    201  std::ostream& operator<<(std::ostream& os, const boost::optional<T>& x)
    +
    202  {
    +
    203  if (x) {
    +
    204  os << x.get();
    +
    205  }
    +
    206  else {
    +
    207  os << "";
    +
    208  }
    +
    209  return os;
    +
    210  }
    +
    211 
    +
    212  template <class T>
    +
    213  static inline
    +
    214  std::istream& operator>>(std::istream& is, boost::optional<T>& x)
    +
    215  {
    +
    216  T result;
    +
    217  if (is >> result) {
    +
    218  x = result;
    +
    219  }
    +
    220  return is;
    +
    221  }
    +
    222 }
    +
    223 
    +
    224 template<class ClockVariables>
    +
    225 struct ResetVars {
    +
    226  std::vector<ClockVariables> resetVars;
    +
    227 };
    +
    228 
    +
    229 template<class ClockVariables>
    +
    230 static inline
    +
    231 std::istream& operator>>(std::istream& is, ResetVars<ClockVariables>& resetVars)
    +
    232 {
    +
    233  is >> resetVars.resetVars;
    +
    234  return is;
    +
    235 }
    +
    236 
    +
    237 template<class ClockVariables>
    +
    238 static inline
    +
    239 std::ostream& operator<<(std::ostream& os, const ResetVars<ClockVariables>& resetVars)
    +
    240 {
    +
    241  os << resetVars.resetVars;
    +
    242  return os;
    +
    243 }
    +
    244 
    +
    245 template<class SignalVariables>
    +
    246 struct BoostTAState {
    +
    247  bool isInit;
    +
    248  bool isMatch;
    +
    249  std::vector<Constraint<SignalVariables>> label;
    +
    250 };
    +
    251 
    +
    252 template<class ClockVariables>
    + + +
    256  std::vector<Constraint<ClockVariables>> guard;
    +
    257 };
    +
    258 
    +
    259 template<class SignalVariables, class ClockVariables>
    +
    260 using BoostTimedAutomaton = boost::adjacency_list<boost::listS, boost::vecS, boost::directedS, BoostTAState<SignalVariables>, BoostTATransition<ClockVariables>,
    +
    261  boost::property<boost::graph_num_of_vars_t, std::size_t,
    +
    262  boost::property<boost::graph_max_constraints_t, std::size_t>>>;
    +
    263 
    +
    264 template<class SignalVariables, class ClockVariables>
    +
    265 static inline
    +
    266 void parseBoostTA(std::istream &file, BoostTimedAutomaton<SignalVariables, ClockVariables> &BoostTA,
    +
    267  std::vector<typename BoostTimedAutomaton<SignalVariables, ClockVariables>::vertex_descriptor> &initStates)
    +
    268 {
    +
    269 
    +
    270  boost::dynamic_properties dp(boost::ignore_other_properties);
    +
    271  dp.property("match", boost::get(&BoostTAState<SignalVariables>::isMatch, BoostTA));
    +
    272  dp.property("init", boost::get(&BoostTAState<SignalVariables>::isInit, BoostTA));
    +
    273  dp.property("label", boost::get(&BoostTAState<SignalVariables>::label, BoostTA));
    +
    274  dp.property("reset", boost::get(&BoostTATransition<ClockVariables>::resetVars, BoostTA));
    +
    275  dp.property("guard", boost::get(&BoostTATransition<ClockVariables>::guard, BoostTA));
    +
    276 
    +
    277  boost::read_graphviz(file, BoostTA, dp, "id");
    +
    278 
    +
    279  auto isMatchMap = boost::get(&BoostTAState<SignalVariables>::isInit, BoostTA);
    +
    280  for (auto range = boost::vertices(BoostTA); range.first != range.second; range.first++) {
    +
    281  auto q = *range.first;
    +
    282  if (isMatchMap[q]) {
    +
    283  initStates.push_back(q);
    +
    284  }
    +
    285  }
    +
    286 
    +
    287  std::size_t num_of_vars = 0;
    +
    288  std::size_t max_constraints = 0;
    +
    289  for (auto range = boost::edges(BoostTA); range.first != range.second; range.first++) {
    +
    290  auto guard = BoostTA[*range.first].guard;
    +
    291  for (auto g: guard) {
    +
    292  num_of_vars = std::max<std::size_t>(num_of_vars, g.x + 1);
    +
    293  max_constraints = std::max<std::size_t>(max_constraints, g.c);
    +
    294  }
    +
    295  }
    +
    296 
    +
    297  boost::set_property(BoostTA, boost::graph_max_constraints, max_constraints);
    +
    298  boost::set_property(BoostTA, boost::graph_num_of_vars, num_of_vars);
    +
    299 }
    +
    Definition: timed_automaton.hh:246
    +
    Definition: timed_automaton.hh:253
    +
    ResetVars< ClockVariables > resetVars
    Definition: timed_automaton.hh:255
    +
    A constraint in a guard of transitions.
    Definition: constraint.hh:18
    +
    Definition: timed_automaton.hh:225
    +
    Definition: timed_automaton.hh:13
    +
    +
    + + + + diff --git a/doxygen/todo.html b/doxygen/todo.html new file mode 100644 index 0000000..f1f8937 --- /dev/null +++ b/doxygen/todo.html @@ -0,0 +1,110 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: Todo List + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    Todo List
    +
    +
    +
    +
    Class DBM
    +
    configure include directory for eigen
    +
    +
    +
    +
    + + + + diff --git a/doxygen/warshall__froid_8hh_source.html b/doxygen/warshall__froid_8hh_source.html new file mode 100644 index 0000000..7f3d47d --- /dev/null +++ b/doxygen/warshall__froid_8hh_source.html @@ -0,0 +1,158 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/warshall_froid.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    warshall_froid.hh
    +
    +
    +
    1 #include <unordered_map>
    +
    2 
    +
    3 #include <boost/graph/adjacency_list.hpp>
    +
    4 
    +
    5 #include "weighted_graph.hh"
    +
    6 
    +
    12 template<typename WeightedGraph>
    +
    13 void warshall_froid(const WeightedGraph &G,
    +
    14  std::unordered_map<typename WeightedGraph::vertex_descriptor,
    +
    15  std::unordered_map<typename WeightedGraph::vertex_descriptor, typename WeightedGraph::edge_property_type::value_type>> &distance) {
    +
    16  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    17  auto i = *range.first;
    +
    18  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    19  auto j = *range.first;
    +
    20  distance[i][j] = WeightedGraph::edge_property_type::value_type::zero();
    +
    21  }
    +
    22  }
    +
    23 
    +
    24  auto edgeWeightMap = get(boost::edge_weight, G);
    +
    25  for (auto range = boost::edges(G); range.first != range.second; range.first++) {
    +
    26  auto e = *range.first;
    +
    27  distance[source(e, G)][target(e, G)] += edgeWeightMap[e];
    +
    28  }
    +
    29 
    +
    30  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    31  auto k = *range.first;
    +
    32  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    33  auto i = *range.first;
    +
    34  if (k == i) {
    +
    35  continue;
    +
    36  }
    +
    37  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    38  auto j = *range.first;
    +
    39  if (k == j) {
    +
    40  continue;
    +
    41  }
    +
    42  distance[i][j] += (distance[i][k] *
    +
    43  distance[k][k].star() *
    +
    44  distance[k][j]);
    +
    45  }
    +
    46  }
    +
    47  for (auto range = boost::vertices(G); range.first != range.second; range.first++) {
    +
    48  auto i = *range.first;
    +
    49  if (k == i) {
    +
    50  continue;
    +
    51  }
    +
    52  distance[k][i] = distance[k][k].star() * distance[k][i];
    +
    53  distance[i][k] = distance[i][k] * distance[k][k].star();
    +
    54  }
    +
    55  distance[k][k] = distance[k][k].star();
    +
    56  }
    +
    57 }
    +
    +
    + + + + diff --git a/doxygen/weighted__graph_8hh_source.html b/doxygen/weighted__graph_8hh_source.html new file mode 100644 index 0000000..35803dd --- /dev/null +++ b/doxygen/weighted__graph_8hh_source.html @@ -0,0 +1,308 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/weighted_graph.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    weighted_graph.hh
    +
    +
    +
    1 #pragma once
    +
    2 
    +
    3 #include <boost/graph/adjacency_list.hpp>
    +
    4 
    +
    5 template<typename Weight>
    +
    6 using WeightedGraph = boost::adjacency_list<boost::listS, boost::listS, boost::directedS, boost::no_property, boost::property<boost::edge_weight_t, Weight>>;
    +
    7 
    +
    8 template<typename Base>
    + +
    10 public:
    +
    11  Base data;
    +
    12  MinPlusSemiring (Base data = 0): data(data) {}
    +
    13  MinPlusSemiring operator+(const MinPlusSemiring& x) const {
    +
    14  return MinPlusSemiring{ std::min(data, x.data) };
    +
    15  }
    +
    16  void operator+=(const MinPlusSemiring& x) {
    +
    17  data = std::min(data, x.data);
    +
    18  }
    +
    19  MinPlusSemiring operator*(const MinPlusSemiring& x) const {
    +
    20  return MinPlusSemiring( data + x.data);
    +
    21  }
    +
    22  void operator*=(const MinPlusSemiring& x) {
    +
    23  data += x;
    +
    24  }
    +
    25  bool operator!=(const MinPlusSemiring& x) const {
    +
    26  return data != x.data;
    +
    27  }
    +
    28  bool operator==(const MinPlusSemiring& x) const {
    +
    29  return data == x.data;
    +
    30  }
    +
    31  static MinPlusSemiring zero() {
    +
    32  static MinPlusSemiring zero = MinPlusSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    33  std::numeric_limits<Base>::infinity():
    +
    34  std::numeric_limits<Base>::max() };
    +
    35  return zero;
    +
    36  }
    +
    37  static MinPlusSemiring one() {
    +
    38  static MinPlusSemiring one = MinPlusSemiring{ 0 };
    +
    39  return one;
    +
    40  }
    +
    41  MinPlusSemiring star() const {
    +
    42  if (data < 0) {
    +
    43  return MinPlusSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    44  -std::numeric_limits<Base>::infinity():
    +
    45  std::numeric_limits<Base>::min() };
    +
    46  } else {
    +
    47  return one();
    +
    48  }
    +
    49  }
    +
    50 };
    +
    51 
    +
    52 template<typename Base>
    +
    53 std::size_t hash_value(MinPlusSemiring<Base> const& v) {
    +
    54  return boost::hash_value(v.data);
    +
    55 }
    +
    56 
    +
    57 template<typename Base>
    + +
    59 public:
    +
    60  Base data;
    +
    61  MaxPlusSemiring (Base data = 0): data(data) {}
    +
    62  MaxPlusSemiring operator+(const MaxPlusSemiring& x) const {
    +
    63  return MaxPlusSemiring{ std::max(data, x.data) };
    +
    64  }
    +
    65  void operator+=(const MaxPlusSemiring& x) {
    +
    66  data = std::max(data, x.data);
    +
    67  }
    +
    68  MaxPlusSemiring operator*(const MaxPlusSemiring& x) const {
    +
    69  return MaxPlusSemiring{data + x.data};
    +
    70  }
    +
    71  void operator*=(const MaxPlusSemiring& x) {
    +
    72  data += x;
    +
    73  }
    +
    74  bool operator!=(const MaxPlusSemiring& x) const {
    +
    75  return data != x.data;
    +
    76  }
    +
    77  bool operator==(const MaxPlusSemiring& x) const {
    +
    78  return data == x.data;
    +
    79  }
    +
    80  static MaxPlusSemiring zero() {
    +
    81  static MaxPlusSemiring zero = MaxPlusSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    82  -std::numeric_limits<Base>::infinity():
    +
    83  std::numeric_limits<Base>::min() };
    +
    84  return zero;
    +
    85  }
    +
    86  static MaxPlusSemiring one() {
    +
    87  static MaxPlusSemiring one = MaxPlusSemiring{ 0 };
    +
    88  return one;
    +
    89  }
    +
    90  MaxPlusSemiring star() const {
    +
    91  if (data > 0) {
    +
    92  return MaxPlusSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    93  std::numeric_limits<Base>::infinity():
    +
    94  std::numeric_limits<Base>::max() };
    +
    95  } else {
    +
    96  return one();
    +
    97  }
    +
    98  }
    +
    99 };
    +
    100 
    +
    101 template<typename Base>
    +
    102 std::size_t hash_value(MaxPlusSemiring<Base> const& v) {
    +
    103  return boost::hash_value(v.data);
    +
    104 }
    +
    105 
    +
    106 template<typename Base>
    + +
    108 public:
    +
    109  Base data;
    +
    110  MaxMinSemiring (Base data = std::numeric_limits<Base>::infinity()): data(data) {}
    +
    111  MaxMinSemiring operator+(const MaxMinSemiring& x) const {
    +
    112  return MaxMinSemiring{ std::max(data, x.data) };
    +
    113  }
    +
    114  void operator+=(const MaxMinSemiring& x) {
    +
    115  data = std::max(data, x.data);
    +
    116  }
    +
    117  MaxMinSemiring operator*(const MaxMinSemiring& x) const {
    +
    118  return MaxMinSemiring{ std::min(data, x.data) };
    +
    119  }
    +
    120  void operator*=(const MaxMinSemiring& x) {
    +
    121  data = std::min(data, x.data);
    +
    122  }
    +
    123  bool operator!=(const MaxMinSemiring& x) const {
    +
    124  return data != x.data;
    +
    125  }
    +
    126  bool operator==(const MaxMinSemiring& x) const {
    +
    127  return data == x.data;
    +
    128  }
    +
    129  MaxMinSemiring star() const {
    +
    130  return one();
    +
    131  }
    +
    132  static MaxMinSemiring one() {
    +
    133  static MaxMinSemiring one = MaxMinSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    134  std::numeric_limits<Base>::infinity():
    +
    135  std::numeric_limits<Base>::max() };
    +
    136  return one;
    +
    137  }
    +
    138  static MaxMinSemiring zero() {
    +
    139  static MaxMinSemiring zero = MaxMinSemiring{ std::numeric_limits<Base>::has_infinity ?
    +
    140  -std::numeric_limits<Base>::infinity():
    +
    141  std::numeric_limits<Base>::lowest() };
    +
    142  return zero;
    +
    143  }
    +
    144 };
    +
    145 
    +
    146 template<class Base>
    +
    147 std::ostream& operator<<(std::ostream& os, const MaxMinSemiring<Base>& s) {
    +
    148  os << s.data;
    +
    149  return os;
    +
    150 }
    +
    151 
    +
    152 template<typename Base>
    +
    153 std::size_t hash_value(MaxMinSemiring<Base> const& v) {
    +
    154  return boost::hash_value(v.data);
    +
    155 }
    +
    156 
    + +
    158 public:
    +
    159  bool data;
    +
    160  BooleanSemiring (bool data = false): data(data) {}
    +
    161  BooleanSemiring operator+(const BooleanSemiring& x) const {
    +
    162  return BooleanSemiring{ data || x.data };
    +
    163  }
    +
    164  void operator+=(const BooleanSemiring& x) {
    +
    165  data = data || x.data;
    +
    166  }
    +
    167  BooleanSemiring operator*(const BooleanSemiring& x) const {
    +
    168  return BooleanSemiring( data && x.data);
    +
    169  }
    +
    170  void operator*=(const BooleanSemiring& x) {
    +
    171  data = data && x.data;
    +
    172  }
    +
    173  bool operator!=(const BooleanSemiring& x) const {
    +
    174  return data != x.data;
    +
    175  }
    +
    176  bool operator==(const BooleanSemiring& x) const {
    +
    177  return data == x.data;
    +
    178  }
    +
    179  static BooleanSemiring zero() {
    +
    180  static BooleanSemiring zero = BooleanSemiring{ false };
    +
    181  return zero;
    +
    182  }
    +
    183  static BooleanSemiring one() {
    +
    184  static BooleanSemiring one = BooleanSemiring{ true };
    +
    185  return one;
    +
    186  }
    +
    187  BooleanSemiring star() const {
    +
    188  if (data == true) {
    +
    189  return one();
    +
    190  } else {
    +
    191  return zero();
    +
    192  }
    +
    193  }
    +
    194 };
    +
    195 
    +
    196 static inline std::size_t hash_value(BooleanSemiring const& v) {
    +
    197  return boost::hash_value(v.data);
    +
    198 }
    +
    Definition: weighted_graph.hh:157
    +
    Definition: weighted_graph.hh:107
    +
    Definition: weighted_graph.hh:58
    +
    Definition: weighted_graph.hh:9
    +
    +
    + + + + diff --git a/doxygen/zone__graph_8hh_source.html b/doxygen/zone__graph_8hh_source.html new file mode 100644 index 0000000..80b262a --- /dev/null +++ b/doxygen/zone__graph_8hh_source.html @@ -0,0 +1,548 @@ + + + + + + + +Quantitative Timed Pattern Matching Developers Manual: src/zone_graph.hh Source File + + + + + + + + + + + + + + + +
    +
    + + + + + + +
    +
    Quantitative Timed Pattern Matching Developers Manual +  0.1.0 +
    +
    +
    + + + + + + + +
    +
    + +
    +
    +
    + +
    + +
    +
    + + +
    + +
    + +
    +
    +
    zone_graph.hh
    +
    +
    +
    1 #pragma once
    +
    2 
    +
    3 #include <boost/algorithm/cxx11/none_of.hpp>
    +
    4 #include <boost/algorithm/cxx11/any_of.hpp>
    +
    5 #include <boost/graph/adjacency_list.hpp>
    +
    6 #include <boost/optional.hpp>
    +
    7 #include <type_traits>
    +
    8 
    +
    9 #include "dbm.hh"
    +
    10 #include "constraint.hh"
    +
    11 #include "timed_automaton.hh"
    +
    12 
    +
    13 
    +
    14 template<class SignalVariables, class ClockVariables, class Value>
    + +
    17  typename BoostTimedAutomaton<SignalVariables, ClockVariables>::vertex_descriptor vertex;
    +
    25  bool jumpable;
    + +
    29  std::vector<std::vector<Value>> valuations;
    +
    30 };
    +
    31 
    +
    33 // https://www.boost.org/doc/libs/1_68_0/libs/graph/doc/adjacency_list.html
    +
    34 template<class SignalVariables, class ClockVariables, class Weight, class Value>
    +
    35 using BoostZoneGraph = boost::adjacency_list<boost::listS, boost::listS, boost::directedS, BoostZoneGraphState<SignalVariables, ClockVariables, Value>, boost::property<boost::edge_weight_t, Weight>>;
    +
    36 
    +
    37 template<class SignalVariables, class ClockVariables, class Weight, class Value>
    +
    38 void zoneConstruction(const BoostTimedAutomaton<SignalVariables, ClockVariables> &TA,
    +
    39  const std::vector<typename BoostTimedAutomaton<SignalVariables, ClockVariables>::vertex_descriptor> &initStatesTA,
    +
    40  BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value> &ZG,
    +
    41  std::vector<typename BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>::vertex_descriptor> &initStatesZG) {
    +
    42  using TA_t = BoostTimedAutomaton<SignalVariables, ClockVariables>;
    +
    43  using ZG_t = BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>;
    +
    44  boost::unordered_map<std::pair<typename TA_t::vertex_descriptor, DBM::Tuple>, typename ZG_t::vertex_descriptor> toZGState;
    +
    45  const auto max_constraints = boost::get_property(TA, boost::graph_max_constraints);
    +
    46  const auto num_of_vars = boost::get_property(TA, boost::graph_num_of_vars);
    +
    47  auto zeroDBM = DBM::zero(num_of_vars + 1);
    +
    48  zeroDBM.M = Bounds{max_constraints, true};
    +
    49 
    +
    50  initStatesZG.reserve(initStatesTA.size());
    +
    51  for (const auto &initState: initStatesTA) {
    +
    52  auto v = boost::add_vertex(ZG);
    +
    53  ZG[v].vertex = initState;
    +
    54  ZG[v].zone = zeroDBM;
    +
    55  initStatesZG.push_back(v);
    +
    56 
    +
    57  toZGState[std::make_pair(initState, zeroDBM.toTuple())] = v;
    +
    58  }
    +
    59  auto nextConf = initStatesZG;
    +
    60 
    +
    61  while (!nextConf.empty()) {
    +
    62  auto currentConf = std::move(nextConf);
    +
    63  nextConf.clear();
    +
    64 
    +
    65  for (auto &currentZGState : currentConf) {
    +
    66  auto taState = ZG[currentZGState].vertex;
    +
    67  DBM nowZone = ZG[currentZGState].zone;
    +
    68 
    +
    69  nowZone.elapse();
    +
    70  for (auto range = boost::out_edges(taState, TA); range.first != range.second; range.first++) {
    +
    71  const auto edge = *range.first;
    +
    72  DBM nextZone = nowZone;
    +
    73  auto nextState = boost::target(edge, TA);
    +
    74 
    +
    75  const auto guard = TA[edge].guard;
    +
    76  for (const auto &delta : guard) {
    +
    77  switch (delta.odr) {
    + +
    79  nextZone.tighten(delta.x,-1,{delta.c, false});
    + +
    81  nextZone.tighten(delta.x,-1,{delta.c, true});
    +
    82  break;
    + +
    84  nextZone.tighten(-1,delta.x,{-delta.c, false});
    + +
    86  nextZone.tighten(-1,delta.x,{-delta.c, true});
    +
    87  break;
    +
    88  }
    +
    89  }
    +
    90 
    +
    91  if (nextZone.isSatisfiable()) {
    +
    92  for (auto x : TA[edge].resetVars.resetVars) {
    +
    93  nextZone.reset(x);
    +
    94  }
    +
    95  nextZone.abstractize();
    +
    96  nextZone.canonize();
    +
    97 
    +
    98  auto zgState = toZGState.find(std::make_pair(nextState, nextZone.toTuple()));
    +
    99 
    +
    100  if (zgState != toZGState.end()) {
    +
    101  // targetStateInZA is already added
    +
    102  boost::add_edge(currentZGState, zgState->second, ZG);
    +
    103 
    +
    104  } else {
    +
    105  // targetStateInZA is new
    +
    106  auto zgState = boost::add_vertex(ZG);
    +
    107  ZG[zgState].vertex = nextState;
    +
    108  ZG[zgState].zone = nextZone;
    +
    109  toZGState[std::make_pair(nextState, nextZone.toTuple())] = zgState;
    +
    110  boost::add_edge(currentZGState, zgState, ZG);
    +
    111 
    +
    112  nextConf.push_back (zgState);
    +
    113  }
    +
    114  }
    +
    115  }
    +
    116  }
    +
    117  }
    +
    118 }
    +
    119 
    +
    120 
    +
    135 template<class SignalVariables, class ClockVariables, class Weight, class Value>
    +
    136 void zoneConstructionWithT(const BoostTimedAutomaton<SignalVariables, ClockVariables> &TA,
    +
    137  const std::vector<std::pair<BoostZoneGraphState<SignalVariables, ClockVariables, Value>, Weight>> &initConfTA,
    +
    138  const std::function<Weight(const std::vector<Constraint<ClockVariables>> &,const std::vector<std::vector<Value>> &)> &cost,
    +
    139  const std::vector<Value> &valuation,
    +
    140  const double duration,
    +
    141  BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value> &ZG,
    +
    142  std::unordered_map<typename BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>::vertex_descriptor,Weight> &initStatesZG) {
    +
    143  using TA_t = BoostTimedAutomaton<SignalVariables, ClockVariables>;
    +
    144  using ZG_t = BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>;
    +
    145  using TAState = typename TA_t::vertex_descriptor;
    +
    146  boost::unordered_map<std::tuple<typename TA_t::vertex_descriptor, bool, DBM::Tuple, std::vector<std::vector<Value>>>, typename ZG_t::vertex_descriptor> toZGState;
    +
    147  // const double max_constraints = std::max<double>(ceil(duration), boost::get_property(TA, boost::graph_max_constraints));
    +
    148 #ifdef DEBUG
    +
    149  const auto num_of_vars = boost::get_property(TA, boost::graph_num_of_vars);
    +
    150 #endif
    +
    151 
    + +
    153  return std::make_tuple(x.vertex, x.jumpable, x.zone.toTuple(), x.valuations);
    +
    154  };
    +
    155  const auto dwellTimeClockVar = initConfTA.front().first.zone.getNumOfVar() - 1;
    +
    156 
    +
    157  std::vector<typename BoostZoneGraph<SignalVariables, ClockVariables, Weight, Value>::vertex_descriptor> nextConf;
    +
    158  nextConf.reserve(initConfTA.size());
    +
    159  initStatesZG.clear();
    +
    160  for (const auto &initState: initConfTA) {
    +
    161  auto v = boost::add_vertex(ZG);
    +
    162  ZG[v] = initState.first;
    +
    163  // the zone must contain the new clock variable T for the dwell time.
    +
    164  // we admit > ... + 1 to use this function for timed pattern matching too.
    +
    165 #ifdef DEBUG
    +
    166  assert(ZG[v].zone.getNumOfVar() >= num_of_vars + 1);
    +
    167  assert(!TA[initState.first.vertex].isMatch);
    +
    168  assert(!TA[ZG[v].vertex].isMatch);
    +
    169 #endif
    +
    170 
    +
    171  ZG[v].zone.tighten(dwellTimeClockVar, -1, {duration, true});
    +
    172 
    +
    173  initStatesZG[v] = initState.second;
    +
    174  nextConf.push_back(v);
    +
    175 
    +
    176  toZGState[convToKey(ZG[v])] = v;
    +
    177  }
    +
    178 
    +
    179  const auto addEdge = [&toZGState,&ZG,&nextConf,&TA,&cost,&convToKey] (const auto currentZGState, const auto nextTAState, const bool jumpable, const DBM &zone, const std::vector<std::vector<Value>> &nextValuations) -> bool {
    +
    180  auto zgState = toZGState.find(std::make_tuple(nextTAState, jumpable, zone.toTuple(), nextValuations));
    +
    181  typename ZG_t::edge_descriptor edge;
    +
    182 
    +
    183  const bool isNew = zgState == toZGState.end();
    +
    184 
    +
    185  if (!isNew) {
    +
    186  // targetStateInZA is already added
    +
    187  // TODO: we can merge some edges
    +
    188  edge = std::get<0>(boost::add_edge(currentZGState, zgState->second, ZG));
    +
    189  } else {
    +
    190  // targetStateInZA is new
    +
    191  auto nextZGState = boost::add_vertex(ZG);
    +
    192  ZG[nextZGState].vertex = nextTAState;
    +
    193  ZG[nextZGState].jumpable = jumpable;
    +
    194  ZG[nextZGState].zone = zone;
    +
    195  ZG[nextZGState].valuations = nextValuations;
    +
    196  toZGState[convToKey(ZG[nextZGState])] = nextZGState;
    +
    197  edge = std::get<0>(boost::add_edge(currentZGState, nextZGState, ZG));
    +
    198  if (!jumpable) {
    +
    199  nextConf.push_back (nextZGState);
    +
    200  }
    +
    201 #ifdef DEBUG
    +
    202  assert((toZGState.find(convToKey(ZG[nextZGState])) != toZGState.end()));
    +
    203 #endif
    +
    204  }
    +
    205 
    +
    206  if (!jumpable) {
    +
    207  boost::put(boost::edge_weight, ZG, edge, cost(TA[ZG[currentZGState].vertex].label,
    +
    208  ZG[currentZGState].valuations));
    +
    209  } else {
    +
    210  boost::put(boost::edge_weight, ZG, edge, Weight::one());
    +
    211  }
    +
    212 
    +
    213  return isNew;
    +
    214  };
    +
    215 
    +
    216 
    +
    217  while (!nextConf.empty()) {
    +
    218 #ifdef DEBUG
    +
    219  assert(std::all_of(nextConf.begin(), nextConf.end(), [&ZG](auto p) {
    +
    220  return boost::algorithm::any_of_equal(boost::vertices(ZG), p);}));
    +
    221 #endif
    +
    222  auto currentConf = std::move(nextConf);
    +
    223  nextConf.clear();
    +
    224  std::unordered_set<typename decltype(currentConf)::value_type> removedVertices;
    +
    225 
    +
    226  for (const auto &currentZGState : currentConf) {
    +
    227  // OPTIMIZATION: This find is unnecessary if currentConf is std::list (I can remove an element during its iteration)
    +
    228  if (removedVertices.find(currentZGState) != removedVertices.end()) {
    +
    229  continue;
    +
    230  }
    +
    231 #ifdef DEBUG
    +
    232  assert(boost::algorithm::any_of_equal(boost::vertices(ZG), currentZGState));
    +
    233 #endif
    +
    234  auto taState = ZG[currentZGState].vertex;
    +
    235  bool jumpable = ZG[currentZGState].jumpable;
    +
    236  DBM nowZone = ZG[currentZGState].zone;
    +
    237 
    +
    238  if (nowZone.value.cols() == 0) {
    +
    239  // when the vertex does not exist
    +
    240  continue;
    +
    241  }
    +
    242 
    +
    243  nowZone.tighten(dwellTimeClockVar, -1, {duration, true});
    +
    244 
    +
    245  const auto listDiscreteTransitions =
    +
    246  [&TA,&taState] (const DBM& nowZone, std::vector<std::pair<TAState, DBM>> &v) {
    +
    247  // discrete transition
    +
    248  for (auto range = boost::out_edges(taState, TA); range.first != range.second; range.first++) {
    +
    249  const auto edge = *range.first;
    +
    250  DBM nextZone = nowZone;
    +
    251  auto nextTAState = boost::target(edge, TA);
    +
    252 
    +
    253  const auto guard = TA[edge].guard;
    +
    254  for (const auto &delta : guard) {
    +
    255  switch (delta.odr) {
    + +
    257  nextZone.tightenWithoutClose(delta.x,-1,{delta.c, false});
    + +
    259  nextZone.tightenWithoutClose(delta.x,-1,{delta.c, true});
    +
    260  break;
    + +
    262  nextZone.tightenWithoutClose(-1,delta.x,{-delta.c, false});
    + +
    264  nextZone.tightenWithoutClose(-1,delta.x,{-delta.c, true});
    +
    265  }
    +
    266  }
    +
    267 
    +
    268  if (nextZone.isSatisfiable()) {
    +
    269  for (auto x : TA[edge].resetVars.resetVars) {
    +
    270  nextZone.reset(x);
    +
    271  }
    +
    272 
    +
    273  v.emplace_back(nextTAState, nextZone);
    +
    274  }
    +
    275  }
    +
    276  };
    +
    277 
    +
    278  if (jumpable) {
    +
    279  // discrete transition
    +
    280  std::vector<std::pair<TAState, DBM>> nextTAStates;
    +
    281  listDiscreteTransitions(nowZone, nextTAStates);
    +
    282 
    +
    283  if (nextTAStates.empty()) {
    +
    284  // If there is no out going transition, it checks if there is a transition later.
    +
    285  auto futureZone = nowZone;
    +
    286  futureZone.elapse();
    +
    287  std::vector<std::pair<TAState, DBM>> futureTAStates;
    +
    288  listDiscreteTransitions(nowZone, futureTAStates);
    +
    289  // If there is no transition in the future, the current state is useless and we remove it.
    +
    290  if (futureTAStates.empty()) {
    +
    291  const auto nextZGStateP = toZGState.find(convToKey(ZG[currentZGState]));
    +
    292  if (nextZGStateP != toZGState.end()) {
    +
    293  initStatesZG.erase(nextZGStateP->second);
    +
    294  clear_vertex(nextZGStateP->second, ZG);
    +
    295  remove_vertex(nextZGStateP->second, ZG);
    +
    296  removedVertices.insert(nextZGStateP->second);
    +
    297  toZGState.erase(nextZGStateP);
    +
    298  }
    +
    299 #ifdef DEBUG
    +
    300  assert(std::none_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    301  return TA[ZG[p.first].vertex].isMatch;
    +
    302  }));
    +
    303  assert(std::all_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    304  return boost::algorithm::any_of_equal(boost::vertices(ZG), p.first);
    +
    305  }));
    +
    306 #endif
    +
    307  }
    +
    308  continue;
    +
    309  }
    +
    310  for (auto &p: nextTAStates) {
    +
    311  addEdge(currentZGState, std::move(p.first), false, std::move(p.second), {});
    +
    312  }
    +
    313 
    +
    314  } else {
    +
    315  // continuous transition
    +
    316  auto nextValuations = ZG[currentZGState].valuations;
    +
    317 
    +
    318  nextValuations.push_back(valuation);
    +
    319  nowZone.elapse();
    +
    320  nowZone.tighten(dwellTimeClockVar, -1, {duration, true});
    +
    321  if (!nowZone.isSatisfiableWithoutCanonize()) {
    +
    322  continue;
    +
    323  }
    +
    324 
    +
    325  std::vector<std::pair<TAState, DBM>> nextTAStates;
    +
    326  listDiscreteTransitions(nowZone, nextTAStates);
    +
    327  // We add the state only if it has a next state
    +
    328 
    +
    329  if (!nextTAStates.empty()) {
    +
    330  bool isNew = addEdge(currentZGState, ZG[currentZGState].vertex, true, nowZone, nextValuations);
    +
    331  if (isNew) {
    +
    332  const auto nextZGStateP = toZGState.find(std::make_tuple(ZG[currentZGState].vertex, true, nowZone.toTuple(), nextValuations));
    +
    333  for (auto &p: nextTAStates) {
    +
    334  addEdge(nextZGStateP->second, std::move(p.first), false, std::move(p.second), {});
    +
    335  }
    +
    336  }
    +
    337  } else {
    +
    338  // if the state is accepting, the state is useful even if it has no outgoing transition.
    +
    339  if (TA[ZG[currentZGState].vertex].isMatch) {
    +
    340  continue;
    +
    341  }
    +
    342  // If there is no out going transition, it checks if there is a transition later.
    +
    343  auto futureZone = nowZone;
    +
    344  futureZone.elapse();
    +
    345  std::vector<std::pair<TAState, DBM>> futureTAStates;
    +
    346  listDiscreteTransitions(nowZone, futureTAStates);
    +
    347  // If there is no transition in the future, the current state is useless and we remove it.
    +
    348  if (futureTAStates.empty()) {
    +
    349  const auto nextZGStateP = toZGState.find(convToKey(ZG[currentZGState]));
    +
    350  // If we cannot go out and the state already exists, we remove the state.
    +
    351  if (nextZGStateP != toZGState.end()) {
    +
    352  initStatesZG.erase(nextZGStateP->second);
    +
    353  clear_vertex(nextZGStateP->second, ZG);
    +
    354  remove_vertex(nextZGStateP->second, ZG);
    +
    355  removedVertices.insert(nextZGStateP->second);
    +
    356  toZGState.erase(nextZGStateP);
    +
    357  }
    +
    358  }
    +
    359  }
    +
    360 
    +
    361  // nowZone.canonize();
    +
    362 #ifdef DEBUG
    +
    363  assert(std::none_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    364  return TA[ZG[p.first].vertex].isMatch;
    +
    365  }));
    +
    366  assert(std::all_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    367  return boost::algorithm::any_of_equal(boost::vertices(ZG), p.first);
    +
    368  }));
    +
    369 #endif
    +
    370  }
    +
    371 #ifdef DEBUG
    +
    372  assert(std::none_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    373  return TA[ZG[p.first].vertex].isMatch;
    +
    374  }));
    +
    375  assert(std::all_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    376  return boost::algorithm::any_of_equal(boost::vertices(ZG), p.first);
    +
    377  }));
    +
    378 #endif
    +
    379  }
    +
    380 #ifdef DEBUG
    +
    381  assert(std::none_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    382  return TA[ZG[p.first].vertex].isMatch;
    +
    383  }));
    +
    384  assert(std::all_of(initStatesZG.begin(), initStatesZG.end(), [&](auto p) {
    +
    385  return boost::algorithm::any_of_equal(boost::vertices(ZG), p.first);
    +
    386  }));
    +
    387 #endif
    +
    388  // remove the removedVertices from nextConf
    +
    389  nextConf.erase(std::remove_if(nextConf.begin(), nextConf.end(), [&removedVertices](auto v) {
    +
    390  return boost::algorithm::any_of_equal(removedVertices, v);
    +
    391  }), nextConf.end());
    +
    392  }
    +
    393 }
    +
    394 
    +
    395 template <class Graph>
    + +
    397  weight_label_writer(const Graph& g) : graph_(g) {}
    +
    398 
    +
    399  template <class Edge>
    +
    400  void operator()(std::ostream& out, const Edge& edge) const
    +
    401  {
    +
    402  write(out, edge, boost::get(boost::edge_weight, graph_, edge));
    +
    403  }
    +
    404 
    +
    405 private:
    +
    406  template <class Edge, class Weight>
    +
    407  void write(std::ostream& out, const Edge&, const Weight& weight) const
    +
    408  {
    +
    409  out << "[weight="
    +
    410  << weight.data
    +
    411  << ", label="
    +
    412  << weight.data
    +
    413  << "]";
    +
    414  }
    +
    415 
    +
    416  const Graph& graph_;
    +
    417 };
    +
    418 
    +
    419 template <class Graph>
    +
    420 inline weight_label_writer<Graph> make_weight_label_writer(const Graph& g)
    +
    421 {
    +
    422  return weight_label_writer<Graph>(g);
    +
    423 }
    +
    424 
    +
    425 template <class ZoneGraph, class TimedAutomaton, class Weight>
    + +
    427  ZoneGraphLabelWriter(const ZoneGraph& ZG, const TimedAutomaton& TA, const std::unordered_map<typename ZoneGraph::vertex_descriptor, Weight> &distance) : ZG(ZG), TA(TA), distance(distance) {}
    +
    428 
    +
    429  template <class Vertex>
    +
    430  void operator()(std::ostream& out, const Vertex& vertex) const
    +
    431  {
    +
    432  out << "[label=\""
    +
    433  << ZG[vertex].vertex << "/"
    +
    434  << TA[ZG[vertex].vertex].isMatch << "/"
    +
    435  << distance.at(vertex).data
    +
    436  << "\"]";
    +
    437  }
    +
    438 
    +
    439 private:
    +
    440  const ZoneGraph& ZG;
    +
    441  const TimedAutomaton& TA;
    +
    442  const std::unordered_map<typename ZoneGraph::vertex_descriptor, Weight> &distance;
    +
    443 };
    +
    444 
    +
    445 template <class ZoneGraph, class TimedAutomaton, class Weight>
    +
    446 inline ZoneGraphLabelWriter<ZoneGraph, TimedAutomaton, Weight> makeZoneGraphLabelWriter(const ZoneGraph& ZG, const TimedAutomaton& TA, const std::unordered_map<typename ZoneGraph::vertex_descriptor, Weight> &distance)
    +
    447 {
    + +
    449 }
    +
    Definition: zone_graph.hh:15
    +
    DBM zone
    The corresponding zone.
    Definition: zone_graph.hh:27
    +
    bool jumpable
    The flag showing if one can fire a (discrete) transition. This is used to forbid having multiple jump...
    Definition: zone_graph.hh:25
    +
    BoostTimedAutomaton< SignalVariables, ClockVariables >::vertex_descriptor vertex
    The corresponding state in the TA.
    Definition: zone_graph.hh:17
    +
    std::vector< std::vector< Value > > valuations
    The signal valuations observed after the latest (discrete) transition.
    Definition: zone_graph.hh:29
    +
    A constraint in a guard of transitions.
    Definition: constraint.hh:18
    +
    Implementation of a zone with DBM DBM For the detail of DBMs, see for example .
    Definition: dbm.hh:52
    +
    void canonize()
    make the zone canonical
    Definition: dbm.hh:169
    +
    std::tuple< std::vector< Bounds >, Bounds > toTuple() const
    Return the tuple representation of the DBM.
    Definition: dbm.hh:91
    +
    void tightenWithoutClose(uint8_t x, uint8_t y, Bounds c)
    add the constraint x - y <= (c,s) but does not close.
    Definition: dbm.hh:98
    +
    bool isSatisfiable()
    check if the zone is satisfiable
    Definition: dbm.hh:187
    +
    void tighten(uint8_t x, uint8_t y, Bounds c)
    add the constraint
    Definition: dbm.hh:105
    +
    void abstractize()
    truncate the constraints compared with a constant greater than or equal to M
    Definition: dbm.hh:195
    +
    static DBM zero(int size)
    Make the zone of size size such that all the values are zero.
    Definition: dbm.hh:79
    +
    void elapse()
    Assign the strongest post-condition of the delay.
    Definition: dbm.hh:154
    +
    Eigen::Matrix< Bounds, Eigen::Dynamic, Eigen::Dynamic > value
    The matrix representing the DBM.
    Definition: dbm.hh:55
    +
    Definition: zone_graph.hh:426
    +
    Definition: zone_graph.hh:396
    +
    +
    + + + +