我正在尝试编写一个 C++ 类,允许我通过字符串查找访问某些矩阵元素。我想创建一个可以执行此操作的“静态”类,例如:
#include <unordered_map>
namespace Mine {
static double AA[3][4] = {
{5.04964676394959,-0.693207030363152,0.0422140829479668,-0.000968959310672217},
{2.6044054979329,0.288475262243944,-0.0208805589126506,0.000380899394040856},
{-4.32707864788065,1.07090008760872,-0.0777874445746693,0.00165150952598117}
};
static unordered_map<std::string, double[3][4]> Mine::parameter_store = { {"AA", AA}};
我的想法是我会有多个矩阵,并且可以根据键查找它们。但是,这似乎完全失败并出现以下错误:
error: object expression of non-scalar type 'double [3][4]' cannot be used in a pseudo-destructor expression
是否可以在 C++ 中以这种方式构建查找表?
最佳答案
#include <unordered_map>
#include <vector>
namespace Mine{
template<class T>
using Matrix = std::vector<std::vector<T>>;
Matrix<double> AA = {
{5.04964676394959,-0.693207030363152,0.0422140829479668,-0.000968959310672217},
{2.6044054979329,0.288475262243944,-0.0208805589126506,0.000380899394040856},
{-4.32707864788065,1.07090008760872,-0.0777874445746693,0.00165150952598117}
};
static std::unordered_map<std::string, Matrix<double>* > parameter_store = { {"AA", &AA}};
}
#include <iostream>
int main()
{
std::cout << (*Mine::parameter_store["AA"])[0][0] << std::endl;
std::cout << (*Mine::parameter_store["AA"])[0][1] << std::endl;
std::cout << (*Mine::parameter_store["AA"])[1][2] << std::endl;
}
输出
5.04965
-0.693207
-0.0208806
Matrix<>
此处使用的模板会导致每一行存储其长度,即使这是多余的。您可以通过使用 std::array
来避免这种情况(但是你被锁定在每个具有相同维度的矩阵中,因为这是类型信息的一部分)或者使用像 Boost 这样提供多维数组的库。不过,这是一个非常小的低效率问题,除非您知道自己需要这样做,否则最好不要担心这一点。
关于C++ - 如何将静态字典制作成查找矩阵,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28777903/