Параллельные вычисления

Простейшие вопросы в области инженерной разработки
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Параллельные вычисления

Сообщение Fancnc »

Здравствуйте!
Подскажите как организовать параллельные вычисления с назначением ядра под определенную задачу. Есть два независимых цикла, 1-ый сбора данный, 2-ой обработка этих данных. на первый цикл отводится 1 и 2 ядро, а под обработку с 3 по 8. Возможно ли такое организовать?
Аватара пользователя
IvanLis

Activity Professionalism Tutorials Gold Man of the year 2012
Автор
guru
guru
Сообщения: 5462
Зарегистрирован: 02 дек 2009, 17:44
Награды: 7
Версия LabVIEW: 2015, 2016
Откуда: СССР
Благодарил (а): 28 раз
Поблагодарили: 86 раз

Re: Параллельные вычисления

Сообщение IvanLis »

Fancnc писал(а):Здравствуйте!
Подскажите как организовать параллельные вычисления с назначением ядра под определенную задачу. Есть два независимых цикла, 1-ый сбора данный, 2-ой обработка этих данных. на первый цикл отводится 1 и 2 ядро, а под обработку с 3 по 8. Возможно ли такое организовать?
Посмотрите: http://zone.ni.com/reference/en-XX/help ... pu_assign/
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

Получается, нужно делать 2 цикла сбора данных и 6 циклов обработки, и потом все это дело синхронизировать :suicide: ???
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

По такому принципу нужно делать ?
Похоже этот вариант не подходит, ацп работают на частоте 2 МГц и как их синхронизировать в разных циклах не особо понимаю...
Вложения
test_FFT_timed_loop.vi
(93.78 КБ) 99 скачиваний
Аватара пользователя
IvanLis

Activity Professionalism Tutorials Gold Man of the year 2012
Автор
guru
guru
Сообщения: 5462
Зарегистрирован: 02 дек 2009, 17:44
Награды: 7
Версия LabVIEW: 2015, 2016
Откуда: СССР
Благодарил (а): 28 раз
Поблагодарили: 86 раз

Re: Параллельные вычисления

Сообщение IvanLis »

Fancnc писал(а):По такому принципу нужно делать ?
Похоже этот вариант не подходит, ацп работают на частоте 2 МГц и как их синхронизировать в разных циклах не особо понимаю...
Выложите snippet, не все переехали на 2016 версию..
Artem.spb

Activity Автор
professor
professor
Сообщения: 3394
Зарегистрирован: 31 июл 2011, 23:05
Награды: 2
Версия LabVIEW: 12-18
Благодарил (а): 49 раз
Поблагодарили: 172 раза
Контактная информация:

Re: Параллельные вычисления

Сообщение Artem.spb »

Fancnc писал(а):По такому принципу нужно делать ?
Похоже этот вариант не подходит, ацп работают на частоте 2 МГц и как их синхронизировать в разных циклах не особо понимаю...
синхронизация должна выражаться в чём?
у вас и так всё условно работает. С АЦП берётся пачка данных (на 2МГц про поточечную обработку можно забыть), через очередь отправляется в соседний цикл, там обрабатывается.
Только нотификаторы - не самый лучший способ в данном случае. Если цикл обработки пропустит данный, они безвозвратно затрутся следующей пачкой.
IvanLis писал(а):Выложите snippet, не все переехали на 2016 версию..
приложение максимум в 15, просто некоторым лень корректно заполнить профиль
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

синхронизация должна выражаться в чём?
синхронный старт всех модулей ацп, когда в разных циклах, то каждый модуль стартует рандомно, если делать все в одном цикле проблем нет.
на 2МГц про поточечную обработку можно забыть
PXIe-8880 справляется c 64 каналами по 2МГц, но на грани, хочется раскинуть определенные задачи по ядрам, а то стандартный параллелизм For Loop странно раскидывает задачи
Только нотификаторы - не самый лучший способ в данном случае
а как лучше сделать?
приложение максимум в 15, просто некоторым лень корректно заполнить профиль
на работе и дома разные версии, извиняйте=)
Выложите snippet, не все переехали на 2016 версию..
Вложения
code.png
Последний раз редактировалось Fancnc 21 мар 2017, 22:34, всего редактировалось 1 раз.
Artem.spb

