Browse Source
Merge branch 'master' into SmtSolvers
Merge branch 'master' into SmtSolvers
Former-commit-id: 20effdeffe
tempestpy_adaptions
David_Korzeniewski
11 years ago
8 changed files with 246 additions and 328 deletions
-
2src/solver/GlpkLpSolver.h
-
105src/storage/dd/CuddDdManager.cpp
-
36src/storage/dd/CuddDdManager.h
-
52src/storage/dd/CuddDdMetaVariable.cpp
-
138src/storage/dd/CuddDdMetaVariable.h
-
65src/storage/dd/DdMetaVariable.cpp
-
136src/storage/dd/DdMetaVariable.h
-
40test/functional/storage/CuddDdTest.cpp
@ -0,0 +1,52 @@ |
|||||
|
#include "src/storage/dd/CuddDdMetaVariable.h"
|
||||
|
#include "src/storage/dd/CuddDdManager.h"
|
||||
|
|
||||
|
namespace storm { |
||||
|
namespace dd { |
||||
|
DdMetaVariable<DdType::CUDD>::DdMetaVariable(std::string const& name, int_fast64_t low, int_fast64_t high, std::vector<Dd<DdType::CUDD>> const& ddVariables, std::shared_ptr<DdManager<DdType::CUDD>> manager) : name(name), type(MetaVariableType::Int), low(low), high(high), ddVariables(ddVariables), cube(manager->getOne()), manager(manager) { |
||||
|
// Create the cube of all variables of this meta variable.
|
||||
|
for (auto const& ddVariable : this->ddVariables) { |
||||
|
this->cube *= ddVariable; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
DdMetaVariable<DdType::CUDD>::DdMetaVariable(std::string const& name, std::vector<Dd<DdType::CUDD>> const& ddVariables, std::shared_ptr<DdManager<DdType::CUDD>> manager) : name(name), type(MetaVariableType::Bool), ddVariables(ddVariables), cube(manager->getOne()), manager(manager) { |
||||
|
// Create the cube of all variables of this meta variable.
|
||||
|
for (auto const& ddVariable : this->ddVariables) { |
||||
|
this->cube *= ddVariable; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
std::string const& DdMetaVariable<DdType::CUDD>::getName() const { |
||||
|
return this->name; |
||||
|
} |
||||
|
|
||||
|
typename DdMetaVariable<DdType::CUDD>::MetaVariableType DdMetaVariable<DdType::CUDD>::getType() const { |
||||
|
return this->type; |
||||
|
} |
||||
|
|
||||
|
int_fast64_t DdMetaVariable<DdType::CUDD>::getLow() const { |
||||
|
return this->low; |
||||
|
} |
||||
|
|
||||
|
int_fast64_t DdMetaVariable<DdType::CUDD>::getHigh() const { |
||||
|
return this->high; |
||||
|
} |
||||
|
|
||||
|
std::size_t DdMetaVariable<DdType::CUDD>::getNumberOfDdVariables() const { |
||||
|
return this->ddVariables.size(); |
||||
|
} |
||||
|
|
||||
|
std::shared_ptr<DdManager<DdType::CUDD>> DdMetaVariable<DdType::CUDD>::getDdManager() const { |
||||
|
return this->manager; |
||||
|
} |
||||
|
|
||||
|
std::vector<Dd<DdType::CUDD>> const& DdMetaVariable<DdType::CUDD>::getDdVariables() const { |
||||
|
return this->ddVariables; |
||||
|
} |
||||
|
|
||||
|
Dd<DdType::CUDD> const& DdMetaVariable<DdType::CUDD>::getCube() const { |
||||
|
return this->cube; |
||||
|
} |
||||
|
} |
||||
|
} |
@ -0,0 +1,138 @@ |
|||||
|
#ifndef STORM_STORAGE_DD_DDMETAVARIABLE_H_ |
||||
|
#define STORM_STORAGE_DD_DDMETAVARIABLE_H_ |
||||
|
|
||||
|
#include <memory> |
||||
|
#include <vector> |
||||
|
#include <cstdint> |
||||
|
#include <string> |
||||
|
|
||||
|
#include "utility/OsDetection.h" |
||||
|
#include "src/storage/dd/CuddDd.h" |
||||
|
#include "src/storage/dd/DdMetaVariable.h" |
||||
|
#include "src/storage/expressions/Expression.h" |
||||
|
|
||||
|
namespace storm { |
||||
|
namespace dd { |
||||
|
// Forward-declare the DdManager class. |
||||
|
template<DdType Type> class DdManager; |
||||
|
|
||||
|
template<> |
||||
|
class DdMetaVariable<DdType::CUDD> { |
||||
|
public: |
||||
|
// Declare the DdManager class as friend so it can access the internals of a meta variable. |
||||
|
friend class DdManager<DdType::CUDD>; |
||||
|
friend class Dd<DdType::CUDD>; |
||||
|
friend class DdForwardIterator<DdType::CUDD>; |
||||
|
|
||||
|
// An enumeration for all legal types of meta variables. |
||||
|
enum class MetaVariableType { Bool, Int }; |
||||
|
|
||||
|
/*! |
||||
|
* Creates an integer meta variable with the given name and range bounds. |
||||
|
* |
||||
|
* @param name The name of the meta variable. |
||||
|
* @param low The lowest value of the range of the variable. |
||||
|
* @param high The highest value of the range of the variable. |
||||
|
* @param ddVariables The vector of variables used to encode this variable. |
||||
|
* @param manager A pointer to the manager that is responsible for this meta variable. |
||||
|
*/ |
||||
|
DdMetaVariable(std::string const& name, int_fast64_t low, int_fast64_t high, std::vector<Dd<DdType::CUDD>> const& ddVariables, std::shared_ptr<DdManager<DdType::CUDD>> manager); |
||||
|
|
||||
|
/*! |
||||
|
* Creates a boolean meta variable with the given name. |
||||
|
* @param name The name of the meta variable. |
||||
|
* @param ddVariables The vector of variables used to encode this variable. |
||||
|
* @param manager A pointer to the manager that is responsible for this meta variable. |
||||
|
*/ |
||||
|
DdMetaVariable(std::string const& name, std::vector<Dd<DdType::CUDD>> const& ddVariables, std::shared_ptr<DdManager<DdType::CUDD>> manager); |
||||
|
|
||||
|
// Explictly generate all default versions of copy/move constructors/assignments. |
||||
|
DdMetaVariable(DdMetaVariable const& other) = default; |
||||
|
DdMetaVariable& operator=(DdMetaVariable const& other) = default; |
||||
|
#ifndef WINDOWS |
||||
|
DdMetaVariable(DdMetaVariable&& other) = default; |
||||
|
DdMetaVariable& operator=(DdMetaVariable&& other) = default; |
||||
|
#endif |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the name of the meta variable. |
||||
|
* |
||||
|
* @return The name of the variable. |
||||
|
*/ |
||||
|
std::string const& getName() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the type of the meta variable. |
||||
|
* |
||||
|
* @return The type of the meta variable. |
||||
|
*/ |
||||
|
MetaVariableType getType() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the lowest value of the range of the variable. |
||||
|
* |
||||
|
* @return The lowest value of the range of the variable. |
||||
|
*/ |
||||
|
int_fast64_t getLow() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the highest value of the range of the variable. |
||||
|
* |
||||
|
* @return The highest value of the range of the variable. |
||||
|
*/ |
||||
|
int_fast64_t getHigh() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the manager that is responsible for this meta variable. |
||||
|
* |
||||
|
* A pointer to the manager that is responsible for this meta variable. |
||||
|
*/ |
||||
|
std::shared_ptr<DdManager<DdType::CUDD>> getDdManager() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the number of DD variables for this meta variable. |
||||
|
* |
||||
|
* @return The number of DD variables for this meta variable. |
||||
|
*/ |
||||
|
std::size_t getNumberOfDdVariables() const; |
||||
|
|
||||
|
private: |
||||
|
/*! |
||||
|
* Retrieves the variables used to encode the meta variable. |
||||
|
* |
||||
|
* @return A vector of variables used to encode the meta variable. |
||||
|
*/ |
||||
|
std::vector<Dd<DdType::CUDD>> const& getDdVariables() const; |
||||
|
|
||||
|
/*! |
||||
|
* Retrieves the cube of all variables that encode this meta variable. |
||||
|
* |
||||
|
* @return The cube of all variables that encode this meta variable. |
||||
|
*/ |
||||
|
Dd<DdType::CUDD> const& getCube() const; |
||||
|
|
||||
|
// The name of the meta variable. |
||||
|
std::string name; |
||||
|
|
||||
|
// The type of the variable. |
||||
|
MetaVariableType type; |
||||
|
|
||||
|
// The lowest value of the range of the variable. |
||||
|
int_fast64_t low; |
||||
|
|
||||
|
// The highest value of the range of the variable. |
||||
|
int_fast64_t high; |
||||
|
|
||||
|
// The vector of variables that are used to encode the meta variable. |
||||
|
std::vector<Dd<DdType::CUDD>> ddVariables; |
||||
|
|
||||
|
// The cube consisting of all variables that encode the meta variable. |
||||
|
Dd<DdType::CUDD> cube; |
||||
|
|
||||
|
// A pointer to the manager responsible for this meta variable. |
||||
|
std::shared_ptr<DdManager<DdType::CUDD>> manager; |
||||
|
}; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#endif /* STORM_STORAGE_DD_DDMETAVARIABLE_H_ */ |
@ -1,65 +0,0 @@ |
|||||
#include "src/storage/dd/DdMetaVariable.h"
|
|
||||
#include "src/storage/dd/CuddDdManager.h"
|
|
||||
|
|
||||
namespace storm { |
|
||||
namespace dd { |
|
||||
template<DdType Type> |
|
||||
DdMetaVariable<Type>::DdMetaVariable(std::string const& name, int_fast64_t low, int_fast64_t high, std::vector<Dd<Type>> const& ddVariables, std::shared_ptr<DdManager<Type>> manager) : name(name), type(MetaVariableType::Int), low(low), high(high), ddVariables(ddVariables), cube(manager->getOne()), manager(manager) { |
|
||||
// Create the cube of all variables of this meta variable.
|
|
||||
for (auto const& ddVariable : this->ddVariables) { |
|
||||
this->cube *= ddVariable; |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
DdMetaVariable<Type>::DdMetaVariable(std::string const& name, std::vector<Dd<Type>> const& ddVariables, std::shared_ptr<DdManager<Type>> manager) : name(name), type(MetaVariableType::Bool), ddVariables(ddVariables), cube(manager->getOne()), manager(manager) { |
|
||||
// Create the cube of all variables of this meta variable.
|
|
||||
for (auto const& ddVariable : this->ddVariables) { |
|
||||
this->cube *= ddVariable; |
|
||||
} |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
std::string const& DdMetaVariable<Type>::getName() const { |
|
||||
return this->name; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
typename DdMetaVariable<Type>::MetaVariableType DdMetaVariable<Type>::getType() const { |
|
||||
return this->type; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
int_fast64_t DdMetaVariable<Type>::getLow() const { |
|
||||
return this->low; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
int_fast64_t DdMetaVariable<Type>::getHigh() const { |
|
||||
return this->high; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
std::size_t DdMetaVariable<Type>::getNumberOfDdVariables() const { |
|
||||
return this->ddVariables.size(); |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
std::shared_ptr<DdManager<Type>> DdMetaVariable<Type>::getDdManager() const { |
|
||||
return this->manager; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
std::vector<Dd<Type>> const& DdMetaVariable<Type>::getDdVariables() const { |
|
||||
return this->ddVariables; |
|
||||
} |
|
||||
|
|
||||
template<DdType Type> |
|
||||
Dd<Type> const& DdMetaVariable<Type>::getCube() const { |
|
||||
return this->cube; |
|
||||
} |
|
||||
|
|
||||
// Explicitly instantiate DdMetaVariable.
|
|
||||
template class DdMetaVariable<DdType::CUDD>; |
|
||||
} |
|
||||
} |
|
@ -1,137 +1,13 @@ |
|||||
#ifndef STORM_STORAGE_DD_DDMETAVARIABLE_H_ |
|
||||
#define STORM_STORAGE_DD_DDMETAVARIABLE_H_ |
|
||||
|
#ifndef STORM_STORAGE_DD_DDMETAVARIBLE_H_ |
||||
|
#define STORM_STORAGE_DD_DDMETAVARIBLE_H_ |
||||
|
|
||||
#include <memory> |
|
||||
#include <vector> |
|
||||
#include <cstdint> |
|
||||
#include <string> |
|
||||
|
|
||||
#include "utility/OsDetection.h" |
|
||||
#include "src/storage/dd/CuddDd.h" |
|
||||
#include "src/storage/expressions/Expression.h" |
|
||||
|
#include "src/storage/dd/DdType.h" |
||||
|
|
||||
namespace storm { |
namespace storm { |
||||
namespace dd { |
namespace dd { |
||||
// Forward-declare the DdManager class. |
|
||||
template<DdType Type> class DdManager; |
|
||||
|
|
||||
template <DdType Type> |
|
||||
class DdMetaVariable { |
|
||||
public: |
|
||||
// Declare the DdManager class as friend so it can access the internals of a meta variable. |
|
||||
friend class DdManager<Type>; |
|
||||
friend class Dd<Type>; |
|
||||
friend class DdForwardIterator<Type>; |
|
||||
|
|
||||
// An enumeration for all legal types of meta variables. |
|
||||
enum class MetaVariableType { Bool, Int }; |
|
||||
|
|
||||
/*! |
|
||||
* Creates an integer meta variable with the given name and range bounds. |
|
||||
* |
|
||||
* @param name The name of the meta variable. |
|
||||
* @param low The lowest value of the range of the variable. |
|
||||
* @param high The highest value of the range of the variable. |
|
||||
* @param ddVariables The vector of variables used to encode this variable. |
|
||||
* @param manager A pointer to the manager that is responsible for this meta variable. |
|
||||
*/ |
|
||||
DdMetaVariable(std::string const& name, int_fast64_t low, int_fast64_t high, std::vector<Dd<Type>> const& ddVariables, std::shared_ptr<DdManager<Type>> manager); |
|
||||
|
|
||||
/*! |
|
||||
* Creates a boolean meta variable with the given name. |
|
||||
* @param name The name of the meta variable. |
|
||||
* @param ddVariables The vector of variables used to encode this variable. |
|
||||
* @param manager A pointer to the manager that is responsible for this meta variable. |
|
||||
*/ |
|
||||
DdMetaVariable(std::string const& name, std::vector<Dd<Type>> const& ddVariables, std::shared_ptr<DdManager<Type>> manager); |
|
||||
|
|
||||
// Explictly generate all default versions of copy/move constructors/assignments. |
|
||||
DdMetaVariable(DdMetaVariable const& other) = default; |
|
||||
DdMetaVariable& operator=(DdMetaVariable const& other) = default; |
|
||||
#ifndef WINDOWS |
|
||||
DdMetaVariable(DdMetaVariable&& other) = default; |
|
||||
DdMetaVariable& operator=(DdMetaVariable&& other) = default; |
|
||||
#endif |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the name of the meta variable. |
|
||||
* |
|
||||
* @return The name of the variable. |
|
||||
*/ |
|
||||
std::string const& getName() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the type of the meta variable. |
|
||||
* |
|
||||
* @return The type of the meta variable. |
|
||||
*/ |
|
||||
MetaVariableType getType() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the lowest value of the range of the variable. |
|
||||
* |
|
||||
* @return The lowest value of the range of the variable. |
|
||||
*/ |
|
||||
int_fast64_t getLow() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the highest value of the range of the variable. |
|
||||
* |
|
||||
* @return The highest value of the range of the variable. |
|
||||
*/ |
|
||||
int_fast64_t getHigh() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the manager that is responsible for this meta variable. |
|
||||
* |
|
||||
* A pointer to the manager that is responsible for this meta variable. |
|
||||
*/ |
|
||||
std::shared_ptr<DdManager<Type>> getDdManager() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the number of DD variables for this meta variable. |
|
||||
* |
|
||||
* @return The number of DD variables for this meta variable. |
|
||||
*/ |
|
||||
std::size_t getNumberOfDdVariables() const; |
|
||||
|
|
||||
private: |
|
||||
/*! |
|
||||
* Retrieves the variables used to encode the meta variable. |
|
||||
* |
|
||||
* @return A vector of variables used to encode the meta variable. |
|
||||
*/ |
|
||||
std::vector<Dd<Type>> const& getDdVariables() const; |
|
||||
|
|
||||
/*! |
|
||||
* Retrieves the cube of all variables that encode this meta variable. |
|
||||
* |
|
||||
* @return The cube of all variables that encode this meta variable. |
|
||||
*/ |
|
||||
Dd<Type> const& getCube() const; |
|
||||
|
|
||||
// The name of the meta variable. |
|
||||
std::string name; |
|
||||
|
|
||||
// The type of the variable. |
|
||||
MetaVariableType type; |
|
||||
|
|
||||
// The lowest value of the range of the variable. |
|
||||
int_fast64_t low; |
|
||||
|
|
||||
// The highest value of the range of the variable. |
|
||||
int_fast64_t high; |
|
||||
|
|
||||
// The vector of variables that are used to encode the meta variable. |
|
||||
std::vector<Dd<Type>> ddVariables; |
|
||||
|
|
||||
// The cube consisting of all variables that encode the meta variable. |
|
||||
Dd<Type> cube; |
|
||||
|
|
||||
// A pointer to the manager responsible for this meta variable. |
|
||||
std::shared_ptr<DdManager<Type>> manager; |
|
||||
}; |
|
||||
|
// Declare DdMetaVariable class so we can then specialize it for the different DD types. |
||||
|
template<DdType Type> class DdMetaVariable; |
||||
} |
} |
||||
} |
} |
||||
|
|
||||
#endif /* STORM_STORAGE_DD_DDMETAVARIABLE_H_ */ |
|
||||
|
#endif /* STORM_STORAGE_DD_DDMETAVARIBLE_H_ */ |
Write
Preview
Loading…
Cancel
Save
Reference in new issue