ProgTutorial/Recipes/Sat.thy
author Norbert Schirmer <norbert.schirmer@web.de>
Wed, 22 May 2019 12:38:51 +0200
changeset 574 034150db9d91
parent 572 438703674711
permissions -rw-r--r--
polish document
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
127
74846cb0fff9 updated and added two tentative recipes
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
74846cb0fff9 updated and added two tentative recipes
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
theory Sat
441
Christian Urban <urbanc@in.tum.de>
parents: 346
diff changeset
     3
imports "../Appendix" "../First_Steps" 
127
74846cb0fff9 updated and added two tentative recipes
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
begin
74846cb0fff9 updated and added two tentative recipes
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
     6
section \<open>SAT Solvers\label{rec:sat}\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
     7
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
     8
text \<open>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
     9
  {\bf Problem:}
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    10
  You like to use a SAT solver to find out whether
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    11
  an Isabelle formula is satisfiable or not.\smallskip
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    12
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    13
  {\bf Solution:} Isabelle contains a general interface for 
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    14
  a number of external SAT solvers (including ZChaff and Minisat)
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    15
  and also contains a simple internal SAT solver that
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    16
  is based on the DPLL algorithm.\smallskip
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    17
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    18
  The SAT solvers expect a propositional formula as input and produce
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    19
  a result indicating that the formula is either satisfiable, unsatisfiable or
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    20
  unknown. The type of the propositional formula is  
458
242e81f4d461 updated to post-2011 Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 441
diff changeset
    21
  @{ML_type "Prop_Logic.prop_formula"} with the usual constructors such 
242e81f4d461 updated to post-2011 Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 441
diff changeset
    22
  as @{ML And in Prop_Logic}, @{ML Or in Prop_Logic} and so on.
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    23
458
242e81f4d461 updated to post-2011 Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 441
diff changeset
    24
  The function  @{ML  Prop_Logic.prop_formula_of_term} translates an Isabelle 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    25
  term into a propositional formula. Let
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    26
  us illustrate this function by translating @{term "A \<and> \<not>A \<or> B"}. 
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    27
  The function will return a propositional formula and a table. Suppose 
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    28
\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    29
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    30
ML %grayML\<open>val (pform, table) = 
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    31
       Prop_Logic.prop_formula_of_term @{term "A \<and> \<not>A \<or> B"}  Termtab.empty\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    32
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    33
text \<open>
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    34
  then the resulting propositional formula @{ML pform} is 
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    35
  
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    36
  @{ML [display] \<open>Or (And (BoolVar 1, Not (BoolVar 1)), BoolVar 2)\<close> in Prop_Logic} 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    37
  
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    38
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    39
  where indices are assigned for the variables 
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    40
  \<open>A\<close> and \<open>B\<close>, respectively. This assignment is recorded 
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    41
  in the table that is given to the translation function and also returned 
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    42
  (appropriately updated) in the result. In the case above the
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    43
  input table is empty (i.e.~@{ML Termtab.empty}) and the output table is
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    44
572
438703674711 prefer more result checking in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 569
diff changeset
    45
  @{ML_response [display,gray]
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    46
  \<open>Termtab.dest table\<close>
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    47
  \<open>[(Free ("A", "bool"), 1), (Free ("B", "bool"), 2)]\<close>}
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    48
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    49
  An index is also produced whenever the translation
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    50
  function cannot find an appropriate propositional formula for a term. 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    51
  Attempting to translate @{term "\<forall>x::nat. P x"}
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    52
\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    53
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    54
ML %grayML\<open>val (pform', table') = 
574
034150db9d91 polish document
Norbert Schirmer <norbert.schirmer@web.de>
parents: 572
diff changeset
    55
  Prop_Logic.prop_formula_of_term @{term "\<forall>x::nat. P x"}
