使用C++缩小2D-Vector

我想深入研究神经网络,因此我想编写自己的C++矩阵类。问题是我对C++也比较新手,为了保持简单,我想使用std::vector而不是2D数组。目前我的类大致如下:

class Matrix {private:    std::vector<std::vector<float>> data_;public:    Matrix(const int& rows, const int& columns);};

我知道std::vector会带来一些额外的开销,但我希望将这种开销尽可能地减小,只将向量调整到所需的精确大小:

Matrix::Matrix(const int &rows, const int &columns) {    this->data_ = std::vector<std::vector<float>>{};    this->data_.resize(rows);    for (auto col : this->data_) {        col.resize(columns);    }}

我的问题是:这种缩小方法是否如我所愿,或者有没有更好的方法来做这件事?

非常感谢!


回答:

缩小意味着变小。在构造函数的上下文中,我认为你指的是扩大

你的解决方案并不是完全正确的,因为你的for循环调整的是你想要调整的向量的副本的大小。

虽然不那么重要,但值得一提的是:此外,你还对一个空向量进行了不必要的复制来初始化data_。事实上,当你进入构造函数的主体时,所有的成员都已经被构建了。最后,使用this->来访问成员也不是必须的,除非与参数名存在歧义:

Matrix::Matrix(const int &rows, const int &columns) {    data_.resize(rows);    for (auto& col : data_) {   // 注意这里的&,用于调整向量中的向量的大小         col.resize(columns);    }}

补充说明:

你还可以为成员的构造函数提供显式的参数:

Matrix::Matrix(const int &rows, const int &columns) : data_(rows) {    for (auto& col : data_) {        col.resize(columns);    }}

如果你喜欢简洁,你甚至可以这样做:

Matrix::Matrix(const int &rows, const int &columns) : data_(rows, vector<float>(columns)) {}

Related Posts

为什么我们在K-means聚类方法中使用kmeans.fit函数?

我在一个视频中使用K-means聚类技术,但我不明白为…

如何获取Keras中ImageDataGenerator的.flow_from_directory函数扫描的类名?

我想制作一个用户友好的GUI图像分类器,用户只需指向数…

如何查看每个词的tf-idf得分

我试图了解文档中每个词的tf-idf得分。然而,它只返…

如何修复 ‘ValueError: Found input variables with inconsistent numbers of samples: [32979, 21602]’?

我在制作一个用于情感分析的逻辑回归模型时遇到了这个问题…

如何向神经网络输入两个不同大小的输入?

我想向神经网络输入两个数据集。第一个数据集(元素)具有…

逻辑回归与机器学习有何关联

我们正在开会讨论聘请一位我们信任的顾问来做机器学习。一…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注