-->
Home » , , » ACL2 is a software system consisting of a programming language, an extensible theory in a first-order logic.
Thursday
27 February 2014

ACL2 is a software system consisting of a programming language, an extensible theory in a first-order logic.

ACL2 is both a programming language in which you can model computer systems and a tool to help you prove properties of those models.

ACL2 is part of the Boyer-Moore family of provers, for which its authors have received the 2005 ACM Software System Award.

Functions that display or change history

ACL2 keeps track of the commands that you have executed that have extended the logic or the rule database, as by the definition of macros, functions, etc. Using the facilities in this section you can review the sequence of commands executed so far. For example, you can ask to see the most recently executed command, or the command 10 before that, or the command that introduced a given function symbol. You can also undo back through some previous command, restoring the logical world to what it was before the given command.

The annotations printed in the margin in response to some of these commands (such as `P', `L', and `V') are explained in the documentation for :pc.

Several technical terms are used in the documentation of the history commands. You must understand these terms to use the commands. These terms are documented via :doc entries of their own. See command, see events, see command-descriptor, and see logical-name.

ACL2_Logo
    Libraries (Books).
    Libraries of books (files containing definitions and theorems) extend the code that we have written. The installation instructions explain how to fetch the community books, which are contributed and maintained by the members of the ACL2 community. For more information, see the acl2-books project page.

    Documentation.
    There is an extensive user's manual for the ACL2 system, and an even more comprehensive manual that documents not only the ACL2 system but also many community books. See below to learn more.
    License and Copyright.
    ACL2 is freely available under the terms of the LICENSE file distributed with ACL2. License, copyright, and authorship information is available from the ACL2 documentation.
    Extensions.
    The ACL2 distribution includes the following extensions, which were developed by the individuals shown.
        ACL2(r)
        Support for the real numbers by way of non-standard analysis
        Ruben Gamboa
        ACL2(h)
        Support for hash cons, applicative hash tables, and function memoization for reuse of previously computed results
        Bob Boyer, Warren A. Hunt, Jr., Jared Davis, and Sol Swords
        ACL2(p)
        Support for parallel evaluation
        David L. Rager
    Another extension of ACL2 is the Eclipse-based ACL2 Sedan (ACL2s). Unlike the systems above, ACL2s is distributed and maintained by Pete Manolios and his research group. ACL2s comes with a standard executable ACL2 image for Windows, but it also comes with pre-certified community books and an extension of ACL2 with additional features, including extra automation for termination proofs as well as counterexample generation.

To learn about ACL2, read at least the following two links.

    Industrial Applications of ACL2 (10 minutes) to help you understand what sophisticated users can do;
    A Flying Tour (10 minutes) to get an overview of the system and what skills the user must have.

