-
Notifications
You must be signed in to change notification settings - Fork 0
jovenlin0527/formal
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
b05902132 林敬文 本次project要證明merge sort,為了證明方便拆成兩個function,merge_sort跟merge, 放在不同檔案,這樣prover可以不用看到一些無關的敘述。 function的precondition跟postcondition都放在merge_sort.h。 證明時有使用到Coq,使用的script放在/coq_script中,檔名跟assertion的名字一致。 為了方便起見,這些script我也放在/.frama_c裡面,wp會自己到這個資料夾找coq的script。 證明時請使用-wp -wp-rte -wp-prover=coq,alt-ergo -wp-timeout=300, 而且請一次只證明一個檔案。 證明某些變數沒有改變時花的時間異常地久,請稍候。 Coq的證明大多有寫註解,難懂的證明會寫的比較詳細。 有些指令用到的地方比較多就統一列在這裡。 lia可以用來自動證明有關整數的定理,在比較舊的Coq中稱為omega, 需要Import才能用。 natlike_ind顧名思義就是用來在整數上做自然數的數學歸納法, 如果想證明的定理是0 <= z -> P z,則可以apply natlike_ind P。 有的時候P會很長,看起來就會很醜,不過我找不到要怎麼自動化。 (有時候apply natlike_ind可以自動偵測出P是啥, 不過這次有用到的地方沒有一個是有辦法偵測出來的。) 證明進度: merge_sort完全證明完畢。 merge的部分沒辦法證明只有Assign到Out,儘管函式內動到的變數只有這個不是Global ariable。 merge還有另外一個無法證明的assertion,loop1_append_i1_loop2,證明這個需要用到 記憶體的一些性質,超出我的能力範圍。(神奇的是證明另一個對應的迴圈卻不用。) 使用的工具版本: why3 1.3.3 frama-c 22.0 coq 8.12.2 alt-ergo 2.3.3
About
No description, website, or topics provided.
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published