Конкретные входы эксперимента возвращают ошибку парсера - PullRequest
0 голосов
/ 28 апреля 2019
#!/bin/bash
for tracelength in 50 100 150 200 250 300 350 400 450 500 ; do
    step=0.2
    short=0
    long=1
    for i in {1..4}; do
    ratio=0
        for j in {1..4}; do
                declare -a listofresults
                echo "$tracelength $short $long $ratio" >> results.csv
                python3 main.py "$tracelength" "$short" "$long" "$ratio">file.smt2
                chmod 775 file.smt2
                declare total=0
                declare m=0
                for repeat in {1..10}; do
                    executiontime=$(timeout 500 gtime -f "%U" /Users/ouafaelachhab/Desktop/SemanticLocality/optimathsat-1.6.2-macos-64-bit/bin/optimathsat < file.smt2 2>&1 >/dev/null)
                    echo "$executiontime"
                    total=$(echo "scale=2; ($total) + ($executiontime)" | bc) #echo $(bc <<< "scale=2; $total/100")
                    echo "$total"
                    let "m=m+1"
                    echo "m=$m"
                done
                echo $(bc <<< "scale=2; ($total)/10") >> results.csv
                ratio=$(echo "scale=10; ($ratio) + ($step)" | bc) #float points arithmetics are different
            done
            short=$(echo "scale=10; ($short) + ($step)" | bc)
            long=$(echo "scale=10; ($long) - ($step)" | bc)
        done
    done

Я просто запускаю эксперимент, в котором я запускаю файл с вариантами ввода.Код работает для некоторых значений, а для некоторых он просто дает мне:

(standard_in) 1: parse error

В моем файле результатов это вывод, который у меня есть:

50 0 1 0
21.82
50 0 1 .2
27.08
50 0 1 .4
40.89
50 0 1 .6

Эксперимент, который я запускаю, всегда останавливаетсяпри тех же самых входных значениях (последнее напечатано в выходном файле), а затем оттуда все ошибок синтаксического анализатора !почему он это делает?и как мне это исправить?Я пробовал несколько решений, которые я нашел здесь для похожих вопросов (связанных с bc), но ни одно из них не сработало.

1 Ответ

1 голос
/ 28 апреля 2019

Я подозреваю, что это связано со следующей строкой:


executiontime=$(timeout 500 gtime -f "%U" /Users/ouafaelachhab/Desktop/SemanticLocality/optimathsat-1.6.2-macos-64-bit/bin/optimathsat &1 >/dev/null)

Когда я изменяю ваш код с помощью

executetime = "ISSUE"

Я получаю это как вывод (обратите внимание, как ПРОБЛЕМА печатается построчно)


m=3<br>
ISSUE<br>
(standard_in) 1: parse error
(standard_in) 1: illegal character: I
(standard_in) 1: illegal character: S
(standard_in) 1: illegal character: S
(standard_in) 1: illegal character: U

...