If you want to learn how to use ACL2, we recommend that you read a selection of the materials referenced below, depending on your learning style, and do suggested exercises.

   A Walking Tour (1 hour) provides an overview of the theorem prover.

    The Try ACL2 [External link to http://tryacl2.org] web site provides interactive lessons to get you started using ACL2.
    Introduction to the Theorem Prover (10-40 hours) provides instruction on how to interact with the system. Unlike the three documents above, this document expects you to think! It cites the necessary background pages on programming in ACL2 and on the logic and then instructs you in the-method, which is how expert users use ACL2. It concludes with some challenge problems for the ACL2 beginner (including solutions) and an FAQ. Most users will spend several hours a day for several days working through this material.
    The book Computer-Aided Reasoning: An Approach [External link to http://www.cs.utexas.edu/users/moore/publications/acl2-books/car/index.html] is worth a careful read, as you work exercises and learn the-method.
    Annotated ACL2 Scripts and Demos contains relatively elementary proof scripts that have been annotated to help train the newcomer.
    Many files (``books'') in the ACL2 community books (see community-books) are extensively annotated.
    An Alternative Introduction document, while largely subsumed by the Introduction to the Theorem Prover mentioned above, still might be useful because it covers much of the tutorial material in a different way.

At this point you are probably ready to use ACL2 on your own small projects. A common mistake for beginners is to browse the documentation and then try to do something that is too big! Think of a very small project and then simplify it!

Note that ACL2 has a very supportive user network. See the link to ``Mailing Lists'' on the ACL2 home page [External link to http://www.cs.utexas.edu/users/moore/acl2] .

The topics listed below are a hodge podge, developed over time. Although some of these are not mentioned above, you might find some to be useful as well.

If you liked this article, subscribe to the feed by clicking the image below to keep informed about new contents of the blog:

0 commenti:

Post a Comment

Random Posts

  • Edubuntu is an official derivative of the Ubuntu operating system designed for use in classrooms inside schools, homes and communities.
    20.05.2011 - 0 Comments
    Edubuntu is a partner project of Ubuntu Linux, a distribution suitable for classroom use. The aim is that an educator with limited technical knowledge and skill will be able to set up a computer lab, or establish an on-line learning environment,…
  • Unlimited Free Polls With Unlimited Votes Per Poll With PollDaddy
    01.01.2009 - 0 Comments
    PollDaddy is a crowd favorite; I've seen lots of folks using it, and no wonder -- it's robust (you can ask multiple choice, short answer, long answer, . . .), it's pretty (you have a number of styles to choose from for the look of your poll or…
  • Ultimate Edition: the goal of the project is to create a complete, seamlessly integrated, visually stimulating, and easy-to-install operating system.
    22.10.2010 - 0 Comments
    Ultimate Edition, first released in December 2006, is a fork of Ubuntu. The goal of the project is to create a complete, seamlessly integrated, visually stimulating, and easy-to-install operating system. Single-button upgrade is one of several…
  • Ratpoison is a Window Manager that puts that sick little rodent out of its misery.
    26.02.2011 - 0 Comments
    Ratpoison is a tiling window manager for the X Window System primarily developed by Shawn Betts. Ratpoison is a simple Window Manager with no fat library dependencies, no fancy graphics, no window decorations, and no rodent dependence. It is…
  • Xorcom Rapid - Risk-free Asterisk
    24.06.2009 - 0 Comments
    Xorcom Rapid is a free Debian/Asterisk distribution program that includes an auto-install and special auto-configuration features. It quickly and effortlessly converts any PC to a functioning Asterisk PBX.Xorcom Rapid 1.1Features: Asterisk 1.0.9 …
  • The Apache HTTP Server Project is an effort to develop and maintain an open-source HTTP server for modern operating systems including UNIX
    23.01.2010 - 0 Comments
    The Apache HTTP Server Project is an effort to develop and maintain an open-source HTTP server for modern operating systems including UNIX and Windows NT. The goal of this project is to provide a secure, efficient and extensible server that provides…
  • GMPC is a GTK2 frontend for Music Player Daemon.
    04.09.2012 - 0 Comments
    GMPC (Gnome Music Player Client) is a GTK2 frontend for Music Player Daemon. It is released under the GNU General Public License and is free software.  It is designed to be lightweight and easy to use, while providing full access to all of…
  • The Siduction distribution is a desktop-oriented operating system and live medium based on the
    21.01.2012 - 0 Comments
    The Siduction distribution is a desktop-oriented operating system and live medium based on the "unstable" branch of Debian GNU/Linux. Forked from aptosid in late 2011, siduction offers three separate live media with KDE, LXDE and Xfce…
  • Oxine is a lightweight, purely OSD-based xine frontend for set-top boxes and home entertainment systems.
    01.07.2010 - 0 Comments
    Oxine is a lightweight, purely OSD-based xine frontend for set-top boxes and home entertainment systems.It uses the on screen display functionality of xine to display its user interface elements like buttons, lists, sliders, and so on. Due to this,…
  • Installing a MySQL Source Distribution.
    18.05.2008 - 0 Comments
    Before you proceed with the source installation, check first to see if our binary is available for your platform and if it will work for you. We put in a lot of e ort into making sure that our binaries are built with the best possible options. You…

Recent Posts

Recent Posts Widget

Popular Posts

Labels

Archive

page counter follow us in feedly
 
Copyright © 2014 Linuxlandit & The Conqueror Penguin
-->