|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
|
распараллеливание13.05.2013, 18:04. Показов 6400. Ответов 16
Метки нет (Все метки)
Скажите, кто-нибудь занимался распараллеливанием в си++? В моих попытках что-либо распараллелить через omp все выходило только в несколько раз медленнее. По сути у меня 8 ядер на ноуте, но их задействовать что-то не получается. По большей степени мне надо распараллеливать циклы. Если кто-то баловался
этим, то помогите мне рабочим примером.
0
|
|
| 13.05.2013, 18:04 | |
|
Ответы с готовыми решениями:
16
Распараллеливание циклов |
|
419 / 418 / 72
Регистрация: 27.05.2012
Сообщений: 1,168
|
|
| 13.05.2013, 18:21 | |
|
тебе нужна многопоточность, вообще многопроцессорность, но почитай про многопоточность))
0
|
|
|
Ушел с форума
|
|
| 13.05.2013, 18:34 | |
|
Можете описать на конкретных примерах, что именно не получается ?
0
|
|
|
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
|
|
| 13.05.2013, 18:39 | |
|
mat_for_c, Мне 1 раз надо было сделать прекальк расстановки магарадж, так вот я врубил 8 процессов независимых и даже не парился с openmp, кстати в omp нужно очень аккуратно.
0
|
|
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
|||||||
| 13.05.2013, 19:00 [ТС] | |||||||
и еще вопрос. Если в цикле используется контейнер vector<> и его метод push_back(), то можно ли распараллелить такой цикл?
0
|
|||||||
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
|||
| 13.05.2013, 19:24 | |||
|
Добавлено через 2 минуты
0
|
|||
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
|||||||
| 13.05.2013, 20:00 [ТС] | |||||||
0
|
|||||||
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
||
| 13.05.2013, 20:29 | ||
|
Функция clock ситает процессорное время. Воспользуйтесь какой-нибудь gettimeofday.
0
|
||
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
|||
| 14.05.2013, 11:30 [ТС] | |||
|
http://ccfit.nsu.ru/~kireev/lab1/lab1time.htm
0
|
|||
|
|
||||||
| 14.05.2013, 12:00 | ||||||
|
Время можно замерить при помощи самого OpenMP.
2
|
||||||
|
3258 / 2060 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
|
|
| 14.05.2013, 12:06 | |
|
mat_for_c, в статье говорится о времени процесса - т.е. о том времени, которое процесс занимал процессор. Оно точнее отражает время выполнения программы в многозадачной системе по сравнению с системным временем.
Функция clock возвращает количество тиков процессора. Т.е. если параллельно выполнялось два потока и время первого N, второго - K, то с использованием функции clock получим N+K. Ну выше уже написали, что в openmp есть функция для измерения времени.
0
|
|
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
|
| 14.05.2013, 18:47 [ТС] | |
|
lazybiz, а правильно ли я понимаю, что небольшие циклы распараллеливать смысла нет? скажем в вашем примере я j изменял до 1000 и при использовании omp работало только медленнее...
0
|
|
|
|
||
| 14.05.2013, 21:54 | ||
|
В данном примере распараллеливается только цикл с переменной i. Поэтому, если у цикла как минимум 2 итерации, то есть смысл его распараллелить.
0
|
||
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
||
| 14.05.2013, 22:12 [ТС] | ||
|
0
|
||
|
|
|
| 14.05.2013, 22:32 | |
|
У меня с 0 <= j < 1000, независимо от того, использую я OpenMP или нет, результат времени == 0. Т.е. это слишком "слабый" цикл.
Я понял что вы имеете в виду. Разумеется, что если вам заранее известно, что цикл занимает очень мало процессорного времени, то нет смысла его распаралелливать.
1
|
|
|
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
|
||||||
| 15.05.2013, 00:07 | ||||||
|
разные алгоритмы параллелятся с разной эффективностью. Тут смотреть как оно все масштабируется, что,
что там со всякими кеш промахами, какова нагрузка на шину данных и прочее. Вот пример тестиков немного разных циклов, запущенных в ДЕБАГЕ 12 студии (в релизе совсем другие цифры, т.к. код другой и распараллелилось соответственно по другому): Max threads = 8 ################################### Test1: serial time = 0.00319136 parallel time = 0.0707065 serial/parallel = 0.0451353 ################################### Test2: serial time = 3.358 parallel time = 1.0248 serial/parallel = 3.27672 ################################### Test3: serial time = 2.45181 parallel time = 0.722106 serial/parallel = 3.39536 Press any key to continue . . .
1
|
||||||
|
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
|
||
| 15.05.2013, 00:59 [ТС] | ||
|
так это что получается? если делать релизную версию, то там только для малых входных данных распараллеливание хорошо работает?
0
|
||
| 15.05.2013, 00:59 | |
|
Помогаю со студенческими работами здесь
17
Распараллеливание вычислений Распараллеливание программы Распараллеливание вычислений Странное распараллеливание Распараллеливание циклов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Рецензия / Мнение/ Перевод
https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs
. . .
|
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
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|