1

我对 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' 没有可行的转换

有关如何转换的任何提示?

4

1 回答 1

1

mfcc_features_a是 类型Features,是vectors的一个FeatureVector;后者又是boost::array<T, feature_number>.

简而言之,您正在尝试将 a 分配boost::array<T, feature_number>给 a float。现在,假设模板参数TFeatureTypeDTW一个float(或可转换为浮点数的东西),这应该可以工作。

float MYFLOAT = mfcc_features_a[s][0];  // assigns first element of boost::array
                                        // to MYFLOAT
于 2013-03-29T06:28:38.310 回答