C++-如何制作查找矩阵的静态字典

C++ - How to Make Static Dictionary to Lookup Matrix

本文关键字:静态 字典 何制作 查找 C++-      更新时间:2023-10-16

我正在尝试编写一个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的库来提供多维数组。这是一个非常小的低效率,除非你知道你需要,否则最好不要担心。

您可以尝试在结构/类中包装double[3][4]

structure myMatrix {
double arr[3][4];
//if you want to initialize it 
myMatrix(double[3][4] p){
   //copy matrix here
}
};