§Dependencies
Based on how you are planning to use the library and for what purpose, there is a number of dependencies to take care of before installing:
§General dependencies
These are required to acquire, install and use the base libraries:
-
The Haskell Platform. The libraries usually support the latest
ghc
versions, but you can check the tested versions in theforsyde-atom.cabal
file in case the installation does not succeed. -
Git if you want to clone the whole repository, and not just download the sources.
Library dependencies are taken care of by the Stack sandboxing tool shipped with Haskell Platform.
§Plotting the signals
If you intend to use the ForSyDe.Atom.Utility.Plot library features to plot signals instead of printing them to the terminal output, then you need to install the respectve plotting engines and their dependencies.
§Using Gnuplot
ForSyDe.Atom.Utility.Plot provides helper functions for plotting signals using the gnuplot engine. Naturally, you need to have it installed for your OS.
For an OS using the X Window System e.g. Ubuntu Linux, you might need to install the gnuplot-x11
library, to be able to launch plots from an interpreter session. For example, in Ubuntu, you need to type in:
sudo apt instal gnuplot-x11
§Using ForSyDe-LaTeX
ForSyDe.Atom.Utility.Plot also provides helper functions to generate LaTeX files using the ForSyDe-LaTeX style package. To be able to compile them you need:
-
a LaTeX compiler suite. We have tested and recommend TexLive.
-
the ForSyDe-LaTeX package. To acquire it, you need to follow the installation instructions.
§Installation
Before trying to install, check the list of dependencies above, to see that you meet the requirements based on how you are planning to use the library.
This package has been developped using Cabal, however at the time of updating this setup page, it has fallen behind the contemporary package management practices. As of now there are several ways to install a Haskell package using different tools, however we recommend you use the Stack sandboxing tool, which reproduces the (by now old) development environment.
§Using Stack (recommended)
The following instructions assume you want to build a Haskell sandbox using the Stack tool, shipped with the Haskell Platform. Go to the forsyde-atom
directory and type in
stack install
And be patient… This will install the package and its dependencies locally, including a working GHC compiler. To open an interpreter session with the default ForSyDe-Atom libraries loaded, run the command:
stack ghci
By default Stack loads all forsyde-atom
modules. We do not want this, rather have only the root ForSyDe.Atom
module loaded, the rest being used (qualified) as aliases. To unload all modules and keep ForSyDe.Atom
type in
*ForSyDe.Atom... > :m ForSyDe.Atom
For a quick test that everything works fine, you can try the following example inside the interpreter session. The example implements a Moore finite state machine that calculates the running sum and multiplies the output with 2.
*Prelude ForSyDe.Atom> import ForSyDe.Atom.MoC.SY as SY
*Prelude ForSyDe.Atom SY> let s = SY.signal [1..4]
*Prelude ForSyDe.Atom SY> SY.moore11 (+) (*2) 0 s
{0,2,6,12,20}
For more examples, please check the user manual generated from the forsyde-atom-examples
project.
To uninstall the library and everything that was generated, simply delete the sandbox folder:
rm -rf .stack-work
To test the library using the provided test suites and doctests, type
stack test
To generate the API documentation locally type in
stack haddock
The documentation will be found at the path pointed out after the line
Updating Haddock index for local packages in
[path/to/index.html]
Notice that all pictures are missing from the documentation, as compared to the online version. This is because the pictures are compiled and included from a separate repo.
§Using Cabal-v1 (deprecated, not recommended)
It is recommended to install and test inside a sandbox:
cabal update # downloads the most recent list of packages from the Hackage repository
cabal sandbox init # initializes the sandbox
cabal install --dependencies-only # (optional) installs only dependencies inside the sandbox
cabal install # installs the library inside the sandbox
cabal configure # configures the package
Now the forsyde-atom
package should be installed in a sandbox in the current path. To open an interpreter session with the default ForSyDe-Atom libraries loaded, run the command:
cabal repl # starts GHCi with the sandbox loaded
For a quick test that everything works fine, you can try the following example inside the interpreter session. The example implements a Moore finite state machine that calculates the running sum and multiplies the output with 2.
*ForSyDe.Atom> import ForSyDe.Atom.MoC.SY as SY
*ForSyDe.Atom SY> let s = SY.signal [1..4]
*ForSyDe.Atom SY> SY.moore11 (+) (*2) 0 s
{0,2,6,12,20}
For more examples, please check the user manual generated from the forsyde-atom-examples
project.
To uninstall the library and everything that was generated, you can type in:
cabal sandbox delete # deletes the sandbox and everything in it
The test suite and its dependencies can be installed and run by
explicitly adding the flag --enable-tests
to the previous
installation commands, namely:
cabal install --enable-tests --dependencies-only # (optional)
cabal install --enable-tests # installs library + test suite
cabal configure --enable-tests # configures the package to run the test suite
cabal test # runs the test suite
The API documentation for latest release is publicly available here but if for some reason you need to generate it locally on your machine you need perform the following steps:
-
install the
hscolour
Haskell packagecabal install hscolour
-
download the archive containing the figures from the documentation from here and unzip it in the same folder as the
forsyde-atom.cabal
file. -
open the
forsyde-atom.cabal
using your favourite text editor and uncomment the following line:-- extra-doc-files: fig/*.png
-
cd
into the root of the project (the folder containing theforsyde-atom.cabal
file) and type in:cabal haddock --hyperlink-source