如何命名一个带有索引的变量来存储输入的mxArray?

How to name a variable with index to store the input mxArray?

我想实现一个将mxArray(来自Matlab)的输入变量转换为C++的功能。详细来说,如果输入变量是一个单元格,它将被排列成一个向量。(根据建议编辑)如下所示,

#include "mex.h"
#include <vector>
#include <iostream>
#include <algorithm>
#include <omp.h>
#include <map>
#include <string>
using namespace std;

vector<vector<int>> transfer(const mxArray* ix)
{
    mwSize Num = mxGetNumberOfElements(ix);
    mxArray* ptr = NULL;
    mxDouble* ptr_double;
    vector<vector<int>> V(Num);
    mwSize Num0;
    int i,j;
    for (i = 0; i < (int)Num; i++) {
        ptr = mxGetCell(ix, i);
        Num0 = mxGetNumberOfElements(ptr);
        ptr_double = mxGetPr(ptr);
        for (j = 0; j < (int)Num0; j++) {
            V[i].push_back(*ptr_double++);
        }
    }
    return V;
}
void mexFunction(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[])
{
    for (int i = 0; i < nrhs; i++) {
        if (mxIsCell(prhs[i])) {
            vector<vector<int>>  V1 = transfer(prhs[i]);
            for (int j = 0; j < V1.size(); j++)
            {   
                for (int k = 0; k < V1[j].size(); k++) {
                    mexPrintf("  %d", V1[j][k]);
                }
                mexPrintf("\n size is %d\n", V1[j].size());
            }
        }
       //else
    }
    return;
}

我现在无法命名上述变量。我必须命名与索引 i(示例中的 1)相对应的变量(如 V1)。但我不知道如何在c++中实现它。你能告诉我如何用 C++ 实现吗?

我在互联网上搜索了一下,发现在 C++ 中似乎不可能有一个动态名称。如果这是真的,谁能知道如何安排这些输入变量,哪种类型是 vector> 和 double array?也许结构?那么如何动态初始化结构对我来说是一个更大的挑战。 此外,我想这样做是因为我使用的是 OpenMP,它在并行循环中不能有任何与 Matlab 相关的变量或指针。我必须将所有数据从 mx- 复制到 C++ 支持的类型数据(如 vector)。

除法函数。

顺便说一句,new mxArray * [Num] 是个坏主意。使用 std::vector<mxArray>

void transfer_impl(vector<vector<int>>& V, mxDouble*& ptr, mwSize Num0){
    for (mwSize i = 0; j < Num0; j++) {
        V[i].push_back(*ptr_double++);
    }
}

Because the OpenMP is always crash

您应该考虑使用 C++17 并行算法。

可能是这样的:

#include "mex.h"
#include <vector>
#include <iostream>
#include <algorithm>
#include <omp.h>
#include <map>
#include <string>
using namespace std;

vector<vector<double>> transfer(const mxArray* ix) // changed to double
{
    mwSize Num = mxGetNumberOfElements(ix);
    mxArray* ptr = NULL;
    mxDouble* ptr_double;
    vector<vector<double>> V(Num); // changed to double
    mwSize Num0;
    int i,j;
    for (i = 0; i < (int)Num; i++) {
        ptr = mxGetCell(ix, i);
        if( ptr ) { // check for NULL pointer
            if( !mxIsDouble(ptr) || mxIsComplex(ptr) || mxIsSparse(ptr) ) { // check for proper type etc.
                mexErrMsgTxt("cell must contain full real double");
            }
            Num0 = mxGetNumberOfElements(ptr);
            ptr_double = mxGetPr(ptr);
            for (j = 0; j < (int)Num0; j++) {
                V[i].push_back(*ptr_double++);
            }
        }
    }
    return V;
}
void mexFunction(int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[])
{
        for (int i = 0; i < nrhs; i++) {
        if (mxIsCell(prhs[i])) {
            vector<vector<double>>  V1 = transfer(prhs[i]); // changed to double
            for (int j = 0; j < V1.size(); j++)
            {   
                for (int k = 0; k < V1[j].size(); k++) {
                    mexPrintf("  %g", V1[j][k]); // changed to %g
                }
                mexPrintf("\n size is %d\n", V1[j].size());
            }
        }
       //else
    }
    return;
}