Skip to content

Nλ is a simple functional programming language aimed at manipulating infinite, but first-order definable structures, such as the countably infinite clique graph or the set of all intervals with rational endpoints.

License

Notifications You must be signed in to change notification settings

szynwelski/nlambda

Repository files navigation

Nλ is a simple functional programming language aimed at manipulating infinite, but first-order definable structures, such as the countably infinite clique graph or the set of all intervals with rational endpoints. Internally, such sets are represented by logical formulas that define them, and an external satisfiability modulo theories (SMT) solver is regularly run by the interpreter to check their basic properties.

For more information, visit NLambda website.

Installation guide

  1. There are two ways to get a source code:
  1. The language is implemented in a Haskell and installation of GHC (at least 7.10) is required.

  2. Move into nlambda directory and perform the following commands:

    cabal v2-configure -fTOTAL_ORDER
    cabal v2-build
    cabal v2-install
    

    The flag TOTAL_ORDER is required to install the package with ordered atoms (otherwise equality atoms will be used).

    More information on how to install a Cabal package can be found here.

  3. You can also use dedicated scripts:

  • for ordered atoms

    $ ./intall-total-order.sh

  • for equality atoms

    $ ./install-equality.sh

  1. Additionally, you should install the Z3 Theorem Prover and add it to the PATH environment variable.

Interactive environment

Nλ expressions can be interpreted and evaluated on the fly using the interactive GHCi environment. For easier use of the environment, one can use the .ghci configuration file, which imports the module with the language, hides Prelude functions that conflict with Nλ, and sets useful options.

:set -XNoImplicitPrelude
:set -XRebindableSyntax
:m NLambda
:set prompt "Nλ> "
import Prelude hiding (or, and, not, sum, map, filter, maybe)
let [a,b,c,d,e] = fmap atom ["a","b","c","d","e"]

Note on Z3 versions

This was originally developed with Z3 versions between 4.4.0 and 4.6.0 (roughly). We have since then noticed some differences in the Z3 versions. Two are notable:

  • From Z3 version 4.8.11 onwards, formulas returned after simplification are noticable longer than before. Consequently, the NLambda library slows down.

  • From Z3 version 4.8.10 onwards, the syntax for a model outputted from Z3 has changed. This is relevant for the function parseModel in Nominal.Formula.Solver. Currently we default to the old syntax.

About

Nλ is a simple functional programming language aimed at manipulating infinite, but first-order definable structures, such as the countably infinite clique graph or the set of all intervals with rational endpoints.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published