X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Fcic_disambiguation%2Farit_notation.ml;h=780fed363d575f473f6056607970cdc39e127ccd;hb=5325734bc2e4927ed7ec146e35a6f0f2b49f50c1;hp=998688cbebc61a9ca5c28a9907a96c76a200ac50;hpb=aba014724c9ad08f80944ec3021c9fa3826dca4a;p=helm.git diff --git a/helm/ocaml/cic_disambiguation/arit_notation.ml b/helm/ocaml/cic_disambiguation/arit_notation.ml index 998688cbe..780fed363 100644 --- a/helm/ocaml/cic_disambiguation/arit_notation.ml +++ b/helm/ocaml/cic_disambiguation/arit_notation.ml @@ -23,28 +23,148 @@ * http://helm.cs.unibo.it/ *) -open Ast -open Parser +open CicTextualParser2 EXTEND term: LEVEL "add" [ [ t1 = term; SYMBOL "+"; t2 = term -> - return_term loc (Appl_symbol ("plus", [t1; t2])) + return_term loc (CicAst.Appl [CicAst.Symbol ("plus", 0); t1; t2]) | t1 = term; SYMBOL "-"; t2 = term -> - return_term loc (Appl_symbol ("minus", [t1; t2])) + return_term loc (CicAst.Appl [CicAst.Symbol ("minus", 0); t1; t2]) ] ]; term: LEVEL "mult" [ [ t1 = term; SYMBOL "*"; t2 = term -> - return_term loc (Appl_symbol ("times", [t1; t2])) + return_term loc (CicAst.Appl [CicAst.Symbol ("times", 0); t1; t2]) | t1 = term; SYMBOL "/"; t2 = term -> - return_term loc (Appl_symbol ("div", [t1; t2])) + return_term loc (CicAst.Appl [CicAst.Symbol ("divide", 0); t1; t2]) + ] + ]; + term: LEVEL "power" + [ + [ t1 = term; SYMBOL "^"; t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("power", 0); t1; t2]) ] ]; term: LEVEL "inv" [ - [ SYMBOL "-"; t = term -> return_term loc (Appl_symbol ("uminus", [t])) ] + [ SYMBOL "-"; t = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("uminus", 0); t]) + ] + ]; + term: LEVEL "relop" + [ + [ t1 = term; SYMBOL <:unicode> (* ≤ *); t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("leq", 0); t1; t2]) + | t1 = term; SYMBOL <:unicode> (* ≥ *); t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("geq", 0); t1; t2]) + | t1 = term; SYMBOL "<"; t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("lt", 0); t1; t2]) + | t1 = term; SYMBOL ">"; t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("gt", 0); t1; t2]) + | t1 = term; SYMBOL <:unicode> (* ≠ *); t2 = term -> + return_term loc (CicAst.Appl [CicAst.Symbol ("neq", 0); t1; t2]) + ] ]; END + +let _ = + let const s = Cic.Const (s, []) in + let mutind s = Cic.MutInd (s, 0, []) in + + DisambiguateChoices.add_num_choice + ("natural number", + (fun _ num _ -> HelmLibraryObjects.build_nat (int_of_string num))); + DisambiguateChoices.add_num_choice + ("real number", + (fun _ num _ -> HelmLibraryObjects.build_real (int_of_string num))); + DisambiguateChoices.add_num_choice + ("binary positive number", + (fun _ num _ -> + let num = int_of_string num in + if num = 0 then + raise DisambiguateChoices.Invalid_choice + else + HelmLibraryObjects.build_bin_pos num)); + DisambiguateChoices.add_num_choice + ("binary integer number", + (fun _ num _ -> + let num = int_of_string num in + if num = 0 then + HelmLibraryObjects.BinInt.z0 + else if num > 0 then + Cic.Appl [ + HelmLibraryObjects.BinInt.zpos; + HelmLibraryObjects.build_bin_pos num ] + else + assert false)); + + DisambiguateChoices.add_binary_op "plus" "natural plus" + HelmLibraryObjects.Peano.plus; + DisambiguateChoices.add_binary_op "plus" "real plus" + HelmLibraryObjects.Reals.rplus; + DisambiguateChoices.add_binary_op "plus" "binary integer plus" + HelmLibraryObjects.BinInt.zplus; + DisambiguateChoices.add_binary_op "plus" "binary positive plus" + HelmLibraryObjects.BinPos.pplus; + DisambiguateChoices.add_binary_op "minus" "natural minus" + (const HelmLibraryObjects.Peano.minus_URI); + DisambiguateChoices.add_binary_op "minus" "real minus" + (const HelmLibraryObjects.Reals.rminus_URI); + DisambiguateChoices.add_binary_op "minus" "binary integer minus" + HelmLibraryObjects.BinInt.zminus; + DisambiguateChoices.add_binary_op "minus" "binary positive minus" + HelmLibraryObjects.BinPos.pminus; + DisambiguateChoices.add_binary_op "times" "natural times" + (const HelmLibraryObjects.Peano.mult_URI); + DisambiguateChoices.add_binary_op "times" "real times" + (const HelmLibraryObjects.Reals.rmult_URI); + DisambiguateChoices.add_binary_op "times" "binary positive times" + HelmLibraryObjects.BinPos.pmult; + DisambiguateChoices.add_binary_op "times" "binary integer times" + HelmLibraryObjects.BinInt.zmult; + DisambiguateChoices.add_binary_op "power" "real power" + (const HelmLibraryObjects.Reals.pow_URI); + DisambiguateChoices.add_binary_op "power" "integer power" + (const HelmLibraryObjects.BinInt.zpower_URI); + DisambiguateChoices.add_binary_op "divide" "real divide" + (const HelmLibraryObjects.Reals.rdiv_URI); + DisambiguateChoices.add_unary_op "uminus" "real unary minus" + (const HelmLibraryObjects.Reals.ropp_URI); + DisambiguateChoices.add_unary_op "uminus" "binary integer negative sign" + (HelmLibraryObjects.BinInt.zneg); + DisambiguateChoices.add_unary_op "uminus" "binary integer unary minus" + (HelmLibraryObjects.BinInt.zopp); + + DisambiguateChoices.add_binary_op "leq" "natural 'less or equal to'" + (mutind HelmLibraryObjects.Peano.le_URI); + DisambiguateChoices.add_binary_op "leq" "real 'less or equal to'" + (const HelmLibraryObjects.Reals.rle_URI); + DisambiguateChoices.add_binary_op "geq" "natural 'greater or equal to'" + (const HelmLibraryObjects.Peano.ge_URI); + DisambiguateChoices.add_binary_op "geq" "real 'greater or equal to'" + (const HelmLibraryObjects.Reals.rge_URI); + DisambiguateChoices.add_binary_op "lt" "natural 'less than'" + (const HelmLibraryObjects.Peano.lt_URI); + DisambiguateChoices.add_binary_op "lt" "real 'less than'" + (const HelmLibraryObjects.Reals.rlt_URI); + DisambiguateChoices.add_binary_op "gt" "natural 'greater than'" + (const HelmLibraryObjects.Peano.gt_URI); + DisambiguateChoices.add_binary_op "gt" "real 'greater than'" + (const HelmLibraryObjects.Reals.rgt_URI); + DisambiguateChoices.add_symbol_choice "neq" + ("not equal to (leibnitz)", + (fun env _ args -> + let t1, t2 = + match args with + | [t1; t2] -> t1, t2 + | _ -> raise DisambiguateChoices.Invalid_choice + in + Cic.Appl [ const HelmLibraryObjects.Logic.not_URI; + Cic.Appl [ + Cic.MutInd (HelmLibraryObjects.Logic.eq_URI, 0, []); + Cic.Implicit (Some `Type); t1; t2 ] ])); + +(* vim:set encoding=utf8: *)