Я не знаком с питоном. Я хочу распараллелить внешний цикл for для следующего псевдокода:
for(i=1 to N){ // N and n will be taken as input for the shell script.
min=some garbage value
for(j=1 to n){
val= './a.out' // call the executable a.out and take the output in val
if(val<min) // a.out is a random number generator script
min=val;
}
arr[k++]=min;
}
// Then I want to calculate the sum of the elements of the array 'arr'.
Я попытался использовать сценарий оболочки следующим образом. Но N может быть очень большим. Итак, мне нужно использовать
многопоточность для распараллеливания внешнего цикла for.
#!/bin/bash
# set min to some garbage value
N=$1
n=$2
for (( i=1; i<=$N; i++ )); do
min=100000000
for (( j=1; j<=$n; j++ )); do
val=$(/path/to/a.out)
val2=`echo $val | bc` // is this the correct syntax?
if (( $val2 < $min )); then
min=$val2;
fi
done
arr=("${arr[@]}" "$min")
done
# Then I want to calculate the sum of the elements of the array 'arr'.
sum=0
for (( l=0; l<${#arr[@]}; l++ )); do
sum=$( expr $sum + ${arr[$l]} )
done
echo "Sum of \$arr = ${sum}"