~~~~~~~~~~~~~~~~~~~~ Arc.Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~ 
Номер скриншота №:
✰ 476E3E6C4A847D730FD34AAA7713D55A__1708398480 ✰
Заголовок документа оригинал.:
✰ Implicit parallelism - Wikipedia ✰
Заголовок документа перевод.:
✰ Неявный параллелизм — Википедия ✰
Снимок документа находящегося по адресу (URL):
✰ https://en.wikipedia.org/wiki/Implicit_parallelism ✰
Адрес хранения снимка оригинал (URL):
✰ https://arc.ask3.ru/arc/aa/47/5a/476e3e6c4a847d730fd34aaa7713d55a.html ✰
Адрес хранения снимка перевод (URL):
✰ https://arc.ask3.ru/arc/aa/47/5a/476e3e6c4a847d730fd34aaa7713d55a__translat.html ✰
Дата и время сохранения документа:
✰ 22.06.2024 17:32:20 (GMT+3, MSK) ✰
Дата и время изменения документа (по данным источника):
✰ 20 February 2024, at 06:08 (UTC). ✰ 

~~~~~~~~~~~~~~~~~~~~~~ Ask3.Ru ~~~~~~~~~~~~~~~~~~~~~~ 
Сервисы Ask3.ru: 
 Архив документов (Снимки документов, в формате HTML, PDF, PNG - подписанные ЭЦП, доказывающие существование документа в момент подписи. Перевод сохраненных документов на русский язык.)https://arc.ask3.ruОтветы на вопросы (Сервис ответов на вопросы, в основном, научной направленности)https://ask3.ru/answer2questionТоварный сопоставитель (Сервис сравнения и выбора товаров) ✰✰
✰ https://ask3.ru/product2collationПартнерыhttps://comrades.ask3.ru


Совет. Чтобы искать на странице, нажмите Ctrl+F или ⌘-F (для MacOS) и введите запрос в поле поиска.
Arc.Ask3.ru: далее начало оригинального документа

Неявный параллелизм — Википедия Jump to content

Неявный параллелизм

Из Википедии, бесплатной энциклопедии

В информатике , неявный параллелизм — это характеристика языка программирования, которая позволяет компилятору или интерпретатору автоматически использовать параллелизм присущий вычислениям, выраженным некоторыми конструкциями языка. Чистый неявно параллельный язык не нуждается в специальных директивах, операторах или функциях для обеспечения параллельного выполнения, в отличие от явного параллелизма .

К языкам программирования с неявным параллелизмом относятся Axum , BMDFM , HPF , Id , LabVIEW , MATLAB M-code , NESL , SaC , SISAL , ZPL и pH. [1]

Пример [ править ]

Если конкретная задача предполагает выполнение одной и той же операции над группой чисел (например, поочередное извлечение синуса или логарифма каждого из них), язык, обеспечивающий неявный параллелизм, может позволить программисту написать инструкцию следующим образом:

числа   =   [  0   1   2   3   4   5   6   7  ]; 
  результат   =   грех  (  числа  ); 

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

Преимущества [ править ]

Программисту, который пишет неявно параллельный код, не нужно беспокоиться о разделении задач или взаимодействии процессов, вместо этого он сосредотачивается на проблеме, которую его программа призвана решить. Неявный параллелизм обычно облегчает разработку параллельных программ и, следовательно, приводит к существенному повышению производительности программистов.

Многие из конструкций, необходимых для поддержки этого, также добавляют простоты и ясности даже при отсутствии фактического параллелизма. Приведенный выше пример понимания списка в sin()Функция сама по себе является полезной функцией. Используя неявный параллелизм, языки фактически должны предоставлять пользователям такие полезные конструкции просто для поддержки требуемой функциональности (например, язык без приличного цикла for будет использоваться немногими программистами).

Недостатки [ править ]

Языки с неявным параллелизмом уменьшают контроль программиста над параллельным выполнением программы, что иногда приводит к неоптимальной эффективности параллельного выполнения . Создатели языка программирования Oz также отмечают, что их ранние эксперименты с неявным параллелизмом показали, что неявный параллелизм затрудняет отладку, а объектные модели становятся излишне неудобными. [2]

Более серьезная проблема заключается в том, что каждая программа имеет некоторую параллельную и некоторую последовательную логику. Например, двоичный ввод-вывод требует поддержки таких последовательных операций, как Write() и Seek(). Если желателен неявный параллелизм, это создает новые требования к конструкциям и ключевым словам для поддержки кода, который не может быть многопоточным или распределенным.

Примечания [ править ]

  1. ^ Нихил, Ришиюр; Арвинд (20 февраля 2024 г.). Неявное параллельное программирование в pH . Издательство Морган Кауфманн. ISBN  978-1-55860-644-9 .
  2. ^ Сейф Хариди (14 июня 2006 г.). "Введение" . Учебник страны Оз . Архивировано из оригинала 14 мая 2011 года . Проверено 20 сентября 2007 г.
Arc.Ask3.Ru: конец оригинального документа.
Arc.Ask3.Ru
Номер скриншота №: 476E3E6C4A847D730FD34AAA7713D55A__1708398480
URL1:https://en.wikipedia.org/wiki/Implicit_parallelism
Заголовок, (Title) документа по адресу, URL1:
Implicit parallelism - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть, любые претензии не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, денежную единицу можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)