#include #include #ifdef _CIVL #include #pragma CIVL ACSL #endif #ifdef _CIVL $input int ni,nj; $assume(ni > 1); $assume(nj > 1); $input double uin[ni][nj]; #endif int main(int argc, char** argv) { int i,j,ir,jr; double u1[ni][nj]; double u2[ni][nj]; $assume($forall (int i : 0 .. ni-1) ($forall (int j : 0 .. nj-1) u1[i][j] == 0 && u2[i][j] == 0) ); double tmp1[ni][nj]; $assume($forall (int i : 1 .. ni-2) ($forall (int j : 1 .. nj-2) tmp1[i][j] == uin[i][j] * uin[i][j]) ); $assume($forall (int j : 0 .. nj-1) tmp1[0][j] == 0 && tmp1[ni-1][j] == 0); $assume($forall (int i : 0 .. ni - 1) tmp1[i][0] == 0 && tmp1[i][nj-1] == 0); memcpy(u1, tmp1, sizeof(double) * ni * nj); if (ni > 2) { i = ni - 1; if (nj > 2) j = nj - 1; else j = 1; } else { i = 1; j = nj; } /*@ loop invariant 1 <= i && i <= ni-1; @ loop invariant 1 < i ==> (nj - 2 <= j && j <= nj - 1 && j % 2 != 0); // needed for the rest of the code @ loop invariant \forall int t, k; 1 <= t && t < i && 1 <= k && k < nj - 2 && k % 2 != 0 @ ==> u2[t][k] == uin[t][k]*uin[t][k] && u2[t][k+1] == uin[t][k+1]*uin[t][k+1]; @ loop invariant i % 2 != 0; @ loop assigns u2[1 .. ni-2][1 .. nj-2], i, j; @*/ for(i=1;i u2[i][k] == uin[i][k]*uin[i][k] && u2[i+1][k] == uin[i+1][k]*uin[i+1][k] ; @ loop invariant i % 2 != 0 && j % 2 != 0; @ loop assigns u2[i][1 .. nj-2], u2[i+1][1 .. nj-2], j; @*/ for(j=1;j @ u2[i][t] == uin[i][t]*uin[i][t]; @ loop assigns jr, u2[i][1 .. nj-2]; @*/ for(jr=1;jr @ u2[t][j] == uin[t][j]*uin[t][j]; @ loop assigns ir, u2[1 .. ni-2][j]; @*/ for(ir=1;ir