Skip to main content
Version: 0.1.3

Command-line interface

You can run Refinery as a command-line applications via our Docker container on either amd64 or arm64 machines:

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3

This will let you read input files and generate models in the current directory (${PWD}) of your terminal session. Module imports (e.g., import some::module. to import some/module.refinery) relative to the current directory are also supported.

For example, to generate a model based on the file named input.problem in the current directory and write the results into the file named output.refinery, you may run the generate subcommand with

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 generate -o output.refinery input.problem

If you want Refinery CLI to print its documentation, run

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 -help

The generate subcommand​

The generate subcommand generates a consistent concrete model from a partial model. You can also use the short name g to access this subcommand.

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 generate [options] input path

The input path should be a path to a .problem file relative to the current directory. Due to Docker containerization, paths outside the current directory (e.g., ../input.problem) are not supported.

Passing - as the input path will read a partial model from the standard input.

By default, the generator is deterministic and always outputs the same concrete model. See the -random-seed option to customize this behavior.

See below for the list of supported [options].

-output, -o​

The output path for the concretized model, usually a file with the .refinery extension. Passing -o - will write the generated model to the standard output.

When generating multiple models with -solution-number, the value - is not supported and individual solutions will be saved to numbered files. For example, if you pass -o output.refinery -n 10, solutions will be saved as output_001.refinery, output_002.refinery, …, output_010.refinery.

Default value: -, i.e., the solution is written to the standard output.

-random-seed, -r​

Random seed to control the behavior of model generation.

The same random seed value and Refinery release will produce the same output model for an input problem. Models generated with different values of -random-seed are highly likely (but are not guaranteed) to be substantially different.

Default value: 1

-scope, -s​

Add scope constraints to the input problem.

This option is especially useful if you want to generate models of multiple sizes from the same partial model.

For example, the command

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 generate -s File=20..25 input.problem

is equivalent to appending

input.problem
scope File = 20..25.

to input.problem. The syntax of the argument is equivalent to the scope declaration, but you be careful with the handling of spaces in your shell. Any number of -s arguments are supported. For example, the following argument lists are equivalent:

-scope File=20..25,Directory=3
-s File=20..25,Directory=3
-s File=20..25 -s Directory=3
-s "File = 20..25, Directory = 3"
-s "File = 20..25" -s "Directory = 3"

The * opeator also has to be quoted to avoid shell expansion:

-s "File=20..*"

-scope-override, -S​

Override scope constraints to the input problem.

This argument is similar to -scope, but has higher precedence than the scope declarations already present in the input file. However, you can’t override scope declarations in modules imported in the input file using the import statement.

For example, if we have

input.problem
scope File = 20..25, Directory = 3.

in the input file, the arguments -s File=10..12 input.problem will be interpreted as

scope File = 20..25, Directory = 3.
scope File = 10..12.

which results in an unsatisfiable problem. If the use -S File=10..12 input.problem instead, the type scope for File is overridden as

scope Directory = 3.
scope File = 10..12.

and model generation can proceed as requested. Since we had specified no override for Directory, its type scope declared in input.problem was preserved.

Scope overrides do not override additional scopes specified with -scope, i.e., -s File=20..30 -S File=10..25 is interpreted as -S File=20..25.

-solution-number, -n​

The number of distinct solutions to generate.

Generated solutions are always different, but are frequently not substantially different, i.e., the differences between generated solutions comprise only a few model elements. You’ll likely generate substantially different models by calling the generator multiple times with different -random-seed values instead.

The generator will create numbered output files for each solution found. The generation is considered successful if it finds at least one solution, but may find less than the requested number of solutions if no more exist. In this case, there will be fewer output files than requested.

Default value: 1

The check subcommand​

The check subcommand checks a partial model for inconsistencies.

  • For consistent partial models, it has an exit value of 0.
  • For inconsistent partial models that contains error logic values, it prints the occurrences of error logic values to the standard output and sets the exit value to 1.
  • For partial models that can’t be constructed due to syntax or propagation errors, it prints and error message to the standard output and sets the exit value to 1.
docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 check [options] input path

The input path should be a path to a .problem or .refinery file relative to the current directory. Due to Docker containerization, paths outside the current directory (e.g., ../input.problem) are not supported.

Passing - as the input path will read a partial model from the standard input.

-concretize, -k​

If you provide this flag, the partial model will be concretized according to the behavior of the concretize subcommand before checking for inconsistencies. You can use this flag to check whether a partial model can be concretized consistently without having to save the result somewhere.

The concretize subcommand​

The concretize subcommand creates a concrete model by replacing unknown aspects of a partial model with false logic values. The resulting concrete model is the same as the one shown in the concrete view in the Refinery web UI.

This subcommand is only able to save consistent concrete models. If the result of the concretization is inconsistent, it shows an error with a form similar to the check subcommand.

Scope constraints will likely render your partial model inconsistent after concretization if they prescribe multiple nodes to be created. You should the required nodes manually to the model or remove the scope constraints before concretization.

docker run --rm -it -v ${PWD}:/data ghcr.io/graphs4value/refinery-cli:0.1.3 concretize [options] input path

The input path should be a path to a .problem or .refinery file relative to the current directory. Due to Docker containerization, paths outside the current directory (e.g., ../input.problem) are not supported.

Passing - as the input path will read a partial model from the standard input.

See below for the list of supported [options].

-output, -o​

The output path for the concretized model, usually a file with the .refinery extension. Passing -o - will write the concretized model to the standard output.

Default value: -, i.e., the model is written to the standard output.