Федотов И.Е.
Модели параллельного программирования


Федотов И.Е. Модели параллельного программирования. - М.: СОЛОН-ПРЕСС, 2012. - 384 с.
ISBN 978-5-91359-102-9
Ссылки для загрузки
Book cover

Ссылки для загрузки

Книга посвящена рассмотрению некоторых высокоуровневых моделей параллельного и распределенного программирования. В порядке усложнения описываются несколько моделей внутренней организации параллельных программ: ярусно-параллельная форма программы, сети конечных автоматов, сети Петри, модель актеров, а также модель квантовых вычислений. Приводятся примеры программной реализации на C++ с использованием различных средств распараллеливания (OpenMP, MPI, POSIX Threads, Windows API). В каждом случае рассматриваются вопросы контекстно-независимой реализации конструкций описываемой модели без привязки к конкретным задачам, а также приведены примеры решения с использованием такой реализации некоторых конкретных задач. Некоторые из описанных моделей (к примеру, модель актеров), в настоящий момент приобретают все большую популярность вследствие распространения основанных на ее использовании языков и библиотек.

Книга ориентирована на подготовленного читателя в области программирования. Будет полезна программистам, желающим освоить высокоуровневые подходы к организации параллельных и распределенных программ, студентам старших курсов, аспирантам и преподавателям технических ВУЗов, преподающим параллельное программирование.


Ссылки для загрузки

Описание

Вот уже несколько лет, как современные компьютеры вплотную приблизились к своему пределу тактовых частот. Производительность процессоров (точнее, их отдельных ядер) перестала нарастать сказочными темпами, и теперь остается возможность обеспечить дальнейшее повышение вычислительных мощностей лишь за счет увеличения их количества: производительность компьютеров начала расти "вширь", а не "в высоту". В связи с этим параллельное программирование уже перестало быть узкоспециализированной дисциплиной для высокопроизводительных вычислений и приобретает все большую актуальность для широких масс представителей программистского сообщества. Есть немало публикаций, посвященных рассмотрению архитектур параллельных вычислительных систем и теоретическим вопросам распараллеливания последовательных алгоритмов. Также существует достаточно учебных пособий и статей, посвященных рассмотрению существующих технологий, программных интерфейсов и библиотек. В то же время, довольно давно создано немало моделей, успешно описывающих выполнение параллельных процессов, которые уже являются основой многих программных технологий и некоторых не слишком популярных инструментов построения параллельных программ. Таким моделям посвящено немало учебного материала теоретического характера, однако ощущается некоторый дефицит в области практического их рассмотрения с доступными примерами программной реализации на основе современных средств. В результате освещения таких моделей лишь с теоретической точки зрения они, порой, остаются вне практического арсенала программиста, отчего возможность использования их при решении конкретной задачи зачастую даже не рассматривается. Настоящее издание стремится в какой-то степени восполнить указанную нишу и попытаться исправить такое положение.

В книге приводятся исходные тексты примеров на языке C++ с использованием библиотеки шаблонов STL, в связи с чем необходимо предварительное знакомство читателя с ними. В примерах реализации описанных подходов иллюстрируется использование технологий OpenMP и MPI, а также низкоуровневых программных интерфейсов Win32 API и POSIX Threads (pthreads). Последние используются в случаях, когда средства высокоуровневых интерфейсов оказываются недостаточно гибкими.

Для компиляции приведенных примеров программ могут быть использованы компиляторы MS Visual C++ версии от 8.0 (2005) или GNU C++. Для компиляции в среде MS Windows программ, использующих функции интерфейса POSIX Threads, возможно использование библиотеки Pthreads-w32 или эмулятора Cygwin.


Ссылки для загрузки

Оглавление


Ссылки для загрузки

Полный текст книги в ZIP(PDF)-файле (2.38 MB)
Исходные тексты примеров программ, приведенных и описанных в книге, в ZIP-файле (296 KB)

Прочие ссылки

MinGW - Портированный для систем семейства Windows набор компиляторов GCC
SciTE - Многофункциональный текстовый редактор для разработчика
Сygwin - Эмулятор UNIX-среды для Windows-систем
MPICH2 - Одна из свободно распространяемых реализаций интерфейса MPI
MPI 1.1 - Спецификация интерфейса MPI версии 1.1
OpenMP - Спецификации интерфейса OpenMP
POSIX Threads - Спецификации интерфейса POSIX Threads
Irtegov_Tech - Лекции по программированию с использованием POSIX Threads
parallel.ru, cluster.bsu.by - Другие учебные материалы по теме параллельных вычислений
softcraft.ru - Некоторые публикации по теме абстрактных моделей вычислений

Гостевая книга
Персональный форум
Связаться с автором

Copyright © 2011 Ilyh&So