source: CIVL/examples/verifyThisProblems/relaxedPrefix.c@ 05f3dc42

1.23 2.0 main test-branch
Last change on this file since 05f3dc42 was 76f18de, checked in by Yihao Yan <yihaoyan1@…>, 10 years ago

format changes

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

  • Property mode set to 100644
File size: 2.1 KB
RevLine 
[260762f]1/*
[76f18de]2Author: Yihao Yan
[f3368e99]3
[41eb9b6]4See challenge 1 of: http://etaps2015.verifythis.org/challenges
5
6-----------------
7Problem description:
[260762f]8
9Verify a function isRelaxedPrefix determining if a list _pat_ (for
10pattern) is a relaxed prefix of another list _a_.
11
12The relaxed prefix property holds iff _pat_ is a prefix of _a_ after
13removing at most one element from _pat_.
14
15examples:
16pat = {1,3} is a relaxed prefix of a = {1,3,2,3} (standard prefix)
17pat = {1,2,3} is a relaxed prefix of a = {1,3,2,3} (remove 2 from pat)
18pat = {1,2,4} is not a relaxed prefix of a = {1,3,2,3}.
19
[41eb9b6]20-----------------
21Verification Task:
22
23Implement the isRelaxedPrefix function which takes two arrays and their length
24as input and verify that it behaves as described.
25
26command: civl verify relaxedPrefix.c
[260762f]27
[76f18de]28result:
29For any array X1 with length less than 5 and any array X2 with length less than 4,
30function isRelaxedPrefix will tell if X1 can become a prefix of X2 by removing at
31most one element.
[f7e5282]32
[260762f]33*/
[0ae124a]34
35#include <stdio.h>
36#include <stdbool.h>
37#include <civlc.cvh>
38
[260762f]39$input int N1_BOUND = 4;
40$input int N2_BOUND = 3;
41$input int n1;
42$input int n2;
43$input int X2[n2];
[f3368e99]44$input int X1[n1];
45$assume (n2>=0 && n2 < N2_BOUND);
46$assume (n1>=0 && n1 < N1_BOUND);
[260762f]47
[0ae124a]48bool isRelaxedPrefix(int* pat, int patLen, int* a, int aLen) {
[260762f]49 int shift = 0;
50 int i;
[f3368e99]51
[260762f]52 if(patLen > aLen+1) return false;
[f3368e99]53
[4b8f2689]54 if(aLen == 0) return true;
[f3368e99]55
[0ae124a]56 for(i=0; i<patLen; i++) {
57 if(pat[i] != a[i-shift]) {
[260762f]58 if(shift == 0)
59 shift = 1;
60 else
61 return false;
[f3368e99]62 }
[4b8f2689]63 if(i == aLen - 1 && shift == 0) return true;
64 }
[260762f]65 return true;
66}
67
[0ae124a]68void main() {
[4b8f2689]69 bool result = isRelaxedPrefix(X1, n1, X2, n2);
[f3368e99]70
[0ae124a]71 if(n1 > n2+1) {
[260762f]72 $assert(!result);
[0ae124a]73 } else if(n1 == n2+1) {
[4b8f2689]74 $assert( result ==
75 ($exists {int k | k >= 0 && k < n1}
[260762f]76 (
77 ($forall {int i | i >= 0 && i < k} X1[i] == X2[i]) &&
78 ($forall {int i | i > k && i < n1} X1[i] == X2[i-1])
79 )
80 )
81 );
[0ae124a]82 } else {
[260762f]83 $assert(result ==
84 ($exists {int k | k >= 0 && k <=n1}
85 (
86 ($forall {int i | i >= 0 && i < k} X1[i] == X2[i]) &&
87 ($forall {int i | i > k && i < n1} X1[i] == X2[i-1])
88 )
89 )
90 );
[f3368e99]91 }
[260762f]92}
Note: See TracBrowser for help on using the repository browser.