8
OpenMP'de yeni. MSVS2010 ile yapılandırılmış Matlab mex kullanarak iyi derleyen aşağıdaki kod var. Bilgisayarda 8 işlemciye sahip (matlabpool kullanarak da kontrol ettim).OpenMP neden bir mex dosyasında sadece 1 iş parçacığı üretiyor?
#include "mex.h"
#include <omp.h>
typedef unsigned char uchar;
typedef unsigned int uint;
//Takes a uint8 input array and uint32 index array and preallocated uint8 array the same
//size as the first one and copies the data over using the indexed mapping
void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray*prhs[])
{
uint N = mxGetN(prhs[0]);
mexPrintf("n=%i\n", N); mexEvalString("drawnow");
uchar *input = (uchar*)mxGetData(prhs[0]);
uint *index = (uint*)mxGetData(prhs[1]);
uchar *output = (uchar*)mxGetData(prhs[2]);
uint nThreads, tid;
#pragma omp parallel private(tid) shared(input, index, output, N, nThreads) num_threads(8)
{
tid = omp_get_thread_num();
if (tid==0) {
nThreads = omp_get_num_threads();
}
for (int i=tid*N/nThreads;i<tid*N/nThreads+N/nThreads;i++){
output[i]=input[index[i]];
}
}
mexPrintf("nThreads = %i\n",nThreads);mexEvalString("drawnow");
}
alıyorum çıktı sadece bir dişin bana 8 talep rağmen oluşturulurken Neden
n=600000000
nThreads = 1
mı?
ile mexed gerekmektedir. – CptSupermrkt
Dergi olarak gcc ile linux altında eşdeğer seçenek nedir? -fopenmp? – linello
@linello Evet. Aslında sadece birkaç saatimi harcadım çünkü -fopenmp’i doğru bir şekilde geçemedim. Hem derleyiciye hem de bağlayıcıya iletmeniz gerekiyor. mex CXXFLAGS = "\ $ CXXFLAGS -fopenmp" LDFLAGS = "\ $ LDFLAGS -fopenmp" [Diğer seçenekler] C++ için '. (C için, CXXFLAGS yerine "CFLAGS" kullanın; hem C hem de C++ için her ikisini de kullanın.) –