Как мне использовать zero_vector для инициализации в boost / C++?
Я искал один из ответов на: заполнение вектора или матрицы форсирования, но я думаю, что я новичок в форсировании (и xcode, если на то пошло), и пытаюсь обернуть голову вокруг нулевого вектора форсирования.
Я попробовал простую программу, которая, по моему мнению, была примерно такой же, как один из ответов:
#include <boost/numeric/ublas/vector.hpp>
#include <boost/numeric/ublas/io.hpp>
int main (int argc, char * const argv[]) {
// insert code here...
using namespace boost::numeric::ublas;
int gameSize = 9;
typedef vector<int> possiblesVector;
possiblesVector foo;
foo.resize(gameSize);
foo = zero_vector<int>(gameSize);
std::cout << foo << std::endl;
return 0;
}
который компилируется, но когда он запускается, я получаю ошибку времени выполнения (заменяя реальный путь "/PATH/TO").
Check failed in file /PATH/TO/boost_1_48_0/boost/numeric/ublas/detail/vector_assign.hpp at line 370:
detail::expression_type_check (v, cv)
terminate called after throwing an instance of 'boost::numeric::ublas::external_logic'
what(): external logic or bad condition of inputs
Program received signal: “SIGABRT”.
sharedlibrary apply-load-rules all
Здесь я просто использую один main.cpp в качестве тестовой области. В моей настоящей программе у меня есть объявления, разделенные на файл.h, и мои инициализации в файле.cpp моего объекта. Но приведенный выше код не работает так же, как моя настоящая программа. (т.е. почему я делю объявление и инициализацию на 2 шага)
Кроме того, я знаю, что изменение размера уже инициализируется до нуля. Возможно, я вместо этого сделаю scalar_vector, или, возможно, мне нужно будет позже сбросить массив или что-то в этом роде. Я просто пытался изолировать код, который ломается.
1 ответ
template<template <class T1, class T2> class F, class V, class E>
// BOOST_UBLAS_INLINE This function seems to be big. So we do not let the compiler inline it.
void vector_assign (V &v, const vector_expression<E> &e, sparse_tag) {
BOOST_UBLAS_CHECK (v.size () == e ().size (), bad_size ());
typedef F<typename V::iterator::reference, typename E::value_type> functor_type;
BOOST_STATIC_ASSERT ((!functor_type::computed));
typedef typename V::value_type value_type;
#if BOOST_UBLAS_TYPE_CHECK
vector<value_type> cv (v.size ());
indexing_vector_assign<scalar_assign> (cv, v);
indexing_vector_assign<F> (cv, e);
#endif
v.clear ();
typename E::const_iterator ite (e ().begin ());
typename E::const_iterator ite_end (e ().end ());
while (ite != ite_end) {
value_type t (*ite);
if (t != value_type/*zero*/())
v.insert_element (ite.index (), t);
++ ite;
}
#if BOOST_UBLAS_TYPE_CHECK
if (! disable_type_check<bool>::value)
BOOST_UBLAS_CHECK (detail::expression_type_check (v, cv),
external_logic ("external logic or bad condition of inputs"));
#endif
}
где v ваш vector<int> possiblesVector
и это временно zero_vector<int>
// Weak equality check - useful to compare equality two arbitary vector expression results.
// Since the actual expressions are unknown, we check for and arbitary error bound
// on the relative error.
// For a linear expression the infinity norm makes sense as we do not know how the elements will be
// combined in the expression. False positive results are inevitable for arbirary expressions!
template<class E1, class E2, class S>
BOOST_UBLAS_INLINE
bool equals (const vector_expression<E1> &e1, const vector_expression<E2> &e2, S epsilon, S min_norm) {
return norm_inf (e1 - e2) < epsilon *
std::max<S> (std::max<S> (norm_inf (e1), norm_inf (e2)), min_norm);
}
template<class E1, class E2>
BOOST_UBLAS_INLINE
bool expression_type_check (const vector_expression<E1> &e1, const vector_expression<E2> &e2) {
typedef typename type_traits<typename promote_traits<typename E1::value_type,
typename E2::value_type>::promote_type>::real_type real_type;
return equals (e1, e2, BOOST_UBLAS_TYPE_CHECK_EPSILON, BOOST_UBLAS_TYPE_CHECK_MIN);
}
проверьте функции.
Все элементы zero_vector равны 0, поэтому после
v.clear ();
typename E::const_iterator ite (e ().begin ());
typename E::const_iterator ite_end (e ().end ());
while (ite != ite_end) {
value_type t (*ite);
if (t != value_type/*zero*/())
v.insert_element (ite.index (), t);
++ ite;
}
вектор v оставлен пустым и проверка не удалась. Попробуй использовать double
или же float
вместо int
,