1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
typedef short Guard;

/* In order to be able to inspect the result... */
int res;
int T_res;

void square_root(int n)
{
{
/*TP*/ int T_n = n;
/*TP*/ Guard Ret = 0;
/*TP*/ Guard T_Ret = 0;
{
{
int result;
int T_result;
/* {char *CP0;} */
int k;
int T_k;
/* {char *CP1;} */
int i;
int T_i;
/* {char *CP2;} */
if (!Ret) i = 1;
if (!T_Ret) T_i = 1;
/* {char *CP3;} */
if (!Ret) result = 0;
if (!T_Ret) T_result = 0;
/* {char *CP4;} */
if (!Ret) k = 1;
if (!T_Ret) T_k = 1;
/* {char *CP5;} */
L1:;
T_L1:;
{
{
Guard G0 = 1;
Guard T_G0 = 1;
if (!Ret) G0 = (k <= n);
if (!T_Ret) T_G0 = (T_k <= T_n);
/* {char *CP6;} */
{
{
{
{
Guard G1 = 1;
Guard T_G1 = 1;
if (!Ret) if (G0) G1 = (k == n);
if (!T_Ret) if (T_G0) T_G1 = (T_k == T_n);
/* {char *CP7;} */
{
{
if (!Ret) if (G0) if (G1) result = i;
if (!T_Ret) if (T_G0) if (T_G1) T_result = T_i;
/* {char *CP8;} */
}
}
{
{
}
}
}
}
if (!Ret) if (G0) i = (i + 1);
if (!T_Ret) if (T_G0) T_i = (T_i + 1);
/* {char *CP9;} */
if (!Ret) if (G0) k = (i * i);
if (!T_Ret) if (T_G0) T_k = (T_i * T_i);
/* {char *CP10;} */
}
}
L2:;
T_L2:;
if (!Ret) if (G0) goto L1;
if (!T_Ret) if (T_G0) goto T_L1;
/* {char *CP11;} */
L3:;
T_L3:;
}
}
if (!Ret) res = result;
if (!T_Ret) T_res = T_result;
{char *CP12;}
}
}
}
}