```
nonogrid -w 5933 ```
```
wget 'http://webpbn.com/XMLpuz.cgi?id=2992' -O 2992.xml nonogrid 2992.xml
wget 'http://webpbn.com/XMLpuz.cgi?id=2992' -O- | nonogrid ```
nonogrid examples/hello.toml
RUST_BACKTRACE=1 RUST_LOG=nonogrid=info cargo run -- examples/hello.toml
By default the --no-default-features --features="clap std_time env_logger"
are enabled but you can disable almost anything
to speed up and/or shrink the size of the application.
To support command-line arguments, the clap
feature is enabled by default.
To use the nonogrid
binary you have to included it anyway, or binary crate will not compile.
It can be disabled when using the solver as a library in another projects, e.g.
By default you can provide the --timeout
option to stop backtracking after reaching the specified time limit.
You can disable this feature and the timeout will simply be ignored.
cargo run --no-default-features --features=clap -- puzzles/2040.xml
My custom TOML-based format is supported by default via feature ini
.
It can be disabled when using the solver as a library in another projects, e.g.
The Jan Wolter's XML format supported via feature xml
.
You can enable it by building with the --features=xml
.
You can enable the feature colored
to allow to print colored nonograms with real terminal colors:
cargo run --no-default-features --features="clap colored" -- puzzles/2192.xml
To support pretty formatted logs the env_logger
crate is enabled by default.
As alwasys, you can disable it by skipping one in the list of features.
Solved puzzles can be automatically downloaded from the Internet with the reqwest
library
but it requires too many dependencies and increases compile time, so it's optional by default.
Enable it as simple as:
cargo run --features=web -- --webpbn 5933
By default, the solver and all the algorithms are single-threaded. To use the structures
in multi-threaded environment, provide the threaded
feature. In essense, this feature
replaces every occurence of Rc/RefCell
with Arc/RwLock
.
When the 'logical' solving gets stuck, the 'probing' phase starting which tries every variant for every unsolved cells. It does this by calculating the priority for each cell:
``` P = N + R + C,
where 0<=N<=4 - number of neighbours which are solved cells or puzzle edges. For example, the cell which has all 4 heighboring cells solved, has N = 4. The upper left cell of the puzzle without any neighbours solved, has N = 2, since it has 2 edges of the puzzle.
0<=R<=1 - row solution rate, the ratio of solved cells in the row to total number of cells (width) 0<=C<=1 - column solution rate, the ratio of solved cells in the column to total number of cells (height) ```
By default every cell with P>=0
checked, but you can customize the threshold by specifying
the LOW_PRIORITY
environment variable.
For example, running
LOW_PRIORITY=1 nonogrid puzzles/6574.xml
can be solved 3 times faster than standard way, by skipping the probing of cells with P < 1
.