summaryrefslogtreecommitdiff
path: root/examples/nqueens/NQueens.gf
blob: 6eec8953f468d211d73c62ad4246104ef539cca4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
abstract NQueens = Nat ** {

cat S ;
cat Matrix Nat ;
cat [Nat] ;
cat Vec (s,l : Nat) [Nat] ;
cat Sat Nat Nat [Nat] ;

data nqueens : (n : Nat) -> Matrix n -> S ;

data nilV  : ({s} : Nat) -> ({c} : [Nat]) -> Vec s zero c ;
     consV : ({l},j,k : Nat) -> 
                let s = succ (plus j k)
                in ({c} : [Nat]) -> Sat j (succ zero) c -> Vec s l (ConsNat j c) -> Vec s (succ l) c ;

     nilS : ({j,d} : Nat) -> Sat j d BaseNat ;
     consS : ({i,j,d} : Nat) -> ({c} : [Nat]) -> NE i j -> NE i (plus d j) -> NE (plus d i) j -> Sat j (succ d) c -> Sat j d (ConsNat i c) ;

     matrix : ({s} : Nat) -> Vec s s BaseNat -> Matrix s ;

}