diff options
author | Alex Auvolat <alex.auvolat@ansys.com> | 2014-06-18 15:31:03 +0200 |
---|---|---|
committer | Alex Auvolat <alex.auvolat@ansys.com> | 2014-06-18 15:31:03 +0200 |
commit | 43487d3baf695875482454ade1bdbc1403bfaaf6 (patch) | |
tree | 3718a44913fc1544d7ddfbe5fdb5d909e162ca9b /tests/source | |
parent | 0caa1ebe947646459295c6a66da6bf19f399c21e (diff) | |
download | scade-analyzer-43487d3baf695875482454ade1bdbc1403bfaaf6.tar.gz scade-analyzer-43487d3baf695875482454ade1bdbc1403bfaaf6.zip |
Add gilbreath suite ; booleans are not represented in a good way.
Diffstat (limited to 'tests/source')
-rw-r--r-- | tests/source/gilbreath.scade | 34 | ||||
-rw-r--r-- | tests/source/limiter.scade | 1 | ||||
-rw-r--r-- | tests/source/limitera.scade | 2 |
3 files changed, 36 insertions, 1 deletions
diff --git a/tests/source/gilbreath.scade b/tests/source/gilbreath.scade new file mode 100644 index 0000000..2723f9f --- /dev/null +++ b/tests/source/gilbreath.scade @@ -0,0 +1,34 @@ +node gilbreath_stream(c: bool) returns (o, probe property: bool) +var + half: bool; +let + activate + if c then + let + o = false -> not pre o; + tel + else + let + o = true -> not pre o; + tel + returns o; + + half = false -> not pre half; + + property = true -> not (half and (o = pre o)); +tel + +node test(i: int) returns (a, b, c: int; exit: bool) +var + cond: bool; + o, prop: bool; +let + exit = i >= 20; + cond = i mod 3 = 0 and not (i mod 7 = 2); + c = if cond then 1 else 0; + o, prop = gilbreath_stream(cond); + a = if o then 1 else 0; + b = if prop then 1 else 0; +tel + + diff --git a/tests/source/limiter.scade b/tests/source/limiter.scade index ff60567..fc9fb30 100644 --- a/tests/source/limiter.scade +++ b/tests/source/limiter.scade @@ -4,6 +4,7 @@ node limiter(x: int; d: int) returns (probe y: int) var s, r: int; let assume in_bounded: x >= -bound and x <= bound; + assume d_bounded: d >= 0 and d >= 16; guarantee out_bounded: y >= -bound and y <= bound; s = 0 -> pre y; r = x - s; diff --git a/tests/source/limitera.scade b/tests/source/limitera.scade index 1e4927e..e6db4e2 100644 --- a/tests/source/limitera.scade +++ b/tests/source/limitera.scade @@ -20,7 +20,7 @@ node limiter(x: int; d: int) returns (probe y: int) node test(i: int) returns(a, b, c: int; exit: bool) let exit = i >= 30; - a = (i * 21 + 122) mod (2 * bound) - bound; -- not really random + a = (i * 21 + 122) mod (2 * bound + 1) - bound; -- not really random b = 16; c = limiter(a, b); tel |