source: CIVL/examples/loop_invariants/loop_assigns_given/arrayZeroes2d.cvl@ 7d77e64

main test-branch
Last change on this file since 7d77e64 was ea777aa, checked in by Alex Wilton <awilton@…>, 3 years ago

Moved examples, include, build_default.properties, common.xml, and README out from dev.civl.com into the root of the repo.

git-svn-id: svn://vsl.cis.udel.edu/civl/trunk@5704 fb995dde-84ed-4084-dfe6-e5aef3e2452c

  • Property mode set to 100644
File size: 764 bytes
Line 
1#include<assert.h>
2
3#pragma CIVL ACSL
4
5$input int N;
6$assume(N > 0);
7
8int a[N][N];
9
10void arrayZeroes(int n) {
11 int i, j;
12
13 /*@ loop invariant 0 <= i && i <= n;
14 @ loop invariant \forall int t; 0<=t && t<i ==> (\forall int k; 0<=k && k<n ==>
15 @ a[t][k] == 0);
16 @ loop assigns a[0 .. n-1][0 .. n-1], i, j;
17 @*/
18 for (i = 0; i < n; i++) {
19 /*@ loop invariant 0 <= j && j <= n;
20 @ loop invariant \forall int k; 0<=k && k<j
21 @ ==> a[i][k] == 0;
22 @ loop assigns a[i][0 .. n-1], j;
23 @*/
24 for (j = 0; j < n; j++)
25 a[i][j] = 0;
26 }
27}
28
29int main() {
30 $havoc(&a);
31 arrayZeroes(N);
32 $assert($forall (int i : 0 .. N-1) ($forall (int j : 0 .. N-1) a[i][j] == 0));
33}
Note: See TracBrowser for help on using the repository browser.