矢量和阵列通过误差
vector and array passing error
我正在编写一个基于多链Metropolis算法的程序,以找到给定函数的最小能量参数。这个程序基本上运行两次:
- 第一次多链老化运行,扫描参数空间,并在满足给定收敛标准时停止
- 探索性运行,对第一步中计算的收敛点周围的各种参数可能性进行采样,但仅使用一条链
对于每条链,我保存它通过的所有参数及其相应的能量。每条链的每一步都运行(除其他外(以下代码:
int Step(double * current_energy, vector<double> & energy){
energy.push_back(current_energy);
return 0;
}
问题是,在程序的第一部分,我将能量存储在中
vector< vector<double> > burn_energy;
让我可以在一个地方保存多个系列的能量。在第二部分中,我将能量存储在中
vector<double> explore_energy;
因为我只需要节省一系列的能量。
当我不得不调用这些步骤时,问题就出现了。对于第一部分,我会这样称呼他们:
Step(& current_energy[j], burn_energy[j]);
其中j表示链的数目。在第二部分中,由于只有一条链,调用将类似于:
Step(& current_energy, explore_energy);
我看不出我的实现有什么问题,但XCode在第一部分中给了我以下错误:
error: no matching function for call to 'std::vector<double, std::allocator<double> >::push_back(double*&)'
这是矢量能量或阵列current_energy
的元素通过的误差吗?
int Step(double * current_energy, vector<double> & energy)
应该是
int Step(double current_energy, vector<double> & energy)
编辑:
在OP发表评论后,我建议这样做;
int Step(double& current_energy, vector<double> & energy)
^^^^
在这种情况下,您可以在不使用任何指针语法的情况下更改当前能量。它被称为参考。
energy
是double
s的向量,但您正试图将double*
推到它上面。不要这样做。
相关文章:
- OpenMP阵列性能较差
- 为什么在浮点中从大到小会引入更多的误差
- 如何将三维尺寸不固定的三维阵列展平为一维阵列
- 当我的阵列太大时出现分段错误
- 位阵列上的快速AND运算
- 阵列必须使用大括号封闭的初始器进行初始化
- 没有从阵列<float>到阵列<int>的可行转换
- C++动态安全 2D 交错阵列
- 将平面阵列重塑为复杂的特征类型
- 如何使用英特尔 PIN 捕获阵列的所有负载?
- 为什么我能够为阵列分配比计算机实际拥有的内存更多的内存
- 库特<<恩德尔;不适用于打印 2D 阵列
- 数组类 阵列的打印输出
- 从较小的阵列到较大的阵列的元素级转换
- 仅在大型阵列上出现合并排序分段错误
- 从阵列C++中删除重复项
- 阵列的大小在C++中是否灵活?
- 反转阵列中的正序列
- 具有可变尺寸的 C++ 2D 阵列
- 矢量和阵列通过误差