все! Печатать из Италии
Этот маленький кусочек кода работает, если размер матрицы меньше 800, и приводит к ошибке сегментации для больших размеров ....
Я пробовал это с компилятором gcc 4.3.2 в Linux и Macosx и компилятором VisualStudio в Windows.
Кажется, проблема в размере стека ..... как я могу увеличить его?
Как я могу решить проблему для больших размеров матрицы?
Код работает нормально в последовательных путах, при параллельном выполнении.
Спасибо.
#include <omp.h>
#include <stdio.h>
#define Nu 4000
int main() {
float A[Nu][Nu],B[Nu][Nu],C[Nu][Nu];
int i,j;
#pragma omp parallel
printf("Hello from thread %d, nthreads %d\n", omp_get_thread_num(), omp_get_num_threads());
#pragma omp parallel for private(j,i) shared(A,B,C) schedule(static)
for(j=0;j<Nu;j++){
for(i=0;i<Nu;i++){
//printf("Hello from thread %d, i,j %d %d\n", omp_get_thread_num(),i,j );
A[i][j]=0;
B[i][j]=0;
C[i][j]=0;
}}
}