Skip to content

Latest commit

 

History

History
116 lines (88 loc) · 3.36 KB

README.md

File metadata and controls

116 lines (88 loc) · 3.36 KB

The APEX APL Compiler HAS BEEN MOVED!!!!!

APEX is now at [email protected]/bernecky/apex.git

ALL OF THIS CODE IS VERY OBSOLETE, SO GET THEE HENCE.

=====================

APEX compiles a subset of Dyalog APL into one of several languages, currently SISAL, SaC, and D.

Get Started

To generate the compiler from github, clone the repository, say into directory apexgit. When cloning this repo, remember to also load the git submodules using either git submodule update --init, or when cloning for the first time git clone --recursive ...

After that, you can load APEX in Dyalog:

    cd apexgit
     Start Dyalog APL V18.0 (or newer), downloadable from www.dyalog.com, and then
    )load wss/apex.dws

At this point, you should have a copy of the apex workspace, which you can try out. The Ancillary/benchmks folder contains subfolders of benchmarks and unit tests, including benchmksAPL, DynamicProgramming, MatrixProducts, benchmksPerf, DeepLearning, Geophysics, UnitTests. Others are on their way. To compile the APL code (*.aplf files) to SaC, do this:

    bmbenchmks.benchmks'Ancillary/MatrixProducts'
    zapex¨bm
    z  Names of generated SaC source code files

Rarely, you will need a left argument to apex. If specified, the left argument to the apex verb is a set of space-delimited compiler options, e.g. 'option0=x option1=y...'

Default options are: targetlanguage=sac trace=0 This disables debug tracing during compilation, and tells the compiler to generate SaC code as its output.

The right argument is a folder name, containing the APL code to be compiled, as a set of *.aplf files, each containing the source code for one defined function, e.g., in Ancillary/benchmks/benchmksAPL/iotan, we have:

The verb main.aplf is:

    rmain;⎕IO;⎕RL;n;⎕PP;⎕PW
    ⎕IO0
    n100000000
    ⎕RL16807
    ⎕PP16
    ⎕PW80
    riotan n
    r
    r(r(n×n+1.5-0.5)÷2)-1

This sets some global variables, most of which are not used in common applications, invokes iotan with the problem size, n, then compares the result to what is should be, using Gauss' insight.

The verb iotan.aplf is:

    riotan n
    r+/(1.5-0.5)+n

It would have been written as a Dfn in this form, but Dfns had not been invented when the benchmark was written:

    iotan{ r+/(1.5-0.5)+}

The funny business with the real numbers is a sloppy way to force the result to 64-bit IEEE floating point.

The apex compiler's output is a pair of SaC source code files in the argument folder, Ancillary/benchmks/benchmksAPL/iotan/src. The iotan.sac file will generate a SaC module (Shared library, .so, .dll) that can be called from Dyalog APL via ⎕na, or from an executable SaC program, e.g, iotan.unittest.sac:

   cd src
   sac2c iotan.sac
   sac2c iotan.unittest.sac

Alternately, an entire set of tests can be compiled this way, using, e.g., 7 tasks:

   cd Ancillary/benchmks/benchmksAPL
   mkdir build
   cd build
   cmake ..
   make -j 7

When compiled with sac2c (from www.sac-home.org), the resulting binary, when executed, will compute the sum of the first n non-negative integers. The result (r) of executing main should be 0 if the result is correct, and 0 otherwise.

You can use ctest to run all tests automatically:

   ctest -j 7