Browse Source

fixed 'toIntegralVector' method

tempestpy_adaptions
TimQu 8 years ago
parent
commit
b3507b8f96
  1. 13
      src/storm/utility/vector.h

13
src/storm/utility/vector.h

@ -872,7 +872,7 @@ namespace storm {
} }
template<typename ValueType, typename TargetValueType> template<typename ValueType, typename TargetValueType>
typename std::enable_if<std::is_same<ValueType, storm::RationalFunction>::value, std::pair<std::vector<TargetValueType>, ValueType>>::type
typename std::enable_if<std::is_same<ValueType, storm::RationalNumber>::value, std::pair<std::vector<TargetValueType>, ValueType>>::type
toIntegralVector(std::vector<ValueType> const& vec) { toIntegralVector(std::vector<ValueType> const& vec) {
// Collect the numbers occurring in the input vector // Collect the numbers occurring in the input vector
@ -910,7 +910,7 @@ namespace storm {
// Build the result // Build the result
std::vector<TargetValueType> result; std::vector<TargetValueType> result;
result.resize(vec.size());
result.reserve(vec.size());
for (auto const& v : vec) { for (auto const& v : vec) {
result.push_back(storm::utility::convertNumber<TargetValueType, ValueType>(v / factor)); result.push_back(storm::utility::convertNumber<TargetValueType, ValueType>(v / factor));
STORM_LOG_ASSERT(storm::utility::isInteger(result.back()), "Resulting number '" << result.back() << "' is not integral."); STORM_LOG_ASSERT(storm::utility::isInteger(result.back()), "Resulting number '" << result.back() << "' is not integral.");
@ -920,10 +920,13 @@ namespace storm {
} }
template<typename ValueType, typename TargetValueType> template<typename ValueType, typename TargetValueType>
typename std::enable_if<!std::is_same<ValueType, storm::RationalFunction>::value, std::pair<std::vector<TargetValueType>, ValueType>>::type
typename std::enable_if<!std::is_same<ValueType, storm::RationalNumber>::value, std::pair<std::vector<TargetValueType>, ValueType>>::type
toIntegralVector(std::vector<ValueType> const& vec) { toIntegralVector(std::vector<ValueType> const& vec) {
STORM_LOG_THROW(false, storm::exceptions::NotImplementedException, "Functionality not implemented.");
return std::pair<std::vector<TargetValueType>, ValueType>();
// TODO: avoid converting back and forth
auto rationalNumberVec = convertNumericVector<storm::RationalNumber>(vec);
auto rationalNumberResult = toIntegralVector<storm::RationalNumber, TargetValueType>(rationalNumberVec);
return std::make_pair(std::move(rationalNumberResult.first), storm::utility::convertNumber<ValueType>(rationalNumberResult.second));
} }
template<typename Type> template<typename Type>

Loading…
Cancel
Save