Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/22: Рейтинг темы: голосов - 22, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 21.11.2009
Сообщений: 73

Помогите распараллелить цикл!!!

05.11.2011, 19:44. Показов 4482. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Эксперты помогите, распараллелить консольное приложение на два(или четыре) ядра. Раньше ни когда не сталкивался с этим, даже не знаю, что лучше использовать (MPI, OpenMP, и т.п.)

В задаче требуется вычислить n максимальных значений, значений произведений элементов двух исходных массивов.

Саму программу без распараллеливания я написал:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include<iostream>;
#include<ctime>;
    using namespace std;                //*****************************************************//
int main()                              //  В задании требуется создать массив(С) максимальных //
{                                       //  значений, произведений элементов двух исходных     //
    setlocale(LC_ALL, "Russian");       //  массивов(А и В)используя параллельное вычисление.  //
    srand(time(0));                     //*****************************************************//
 
    int i,j,n,A[100],B[100],T,k,min;
    
    cout<<"\n  Размер массива С: ";
    cin>>n;
    int *C = new int[n];                // Создаем динам. массив с размерностью n (n<10000)
 
    for(i=0;i<100;i++)                  //
    {                                   //  Заполняем два исходных массива А[100] и B[100]
        A[i]=rand()%19-9;               //  случайными числами 
        B[i]=rand()%19-9;               //
        cout<<A[i]<<"\t"<<B[i]<<endl;   //
    }
    for(i=0;i<10;i++)                   //  Начало фрагмента для распараллеливания
        for(j=0;j<10;j++)
        {
            T=A[i]*B[j];
            if((i*10+j+1)<=n)
                C[i*10+j]=T;
            else
            {
                min=0;
                for(k=1;k<n;k++)
                    if(C[min]>C[k])
                        min=k;
                if(T>C[min])
                    C[min]=T;
            }
        }                               //  Конец фрагмента для распараллеливания
    for(k=0;k<n;k++)
        cout<<C[k]<<" ";
    cout<<endl;
    system("pause");
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.11.2011, 19:44
Ответы с готовыми решениями:

Распараллелить цикл
Распараллелить цикл: For(i=2;i&lt;N;i++) For(j=2;i&lt;N;j++) A =A +A; #include &lt;iostream&gt; #include &lt;omp.h&gt; #include...

Не получается распараллелить цикл
Добрый день! В ходе опытов я выяснил, что распараллеливание цикла for с помощью OMP не приносит выигрыша во времени. Т.е. код...

Как распараллелить цикл while?
Доброго времени суток. При распараллелировании применять технологии Openmp. Было бы здорово, если бы ответ на вопрос, что в заглавии,...

1
1080 / 1007 / 107
Регистрация: 28.02.2010
Сообщений: 2,889
06.11.2011, 09:15
Лучший ответ Сообщение было отмечено Unikum как решение

Решение

Это ставьте где-нибудь в начале программы:
C
1
2
3
4
5
6
7
8
#ifdef _OPENMP
    puts("OpenMP is supported!");
    //omp_set_dynamic(0);      // запретить библиотеке openmp менять число потоков во время исполнения
    //omp_set_num_threads(10); // установить число потоков в 10
#else
    puts("OpenMP is NOT supported!");
    return 0;
#endif
Цикл выглядит примерно так:
В private указываете переменные чьи "экземпляры" должны быть на отдельных потоках.
В shared указываете общие переменные.
Я сам не все указал.
C
1
2
3
4
5
6
7
8
#pragma omp parallel shared(A,B) private(i, j, k)
{
#pragma omp for
    for (i = 0; i < 10; i++)
    {
        ...
    }
}
Кстати, я сомневаюсь что в Вашем фрагменте применять параллельные можно. Может случится, что в каком-то потоке какой-то элемент массива C не определен и производится попытка получить значение.

Компилируйте с поддержкой OpenMP. Для gcc указываете -fopenmp в качестве параметра. Если у Вас не gcc - используйте поиск.
OpenMP только недавно начал изучать. Поэтому не рассчитывайте что отвечу на Ваши вопросы.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.11.2011, 09:15
Помогаю со студенческими работами здесь

Распараллелить цикл со сложной индексацией используя OpenMP
Пусть есть такой цикл, преобразующий массив: #define N 6 #define RADIUS 1 int arr; int flag; int x,y; do { flag = 0;

Цикл for/Цикл while Помогите срочно пожалуйста...
1.Вычислить и вывести на экран в виде таблицы значения функции F от x1 до x2 с шагом dx. где a, b и c - действительные числа. 2.Цикл...

Помогите найти ошибку в коде(цикл for проходит не по всем элементам массива)
#include &quot;stdafx.h&quot; #include &quot;iostream&quot; #include &lt;clocale&gt; #include &lt;stdio.h&gt; #include &lt;math.h&gt; using namespace std; int...

Распараллелить For
#include &lt;QCoreApplication&gt; #include &lt;iostream&gt; #include &lt;cstdlib&gt; #include &lt;ctime&gt; #include &lt;omp.h&gt; using namespace std; ...

помогите сделать цикл,чтобы выводило ряд Фибоначии до определенного числа N которое я ввела с клавиатуры.
есть у меня код рекурсии по нахождению числа фибоначчи за номером. помогите сделать цикл,чтобы выводило ряд Фибоначии до определенного...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru