为了简单起见,请问用以下 Python 代码用 C++ 编写以下代码的最佳方法是什么
import numpy as np
X = np.array([1,2,3,...])
Y = np.array([10,11,12,...])
def funct(X,Y):
return 0.5 * X + 0.5 * 3 * Y
或者,为了不使用 Python 进行解释,有没有办法:
#include <vector>
std::vector<double> Z {};
std::vector<double> X {1,2,3,4};
std::vector<double> Y {5,6,7,8};
Z = 0.5 * X + 0.5 * 3 * Y; // something like this
最佳答案
也许 valarray
就是您所需要的:
#include <iostream>
#include <valarray>
int main() {
std::valarray<double> Z {};
std::valarray<double> X {1,2,3,4};
std::valarray<double> Y {5,6,7,8};
Z = 0.5 * X + 0.5 * 3 * Y;
for(auto v : Z) std::cout << v << '\n';
}
输出
8
10
12
14
注释来自 std::valarray
: "当两个参数是具有不同大小的 valarray 时,行为未定义。"
关于c++ - 使用两个 C++ vector 作为参数的 'complex' 操作函数的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66402373/