Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2013.03.22;
Скачать: CL | DM;

Вниз

OpenMP vs Multithread   Найти похожие ветки 

 
DevilDevil ©   (2012-07-13 16:34) [0]

Честно говоря, не много кода создал, использующего разные потоки, синхронизации, общую память.

С OpenMP не работал, да и вообще на С++ с потоками не имел дело.
Но интересно стало подискутировать о плюсах и минусах разных подходов, о взаимозаменяемости.

Если я правильно понял, то OpenMP в основе своей использует старые добрые потоки. Мощь OpenMP состоит в том, что программист автоматически освобождается от тонны рутины, связанной с созданием, удалением и синхронизацией потоков. Это прекрасно, но универсальное средство не всегда эффективнее ручного. И если ты до конца не разбираешься, как оно работает - рискуешь не довести оптимизацию до желаемого результата.

Собственно вопросов несколько. Если есть дополнительные моменты которые хотелось бы осветить - пожалуйста выражайтесь
- помогает ли OpenMP при программировании кластеров ? Как кластеры устроены - я не знаю, интересует вопрос теоретически
- какое оптимальное количество потоков на ядро ? Чисто теоретически - чем больше потоков, тем больше вероятность выиграть вычислительную мощь в борьбе между потоками
- чем обусловлен параметр num_threads в OpenMP ? Разве он не должен вычисляться автоматически ?
- имеет ли смысл явно задавать высокий приоритет при создании потоков ?
- каким образом эффективно учитывать технологию HyperThreading ?


 
TUser ©   (2012-07-13 17:00) [1]


> - помогает ли OpenMP при программировании кластеров ? Как
> кластеры устроены - я не знаю, интересует вопрос теоретически

OpenMPI помогает. Если программа для кластера, то она должна уметь распараллеливаться, и это делается через эту библиотеку.

зы. Сам не писал такого, питаюсь слухами.

> - какое оптимальное количество потоков на ядро ? Чисто теоретически
> - чем больше потоков, тем больше вероятность выиграть вычислительную мощь в борьбе между потоками

Реально, с ростом числа потоков на кластере растет расход ресурсов на взаимодействие между ними. Если задача состоит в том, чтобы миллион раз запустить одну и туже программу на разные входные данные, скажем по секунде на запуск, то это не важно. Если есть много этапов, каждый из которых начинается после полного завершения предыдущего, то пусть даже этап можно распараллелить - после этапа надо собрать результаты со всех узлов, из обработать, тогда реально увеличение числа узлов до inf бессмысленно.


 
картман ©   (2012-07-13 19:46) [2]


> - каким образом эффективно учитывать технологию HyperThreading
> ?

лучше не учитывать



Страницы: 1 вся ветка

Текущий архив: 2013.03.22;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.053 c
15-1331053532
vrem
2012-03-06 21:05
2013.03.22
телевизор 42" как монитор для компьютера


2-1328461488
Xmen
2012-02-05 21:04
2013.03.22
архивация открытого документа


10-1181018110
Yriy
2007-06-05 08:35
2013.03.22
Проблема с Excel 2003


15-1347978249
alexdn
2012-09-18 18:24
2013.03.22
Серьёзный вопрос


2-1329494261
leklerk
2012-02-17 19:57
2013.03.22
Проблемы с вычисляемым полем