Странные результаты, когда я вызываю метод класса C ++ внутри цикла openmp - PullRequest
0 голосов
/ 04 июля 2018

Доброе утро, люди.

Я создал код, работающий в однопоточном режиме, и пытаюсь адаптировать его в многопоточном режиме. Я использую метод, очень похожий на MARCH :: RUN_PAR в однопоточном режиме, с хорошими результатами, но когда я пытаюсь выполнить в многопоточном режиме (используя Openmp), результаты слишком странные.

Кто-то может мне помочь в этом вопросе?

Следуйте ниже моего куска кода:

void MI_MARCH::RUN_PARALELO(double zt,double ***Vpar,int mt,int red_yred,int prof,int tam) {

        int RANK, numero_proc_parall;
        int shift,cont,m,rredy;
        //start the number of (possible) threads
        numero_proc_parall = tam;   
        //shift the loop of threads
        shift = 0;
        //the necessary total number of threads
        cont = prof;
        //set the number of threads
        omp_set_num_threads(numero_proc_parall);    
        //argument initialization    
        rredy = red_yred;   

        MARCH VETOR_MARCH[numero_proc_parall];  //vector of class   

        //open the parallel section
        #pragma omp parallel shared(cont,shift,numero_proc_parall) private(red_yred,RANK,m)
        {

            while(cont > 0)
            {

                #pragma omp critical
                std::cout<<"[MI_MARCH RUN_PAR] loop cont "<<cont<<" shift "<<shift<<" numero_proc_parall "<<numero_proc_parall<<"\n";           
                #pragma omp for
                for(m=0;m<numero_proc_parall;m++) //loop de profundidade
                {
                    //atualize the rank 
                    RANK = omp_get_thread_num();
                    //set the reference
                    red_yred = rredy + m + shift            
                    //run the method of the MARCH class
                    VETOR_MARCH[m].RUN_PAR(zt,Vpar[m],mt,red_yred,RANK + shift);                
                }   
                //execute only in the master thread
                #pragma omp master
                {
                    //increment the shift variable
                    shift = shift + numero_proc_parall;
                    //decrement the loop control
                    cont = cont - numero_proc_parall;
                    //verify if the process is greater than controller  
                    if(cont<numero_proc_parall)
                    {
                        //set a new number of parallel process
                        numero_proc_parall = cont;
                    }                               
                }
                #pragma omp barrier //waiting other process
            }       
        }
    }   

Метод MARCH :: RUN_PAR:

    void MARCH::RUN_PAR(double zt,double **Vxy,int mt,int red_yred,int RANK);
    {

        int xf,yf;    
        xf = 100;
        yf = 100; 

        //execute this piece of code in critical mode
        #pragma omp critical
        {       

            for(int i=0;i<xf;i++)
            {
                 for(int j=0;j<yf;j++)
                {           
                    Vcopia[i][j] = Vxy[i][j];  //Vcopia is a member of MARCH class
                }
            }

        }

        V_H(Vcopia,xf,yf,red_yred); //this method is a member of MARCH class

        CALC(mt,zt,RANK); //this method is a member of MARCH class

    }

...
    class MARCH{
    public: 
    ...
      void RUN_PAR(double zt,double **Vxy,int mt,int red_yred,int RANK);

    private:    
    ...
      double **Vcopia;
    ...
      void V_H(double **Vcopia,int xf,int yf,int red_yred); 

      void CALC(int mt,double zt,int RANK); 
    };

Неправильные результаты, по-видимому, появляются в последовательном режиме.

Правильный результат в однопоточном режиме - это изображение: Правильное изображение

Неправильное использование нескольких потоков - это изображение, подобное этому: Неправильное изображение

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...