मेरे आवेदन के लिए, मुझे कोक में सीमित नक्शे के बारे में उपयोग करने और तर्क करने की आवश्यकता है। चारों ओर घूमते हुए मुझे FMapAVL के बारे में पता चला है जो मेरी आवश्यकताओं के लिए एकदम सही फिट लगता है। समस्या यह है कि दस्तावेज दुर्लभ है, और मुझे पता नहीं चला है कि मुझे इसका उपयोग कैसे करना है।अंतिम नक्शा उदाहरण
एक मामूली उदाहरण के रूप में, जोड़े की सूची का उपयोग करके एक सीमित मानचित्र के निम्नलिखित मूर्ख कार्यान्वयन पर विचार करें।
Require Export Bool.
Require Export List.
Require Export Arith.EqNat.
Definition map_nat_nat: Type := list (nat * nat).
Fixpoint find (k: nat) (m: map_nat_nat) :=
match m with
| nil => None
| kv :: m' => if beq_nat (fst kv) k
then Some (snd kv)
else find k m'
end.
Notation "x |-> y" := (pair x y) (at level 60, no associativity).
Notation "[ ]" := nil.
Notation "[ p , .. , r ]" := (cons p .. (cons r nil) ..).
Example ex1: find 3 [1 |-> 2, 3 |-> 4] = Some 4.
Proof. reflexivity. Qed.
Example ex2: find 5 [1 |-> 2, 3 |-> 4] = None.
Proof. reflexivity. Qed.
मैं FMapAVL का उपयोग करके समान उदाहरणों को परिभाषित और साबित कैसे कर सकता हूं बल्कि जोड़े की सूची?
समाधान
answer from Ptival bellow के लिए धन्यवाद, यह एक पूर्ण काम कर उदाहरण है:
Require Export FMapAVL.
Require Export Coq.Structures.OrderedTypeEx.
Module M := FMapAVL.Make(Nat_as_OT).
Definition map_nat_nat: Type := M.t nat.
Definition find k (m: map_nat_nat) := M.find k m.
Definition update (p: nat * nat) (m: map_nat_nat) :=
M.add (fst p) (snd p) m.
Notation "k |-> v" := (pair k v) (at level 60).
Notation "[ ]" := (M.empty nat).
Notation "[ p1 , .. , pn ]" := (update p1 .. (update pn (M.empty nat)) ..).
Example ex1: find 3 [1 |-> 2, 3 |-> 4] = Some 4.
Proof. reflexivity. Qed.
Example ex2: find 5 [1 |-> 2, 3 |-> 4] = None.
Proof. reflexivity. Qed.
आपके उत्तर के लिए धन्यवाद, लेकिन हाँ, अगर आप ऑर्डर्डनेट मॉड्यूल बनाने पर मुझे थोड़ा और मदद दे सकते हैं तो मुझे खुशी होगी। –
स्क्रैच करें, मुझे लगता है कि मैंने इसे समझ लिया है। मैं जल्द ही एक उदाहरण के साथ एक अद्यतन पोस्ट करूंगा। धन्यवाद! –
असल में, 'नेट' के लिए, आप यहां दिए गए 'Nat_as_OT' का पुन: उपयोग कर सकते हैं: http://coq.inria.fr/distrib/8.4/stdlib/Coq.Structures.OrderedTypeEx.html – Ptival