Вы не первый, кто попал в знаменитую «задержанную ловушку расширения» (и вы не станете последним)
Вам нужно задержать расширение, если вы хотите использовать переменную, что вы изменен в том же блоке (блок представляет собой последовательность команд в скобках (
и )
)
Отложенные переменные ссылаются на !var!
вместо %var%
Причина в том, что cmd
анализирует код. Полная строка или блок анализируется сразу, заменяя обычные переменные своим значением во время разбора. Отложенные переменные оцениваются во время выполнения.
Две простые партии для демонстрации:
setlocal enabledelayedexpansion
set "var=hello"
if 1==1 (
set "var=world"
echo %var% !var!
)
.
setlocal enabledelayedexpansion
for /L %%i in (1,1,5) do (
echo %random% !random!
)
Примечание: также строка рассматривается как block:
set "var=old"
set "var=new" & echo %var%
с задержкой расширения:
setlocal enabledelayedexpansion
set "var=old"
set "var=new" & echo !var!
Отсроченное расширение по умолчанию отключено в командной строке. Если вам это действительно нужно, вы можете сделать:
cmd /v:on /c "set "var=hello" & echo !var!"
Также есть способ сделать то же самое без задержки расширения (но call
стоит некоторое время, поэтому он медленнее, но если по какой-то причине вы не можете / не хотите использовать замедленное расширение, это альтернатива):
setlocal DISabledelayedexpansion
for /L %%i in (1,1,5) do (
call echo %random% %%random%%
)
Оба метода могут использоваться для отображения переменных типа массива :
setlocal ENabledelayedexpansion
set "num=4"
set "var[%num%]=hello"
echo !var[%num%]!
или
setlocal DISabledelayedexpansion
set "num=4"
set "var[%num%]=hello"
call echo %%var[%num%]%%
(этого часто задают как «переменная, которая содержит другую переменную» или «вложенные переменные»
Существует ряд инструментов анализа производительности, предназначенных для программ Parallel / MPI, таких как:
Сначала они могут быть не такими простыми в использовании простыми в использовании, но они обеспечивают гораздо большую помощь в исследовании производительности параллельных приложений
Allinea MAP - профайлер, простой и понятный, но очень мощный.
Он предназначен для отображения проблем производительности в приложениях Fortran, C и C ++ MPI и требует очень мало усилий для начала работы и профилирования.
Он графический и имеет интегрированный с браузером исходного кода, который показывает производительность против строк кода и способен анализировать плохое поведение MPI, плохой рабочий баланс или плохую векторизацию.
Я одна из команды за продуктом, поэтому я немного предвзятый. Это коммерческая - на веб-сайте доступны лицензии для оценки.
Вы можете использовать анализатор трассировки Intel для передачи сообщений MPI и Intel VTune для получения профиля одной задачи MPI. Оба программного обеспечения были широко документированы на веб-сайте Intel.
Я хотел бы добавить еще два профайлера: (1) mpiP - легкий профилировщик и может производить текстовый вывод, но только для MPI-функций. (2) Scalasca - это создает сложный вывод, который также может указывать на дисбалансы синхронизации (поздний отправитель / поздний приемник) (в отличие от TAU, который не указывает на дисбалансы синхронизации).
Когда вопроситель говорит, что «gprof, похоже, работает некорректно», возможно, он ссылается на то, что процессы N MPI могут сбивать файл gmon.out. В этом случае переменная среды (недокументированная) GMON_OUT_PREFIX может сделать gprof более полезной:
$ export GMON_OUT_PREFIX=gmon.out
$ mpiexec -np 4 cpi
gprof
является хорошим профилировщиком для Fortran и других компиляторов на основе GNU.