我对 C++ 的经验很少或根本没有,所以问题可能听起来很奇怪,问题是我有一个包含浮点值的 std::vector,我想通过迭代它来从中提取浮点值。
向量的定义代码如下:
template <typename T, size_t feature_number>
T vector_distance(const boost::array<T, feature_number>& v1,
const boost::array<T, feature_number>& v2);
template <typename T = double, size_t feature_number=3>
class CLASSNAME
{
public:
typedef boost::array<T, feature_number> FeatureVector;
typedef std::vector<FeatureVector> Features;
...
我通过以下方式使用它:
FeatureTypeDTW::Features mfcc_features_a = METHODTHATRETURNSVECTOR();
for (int s = 0; s < (int) mfcc_features_a.size(); s++)
{
float MYFLOAT = mfcc_features_a[s];
}
但我得到的编译错误是:
从 'boost::array (float, 7)' 到 'float' 没有可行的转换
有关如何转换的任何提示?