034150db9d91 polish document
Norbert Schirmer <norbert.schirmer@web.de>
parents: 572
diff changeset
    56
  Termtab.empty\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    57
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    58
text \<open>
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    59
  returns @{ML \<open>BoolVar 1\<close> in Prop_Logic} for  @{ML pform'} and the table 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    60
  @{ML table'} is:
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    61
572
438703674711 prefer more result checking in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 569
diff changeset
    62
  @{ML_response [display,gray]
574
034150db9d91 polish document
Norbert Schirmer <norbert.schirmer@web.de>
parents: 572
diff changeset
    63
  \<open>map (apfst (YXML.content_of o Syntax.string_of_term @{context})) 
034150db9d91 polish document
Norbert Schirmer <norbert.schirmer@web.de>
parents: 572
diff changeset
    64
    (Termtab.dest table')\<close>
572
438703674711 prefer more result checking in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 569
diff changeset
    65
  \<open>("\<forall>x. P x", 1)\<close>}
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    66
  
191
0150cf5982ae polished some recipies
Christian Urban <urbanc@in.tum.de>
parents: 189
diff changeset
    67
  In the print out of the tabel, we used some pretty printing scaffolding 
0150cf5982ae polished some recipies
Christian Urban <urbanc@in.tum.de>
parents: 189
diff changeset
    68
  to see better which assignment the table contains.
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    69
 
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    70
  Having produced a propositional formula, you can now call the SAT solvers 
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    71
  with the function @{ML \<open>SAT_Solver.invoke_solver\<close>}. For example
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    72
567
f7c97e64cc2a tuned ML-antiquotations; added intro portions.
Norbert Schirmer <norbert.schirmer@web.de>
parents: 565
diff changeset
    73
  @{ML_matchresult_fake [display,gray]
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    74
  \<open>SAT_Solver.invoke_solver "minisat" pform\<close>
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    75
  \<open>SAT_Solver.SATISFIABLE assg\<close>}
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    76
\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    77
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    78
text \<open>
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    79
  determines that the formula @{ML pform} is satisfiable. If we inspect
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    80
  the returned function \<open>assg\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    81
567
f7c97e64cc2a tuned ML-antiquotations; added intro portions.
Norbert Schirmer <norbert.schirmer@web.de>
parents: 565
diff changeset
    82
  @{ML_matchresult [display,gray]
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    83
\<open>let
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    84
  val SAT_Solver.SATISFIABLE assg = SAT_Solver.invoke_solver "auto" pform
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    85
in 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    86
  (assg 1, assg 2, assg 3)
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    87
end\<close>
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
    88
  \<open>(NONE, SOME true, NONE)\<close>}
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    89
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
    90
  we obtain a possible assignment for the variables \<open>A\<close> an \<open>B\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    91
  that makes the formula satisfiable. 
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    92
556
3c214b215f7e some small updates for Isabelle and corrections in the Parsing chapter
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 553
diff changeset
    93
  Note that we invoked the SAT solver with the string @{text [quotes] auto}. 
3c214b215f7e some small updates for Isabelle and corrections in the Parsing chapter
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 553
diff changeset
    94
  This string specifies which specific SAT solver is invoked. If instead 
3c214b215f7e some small updates for Isabelle and corrections in the Parsing chapter
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 553
diff changeset
    95
  called with @{text [quotes] "auto"}
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    96
  several external SAT solvers will be tried (assuming they are installed). 
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
    97
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
    98
  There are also two tactics that make use of SAT solvers. One 
553
c53d74b34123 updated to changes in Isabelle
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 517
diff changeset
    99
  is the tactic @{ML sat_tac in SAT}. For example 
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
   100
\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   101
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   102
lemma "True"
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
   103
apply(tactic \<open>SAT.sat_tac @{context} 1\<close>)
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   104
done
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   105
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
   106
text \<open>
569
f875a25aa72d prefer cartouches over " in ML antiquotations
Norbert Schirmer <norbert.schirmer@web.de>
parents: 567
diff changeset
   107
  However, for proving anything more exciting using @{ML \<open>sat_tac\<close> in SAT} you 
191
0150cf5982ae polished some recipies
Christian Urban <urbanc@in.tum.de>
parents: 189
diff changeset
   108
  have to use a SAT solver that can produce a proof. The internal 
0150cf5982ae polished some recipies
Christian Urban <urbanc@in.tum.de>
parents: 189
diff changeset
   109
  one is not usuable for this. 
184
c7f04a008c9c some polishing
Christian Urban <urbanc@in.tum.de>
parents: 181
diff changeset
   110
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   111
  \begin{readmore} 
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   112
  The interface for the external SAT solvers is implemented
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   113
  in @{ML_file "HOL/Tools/sat_solver.ML"}. This file contains also a simple
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   114
  SAT solver based on the DPLL algorithm. The tactics for SAT solvers are
553
c53d74b34123 updated to changes in Isabelle
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 517
diff changeset
   115
  implemented in @{ML_file "HOL/Tools/sat.ML"}. Functions concerning
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   116
  propositional formulas are implemented in @{ML_file
181
5baaabe1ab92 updated to new method_setup
Christian Urban <urbanc@in.tum.de>
parents: 180
diff changeset
   117
  "HOL/Tools/prop_logic.ML"}. The tables used in the translation function are
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   118
  implemented in @{ML_file "Pure/General/table.ML"}.  
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   119
  \end{readmore}
565
cecd7a941885 isabelle update_cartouches -t
Norbert Schirmer <norbert.schirmer@web.de>
parents: 562
diff changeset
   120
\<close>
180
9c25418db6f0 added a recipy about SAT solvers
Christian Urban <urbanc@in.tum.de>
parents: 127
diff changeset
   121
127
74846cb0fff9 updated and added two tentative recipes
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   122
517
d8c376662bb4 removed special ML-setup and replaced it by explicit markups (i.e., %grayML)
Christian Urban <urbanc@in.tum.de>
parents: 458
diff changeset
   123
end