These are some basic instructions to compile and install YAP: 1. How to compile Yap: To compile YAP just do: (1) mkdir arch (2) cd arch (3) ../configure (4) check the Makefile for any extensions or changes you want to make. (5) make (6) If the compilation succeeds, try ./yap (7) Happy? make install If you want corouting or CLP(QR) 1.1 Where to install Yap Recent versions of Yap try to follow GNU conventions on where to place software. o The main executable is placed at BINDIR. This executable is actually a script that calls the Prolog engine, stored at LIBDIR. o LIBDIR contains the Prolog engine and a Prolog library. o INCLUDEDIR is used if you want to use Yap as a library. 1.2 Which Yap Compiling Yap with the standard options give you a plain vanilla Prolog. You can tune Yap to include some extra functionality o -DCOROUTINING=1 gives you delaying on goals, eg, freeze. o -DRATIONAL_TREES=1 includes support for rational trees. o -DDEPTH_LIMIT=1 allows depth limited evaluation, say for implementing iterative deepening. o -DYAP_ARRAYS gives you two different styles of arrays. o -DANALYST and -DLOW_LEVEL_TRACER give you low level debugging. ANALYST tells how your program uses the abstract machine instructions. LOW_LEVEL_TRACER dumps the gory details of what your program is doing. The next two options are good fun, but arguably not production quality: o -DTABLING gives tabling in XSB style. o -DYAPOR gives or-parallelism in Muse style. If you add -DSBA to it you will have the Sparse Binding Array instead of copying. If you add -DACOW instead you will have the \alphaCOW model, that is, forking instead of copying. 1.3 Porting Yap The system has been mainly tested with GCC, but we have been able to compile versions of Yap under lcc in Linux, Sun's cc compiler, IBM's xlc, SGI's cc, Microsoft's Visual C++ 6.0 and HP's cc. 1.3.1 Yap and GCC Yap has been developed to take advantage of GCC (but not to depend on it). The major advantage of GCC is threaded code and register reservation. YAP is set by default to compile with the best compilation flags we know. Even so, a few specific options can be used depending on the architecture: 1.3.1.1 x86 The flag: YAP_EXTRAS= ... -DBP_FREE=1 tells us to use the %bp register (frame-pointer) as the emulator's program counter. This seems to be stable and should become default real soon now. 1.3.1.2 Sparc/Solaris2 Use: YAP_EXTRAS= ... -mno-app-regs -DOPTIMISE_ALL_REGS_FOR_SPARC=1 and YAP will get two extra registers! This trick does not work on SunOS 4 machines. 1.3.1.3 Tuning GCC/Yap for your machine model Versions of GCC can be tweaked for different processors, eg, 486, Pentium, PentiumPro, Ultrasparc, Supersparc. Unfortunately, some of these tweaks do may make Yap run slower or not at all in other machines with the same instruction set, so they cannot be made default. The best options also depends on the version of GCC you are using, and it is a good idea to consult the GCC manual under the menus "Invoking GCC"/"Submodel Options". We next describe a few: (a) GCC up to 2.7.*: o 486: YAP_EXTRAS= ... -m486 -DBP_FREE=1 to take advantage of 486 specific optimisations in GCC 2.7.*. o Pentium: YAP_EXTRAS= ... -m486 -malign-loops=2 -malign-jumps=2 -malign-functions=2 o PentiumPros are known not to require alignment. o Super and UltraSparcs: YAP_EXTRAS= ... -msupersparc (b) GCC 2.8.*, EGCS, GCC 2.95.* o Check -march=XXX for fun.