Создайте параллельный пул на кластере
parpool
parpool(poolsize)
parpool(profilename)
parpool(profilename,poolsize)
parpool(cluster)
parpool(cluster,poolsize)
parpool(___,Name,Value)
poolobj = parpool(___)
parpool
запускает параллельный пул рабочих, использующих кластерный профиль по умолчанию, с размером пула, заданным вашими параллельными настройками и профилем по умолчанию. parpool
создает пул на кластере по умолчанию с его NumWorkers
в области значений [1, preferredNumWorkers]
для идущих параллельно функций языка. preferredNumWorkers
является значением, заданным в ваших параллельных настройках.
parpool
добавляет полную функциональность функций языка параллельного программирования в MATLAB® путем создания специального задания на пуле рабочих и подключения клиента MATLAB с параллельным пулом. Функции языка параллельного программирования включают parfor
, parfeval
, parfevalOnAll
, spmd
и distributed
. Если возможно, рабочая папка на рабочих собирается совпадать с тем из клиентского сеанса MATLAB.
parpool(
создает и возвращает пул с конкретным количеством рабочих. poolsize
)poolsize
может быть положительным целым числом или областью значений, заданной как вектор с 2 элементами целых чисел. Если poolsize
является областью значений, получившийся пул имеет размер как можно больше в области значений, которую требуют.
Определение poolsize
заменяет количество рабочих, заданных в настройках или профиле, и запускает пул точно, что количество рабочих, даже если это должно ожидать их, чтобы быть доступным. Большинство кластеров имеет максимальное количество рабочих, которых они могут запустить. Если профиль задает кластер Планировщика Задания MATLAB, parpool
резервирует своих рабочих из числа тех, которые уже запускаются и доступный под тем Планировщиком Задания MATLAB. Если профиль задает локальный или сторонний планировщик, parpool
дает планировщику команду запускать рабочих для пула.
parpool(
или profilename
)parpool(
запускает пул рабочего с помощью кластерного профиля, идентифицированного profilename
,poolsize
)profilename
.
parpool(___,
применяет заданные значения для определенных свойств при запуске пула.Name,Value
)
возвращает параллель. Объект пула к клиентской рабочей области, представляющей пул на кластере. Можно использовать объект пула программно удалить пул или получить доступ к его свойствам. Используйте poolobj
= parpool(___)delete(pool)
, чтобы закрыть параллельный пул.
Удалите любой startup.m
из своего пути MATLAB, если вы хотите запустить какой-либо параллельный код включая parpool
. Если вы испытываете затруднения при запуске параллельного пула, смотрите эту страницу MATLAB Answers: https://uk.mathworks.com/matlabcentral/answers/92124-why-am-i-unable-to-use-parpool-with-the-local-scheduler-or-validate-my-local-configuration-of-parall
Индикатор состояния пула в нижнем левом углу рабочего стола показывает клиентское соединение на время сеанса с пулом и состоянием пула. Кликните по значку для меню поддерживаемых действий пула.
С выполнением пула: Без выполнения пула:
Если вы устанавливаете свои параллельные настройки автоматически создавать параллельный пул при необходимости, вы не должны явным образом вызывать команду parpool
. Вы можете явным образом создать пул, чтобы управлять, когда вы подвергаетесь служебному времени подготовки его, таким образом, пул готов к последующим построениям языка параллельного программирования.
delete(poolobj)
закрывает параллельный пул. Ни с чем не сравнимый пул, spmd
и parfor
, запущенный как один поток в клиенте, если ваши параллельные настройки не собираются автоматически запустить параллельный пул для них.
Когда вы используете редактора MATLAB, чтобы обновить файлы на клиенте, которые присоединены к параллельному пулу, те обновления автоматически распространяют рабочим в пуле. (Это автоматическое обновление не применяется к файлам модели Simulink®. Чтобы распространить обновленные образцовые файлы рабочим, используйте функцию updateAttachedFiles
.)
Если возможно, рабочая папка на рабочих первоначально собирается совпадать с тем из клиентского сеанса MATLAB. Впоследствии, следующие команды, вводимые в клиентском Командном окне также, выполняются на всех рабочих в пуле:
Это поведение позволяет вам устанавливать рабочую папку и путь поиска файлов команды на всех рабочих, так, чтобы последующие действия пула, такие как parfor
- циклы выполнились в соответствующем контексте.
При изменении папок или добавлении пути с cd
или addpath
на клиентах с операционными системами Windows®, значение, отправленное рабочим, является путем UNC для папки, если это возможно. Для клиентов с операционными системами Linux® это - абсолютное местоположение папки.
Если какая-либо из этих команд не работает над клиентом, это не выполняется на рабочих также. Например, если addpath
задает папку, к которой не может получить доступ клиент, команда addpath
не выполняется на рабочих. Однако, если рабочая папка может быть установлена на клиенте, но не может быть установлена, как задано ни на одном из рабочих, вы не возвратили сообщение об ошибке в клиентское Командное окно.
Остерегайтесь этих незначительных различий в поведении в среде смешанной платформы, где клиент не является той же платформой как рабочие, где папки, локальные для или сопоставленный от клиента, не доступны таким же образом рабочим, или где папки находятся в неразделяемой файловой системе. Например, если у вас есть клиент MATLAB, работающий на операционной системе Windows Microsoft®, в то время как работники MATLAB все работают на операционных системах Linux, тот же аргумент к addpath
не может работать над обоими. В этой ситуации можно использовать функциональный pctRunOnAll
, чтобы гарантировать, что команда работает на всех рабочих.
Другое различие между клиентом и рабочими - то, что любые аргументы addpath
, которые являются частью папки matlabroot
, не установлены на рабочих. Предположение - то, что основа установки MATLAB уже включена в пути рабочих. Правила для addpath
относительно рабочих в пуле:
Подпапки папки matlabroot
не отправляются рабочим.
Любые папки, которые появляются перед первым вхождением папки matlabroot
, добавляются к верхней части пути на рабочих.
Любые папки, которые появляются после первого вхождения папки matlabroot
, добавляются после группы matlabroot
папок на путях рабочих.
Например, предположите, что matlabroot
на клиенте является C:\Applications\matlab\
. С открытым параллельным пулом выполните следующее, чтобы установить путь на клиенте и всех рабочих:
addpath('P1', 'P2', 'C:\Applications\matlab\T3', 'C:\Applications\matlab\T4', 'P5', 'C:\Applications\matlab\T6', 'P7', 'P8');
Поскольку T3
, T4
и T6
являются подпапками matlabroot
, они не установлены на путях рабочих. Таким образом на рабочих, подходящая часть пути, следующего из этой команды:
P1 P2 <worker original matlabroot folders...> P5 P7 P8
Composite
| delete
| distributed
| gcp
| parallel.defaultClusterProfile
| parallel.pool.Constant
| parcluster
| parfeval
| parfevalOnAll
| parfor
| pctRunOnAll
| spmd