Activity Автор
professor
professor
Сообщения: 3394
Зарегистрирован: 31 июл 2011, 23:05
Награды: 2
Версия LabVIEW: 12-18
Благодарил (а): 49 раз
Поблагодарили: 172 раза
Контактная информация:

Re: Параллельные вычисления

Сообщение Artem.spb »

Fancnc писал(а):
синхронизация должна выражаться в чём?
синхронный старт всех модулей ацп, когда в разных циклах, то каждый модуль стартует рандомно, если делать все в одном цикле проблем нет.
как раз в запихивании всего чтения в один цикл нет ничего плохого. Но если хочется разнести то копайте стартовые триггеры (есть во многих примерах чтения DAQmx)
Только нотификаторы - не самый лучший способ в данном случае
а как лучше сделать?
очередь
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

Но если хочется разнести то копайте стартовые триггеры (есть во многих примерах чтения DAQmx)
Так и делаю, но проблема в том, что циклы запускаются в разное время и сбор данных и из-за этого разбегается. Синхронизировать их можно с частотой 1 КГц, что не очень помогает, если ацп работают на 2МГц,
Artem.spb

Activity Автор
professor
professor
Сообщения: 3394
Зарегистрирован: 31 июл 2011, 23:05
Награды: 2
Версия LabVIEW: 12-18
Благодарил (а): 49 раз
Поблагодарили: 172 раза
Контактная информация:

Re: Параллельные вычисления

Сообщение Artem.spb »

при чём тут старт циклов?
конфигурируете стартовые триггеры, и чтение начнётся одновременно. А циклы подождут
http://www.ni.com/tutorial/4329/en/
Borjomy_1

Activity Professionalism Silver
doctor
doctor
Сообщения: 2210
Зарегистрирован: 28 июн 2012, 09:32
Награды: 3
Версия LabVIEW: 2009..2020
Откуда: город семи холмов
Благодарил (а): 27 раз
Поблагодарили: 26 раз

Re: Параллельные вычисления

Сообщение Borjomy_1 »

У очередей и нотификаторов есть ограничения по времени выполнения, накладываемые операционной системой (время переключения процессов). Поэтому даже на мощной машине интенсивная работа с очередями нагружает процессор серьезно (вопрос не в размере передаваемых данных, а в частоте вызова функций чтения и записи в очередь). Альтернативный вариант кода без очередей работает на пару порядков быстрее. Для высокоскоростных вычислений это может стать проблемой.
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

конфигурируете стартовые триггеры, и чтение начнётся одновременно. А циклы подождут
наверное, что то не понимаю.
конфигурируется система следующим образом, используется counter он же задает и fd и запускается по тригеру
схему приблизительно набросал как реализовано
Вложения
sync.PNG
Artem.spb

Activity Автор
professor
professor
Сообщения: 3394
Зарегистрирован: 31 июл 2011, 23:05
Награды: 2
Версия LabVIEW: 12-18
Благодарил (а): 49 раз
Поблагодарили: 172 раза
Контактная информация:

Re: Параллельные вычисления

Сообщение Artem.spb »

почти, но ведомую задачу надо подготовить к старту, а ведущую стартовать только после подготовки ведомой
start.png
за безошибочность не ручаюсь, проверить на на чем
Fancnc
assistant
assistant
Сообщения: 147
Зарегистрирован: 15 ноя 2011, 22:39
Версия LabVIEW: 2018, 2020
Откуда: СПб
Контактная информация:

Re: Параллельные вычисления

Сообщение Fancnc »

но ведомую задачу надо подготовить к старту, а ведущую стартовать только после подготовки ведомой
а Flat Sequence Structure нельзя использовать??
Artem.spb

Activity Автор
professor
professor
Сообщения: 3394
Зарегистрирован: 31 июл 2011, 23:05
Награды: 2
Версия LabVIEW: 12-18
Благодарил (а): 49 раз
Поблагодарили: 172 раза
Контактная информация:

Re: Параллельные вычисления

Сообщение Artem.spb »

зачем, если есть провода?
Ответить

Вернуться в «Для чайников»