CONTRIBUTORS
author blanchet
Wed Jun 11 15:44:09 2014 +0200 (2014-06-11)
changeset 57216 6cd8566e938e
parent 57030 b592202a45cc
child 57235 b0b9a10e4bf4
permissions -rw-r--r--
updated contributors to include students
     1 For the purposes of the license agreement in the file COPYRIGHT, a
     2 'contributor' is anybody who is listed in this file (CONTRIBUTORS) or
     3 who is listed as an author in one of the source files of this Isabelle
     4 distribution.
     5 
     6 Contributions to this Isabelle version
     7 --------------------------------------
     8 
     9 * Summer 2014: Mathias Fleury, ENS Rennes, and Albert Steckermeier, TUM
    10   Work on exotic automatic theorem provers for Sledgehammer (LEO-II, veriT,
    11   Waldmeister, etc.).
    12 
    13 * May 2014: Cezary Kaliszyk, University of Innsbruck, and Jasmin Blanchette, TUM
    14   SML-based engines for MaSh.
    15 
    16 * March 2014: René Thiemann
    17   Improved code generation for multisets.
    18 
    19 * February 2014: Florian Haftmann, TUM
    20   Permanent interpretation inside theory, locale and class targets with mixin definitions.
    21 
    22 * Fall 2013 and Winter 2014: Martin Desharnais, Lorenz Panny, Dmitriy Traytel,
    23   and Jasmin Blanchette, TUM
    24   Various improvements to the BNF-based (co)datatype package, including
    25   a more polished "primcorec" command, optimizations, and integration in
    26   the "HOL" session.
    27 
    28 * Winter/Spring 2014: Sascha Boehme, QAware GmbH, and Jasmin Blanchette, TUM
    29   "SMT2" module and "smt2" proof method, based on SMT-LIB 2 and Z3 4.3.
    30 
    31 * January 2014: Lars Hupel, TUM
    32   An improved, interactive simplifier trace with integration into the
    33   Isabelle/jEdit Prover IDE.
    34 
    35 * December 2013: Florian Haftmann, TUM
    36   Consolidation of abstract interpretations concerning min and max.
    37 
    38 * November 2013: Florian Haftmann, TUM
    39   Abolition of negative numeral literals in the logic.
    40 
    41 
    42 Contributions to Isabelle2013-1
    43 -------------------------------
    44 
    45 * September 2013: Lars Noschinski, TUM
    46   Conversion between function definitions as list of equations and
    47   case expressions in HOL.
    48   New library Simps_Case_Conv with commands case_of_simps,
    49   simps_of_case.
    50 
    51 * September 2013: Nik Sultana, University of Cambridge
    52   Improvements to HOL/TPTP parser and import facilities.
    53 
    54 * September 2013: Johannes Hölzl and Dmitriy Traytel, TUM
    55   New "coinduction" method (residing in HOL-BNF) to avoid boilerplate.
    56 
    57 * Summer 2013: Makarius Wenzel, Université Paris-Sud / LRI
    58   Improvements of Isabelle/Scala and Isabelle/jEdit Prover IDE.
    59 
    60 * Summer 2013: Manuel Eberl, TUM
    61   Generation of elimination rules in the function package.
    62   New command "fun_cases".
    63 
    64 * Summer 2013: Christian Sternagel, JAIST
    65   Improved support for ad hoc overloading of constants, including
    66   documentation and examples.
    67 
    68 * Spring and Summer 2013: Lorenz Panny, Dmitriy Traytel, and
    69   Jasmin Blanchette, TUM
    70   Various improvements to the BNF-based (co)datatype package, including
    71   "primrec_new" and "primcorec" commands and a compatibility layer.
    72 
    73 * Spring and Summer 2013: Ondrej Kuncar, TUM
    74   Various improvements of Lifting and Transfer packages.
    75 
    76 * Spring 2013: Brian Huffman, Galois Inc.
    77   Improvements of the Transfer package.
    78 
    79 * Summer 2013: Daniel Kühlwein, ICIS, Radboud University Nijmegen
    80   Jasmin Blanchette, TUM
    81   Various improvements to MaSh, including a server mode.
    82 
    83 * First half of 2013: Steffen Smolka, TUM
    84   Further improvements to Sledgehammer's Isar proof generator.
    85 
    86 * May 2013: Florian Haftmann, TUM
    87   Ephemeral interpretation in local theories.
    88 
    89 * May 2013: Lukas Bulwahn and Nicolai Schaffroth, TUM
    90   Spec_Check: A Quickcheck tool for Isabelle/ML.
    91 
    92 * April 2013: Stefan Berghofer, secunet Security Networks AG
    93   Dmitriy Traytel, TUM
    94   Makarius Wenzel, Université Paris-Sud / LRI
    95   Case translations as a separate check phase independent of the
    96   datatype package.
    97 
    98 * March 2013: Florian Haftmann, TUM
    99   Reform of "big operators" on sets.
   100 
   101 * March 2013: Florian Haftmann, TUM
   102   Algebraic locale hierarchy for orderings and (semi)lattices.
   103 
   104 * February 2013: Florian Haftmann, TUM
   105   Reworking and consolidation of code generation for target language
   106   numerals.
   107 
   108 * February 2013: Florian Haftmann, TUM
   109   Sieve of Eratosthenes.
   110 
   111 
   112 Contributions to Isabelle2013
   113 -----------------------------
   114 
   115 * 2012: Makarius Wenzel, Université Paris-Sud / LRI
   116   Improvements of Isabelle/Scala and Isabelle/jEdit Prover IDE.
   117 
   118 * Fall 2012: Daniel Kühlwein, ICIS, Radboud University Nijmegen
   119   Jasmin Blanchette, TUM
   120   Implemented Machine Learning for Sledgehammer (MaSh).
   121 
   122 * Fall 2012: Steffen Smolka, TUM
   123   Various improvements to Sledgehammer's Isar proof generator,
   124   including a smart type annotation algorithm and proof shrinking.
   125 
   126 * December 2012: Alessandro Coglio, Kestrel
   127   Contributions to HOL's Lattice library.
   128 
   129 * November 2012: Fabian Immler, TUM
   130   "Symbols" dockable for Isabelle/jEdit.
   131 
   132 * November 2012: Fabian Immler, TUM
   133   Proof of the Daniell-Kolmogorov theorem: the existence of the limit
   134   of projective families.
   135 
   136 * October 2012: Andreas Lochbihler, KIT
   137   Efficient construction of red-black trees from sorted associative
   138   lists.
   139 
   140 * September 2012: Florian Haftmann, TUM
   141   Lattice instances for type option.
   142 
   143 * September 2012: Christian Sternagel, JAIST
   144   Consolidated HOL/Library (theories: Prefix_Order, Sublist, and
   145   Sublist_Order) w.r.t. prefixes, suffixes, and embedding on lists.
   146 
   147 * August 2012: Dmitriy Traytel, Andrei Popescu, Jasmin Blanchette, TUM
   148   New BNF-based (co)datatype package.
   149 
   150 * August 2012: Andrei Popescu and Dmitriy Traytel, TUM
   151   Theories of ordinals and cardinals.
   152 
   153 * July 2012: Makarius Wenzel, Université Paris-Sud / LRI
   154   Advanced support for Isabelle sessions and build management, notably
   155   "isabelle build".
   156 
   157 * June 2012: Felix Kuperjans, Lukas Bulwahn, TUM and Rafal Kolanski, NICTA
   158   Simproc for rewriting set comprehensions into pointfree expressions.
   159 
   160 * May 2012: Andreas Lochbihler, KIT
   161   Theory of almost everywhere constant functions.
   162 
   163 * 2010-2012: Markus Kaiser and Lukas Bulwahn, TUM
   164   Graphview in Scala/Swing.
   165 
   166 
   167 Contributions to Isabelle2012
   168 -----------------------------
   169 
   170 * April 2012: Johannes Hölzl, TUM
   171   Probability: Introduced type to represent measures instead of
   172   locales.
   173 
   174 * April 2012: Johannes Hölzl, Fabian Immler, TUM
   175   Float: Moved to Dyadic rationals to represent floating point numers.
   176 
   177 * April 2012: Thomas Sewell, NICTA and
   178   2010: Sascha Boehme, TUM
   179   Theory HOL/Word/WordBitwise: logic/circuit expansion of bitvector
   180   equalities/inequalities.
   181 
   182 * March 2012: Christian Sternagel, JAIST
   183   Consolidated theory of relation composition.
   184 
   185 * March 2012: Nik Sultana, University of Cambridge
   186   HOL/TPTP parser and import facilities.
   187 
   188 * March 2012: Cezary Kaliszyk, University of Innsbruck and
   189   Alexander Krauss, QAware GmbH
   190   Faster and more scalable Import mechanism for HOL Light proofs.
   191 
   192 * January 2012: Florian Haftmann, TUM, et al.
   193   (Re-)Introduction of the "set" type constructor.
   194 
   195 * 2012: Ondrej Kuncar, TUM
   196   New package Lifting, various improvements and refinements to the
   197   Quotient package.
   198 
   199 * 2011/2012: Jasmin Blanchette, TUM
   200   Various improvements to Sledgehammer, notably: tighter integration
   201   with SPASS, support for more provers (Alt-Ergo, iProver,
   202   iProver-Eq).
   203 
   204 * 2011/2012: Makarius Wenzel, Université Paris-Sud / LRI
   205   Various refinements of local theory infrastructure.
   206   Improvements of Isabelle/Scala layer and Isabelle/jEdit Prover IDE.
   207 
   208 
   209 Contributions to Isabelle2011-1
   210 -------------------------------
   211 
   212 * September 2011: Peter Gammie
   213   Theory HOL/Library/Saturated: numbers with saturated arithmetic.
   214 
   215 * August 2011: Florian Haftmann, Johannes Hölzl and Lars Noschinski, TUM
   216   Refined theory on complete lattices.
   217 
   218 * August 2011: Brian Huffman, Portland State University
   219   Miscellaneous cleanup of Complex_Main and Multivariate_Analysis.
   220 
   221 * June 2011: Brian Huffman, Portland State University
   222   Proof method "countable_datatype" for theory Library/Countable.
   223 
   224 * 2011: Jasmin Blanchette, TUM
   225   Various improvements to Sledgehammer, notably: use of sound
   226   translations, support for more provers (Waldmeister, LEO-II,
   227   Satallax). Further development of Nitpick and 'try' command.
   228 
   229 * 2011: Andreas Lochbihler, Karlsruhe Institute of Technology
   230   Theory HOL/Library/Cset_Monad allows do notation for computable sets
   231   (cset) via the generic monad ad-hoc overloading facility.
   232 
   233 * 2011: Johannes Hölzl, Armin Heller, TUM and
   234   Bogdan Grechuk, University of Edinburgh
   235   Theory HOL/Library/Extended_Reals: real numbers extended with plus
   236   and minus infinity.
   237 
   238 * 2011: Makarius Wenzel, Université Paris-Sud / LRI
   239   Various building blocks for Isabelle/Scala layer and Isabelle/jEdit
   240   Prover IDE.
   241 
   242 
   243 Contributions to Isabelle2011
   244 -----------------------------
   245 
   246 * January 2011: Stefan Berghofer, secunet Security Networks AG
   247   HOL-SPARK: an interactive prover back-end for SPARK.
   248 
   249 * October 2010: Bogdan Grechuk, University of Edinburgh
   250   Extended convex analysis in Multivariate Analysis.
   251 
   252 * October 2010: Dmitriy Traytel, TUM
   253   Coercive subtyping via subtype constraints.
   254 
   255 * October 2010: Alexander Krauss, TUM
   256   Command partial_function for function definitions based on complete
   257   partial orders in HOL.
   258 
   259 * September 2010: Florian Haftmann, TUM
   260   Refined concepts for evaluation, i.e., normalization of terms using
   261   different techniques.
   262 
   263 * September 2010: Florian Haftmann, TUM
   264   Code generation for Scala.
   265 
   266 * August 2010: Johannes Hoelzl, Armin Heller, and Robert Himmelmann, TUM
   267   Improved Probability theory in HOL.
   268 
   269 * July 2010: Florian Haftmann, TUM
   270   Reworking and extension of the Imperative HOL framework.
   271 
   272 * July 2010: Alexander Krauss, TUM and Christian Sternagel, University
   273     of Innsbruck
   274   Ad-hoc overloading. Generic do notation for monads.
   275 
   276 
   277 Contributions to Isabelle2009-2
   278 -------------------------------
   279 
   280 * 2009/2010: Stefan Berghofer, Alexander Krauss, and Andreas Schropp, TUM,
   281   Makarius Wenzel, TUM / LRI
   282   Elimination of type classes from proof terms.
   283 
   284 * April 2010: Florian Haftmann, TUM
   285   Reorganization of abstract algebra type classes.
   286 
   287 * April 2010: Florian Haftmann, TUM
   288   Code generation for data representations involving invariants;
   289   various collections avaiable in theories Fset, Dlist, RBT,
   290   Mapping and AssocList.
   291 
   292 * March 2010: Sascha Boehme, TUM
   293   Efficient SHA1 library for Poly/ML.
   294 
   295 * February 2010: Cezary Kaliszyk and Christian Urban, TUM
   296   Quotient type package for Isabelle/HOL.
   297 
   298 
   299 Contributions to Isabelle2009-1
   300 -------------------------------
   301 
   302 * November 2009, Brian Huffman, PSU
   303   New definitional domain package for HOLCF.
   304 
   305 * November 2009: Robert Himmelmann, TUM
   306   Derivation and Brouwer's fixpoint theorem in Multivariate Analysis.
   307 
   308 * November 2009: Stefan Berghofer and Lukas Bulwahn, TUM
   309   A tabled implementation of the reflexive transitive closure.
   310 
   311 * November 2009: Lukas Bulwahn, TUM
   312   Predicate Compiler: a compiler for inductive predicates to
   313   equational specifications.
   314 
   315 * November 2009: Sascha Boehme, TUM and Burkhart Wolff, LRI Paris
   316   HOL-Boogie: an interactive prover back-end for Boogie and VCC.
   317 
   318 * October 2009: Jasmin Blanchette, TUM
   319   Nitpick: yet another counterexample generator for Isabelle/HOL.
   320 
   321 * October 2009: Sascha Boehme, TUM
   322   Extension of SMT method: proof-reconstruction for the SMT solver Z3.
   323 
   324 * October 2009: Florian Haftmann, TUM
   325   Refinement of parts of the HOL datatype package.
   326 
   327 * October 2009: Florian Haftmann, TUM
   328   Generic term styles for term antiquotations.
   329 
   330 * September 2009: Thomas Sewell, NICTA
   331   More efficient HOL/record implementation.
   332 
   333 * September 2009: Sascha Boehme, TUM
   334   SMT method using external SMT solvers.
   335 
   336 * September 2009: Florian Haftmann, TUM
   337   Refinement of sets and lattices.
   338 
   339 * July 2009: Jeremy Avigad and Amine Chaieb
   340   New number theory.
   341 
   342 * July 2009: Philipp Meyer, TUM
   343   HOL/Library/Sum_Of_Squares: functionality to call a remote csdp
   344   prover.
   345 
   346 * July 2009: Florian Haftmann, TUM
   347   New quickcheck implementation using new code generator.
   348 
   349 * July 2009: Florian Haftmann, TUM
   350   HOL/Library/Fset: an explicit type of sets; finite sets ready to use
   351   for code generation.
   352 
   353 * June 2009: Florian Haftmann, TUM
   354   HOL/Library/Tree: search trees implementing mappings, ready to use
   355   for code generation.
   356 
   357 * March 2009: Philipp Meyer, TUM
   358   Minimization tool for results from Sledgehammer.
   359 
   360 
   361 Contributions to Isabelle2009
   362 -----------------------------
   363 
   364 * March 2009: Robert Himmelmann, TUM and Amine Chaieb, University of
   365   Cambridge
   366   Elementary topology in Euclidean space.
   367 
   368 * March 2009: Johannes Hoelzl, TUM
   369   Method "approximation", which proves real valued inequalities by
   370   computation.
   371 
   372 * February 2009: Filip Maric, Univ. of Belgrade
   373   A Serbian theory.
   374 
   375 * February 2009: Jasmin Christian Blanchette, TUM
   376   Misc cleanup of HOL/refute.
   377 
   378 * February 2009: Timothy Bourke, NICTA
   379   New find_consts command.
   380 
   381 * February 2009: Timothy Bourke, NICTA
   382   "solves" criterion for find_theorems and auto_solve option
   383 
   384 * December 2008: Clemens Ballarin, TUM
   385   New locale implementation.
   386 
   387 * December 2008: Armin Heller, TUM and Alexander Krauss, TUM
   388   Method "sizechange" for advanced termination proofs.
   389 
   390 * November 2008: Timothy Bourke, NICTA
   391   Performance improvement (factor 50) for find_theorems.
   392 
   393 * 2008: Florian Haftmann, TUM
   394   Various extensions and restructurings in HOL, improvements
   395   in evaluation mechanisms, new module binding.ML for name bindings.
   396 
   397 * October 2008: Fabian Immler, TUM
   398   ATP manager for Sledgehammer, based on ML threads instead of Posix
   399   processes.  Additional ATP wrappers, including remote SystemOnTPTP
   400   services.
   401 
   402 * September 2008: Stefan Berghofer, TUM and Marc Bezem, Univ. Bergen
   403   Prover for coherent logic.
   404 
   405 * August 2008: Fabian Immler, TUM
   406   Vampire wrapper script for remote SystemOnTPTP service.
   407 
   408 
   409 Contributions to Isabelle2008
   410 -----------------------------
   411 
   412 * 2007/2008:
   413   Alexander Krauss, TUM and Florian Haftmann, TUM and Stefan Berghofer, TUM
   414   HOL library improvements.
   415 
   416 * 2007/2008: Brian Huffman, PSU
   417   HOLCF library improvements.
   418 
   419 * 2007/2008: Stefan Berghofer, TUM
   420   HOL-Nominal package improvements.
   421 
   422 * March 2008: Markus Reiter, TUM
   423   HOL/Library/RBT: red-black trees.
   424 
   425 * February 2008: Alexander Krauss, TUM and Florian Haftmann, TUM and
   426   Lukas Bulwahn, TUM and John Matthews, Galois:
   427   HOL/Library/Imperative_HOL: Haskell-style imperative data structures
   428   for HOL.
   429 
   430 * December 2007: Norbert Schirmer, Uni Saarbruecken
   431   Misc improvements of record package in HOL.
   432 
   433 * December 2007: Florian Haftmann, TUM
   434   Overloading and class instantiation target.
   435 
   436 * December 2007: Florian Haftmann, TUM
   437   New version of primrec package for local theories.
   438 
   439 * December 2007: Alexander Krauss, TUM
   440   Method "induction_scheme" in HOL.
   441 
   442 * November 2007: Peter Lammich, Uni Muenster
   443   HOL-Lattice: some more lemmas.
   444 
   445 
   446 Contributions to Isabelle2007
   447 -----------------------------
   448 
   449 * October 2007: Norbert Schirmer, TUM / Uni Saarbruecken
   450   State Spaces: The Locale Way (in HOL).
   451 
   452 * October 2007: Mark A. Hillebrand, DFKI
   453   Robust sub/superscripts in LaTeX document output.
   454 
   455 * August 2007: Jeremy Dawson, NICTA and Paul Graunke, Galois and Brian
   456     Huffman, PSU and Gerwin Klein, NICTA and John Matthews, Galois
   457   HOL-Word: a library for fixed-size machine words in Isabelle.
   458 
   459 * August 2007: Brian Huffman, PSU
   460   HOL/Library/Boolean_Algebra and HOL/Library/Numeral_Type.
   461 
   462 * June 2007: Amine Chaieb, TUM
   463   Semiring normalization and Groebner Bases.
   464   Support for dense linear orders.
   465 
   466 * June 2007: Joe Hurd, Oxford
   467   Metis theorem-prover.
   468 
   469 * 2007: Kong W. Susanto, Cambridge
   470   HOL: Metis prover integration.
   471 
   472 * 2007: Stefan Berghofer, TUM
   473   HOL: inductive predicates and sets.
   474 
   475 * 2007: Norbert Schirmer, TUM
   476   HOL/record: misc improvements.
   477 
   478 * 2006/2007: Alexander Krauss, TUM
   479   HOL: function package and related theories on termination.
   480 
   481 * 2006/2007: Florian Haftmann, TUM
   482   Pure: generic code generator framework.
   483   Pure: class package.
   484   HOL: theory reorganization, code generator setup.
   485 
   486 * 2006/2007: Christian Urban, TUM and Stefan Berghofer, TUM and
   487     Julien Narboux, TUM
   488   HOL/Nominal package and related tools.
   489 
   490 * November 2006: Lukas Bulwahn, TUM
   491   HOL: method "lexicographic_order" for function package.
   492 
   493 * October 2006: Stefan Hohe, TUM
   494   HOL-Algebra: ideals and quotients over rings.
   495 
   496 * August 2006: Amine Chaieb, TUM
   497   Experimental support for generic reflection and reification in HOL.
   498 
   499 * July 2006: Rafal Kolanski, NICTA
   500   Hex (0xFF) and binary (0b1011) numerals.
   501 
   502 * May 2006: Klaus Aehlig, LMU
   503   Command 'normal_form': normalization by evaluation.
   504 
   505 * May 2006: Amine Chaieb, TUM
   506   HOL-Complex: Ferrante and Rackoff Algorithm for linear real
   507   arithmetic.
   508 
   509 * February 2006: Benjamin Porter, NICTA
   510   HOL and HOL-Complex: generalised mean value theorem, continuum is
   511   not denumerable, harmonic and arithmetic series, and denumerability
   512   of rationals.
   513 
   514 * October 2005: Martin Wildmoser, TUM
   515   Sketch for Isar 'guess' element.
   516 
   517 
   518 Contributions to Isabelle2005
   519 -----------------------------
   520 
   521 * September 2005: Lukas Bulwahn and Bernhard Haeupler, TUM
   522   HOL-Complex: Formalization of Taylor series.
   523 
   524 * September 2005: Stephan Merz, Alwen Tiu, QSL Loria
   525   Components for SAT solver method using zChaff.
   526 
   527 * September 2005: Ning Zhang and Christian Urban, LMU Munich
   528   A Chinese theory.
   529 
   530 * September 2005: Bernhard Haeupler, TUM
   531   Method comm_ring for proving equalities in commutative rings.
   532 
   533 * July/August 2005: Jeremy Avigad, Carnegie Mellon University
   534   Various improvements of the HOL and HOL-Complex library.
   535 
   536 * July 2005: Florian Zuleger, Johannes Hoelzl, and Simon Funke, TUM
   537   Some structured proofs about completeness of real numbers.
   538 
   539 * May 2005: Rafal Kolanski and Gerwin Klein, NICTA
   540   Improved retrieval of facts from theory/proof context.
   541 
   542 * February 2005: Lucas Dixon, University of Edinburgh
   543   Improved subst method.
   544 
   545 * 2005: Brian Huffman, OGI
   546   Various improvements of HOLCF.
   547   Some improvements of the HOL-Complex library.
   548 
   549 * 2005: Claire Quigley and Jia Meng, University of Cambridge
   550   Some support for asynchronous communication with external provers
   551   (experimental).
   552 
   553 * 2005: Florian Haftmann, TUM
   554   Contributions to document 'sugar'.
   555   Various ML combinators, notably linear functional transformations.
   556   Some cleanup of ML legacy.
   557   Additional antiquotations.
   558   Improved Isabelle web site.
   559 
   560 * 2004/2005: David Aspinall, University of Edinburgh
   561   Various elements of XML and PGIP based communication with user
   562   interfaces (experimental).
   563 
   564 * 2004/2005: Gerwin Klein, NICTA
   565   Contributions to document 'sugar'.
   566   Improved Isabelle web site.
   567   Improved HTML presentation of theories.
   568 
   569 * 2004/2005: Clemens Ballarin, TUM
   570   Provers: tools for transitive relations and quasi orders.
   571   Improved version of locales, notably interpretation of locales.
   572   Improved version of HOL-Algebra.
   573 
   574 * 2004/2005: Amine Chaieb, TUM
   575   Improved version of HOL presburger method.
   576 
   577 * 2004/2005: Steven Obua, TUM
   578   Improved version of HOL/Import, support for HOL-Light.
   579   Improved version of HOL-Complex-Matrix.
   580   Pure/defs: more sophisticated checks on well-formedness of overloading.
   581   Pure/Tools: an experimental evaluator for lambda terms.
   582 
   583 * 2004/2005: Norbert Schirmer, TUM
   584   Contributions to document 'sugar'.
   585   Improved version of HOL/record.
   586 
   587 * 2004/2005: Sebastian Skalberg, TUM
   588   Improved version of HOL/Import.
   589   Some internal ML reorganizations.
   590 
   591 * 2004/2005: Tjark Weber, TUM
   592   SAT solver method using zChaff.
   593   Improved version of HOL/refute.