6260N/APlan and priority list for CoFI tool activities
6260N/A************************************************
6260N/A************************************************
6260N/ASuchfunktion f�r einen Knoten im DG:
6260N/A welche anderen Knoten sind hier mit Theoriemorphismus abbildbar?
6260N/A - Funktion f�r Morphismus-Suche zwischen Theorien
6260N/AKonfidenzgrade von Beweisen?
6260N/A Beweisobjekte an DGs, nicht an Regeln -- done
6260N/A F�r Theoreme in Theorien an Beweisobjekte -- done
6260N/A BasicProof mit Liste von Beweisobjekten -- �berfl�ssig
6260N/A Definitionen auszeichnen -- done
6260N/A F�r alles siehe G_theory, ThSens und SenStatus.
6260N/A Isabelles Beweisobjekte einbinden
6260N/A************************************************
6260N/A************************************************
6260N/AFreiburger Constraint-Solver angucken
6260N/ABremer Constraint-Solver angucken
6260N/A************************************************
6260N/A************************************************
6260N/AFunktionen imageOfMorphism und inhabited
6260N/A"free datatypes and recursive equations are consistent"
6260N/AcheckFreeType :: Morphism f e m -> [FORMULA f] -> Maybe Bool
6260N/AJust True => Yes, is consistent
6260N/AJust False => No, is inconsistent
6260N/Acall the symbols in the image of the signature morphism "new"
6260N/A- each new sort must be a free type,
6260N/A i.e. it must occur in a sort generation constraint that is marked as free
6260N/A such that the sort is in srts, where (srts,ops,_)=recover_Sort_gen_ax constrs
6260N/A if not, output "don't know"
6260N/A and there must be one term of that sort (inhabited)
6260N/A forall x_1:s_n .... x_n:s_n . f(t_1,...,t_m)=t
6260N/A forall x_1:s_n .... x_n:s_n . phi => f(t_1,...,t_m)=t
6260N/A Implication Application Strong_equation
6260N/A forall x_1:s_n .... x_n:s_n . p(t_1,...,t_m)<=>phi
6260N/A forall x_1:s_n .... x_n:s_n . phi1 => p(t_1,...,t_m)<=>phi
6260N/A Implication Predication Equivalence
6260N/A if there are axioms not being of this form, output "don't know"
6260N/Acheck' :: [EquationInfo] -> ([ExhaustivePat],EqnSet)
6260N/Acheck' [] = ([([],[])],emptyUniqSet)
6260N/A-- nur ein Pattern, bestehend aus nur Variablen? fertig, True
6260N/Acheck' [EqnInfo n ctx ps (MatchResult CanFail _)]
6260N/A | all_vars ps = ([(takeList ps (repeat new_wild_pat),[])], unitUniqSet n)
6260N/A-- besteht das erste Pattern nur aus Variablen? dann darf es kein zweites geben!
6260N/Acheck' qs@((EqnInfo n ctx ps (MatchResult CanFail _)):rs)
6260N/A | all_vars ps = (pats, addOneToUniqSet indexs n)
6260N/A-- falls ein Konstruktor dabei ist: split_by_constructor
6260N/A-- wenn die ersten Argument nur Variablen sind: first_column_only_vars
6260N/Acheck' qs@((EqnInfo n ctx ps result):_)
6260N/A | all_vars ps = ([], unitUniqSet n)
6260N/A | constructors = split_by_constructor qs
6260N/A | only_vars = first_column_only_vars qs
6260N/A -- Note: RecPats will have been simplified to ConPats
6260N/A constructors = or (map is_con qs)
6260N/A only_vars = and (map is_var qs)
6260N/Asubsort definitions: are conservative if formula is satisfiable
6260N/A (generate proof obligation)
6260N/A************************************************
6260N/A************************************************
6260N/A show hets output immediately
6260N/A when hets terminates abnormally (
e.g. with a fail), emacs loops
6260N/A C-n jumps to the next error, but the message windows is not always scrolled
6260N/A in such a way that the error is at the top (for long error lists)
6260N/A should work with parser error messages as well (adapt these?)
6260N/A************************************************
6260N/A************************************************
6260N/A see Chapter 4 of "The Description Logic Handbook"
6260N/A and ask Klaus for a print out of it
6260N/A************************************************
6260N/A************************************************
6260N/Amake modules hierarchical, change scoped type variables for ghc-6.5
6260N/A(and older ghcs), replace deprecated code (
i.e. FiniteMap, hslibs),
6260N/Ause HaXml as a cabalized library, provide uni as (one?) cabal
6260N/Apackage(s), uni used to work under windows as well, watch the
6260N/Ai.e. FilePath, Process discussions (libraries@haskell.org)
possibly switch to a subversion repository, talk to Achim
************************************************
************************************************
development graph calculus
(see Sect. IV:4.4 of the CASL Reference Manual)
implement simplified rule Theorem-Hide-Shift
weakly amalgamable cocones
************************************************
************************************************
look at translation to OMDoc
change management via translation to OMDoc
einfaches Merge von lokalen Beweisen eines abgespeichteren DG
************************************************
************************************************
If hets should become successful then requests for support under
windows will surely follow.
Ghc, uni and uDrawGraph should work under windows. Only Isabelle does
not exist for windows, but SPASS does. Probably only a few path
computations need to be adapted (made modular) within hets. Also
position computations (of Parsec) should be checked under windows.
************************************************
************************************************
eine HetCASL spezifische PP Lib (mit neuem Doc Typ), um Text, Latex
und andere Formate besser zu unterst�tzen und einheitlichen PP code
(independent from GlobalAnnos) f�r die (Het-)CASL (and HasCASL!)
Datentypen (particularly for HasCASL data types) zu bekommen.
LaTeX: see
listings.sty for LaTeX generation (cf. CoSiT paper)
************************************************
************************************************
set up a ticket and tracking systems (for bugs and features) instead
refactoring of dgraphs: add unique tags (but no table)
(make it really abstract), possibly contact amahnke@tzi.de regarding
set up default simplifier
set up default tactics using axioms
development graph calculus
- Stack overflow for "show just subtree"
- fail when doing first globDecomp, then local decomp in RelationsAndOrders
- correct MAYA: glob decomp: some links are not found (Jorina)
for local subsume in RelationsAndOrders
************************************************
************************************************
generate infrastructure for circular coinduction
CCS example: commutativity of || by coinduction
************************************************
************************************************
collect the patches for programatica (or create a package)
- conv (SN i p) = PN i (S p)
+ conv (SN i p) = PN i (Sn (show i) p)
fixes translation error of Pair
simplification of HasCASL sentences (omit types)
Logic COL is a ruin (with wrongly qualified module names)
logic coding from the comand line with printing of results
Haskell modules: hiding, renaming
i.e. the f resp. the p in
forall x_1:s_n .... x_n:s_n . phi => f(t_1,...,t_m)=t
forall x_1:s_n .... x_n:s_n . phi1 => p(t_1,...,t_m)<=>phi
if there are axioms not being of this form, output error
Missing points for heterogeneous WADT 04 example:
- improve display of HasCASL sigs + mors
Static analysis for HasCASL
pattern analysis for program equations
implemented only atomic subtyping
Weak amalgamation analysis?
Instantiate Transformation Application system for HasCASL?
Automatic generation of Haskell (for a HasCASL subset)
************************************************
************************************************
Connecting Hets with MathServ
pros: * relies not on external tool
cons: * code is not well maintained
* a lot of the deserialization of the answer must be done
- call a java program included in MathServ distrib
* deserilisation is mostly done in java
cons: * use of external tool
Use modified dfg2tptp to translate SPASS theories into TPTP problems
Add possibility to choose a prover out of a list of available provers
(similar to "More fine grained..." and behind more fine grained)
Adapt existing SPASS GUI to cover call of the MathServ broker
by - transforming the grid layout packer into the packer
- abstraction of certain parts of the GUI into helper functions
forms a new generic Prover-GUI toolkit
- on top of this GUI toolkit
Write a GUI based on the generic Prover-GUI
to call MathServ's Vampire service directly
with additional parameters
************************************************
************************************************
Consistency checker interface
via global interface, accessible from global and node menus
use falseSentence from
Logic.Logic (property: holds in no model)
disproved -> consistent (assuming completeness)
batch mode for automatic provers such as SPASS
(use automatic flag for provers)
batch interface for Isabelle
each goal is proved separatedly, with a time limit enforced
"using Ax1 ... Axn by auto"
where Ax1 ... Axn is the list of all axioms.
"auto" could be replaced with "best", "blast" etc. (user selection)
Ignore axiom selection for interactive provers
Translation between Achim's ontology data structure and CASL (in Hets)
visualization of "taxonomy" of CASL signatures
(subsorts = inheritance, unary preds = concepts, binary preds = relations)
last two ... partially done
f�r Anzeige von (un)bewiesenen Goals, ... done
bewiesene Goals als Axioms mit ausgeben ... was ist das ???
das ist schon implementiert ("Theorems to include if proven")
Recognize guarded fragment of CASL:
G ::= forall x . At(x) => G where At is a conjunction of atoms
Joost Visser wg. ATerms in Haskell => neues Repository
************************************************
************************************************
Weitere %implies-Annotationen zu den Basic Datatypes hinzufuegen
(Vorbild: Larch-Handbuch)
Parser and static analysis for CSP-CASL
************************************************
************************************************
IsaWin: support CASL-libraries
************************************************
************************************************
Regulate concurrent proving
.dg files: store only current library; import .dg files for other libraries
Isabelle: use meta-quantifiers
check for proved theorems
AbstractGraphView: switch to Result monad
unite or rename consCheck and cons_checkers
computeTheory does not work across library imports
hierarchical Isabelle theories
daVinci printing is not adequate
hiding of internal nodes does not work
FOL without quantifiers and with uniform disjunctions
algorithmic path consistency over a relation algebra
plug in reasoner for this
develop correctness results (algorithmic path consistency=path consistency)
FOL without quantifiers (with and without =)
Robinson consistency with shared theory constructed via pre-image?
show theorem links between same instances of different parameterized
specs (where one is an extension of the other one)
link menu for %implies, $def, %cons, even without open proof obligation
for a proved theorem, show minimal part of DG needed for proof
cons, def, mono for nodes
Isabelle interface: each qed should write proof info into file
globally display nodes containing symbols mapped "twice" (
i.e. via
different signature morphisms)
and add a menu for each node allowing for tracking the different
topsort coding: partial functions as relations?
theorem link menu for proof obligations
in Isabelle. Reason: Inlineaxioms does not translate ga_totality axioms
Fail: illegal node type in sublogic computation
J�rgen Zimmer, Saarbr�cken+Edinburgh, Beweiserkennung f�r versch. Logiken im MathWeb
for CSP-CASL example: with logic
theorem links between nodes in different libraries
basicProofs: use info about used axioms
Overload / inlineAxioms: injections
remove "prove" menu in abstracted dg
better sublogic analysis in codings
adjust path for thy files, such that hets can also be started from subdirs
Restrict Sonjas simplifications to HasCASL
add suitable axioms to simplifier and CR
computeTheory: remove double axioms
add suitable axioms to simplifier and classical reasoner
better display of internal nodes (use tooltip?)
update Hets, CASL, daVinci on web page
CASL2PCFOL: x_i -> t_i, t=[inj(x_i)] (and what not!)
packing of binaries: add hets-update, refer to TclTk
test for sublogic before applying comorphism
Missing points for heterogeneous WADT 04 example:
- coding to Isabelle: translate sort gen constraints
- Improve adapation to Isabelle's lexis
Isabelle: (ask Christoph)
remove datatypes from sort list
prove local thm link (=> green)
"prove" menu with choice windows
sublogic translation table
better interaction between Isabelle instance (for one node)
+ selection of single goals that are proved
=> use PGIP interface (Christoph, David)
Keep proofs and lemmas in .thy files (kind of merge)
CASL annotation for lemmas that should be used in proof
inherit CASL's mixfix syntax
Signatures versus theories: where to store additional infos?
comp(id,x)=x for comorphism names
Mixfix analysis + typecheck for modality axiomatizations
Modal logics: modal logic, temporal logic, mu calculus
+ translations (
e.g. modal to FOL)
CASL->Haskell with free DTs (mark sortgens) + recursion
- List[Dec] wird List[Pos]
- node numbers do not match
- thm links with external target should be provable as well
Different types of logic translations
Improve Static analysis of structured specs
Development graph calculus, Strategies for DG rules
FOL-prover by Uli Furhbach
modal logic: IRIT, Toulouse. Tableaux prover LOTREC, Andreas Herzig
Renate Schmidt, Manchester: uses FOL prover for description logic
(as efficient as DL-specific tools!)
consistency: see IJCAR-workshop on non-provability in Cork
IJCAR workshop about logical frameworks and meta-languages
Klaus' wayfinding example
ask Detlef: critical pairs, Fossacs paper by Francesco
first steps towards CASL instance, using ATerms and re-using MMISS instance
variants for specs (needed for DOLCE: CASL variant, DL variant, ...)
+ for TAS: reflection of HOL in HOL, to be composed with encodings
(
i.e. signatures, axioms, signature morphisms in HOL,
re-use ML signatures) (Einar)
Display Specs as daVinci subgraphs
************************************************
************************************************
Hets interactive (provide cmd line interface, but hold loaded libraries in memory, provide switch to context of spec, and type checking of expressions, interaction with emacs mode)
Packaging of installation
with Eclipse, WXHaskell or GTk?
how to integrate with event system of UniForM workbench?
integrate graphviz (or use Java interface for racer? or Isabelle browser? or...?)
Data.Serizable (only when ghc supports it) better: rely on pointer equality
integrate QuickCheck: come to lecture!
++++++++++++++++++++++++++++++++++++++++++++++++
++++++++++++++++++++++++++++++++++++++++++++++++
Mark-Oliver Stehr, Hamburg cf. HOL-Nurpl-Translation in Maude
Proofs with basic datatypes
Verbesserung der Fehlermeldungen
Example of Agnes und Frank: proofs in HOL-CASL (2 days)
Examples for cond rewriting -> Christophe
Doku: VSE-Prover, VSE-Method VSE-demo in Bremen?
Eigene IsaWin-Instanz mit CASL-RS statt HOL-RS
Encoding of structured free (3 days)
Encoding of structured cofree (2 weeks)
Eingabesyntax als Mix zwischen CASL und HOL (3 days)
Adapt Isabelle unions to CASL unions (1 week)
Generate Proof obligations (1 week)
Add renaming to Isabelle kernel (2 months)
Repository mit korrekten und fehlerhaften Specs
HetCATS User manual, Doku fuer Environments (2 weeks)
Comparsion of parsers (ML-yacc parser, SDF-Parser)
Conversion-Tool CASL 1.0 => CASL 1.0.1 komplettieren
PVS anbinden (Kooperation mit Cachan?)
Portations: Intel-Solaris, Mac OS-10 (2 weeks)
(X)Emacs mode for CASL, hide Display Annotations (2 weeks) -> Raffael Sturm
Uebersetzung von CASL-LaTeX-Spezifikationen nach ASCII
Neues Tool-Schaubild auf Web-Seiten ver�ffentlichen
{- This does not work due to needed ordering:
instance Functor Set where
m >>= k = unionManySets (setToList (fmap k m))
[("normal","normal","normal"),
("normal","inclusion","normal"),
("inclusion","normal","normal"),
("inclusion","inclusion","inclusion")]
Aufbau des Graphen selbst