Table of Contents
ACL2 is more than just the executable image. In particular, it comes with a user's manual, but you will almost certainly want to obtain the distributed books. Start here and we will take you through the whole process of obtaining and installing ACL2.
First, create a directory in which to store ACL2 Version 6.5. We will
call this directory dir. For example, dir might be
/home/jones/acl2/v6-5
.
A collection of books (ACL2 input files typically including
definitions and theorems) has been developed over the years for use
with ACL2, called the "community books". It is very useful to
obtain these books, which are distributed via SVN from the Google
Code acl2-books
project website or, as gzipped tarfiles, from
http://acl2.org
.
Directions are included below.
WARNING: Some of these packages might be for old version of ACL2. We recommend that you use the latest version of ACL2 (Version 6.5).
The ACL2 Sedan
(ACL2s) is an Eclipse-based IDE for ACL2 that is distributed with pre-certified
books and pre-built binaries. If you
use an alternative development environment (such as Emacs), you
can still fetch a
tarball for your x86-based Linux/Mac/Windows system that contains a
pre-built binary of (pure) ACL2, using the following instructions
based on information kindly provided by Harsh Raju Chamarthi.
Just extract the
appropriate tarball (using tar xfz
on Linux or Mac
and unzip
on Windows)
under a path with no spaces.
Then run the script you will
find, run_acl2
on Linux or Mac
and run_acl2.exe
on Windows, to start an ACL2 session.
(Note that The first time you execute that command,
the certificate (.cert
) files are automatically
fixed, according to the full pathname of your books/
directory.)
Also see
the ACL2
documentation topic on the ACL2 Sedan.
In the past, a Windows Installer for ACL2 has included a Unix environment, pre-certified standard and workshop books, and a copy of Gnu Emacs. This capability has largely been superseded by the section on Building an Executable Image on Some Particular Systems and the Shortcut using the ACL2 Sedan, above. See also information about ACL2 on Windows.
ACL2 versions have sometimes been made available under MacPorts. If we learn that an up-to-date version is available, we will add instructions here.
A Debian Gnu Linux package is available, which is likely to work on other Linux systems as well. Thanks to Camm Maguire for maintaining this package, and for pointing out that as Debian packages are simply ar and tar archives, they can be unpacked on any linux system, and who has said: "If someone is running Debian, all they want to do is 'apt-get install acl2', doing likewise for any optional add-on package they wish as well, e.g. emacs, infix, etc." Alternatively, Debian GNU Linux users may wish to download the Debian package for Linux. Or, see following annotated log, provided by Camm Maguire, to see another way to proceed.
camm@localhost:~$ cd /tmp camm@localhost:/tmp$ mkdir a camm@localhost:/tmp$ cd a camm@localhost:/tmp/a$ wget ftp://ftp.debian.org/debian/pool/main/a/acl2/acl2*5.0*_{i386,all}*b ;;; or ftp, use browser, etc. I.e. download the .deb files. Replace ;;; i386 above with amd64 if the target is a 64bit Ubuntu machine. ;;; Other target names should be self explanatory. The 'all' ;;; designation refers to binary independent data. camm@localhost:/tmp/a$ ls acl2_5.0-1_i386.deb acl2-books-certs_5.0-1_all.deb acl2-doc_5.0-1_all.deb acl2-infix_5.0-1_i386.deb acl2-source_5.0-1_all.deb acl2-books_5.0-1_i386.deb acl2-books-source_5.0-1_all.deb acl2-emacs_5.0-1_all.deb acl2-infix-source_5.0-1_all.deb camm@localhost:/tmp/a$ for i in *b; do ar x $i; tar zxf data.tar.gz; done ;;; unpack files in current directory camm@localhost:/tmp/a$ sed -e 's,usr,tmp/a/usr,g' usr/bin/acl2 >tmp && chmod 755 tmp && mv tmp usr/bin/acl2 ;;; Edit shell script wrapper to refer to the local path camm@localhost:/tmp/a$ usr/bin/acl2 GCL (GNU Common Lisp) 2.6.7 CLtL1 Aug 22 2012 15:25:31 Source License: LGPL(gcl,gmp), GPL(unexec,bfd,xgcl) Binary License: GPL due to GPL'ed components: (XGCL READLINE UNEXEC) Modifications of this banner must retain notice of a compatible license Dedicated to the memory of W. Schelter Use (help) to get some basic information on how to use GCL. Temporary directory for compiler files set to /tmp/ ACL2 Version 5.0 built August 25, 2012 11:53:08. Copyright (C) 2012 University of Texas at Austin ACL2 comes with ABSOLUTELY NO WARRANTY. This is free software and you are welcome to redistribute it under certain conditions. For details, see the GNU General Public License. Initialized with (INITIALIZE-ACL2 'INCLUDE-BOOK *ACL2-PASS-2-FILES*). See the documentation topic note-5-0 for recent changes. Note: We have modified the prompt in some underlying Lisps to further distinguish it from the ACL2 prompt. ACL2 Version 5.0. Level 1. Cbd "/tmp/a/". System books directory "/tmp/a/usr/share/acl2-5.0/books/". Type :help for help. Type (good-bye) to quit completely out of ACL2. ACL2 !>
(First, a note for Windows users only: we suggest that you obtain a
Unix-like environment or, at least, download a utility such as
djtarnt.exe
to use with the -x
option on
gzipped tarfiles. WARNING: At least one user experienced CR/LF issues
when using WinZIP, but we have received the suggestion that people
untarring with that utility should probably turn off smart cr/lf
conversion.)
md5sum
and compare
with
acl2-tar-gz-md5sum if you wish to verify the transmission.)
tar xpvfi acl2.tar
", if you have problems with
other than Gnu tar. You can see if you have Gnu tar by running
"tar -v
".)
cd dir
tar xfz acl2.tar.gz
rm acl2.tar.gz
cd acl2-sources
http://acl2.org
,
and then extract as follows to create a books/
subdirectory: tar xfz books-6.5.tar.gz
books/
: svn checkout http://acl2-books.googlecode.com/svn/branches/6.5 books
svn checkout https://acl2-books.googlecode.com/svn/branches/6.5 books --username <name>
workshops/
subdirectories of these books/
,
which contains books contributed in support of papers presented at
ACL2 workshops. You can fetch the gzipped tarball for
the workshops/
directory
from http://acl2.org
. Then
put that gzipped tarfile in the acl2-sources/books/
directory, connect to that directory, and extract to create
a workshops/
subdirectory: tar xfz workshops-6.5.tar.gz
PLEASE NOTE: The available memory for ACL2 is determined by the underlying Common Lisp executable. If you need more memory, refer to your Common Lisp's instructions for building an executable.
-md5sum
file
was created using md5sum
. We may add additional
links from time to time.
Now proceed to Using ACL2.
cd
acl2-sources
make LISP=
xxx
By default, if no LISP=
xxx is specified,
LISP=ccl
is used. On our hosts, ccl
is the name of
Clozure Common Lisp (CCL), which can be obtained as explained in the Requirements document.
This will create executable saved_acl2
in the
acl2-sources
directory.
The time taken to carry out this process depends on the host processor but may be only a few minutes for a fast processor. The size of the resulting binary image is dependent on which Lisp was used, but it may a couple hundred megabytes or so.
This make
works for the Common Lisp implementations listed
in Requirements document on systems we
have tested. See the file acl2-sources/GNUmakefile
for
further details. If this make
command does not work for
you, please see the instructions below for other
than Unix-like systems.
You can now skip to Using ACL2.
make
' utility. If you are using a trial
version of Allegro Common Lisp, then you may not be able to save
an image. In that case, skip to Running Without
Building an Executable Image.
See also Building an Executable Image on Some Particular Systems, in case you want to skip directly to the instructions in one of its subtopics.
Otherwise, proceed as follows.
Your Common Lisp should be one of those listed in
Requirements document. Filenames
below should default to the dir/acl2-sources
directory; please connect to that directory before continuing.
nsaved_acl2
if it exists.acl2-sources
directory
and submit the following sequence of commands.
; Compile (load "init.lisp") (in-package "ACL2") (compile-acl2)The commands above will compile the ACL2 sources and create compiled object files on your
acl2-sources
subdirectory.
acl2-sources
subdirectory. In the
fresh Lisp type:
; Initialization, first pass (load "init.lisp") (in-package "ACL2") (load-acl2) (initialize-acl2)This will load the new object files in the Lisp image and bootstrap ACL2 by reading and processing the source files. But the attempt at initialization will end in an error saying that it is impossible to finish because a certain file was compiled during the processing, thus dirtying the image yet again. (If however the attempt ends with an error during compilation of file
TMP1.lisp
, see the first troubleshooting tip below.)
acl2-sources
subdirectory). Then, in the
fresh Lisp type:
; Initialization, second pass (load "init.lisp") (in-package "ACL2") (save-acl2 (quote (initialize-acl2)) "saved_acl2")You have now saved an image. Exit Lisp now. Subsequent steps will put the image in the right place.
osaved_acl2
if it exists.
saved_acl2
and saved_acl2.dxl
both exist THEN:
saved_acl2.dxl
to osaved_acl2.dxl
saved_acl2
to osaved_acl2
and edit osaved_acl2
, changing saved_acl2.dxl
(at end of line) to osaved_acl2.dxl
saved_acl2
exists THEN:
saved_acl2
to osaved_acl2
nsaved_acl2
to saved_acl2
.nsaved_acl2.
suffix is created for some
suffix.
Move it to: saved_acl2.
suffixsaved_acl2
is executable. For Windows
this involves two mini-steps:
(a) Remove the"$*"
from thesaved_acl2
script (because Windows does not understand$*
). Consequently, any arguments you pass to ACL2 via the command line will be ignored.(b) Rename
saved_acl2
tosaved_acl2.bat
, for example by executing the following command.
rename saved_acl2 saved_acl2.bat
Otherwise here are steps to follow.
ftp://ftp.gnu.org/gnu/gcl/
or as explained above. You
may wish to pick a .zip
file from the cvs/
subdirectory (containing pre-releases) that has "mingw32
" in the
name.
gclm/bin/gclm.bat
that came with
gcl-cvs-20021014-mingw32
from the above ftp site, a separate
window popped up, and with an error. Many ACL2 users prefer running in an
emacs shell buffer. (We obtained emacs for Windows from ftp://ftp.gnu.org/gnu/windows/emacs/21.2/emacs-21.2-fullbin-i386.tar.gz
.)
The following modification of gclm.bat
seemed to solve the problem
(your pathnames may vary).
@ % do not delete this line % @ECHO off set cwd=%cd% path C:\gcl\gclm\mingw\bin;%PATH% C:\gcl\gclm\lib\gcl-2.6.2\unixport\saved_gcl.exe -dir C:/gcl/gclm/lib/gcl-2.6.2/unixport/ -libdir C:/gcl/gclm/lib/gcl-2.6.2/ -eval "(setq si::*allow-gzipped-file* t)" %1 %2 %3 %4 %5 %6 %7 %8 %9
saved_acl2.exe
rather than saved_acl2
.
acl2.bat
as explained in
http://www.cs.utexas.edu/users/moore/acl2/v6-5/distrib/images/Readme.html
.
We hope that the above simply works. If you experience problems, the following hints may help.
TROUBLESHOOTING:
TMP1.lisp
. That was easily remedied by starting up a
fresh GCL session and invoking (compile-file "TMP1.lisp")
before
proceeding to the next step.
http://www.faculty.idc.ac.il/yishai/reasoning/win-install.htm
,
some of which we have tried to incorporate here. A useful point made there is
that when you want to quit ACL2, use :good-bye
(or
(good-bye)
which works even in raw Lisp). Or you can use
(user::bye)
in raw Lisp. The point is: Avoid control-c
control-d
, even thought that often works fine in emacs under
Unix-like systems.
PATH
variable gcl-dir\gcc\bin
, where
gcl-dir is the directory where GCL is installed. To get to the place to
set environment variables, you might be able to go to the control panel, under
system, under advanced. Alternately, you might be able to get there by opening
My Computer
and right-clicking to get to Properties
,
then selecting the Advanced
tab. At one time, when GCL/Windows
was release as Maxima, Pete Manolios suggested adding the system variable
LD_LIBRARY_PATH with the value "maxima-dir\gcc\i386-mingw32msvc\include"; this
may or may not be necessary for your GCL installation (and the path would of
course likely be different).
We assume you have obtained ACL2 and placed it in directory dir, as
described above for Unix-like systems or other platforms.
(If you downloaded a pre-built ACL2 image, then you may skip this section.)
Connect to subdirectory acl2-sources
of dir,
start up your Common Lisp, and compile by executing the following forms.
This sequence of steps need only be performed once.
(load "init.lisp") (in-package "ACL2") (compile-acl2)Now each time you want to use ACL2, you need only execute the following forms after starting up Common Lisp in subdirectory
acl2-sources
of
dir.
(load "init.lisp") (in-package "ACL2") (load-acl2) (initialize-acl2)Note. The resulting process includes the ACL2 documentation, and hence will probably be considerably larger (perhaps twice the size) than the result of running an executable image created as described above.
Now proceed to read more about Using ACL2.
acl2.tar.gz
, includes the ACL2 source files as well as
the following files and directories (and a few others not
mentioned here). Note that a books/
directory
is not included; see instructions above to fetch the community
books.
LICENSE ; ACL2 license file GNUmakefile ; For GNU make TAGS ; Handy for looking at source files with emacs doc/ ; ACL2 documentation emacs/ ; Some helpful emacs utilities installation/ ; Installation instructions (start with installation.html)Also available are the following.
images/
:
Some gzip'd tar'd executables; see images/Readme.html
split/
: The result of splitting up acl2.tar.gz
We estimate that the entire acl2.tar.gz
consists of
approximately 4 MB, which extracts to about 15 MB, and the size of
gzipped tarfile books-6.5.tar.gz
(obtained as described
above) is about 15 MB, which extracts
to about 87 MB. (Gzipped tarfile workshops-6.5.tar.gz
and corresponding directory workshops
, which are
mentioned above, have sizes of about 37 MB and 58 MB, respectively.)
Additional space is required to build an image, perhaps 50 to 300
megabytes depending on the platform (including the host Lisp); and
more will be required to certify
books.
acl2-books
and acl2-devel
,
for the ACL2 community books and development sources, respectively.