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

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

05.11.2011, 19:44. Показов 4472. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru