Browse Source

Removed the parameter from const templates, as types can be stated

explicitly (see documentation)
tempestpy_adaptions
Lanchid 12 years ago
parent
commit
48098b596d
  1. 4
      src/formula/ProbabilisticIntervalOperator.h
  2. 14
      src/modelChecker/EigenDtmcPrctlModelChecker.h
  3. 7
      src/storage/SquareSparseMatrix.h
  4. 76
      src/utility/ConstTemplates.h

4
src/formula/ProbabilisticIntervalOperator.h

@ -49,8 +49,8 @@ public:
* Empty constructor * Empty constructor
*/ */
ProbabilisticIntervalOperator() { ProbabilisticIntervalOperator() {
upper = mrmc::utility::constGetZero(upper);
lower = mrmc::utility::constGetZero(lower);
upper = mrmc::utility::constGetZero<T>();
lower = mrmc::utility::constGetZero<T>();
pathFormula = NULL; pathFormula = NULL;
} }

14
src/modelChecker/EigenDtmcPrctlModelChecker.h

@ -64,9 +64,7 @@ public:
std::vector<Type>* result = new std::vector<Type>(stateCount); std::vector<Type>* result = new std::vector<Type>(stateCount);
// Dummy Type variable for const templates
Type dummy;
mrmc::utility::setVectorValues(result, *rightStates, mrmc::utility::constGetOne(dummy));
mrmc::utility::setVectorValues(result, *rightStates, mrmc::utility::constGetOne<Type>());
Type *p = &((*result)[0]); // get the address storing the data for result Type *p = &((*result)[0]); // get the address storing the data for result
MapType vectorMap(p, result->size()); // vectorMap shares data MapType vectorMap(p, result->size()); // vectorMap shares data
@ -94,8 +92,8 @@ public:
// Create the vector with which to multiply and initialize it correctly. // Create the vector with which to multiply and initialize it correctly.
std::vector<Type> x(this->getModel().getNumberOfStates()); std::vector<Type> x(this->getModel().getNumberOfStates());
Type dummy;
mrmc::utility::setVectorValues(&x, *nextStates, mrmc::utility::constGetOne(dummy));
mrmc::utility::setVectorValues(&x, *nextStates, mrmc::utility::constGetOne<Type>());
// Delete not needed next states bit vector. // Delete not needed next states bit vector.
delete nextStates; delete nextStates;
@ -213,10 +211,8 @@ public:
delete eigenSubMatrix; delete eigenSubMatrix;
} }
// Dummy Type variable for const templates
Type dummy;
mrmc::utility::setVectorValues<Type>(result, notExistsPhiUntilPsiStates, mrmc::utility::constGetZero(dummy));
mrmc::utility::setVectorValues<Type>(result, alwaysPhiUntilPsiStates, mrmc::utility::constGetOne(dummy));
mrmc::utility::setVectorValues<Type>(result, notExistsPhiUntilPsiStates, mrmc::utility::constGetZero<Type>());
mrmc::utility::setVectorValues<Type>(result, alwaysPhiUntilPsiStates, mrmc::utility::constGetOne<Type>());
return result; return result;
} }

7
src/storage/SquareSparseMatrix.h

@ -742,12 +742,12 @@ public:
uint_fast64_t rowEnd = rowIndications[row + 1]; uint_fast64_t rowEnd = rowIndications[row + 1];
while (rowStart < rowEnd) { while (rowStart < rowEnd) {
valueStorage[rowStart] = mrmc::utility::constGetZero(valueStorage[rowStart]);
valueStorage[rowStart] = mrmc::utility::constGetZero<T>();
++rowStart; ++rowStart;
} }
// Set the element on the diagonal to one. // Set the element on the diagonal to one.
diagonalStorage[row] = mrmc::utility::constGetOne(diagonalStorage[row]);
diagonalStorage[row] = mrmc::utility::constGetOne<T>();
return true; return true;
} }
@ -885,10 +885,9 @@ public:
// no entries apart from those on the diagonal // no entries apart from those on the diagonal
resultDinv->initialize(0); resultDinv->initialize(0);
// copy diagonal entries to other matrix // copy diagonal entries to other matrix
T dummy;
for (int i = 0; i < rowCount; ++i) { for (int i = 0; i < rowCount; ++i) {
resultDinv->addNextValue(i, i, resultLU->getValue(i, i)); resultDinv->addNextValue(i, i, resultLU->getValue(i, i));
resultLU->getValue(i, i) = mrmc::utility::constGetZero(&dummy);
resultLU->getValue(i, i) = mrmc::utility::constGetZero<T>();
} }
return new mrmc::storage::JacobiDecomposition<T>(resultLU, resultDinv); return new mrmc::storage::JacobiDecomposition<T>(resultLU, resultDinv);

76
src/utility/ConstTemplates.h

@ -17,75 +17,97 @@ namespace utility {
* As (at least) gcc has problems to use the correct template by the return value * As (at least) gcc has problems to use the correct template by the return value
* only, the function gets a pointer as a parameter to infer the return type. * only, the function gets a pointer as a parameter to infer the return type.
* *
* <b>Parameter</b>
* @note
* The template parameter is just inferred by the return type; GCC is not able to infer this
* automatically, hence the type should always be stated explicitly (e.g. @c constGetZero<int>();)
* *
* The parameter is a reference which is used to infer the return type (So, if you want
* the return value to be of type double, the parameter has to be a double variable).
* In most cases, it is a good choice to use the the variable that is to be set.
* @return Value 0, fit to the return type
*/ */
template<typename _Scalar> template<typename _Scalar>
static inline _Scalar constGetZero(_Scalar&) {
static inline _Scalar constGetZero() {
return _Scalar(0); return _Scalar(0);
} }
/*! @cond TEMPLATE_SPECIALIZATION /*! @cond TEMPLATE_SPECIALIZATION
* (exclude the specializations from the documentation) */
* (By default, the template specifications are not included in the documentation)
*/
/*!
* Template specification for int_fast32_t
* @return Value 0, fit to the type int_fast32_t
*/
template <> template <>
inline int_fast32_t constGetZero(int_fast32_t&) {
inline int_fast32_t constGetZero() {
return 0; return 0;
} }
/*! @cond TEMPLATE_SPECIALIZATION
* (exclude the specializations from the documentation) */
/*!
* Template specification for uint_fast64_t
* @return Value 0, fit to the type uint_fast64_t
*/
template <> template <>
inline uint_fast64_t constGetZero(uint_fast64_t&) {
inline uint_fast64_t constGetZero() {
return 0; return 0;
} }
/*! @cond TEMPLATE_SPECIALIZATION
* Specialization of constGetZero for double
/*!
* Template specification for double
* @return Value 0.0, fit to the type double
*/ */
template <> template <>
inline double constGetZero(double&) {
inline double constGetZero() {
return 0.0; return 0.0;
} }
/*! @endcond */ /*! @endcond */
/*! /*!
* Returns a constant value of 0 that is fit to the type it is being written to.
* Returns a constant value of 1 that is fit to the type it is being written to.
* As (at least) gcc has problems to use the correct template by the return value * As (at least) gcc has problems to use the correct template by the return value
* only, the function gets a pointer as a parameter to infer the return type. * only, the function gets a pointer as a parameter to infer the return type.
* *
* <b>Parameter</b>
* @note
* The template parameter is just inferred by the return type; GCC is not able to infer this
* automatically, hence the type should always be stated explicitly (e.g. @c constGetOne<int>();)
* *
* The parameter is a reference which is used to infer the return type (So, if you want
* the return value to be of type double, the parameter has to be a double variable).
* In most cases, it is a good choice to use the the variable that is to be set. */
* @return Value 1, fit to the return type
*/
template<typename _Scalar> template<typename _Scalar>
static inline _Scalar constGetOne(_Scalar&) {
static inline _Scalar constGetOne() {
return _Scalar(1); return _Scalar(1);
} }
/*! @cond TEMPLATE_SPECIALIZATION /*! @cond TEMPLATE_SPECIALIZATION
* (exclude the specializations from the documentation) */
* (By default, the template specifications are not included in the documentation)
*/
/*!
* Template specification for int_fast32_t
* @return Value 1, fit to the type int_fast32_t
*/
template<> template<>
inline int_fast32_t constGetOne(int_fast32_t&) {
inline int_fast32_t constGetOne() {
return 1; return 1;
} }
/*! @cond TEMPLATE_SPECIALIZATION
* (exclude the specializations from the documentation) */
/*!
* Template specification for uint_fast64_t
* @return Value 1, fit to the type uint_fast61_t
*/
template<> template<>
inline uint_fast64_t constGetOne(uint_fast64_t&) {
inline uint_fast64_t constGetOne() {
return 1; return 1;
} }
/*! @cond TEMPLATE_SPECIALIZATION
* (exclude the specializations from the documentation) */
/*!
* Template specification for double
* @return Value 1.0, fit to the type double
*/
template<> template<>
inline double constGetOne(double&) {
inline double constGetOne() {
return 1.0; return 1.0;
} }
/*! @endcond */ /*! @endcond */
} //namespace utility } //namespace utility

Loading…
Cancel
Save