Mercurial > hg > Members > kono > Proof > automaton
view automaton-in-agda/src/automaton.agda @ 253:012f79b51dba
... prime version
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 29 Jun 2021 23:24:03 +0900 |
parents | 3fa72793620b |
children | 91781b7c65a8 |
line wrap: on
line source
module automaton where open import Data.Nat open import Data.List open import Relation.Binary.PropositionalEquality hiding ( [_] ) open import logic record Automaton ( Q : Set ) ( Σ : Set ) : Set where field δ : Q → Σ → Q aend : Q → Bool open Automaton accept : { Q : Set } { Σ : Set } → Automaton Q Σ → (astart : Q) → List Σ → Bool accept {Q} { Σ} M q [] = aend M q accept {Q} { Σ} M q ( H ∷ T ) = accept M ( (δ M) q H ) T moves : { Q : Set } { Σ : Set } → Automaton Q Σ → Q → List Σ → Q moves {Q} { Σ} M q [] = q moves {Q} { Σ} M q ( H ∷ T ) = moves M ( δ M q H) T trace : { Q : Set } { Σ : Set } → Automaton Q Σ → Q → List Σ → List Q trace {Q} { Σ} M q [] = q ∷ [] trace {Q} { Σ} M q ( H ∷ T ) = q ∷ trace M ( (δ M) q H ) T reachable : { Q : Set } { Σ : Set } → (M : Automaton Q Σ ) → (astart q : Q ) → (L : List Σ ) → Set reachable M astart q L = moves M astart L ≡ q