Главная страница
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.063 c
15-1345064481
Inovet
2012-08-16 01:01
2013.03.22
Windows 8 release


2-1339062776
vasa777
2012-06-07 13:52
2013.03.22
экспорты


15-1345632073
Rouse_
2012-08-22 14:41
2013.03.22
Семинар "RAD Studio XE3"


2-1332000787
alexdn
2012-03-17 20:13
2013.03.22
Компонент TRichEdit


15-1339590107
Хригорий
2012-06-13 16:21
2013.03.22
Что такое нативный язык программирования?