#!/bin/bash
for tracelength in 10 20 50 100 ; do
step=0.1
short=0
long=1
for firstloop in {1..10}; do
ratio=0
for secondloop in {1..10} ; do
for repeat in {1..20} ; do
echo $tracelength $short $long $ratio >results.csv
python3 main.py "$tracelength" "$short" "$long" "$ratio" > file.smt2
/usr/bin/time /Users/Desktop/optimathsat-1.5.1-macos-64-bit/bin/optimathsat < file.smt2 > results.csv
done
ratio=$(echo "scale=10; $ratio + $step" | bc)
done
short=$(echo "scale=10; $short + $step" | bc)
long=$(echo "scale=10; $long - $step" | bc)
done
done
我想并行化内部循环(重复(。
我已经安装了GNU并行,我知道一些基础知识,但是因为循环有多个命令,我不知道如何并行化它们。
我将循环的内容转移到另一个脚本中,我想这是要走的路,但我的 3 个命令需要获取变量(跟踪长度、比率、短、长(并根据它们运行。 知道如何将参数从脚本传递到下标。 或者您对并行化有更好的了解吗?
我正在编辑这个问题,因为我使用了下面的答案,但现在我的执行时间总是 0.00 与 file.smt2 有多大无关。
这是新版本的代码:
#!/bin/bash
doone() {
tracelength="$1"
short="$2"
long="$3"
ratio="$4"
#echo "$tracelength $short $long $ratio" >> results.csv
python3 main.py "$tracelength" "$short" "$long" "$ratio" >> file.smt2
gtime -f "%U" /Users/Desktop/optimathsat-1.5.1-macos-64-bit/bin/optimathsat < file.smt2
}
export -f doone
step=0.2
parallel doone
::: 200 300
:::: <(seq 0 $step 0.5)
::::+ <(seq 1 -$step 0.5)
:::: <(seq 0 $step 0.5)
::: {1..5} &> results.csv
在原始代码中,您一次又一次地覆盖results.csv
。我认为这是一个错误,您希望将其组合成一个大的csvfile:
doone() {
tracelength="$1"
short="$2"
long="$3"
ratio="$4"
echo "$tracelength $short $long $ratio"
python3 main.py "$tracelength" "$short" "$long" "$ratio" |
/usr/bin/time /Users/Desktop/optimathsat-1.5.1-macos-64-bit/bin/optimathsat
}
export -f doone
step=0.1
parallel doone
::: 10 20 50 100
:::: <(seq 0 $step 0.9)
::::+ <(seq 1 -$step 0.1)
:::: <(seq 0 $step 0.9)
::: {1..20} > results.csv
如果希望每次运行都有一个 csvfile:
parallel --results outputdir/ doone
::: 10 20 50 100
:::: <(seq 0 $step 0.9)
::::+ <(seq 1 -$step 0.1)
:::: <(seq 0 $step 0.9)
::: {1..20}
如果你想要一个包含参数和运行时的csv文件,请使用:
parallel --results output.csv doone
::: 10 20 50 100
:::: <(seq 0 $step 0.9)
::::+ <(seq 1 -$step 0.1)
:::: <(seq 0 $step 0.9)
::: {1..20}