将脚本外壳的一部分分列化


#!/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}

相关内容

  • 没有找到相关文章

最新更新