मैं filter
और map
के कुछ गुण साबित कर रहा था, जब तक मैं इस संपत्ति पर ठोकर नहीं डालता तब तक सब कुछ ठीक हो गया: filter p (map f xs) ≡ map f (filter (p ∘ f) xs)
। यहाँ कोड है कि प्रासंगिक है का एक हिस्सा है:≡-तर्क और 'साथ' पैटर्न
open import Relation.Binary.PropositionalEquality
open import Data.Bool
open import Data.List hiding (filter)
import Level
filter : ∀ {a} {A : Set a} → (A → Bool) → List A → List A
filter _ [] = []
filter p (x ∷ xs) with p x
... | true = x ∷ filter p xs
... | false = filter p xs
अब, क्योंकि मैं ≡-Reasoning
मॉड्यूल का उपयोग कर सबूत लेखन से प्यार है, पहली बात मैंने कोशिश की थी:
open ≡-Reasoning
open import Function
filter-map : ∀ {a b} {A : Set a} {B : Set b}
(xs : List A) (f : A → B) (p : B → Bool) →
filter p (map f xs) ≡ map f (filter (p ∘ f) xs)
filter-map [] _ _ = refl
filter-map (x ∷ xs) f p with p (f x)
... | true = begin
filter p (map f (x ∷ xs))
≡⟨ refl ⟩
f x ∷ filter p (map f xs)
-- ...
लेकिन अफसोस, कि काम नहीं किया । एक घंटे के लिए कोशिश कर के बाद, मैं अंत में छोड़ दिया और इस तरह से यह साबित हो:
filter-map (x ∷ xs) f p with p (f x)
... | true = cong (λ a → f x ∷ a) (filter-map xs f p)
... | false = filter-map xs f p
फिर भी क्यों ≡-Reasoning
माध्यम से जा रहा काम नहीं किया के बारे में उत्सुक है, मैं बहुत तुच्छ कुछ करने की कोशिश की:
filter-map-def : ∀ {a b} {A : Set a} {B : Set b}
(x : A) xs (f : A → B) (p : B → Bool) → T (p (f x)) →
filter p (map f (x ∷ xs)) ≡ f x ∷ filter p (map f xs)
filter-map-def x xs f p _ with p (f x)
filter-map-def x xs f p() | false
filter-map-def x xs f p _ | true = -- not writing refl on purpose
begin
filter p (map f (x ∷ xs))
≡⟨ refl ⟩
f x ∷ filter p (map f xs)
∎
लेकिन टाइपशेकर मुझसे सहमत नहीं है। ऐसा लगता है कि वर्तमान लक्ष्य filter p (f x ∷ map f xs) | p (f x)
बनी हुई है और भले ही मैं पैटर्न p (f x)
पर मेल खाता हूं, filter
बस f x ∷ filter p (map f xs)
तक कम नहीं होगा।
क्या इस काम को ≡-Reasoning
के साथ बनाने का कोई तरीका है?
धन्यवाद!
इसी तरह की समस्या का पुनरीक्षण: तो "स्टेरॉयड पर निरीक्षण" या "पुनः लिखना" धन्य तरीका है? – nicolas
@nicolas: मुझे लगता है कि वे वास्तव में एकमात्र तरीका हैं (यह न भूलें कि 'पुनः लिखना' सिर्फ 'के साथ' है)। – Vitus
धन्यवाद। भविष्य के इच्छुक पाठकों के संदर्भ में, मैंने उन वीडियो को पाया जो क्रिस जेनकींस द्वारा काफी जानकारीपूर्ण रहे हैं: https://www.youtube.com/channel/UCC84u-u6xRFQQd6wu33NfDw – nicolas