claferIG is an interactive tool that generates instances of Clafer models. http://clafer.org
|Latest on Hackage:||0.4.5|
This package is not currently in any snapshots. If you're interested in using it, we recommend adding it to Stackage Nightly. Doing so will make builds more reliable, and allow stackage.org to host generated Haddocks.
Clafer Instance Generator
Clafer is a powerful (equivalent to first-order predicate logic) yet lightweight structural modeling language. Despite simplicity and conciseness of Clafer, writing correct models remains challenging due to hard-to-predict interactions among all constraints expressed in the model.
Clafer instance generator (ClaferIG) is an interactive tool that generates instances and counter examples of concrete clafers in a Clafer model. If the concrete clafers do not have contradicting constraints, the generator produces valid instance data. Otherwise, the generator produces an unsatisfiable core which included all contradicting constraints and generates a counter example by removing one constraint from the core. The generator can potentially produce many instances if the concrete clafers are not fully specialized. The generator produces different instances on-demand. With these capabilities, the instance generator can be used for debugging models: checking the consistency of the model and detecting under- and overconstraining of the model. The instance generator can also be used programmatically via API (the command line and interactive session interfaces only use the API).
For more information, see technical report.
- Michał Antkiewicz, Main developer.
- Jimmy Liang, Original developer.
- Luke Michael Brown, co-op student May-Aug 2013. Many improvements.
Getting the Clafer Instance Generator
Clafer can be installed from a binary distribution (preferred), from Hackage, and from the source code.
Dependencies for running
Regardless of the installation method, the following are required:
- Clafer v0.4.5
- Java Platform (JDK) v8+, 64bit * On Windows, Java must be 32bit because of Alloy, 64bit otherwise
Installation from binaries
Binary distributions of the release 0.4.5 of Clafer Tools for Windows, Mac, and Linux, can be downloaded from Clafer Tools - Binary Distributions.
- download the binaries and unpack
<target directory>of your choice,
- add the
<target directory>to your system path so that the executables can be found.
Installation From Hackage
Stack is the only requirement: no other Haskell tooling needs to be installed because stack will automatically install the needed Haskell build tools.
stack install claferIG
` cd `stack --local-bin-path``
mv alloy4.2_2015-02-22.jar alloy4.2.jar
- Depending on your OS:
- for Win,
stack exec wget -- https://github.com/gsdlab/claferIG/raw/master/lib/libminisatprover.dll
- for Linux,
- for Mac,
- for Win,
- GHC >= 7.10.3 and 8.0.1 are recommended,
cabal-install>= 1.18, should be installed together with a GHC distribution,
- Install GHC
cabal install claferIG
cd <cabal's lib or share folder>(
C:\Users\<user>\AppData\Roaming\cabal\x86_64-windows-ghc-8.0.1\claferIG-0.4.5on Windows or
- to automatically download alloy4.2.jar
copy the following into the Cabal's
- the file
- the file
- the folder
Installation from the source code
- GHC >= v7.10.3
- Clafer compiler (to produce Alloy models (
- On Linux, might need to manually install
libncurses5-devto build one of Haskell packages on which ClaferIG depends * on Ubuntu, execute
sudo apt-get install zlib1g-dev libncurses5-dev
- it is installed automatically by
stack setup(see Building below)
- update MSYS2 packages
* follow III. Updating packages but always execute
stack exec pacman -- <arguments for pacman>
stack exec pacman -- -S make wget unzip diffutils
Important: branches must correspond
All related projects are following the simultaneous release model.
master contains releases, whereas the branch
develop contains code under development.
When building the tools, the branches should match.
Releases from branches 'master
are guaranteed to work well together.
Development versions from branches develop` should work well together but this might not always be the case.
- install the Clafer compiler
- in some
<source directory>, execute
git clone git://github.com/gsdlab/claferIG.git
<source directory>/claferIG, execute
stack setup. This will install all dependencies, build tools, and MSYS2 (on Windows).
cd <source directory>/claferIG
make install to=<target directory>
On Windows, use
makecommand instead of
make install to=/c/clafer-tools-0.4.5/
Integration with Sublime Text 2/3
Integration with VIM
Clafer Instance Generator can be used in interactive and batch modes, as well as, an API.
(As printed by
ClaferIG v0.4.5 claferIG [OPTIONS] [FILE] Common flags: --all=INT Saves all instances up to the provided scope or a counterexample. --savedir=FILE Specify the directory for storing saved files. --alloysolution Convert Alloy solution to a Clafer solution. -b --bitwidth=INTEGER Set the bitwidth for integers. -m --maxint=INTEGER Set the bitwidth for integers based on the largest required number. Overrides --bitwidth argument. -u --useuids Use unique clafer names in the Clafer solution. --addtypes Add colon/reference types to the Clafer solution. -j --json Render solution as JSON (forces 'addUids'). -i --flatten-inheritance-comp Flatten inheritance during compiling ('alloy' and 'Alloy' modes only) -l --no-layout-comp Don't resolve off-side rule layout during compiling -c --check-duplicates-comp Check duplicated clafer names during compiling -f --skip-resolver-comp Skip name resolution during compiling --ss=SCOPESTRATEGY --scope-strategy-comp Use scope computation strategy during compiling: none or simple (default). -? --help Display help message -V --version Print version information
claferIG <model file name>.cfr
opens an interactive session and displays an instance or a counterexample.
claferIG <model file name>.cfr -all <scope>
opens a non-interactive session and saves all instances up to the provided scope or a counterexample to files named
<model file name>.cfr.<instance number>.data, one instance per file.
Interactive Session Usage
In the interactive mode, the users can invoke the following commands by pressing a letter marked in the command name between '' or the whole command as marked by '':
ClaferIG v0.4.5 You can invoke the following commands as indicated by single quotes: [tab] - print the available commands - auto-complete command name, a clafer name, or clafer instance name in a given context 'n'ext, [enter] - to produce the next instance if available or to output a message that no more instances exist within the given scope 'i'ncrease - to increase the maximum number of instances of a given clafer or all clafers (scope) 's'et - to set the maximum number of instances of a given clafer or all clafers (scope) 'm'axint, 'maxint' - to set the bitwidth by providing the largest integer sa'v'e - to save all instances displayed so far or a counterexample to files named <model file name>.cfr.<instance number>.data, one instance per file 'q'uit - to quit the interactive session 'r'eload - to reload your clafer model 'h'elp - to display this menu options summary 'scope' - to print out the values of the global scope and individual Clafer scopes 'saveScopes' - to generate a '<model>.cfr-scope' file with the current scopes 'loadScopes' - to load scopes from a '<model>.cfr-scope' file 'setUnsatCoreMinimization' - to choose UnSAT core minimization strategy [fastest | medium | best]. Default: fastest 'c', 'claferModel' - to print out the original Clafer model verbatim 'a', 'alloyModel' - to print out the output of Clafer translator verbatim 'alloyInstance' - to print out the Alloy xml document of the most recent solution 'f'ind - to print a Clafer with given name found in the most recent solution Parameterized command usage: 'i [enter]' - to increase for all clafers by 1 'i <name> [enter]' - to increase for the clafer <name> by 1 'i <name> <number>' - to increase for the clafer <name> by <number> 's <number> [enter]'- to set for the clafers to <number> 's <name> <number>' - to set for the clafer <name> to <number> 'f <name>' - to display a clafer <name> 'setUnsatCoreMinimization fastest' - fastest but the worst 'setUnsatCoreMinimization medium' 'setUnsatCoreMinimization best' - best but slowest even for modest size cores
There are two output formats: native (plain text, default) and JSON (
Instance data (native)
The instance data notation is very similar to a regular Clafer notation for concrete clafers with a few differences:
- no constraints
- no types and super types
- except when
--useuids --addtypesparameters are used
- except when
- no clafer and group cardinalities (each clafer has the default group
- no clafers not present in the instance
Additionally, the data notation contains concrete values of the clafers and suffix numbers to distinguish among multiple instances of the same clafer.
The instance data models could be read by the Clafer translator if the translator had simple type inference support.
For a model
abstract A a ? b + c -> integer ? d -> E 2 g -> E 2 h -> integer abstract E f ->> integer + a1 : A e1 : E e2 : E
A possible instance data looks as follows:
=== Instance 1 Begin === a1 b$1 b$2 c -> 10 d$1 -> e1 d$2 -> e2 g1 -> e1 h$1 -> 5 g2 -> e2 h$2 -> 2 e1 f$1 -> 2 f$2 -> 3 f$3 -> 4 f$4 -> 2 --- Instance 1 End ---
Near-miss instance notation is the same as the instance data notation. Additionally, it indicates which constraints belong to the UnSAT Core.
For a model
abstract A a ? b ? [ a ] // C1 a1 : A [ no a ] // C2 [ b ] // C3
Constraints C1, C2, and C3 form an UnSAT Core. Removal of any of them will make the model satisfiable. The constraint C1 is part of the model and cannot be removed (part of domain knowledge). Therefore, either C2 or C3 must be removed to remove the inconsistency.
On possible near-miss instance:
a1 a b
C3 are satisfied but
C2 is not. To resolve the conflict and assuming that the counter example is actually a correct instance data, the user has to modify the model by removing
C2. However, should the counter example actually represent incorrect instance data, the user can remove
C3 to resolve the inconsistency.
If you get an error:
Exception in thread "main" java.lang.UnsatisfiedLinkError: no minisatproverx1 in java.library.path at java.lang.ClassLoader.loadLibrary(Unknown Source) at java.lang.Runtime.loadLibrary0(Unknown Source) at java.lang.System.loadLibrary(Unknown Source) at org.clafer.ig.AlloyIG.main(AlloyIG.java:275)
it means that you have a 64bit Java on Windows instead of the required 32bit one. On Windows, Alloy only supports Minisat with UnSAT core on 32bit Java. There's nothing we can do.
How it works
The Clafer instance generator:
- translates the input Clafer model (.cfr) to an Alloy4.2 model (.als). The compiler's intermediate representation (IR) contains the mapping between Clafer names and Alloy names. The IR also contains the scopes for each Alloy signature to ensure that a valid instance can be found if it exists
- invokes Alloy Analyzer to produce an instance or find an UnSAT core ** given an UnSAT core, removes constraints from the core until an instance is found - that instance represents the counterexample which violates the removed constraints
- translates the instance or the counterexample data produced by Alloy Analyzer to Clafer instance data format using the name map from IR in a reverse direction,
- for a counterexample, translates the counter example in Alloy to Claefr instance data and constraint violations in Alloy into constraint violations in Clafer model
ClaferIG Version 0.4.5 released on Mar 13, 2017
ClaferIG Version 0.4.4 released on Jun 23, 2016
ClaferIG Version 0.4.3 released on Dec 22, 2015
ClaferIG Version 0.4.2.1 released on Oct 19, 2015
Fixed Java manifest file, added stack instructions to README
ClaferIG Version 0.4.2 released on Oct 16, 2015
ClaferIG Version 0.4.1 released on Sep 1, 2015
ClaferIG Version 0.4.0 released on Jul 28, 2015
ClaferIG Version 0.3.10 released on April 24, 2015
ClaferIG Version 0.3.9 released on March 06, 2015
ClaferIG Version 0.3.8 released on January 27, 2015
ClaferIG Version 0.3.7 released on October 23, 2014
ClaferIG Version 0.3.6.1 released on July 08, 2014
ClaferIG Version 0.3.6 released on May 23, 2014
ClaferIG Version 0.3.5 released on January 20, 2014
ClaferIG Version 0.3.4 released on September 20, 2013
ClaferIG Version 0.3.3 released on August 14, 2013
ClaferIG Version 0.3.2 released on April 11, 2013
ClaferIG Version 0.3.1 released on October 17, 2012
ClaferIG Version 0.3 released on July 17, 2012
This was the first release of Clafer Instance Generator and included all code since the beginning of the project.