gpt4 book ai didi

使用 Frama-C 验证线性搜索

转载 作者:行者123 更新时间:2023-12-05 00:57:23 27 4
gpt4 key购买 nike

我再次对一个简单的验证练习感到困惑,这次是在 Frama-C (Sodium) 中使用 WP 插件,因为我无法让 Jessie 在 uni 工作站上工作(正在由管理人员/团队安装) .) 我一直在阅读“ACSL by example”和手册。虽然我认为这个例子很简单,可以很快得到正确的结果。在使用 Dafny 和 Whiley 验证相同的算法后,我的算法可能有点被污染了。

#include <stdio.h>
// A linear search over a sorted array looking for a given element.

/*@ requires len > 0;
@ requires \valid( ls+ ( 0..(len - 1) ) );
@ requires \forall size_t k; 0 <= k < (len - 1) ==> ls[k] <= ls[k + 1];
@ assigns \nothing;
@ behavior found:
@ assumes \exists size_t k; 0 <= k < len && ls[k] == item;
@ ensures \result >= 0;
@ behavior nfound:
@ assumes \forall size_t k; 0 <= k < len ==> ls[k] != item;
@ ensures \result == -1;
@ complete behaviors found, nfound;
@ disjoint behaviors found, nfound;
*/
int search( int ls[], const size_t len, int item )
{
size_t i = 0;

/*@ loop invariant 0 <= i <= len;
@ loop invariant \forall size_t k; 0 <= k < i ==> ls[k] != item;
@ loop assigns i;
@ loop variant len - i;
*/
while ( i < len )
{
if ( ls[i] == item )
return i;
++i;
}
return -1;
}

int main()
{
int src[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
if ( search( src, 10, 5 ) >= 0 ) printf( "found item" );
else printf( "no item found" );
}

我在尝试验证时得到的输出是:
$ frama-c -pp-annot -wp -wp-rte -wp-timeout 100 search.c    
[kernel] Parsing FRAMAC_SHARE/libc/__fc_builtin_for_normalization.i (no preprocessing)
[kernel] Parsing search.c (with preprocessing)
/tmp/ppannot97a491.c:1:0: warning: "__STDC_VERSION__" redefined
#define __STDC_VERSION__ 201112L
^
<built-in>: note: this is the location of the previous definition
/tmp/ppannot97a491.c:2:0: warning: "__STDC_UTF_16__" redefined
#define __STDC_UTF_16__ 1
^
<built-in>: note: this is the location of the previous definition
/tmp/ppannot97a491.c:3:0: warning: "__STDC_UTF_32__" redefined
#define __STDC_UTF_32__ 1
^
<built-in>: note: this is the location of the previous definition
[wp] Running WP plugin...
[wp] Collecting axiomatic usage
[rte] annotating function main
[rte] annotating function search
[wp] 20 goals scheduled
[wp] [Qed] Goal typed_main_call_search_pre : Valid
[wp] [Qed] Goal typed_main_call_search_pre_2 : Valid
[wp] [Alt-Ergo] Goal typed_search_complete_found_nfound : Valid (10ms) (19)
[wp] [Alt-Ergo] Goal typed_search_loop_inv_preserved : Valid (17ms) (21)
[wp] [Alt-Ergo] Goal typed_search_disjoint_found_nfound : Valid (13ms) (19)
[wp] [Qed] Goal typed_search_loop_inv_established : Valid
[wp] [Qed] Goal typed_search_loop_inv_2_established : Valid
[wp] [Alt-Ergo] Goal typed_main_call_search_pre_3 : Valid (383ms) (93)
[wp] [Alt-Ergo] Goal typed_search_loop_inv_2_preserved : Valid (17ms) (33)
[wp] [Qed] Goal typed_search_loop_assign : Valid
[wp] [Alt-Ergo] Goal typed_search_assert_rte_mem_access : Valid (50ms) (89)
[wp] [Alt-Ergo] Goal typed_search_assert_rte_unsigned_overflow : Valid (13ms) (30)
[wp] [Qed] Goal typed_search_assign_part1 : Valid
[wp] [Qed] Goal typed_search_assign_part2 : Valid
[wp] [Qed] Goal typed_search_assign_part3 : Valid
[wp] [Qed] Goal typed_search_assign_part4 : Valid
[wp] [Qed] Goal typed_search_loop_term_decrease : Valid (3ms)
[wp] [Qed] Goal typed_search_loop_term_positive : Valid
[wp] [Alt-Ergo] Goal typed_search_nfound_post : Valid (17ms) (33)
[wp] [Alt-Ergo] Goal typed_search_found_post : Unknown (54.3s)
[wp] Proved goals: 19 / 20
Qed: 11 (3ms-3ms)
Alt-Ergo: 8 (10ms-383ms) (93) (unknown: 1)

最佳答案

这让我困惑了一段时间,但在尝试 Coq 证明后,我发现你无法证明 found 的原因。行为很简单......它是不是 正确的。即,对于 len > INT_MAX和一个 itemINT_MAX 中找不到数组的第一个单元格,但稍后出现在某个地方,结果显示为 int将是负面的。

好吧,从技术上讲,这是实现定义的,如 C99,6.3.1.3§3 中所述:

Otherwise, the new type is signed and the value cannot be represented in it; either the result is implementation-defined or an implementation-defined signal is raised.



如果添加选项 -warn-signed-downcast在您的命令行中,您将看到一个新的 RTE 生成的断言,该断言未被证明:
     /*@ assert rte: signed_downcast: i ≤ 2147483647; */

然后是 found 的后置条件在所述断言成立的假设下,行为得到证明。

关于使用 Frama-C 验证线性搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34625197/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com