Extended logic puzzle solver of Noq.
-
@T0nyX1ang: backend, frontend, new solver implementations, bug fixes
-
@zhuyaoyu: (huge) solver optimizations, new solver implementations, bug fixes
-
Remove redundant codes and formatting codes.
-
New solver backend with new UI design (See issue #2)
-
Change the backend from Django to Starlette with Uvicorn (See issue #31, #50).
-
Change the frontend from Noq native to penpa-edit. (See issue #36).
-
Obtain uniform data structures in every puzzle. (See issue #88).
-
Select puzzle type.
-
Show rules in puzz.link if possible.
-
Choose example puzzle.
-
Show/Edit parameters of the solver if possible.
-
Solve/Reset the puzzle.
Note: if the puzzle is imported from puzz.link, you will need to change the edit mode to Problem
to reset the puzzle itself.
-
Install uv first.
-
Clone this project and switch to
master
branch.
git clone https://github.com/T0nyX1ang/noqx.git
- Create a virtual environment (Optional):
uv venv
- Install non-development packages with uv:
uv sync --extra web --no-dev
- Run with uv:
uv run main.py
- Install requirements (automatically generated by uv):
pip install -r requirements.txt
- Clone this project and switch to
master
branch.
git clone https://github.com/T0nyX1ang/noqx.git
- Run locally (based on your system):
py -3 main.py
python3 main.py
-
Download the latest release here.
-
A new version is released from weekly to monthly.
usage: main.py [-h] [-d] [-H HOST] [-p PORT] [-tl TIME_LIMIT] [-pt PARALLEL_THREADS]
usage: main.exe [-h] [-H HOST] [-p PORT] [-d] [-tl TIME_LIMIT] [-pt PARALLEL_THREADS]
optional arguments:
-h, --help show this help message and exit
-H HOST, --host HOST the host to run the server on.
-p PORT, --port PORT the port to run the server on.
-d, --debug whether to enable debug mode with auto-reloading.
-tl TIME_LIMIT, --time_limit TIME_LIMIT
time limit in seconds (default = 30).
-pt PARALLEL_THREADS, --parallel_threads PARALLEL_THREADS
parallel threads (default = 1).
-
Install uv first.
-
Clone this project and switch to
dev
branch.
git clone https://github.com/T0nyX1ang/noqx.git
git checkout dev
- Install all dependencies with uv:
uv sync --all-extras
- Install pre-commit and add commit hooks:
uv pre-commit install
-
Create a python file in
solver/
and write solver codes in that file. The functions innoqx
package are free to use. -
Use the data structures from the puzzle. The atom element of a puzzle is a cell, and the data structures are all crafted around a cell. In detail, a puzzle has the following attributes:
puzzle_name
: the name of the puzzle, should be the same as the filename of the solver.param
: the parameters of the puzzle.row
: the number of rows in the puzzle.col
: the number of columns in the puzzle.margin
: the margin of the puzzle, the order is a tuple of (top-margin
,bottom-margin
,left-margin
,right-margin
).surface
: the shaded cells in the puzzle.text
: the text clues in the puzzle.symbol
: the symbols in the puzzle.edge
: the borders in the puzzle.line
: the lines in the puzzle.
-
(Optional) Append a
__metadata__
variable in the end of the solver file. The keys of__metadata__
are:name
: the name of the solver.category
: the category of the solver, should beshade
(Shading),loop
(Loop / Path),region
(Area Division),num
(Number),var
(Variety),draw
(Drawing),unk
(Unknown).examples
(Optional): a list of examples of the solver, each example can be created in two conflicting ways,data
andurl
:data
: directly draw the board in noqx and get the data URL by usingShare → Editing URL → Copy
. The URL are suggested to be generated with the following conditions:- contains all the required
modes
in this puzzle. - contains the required
sub-types
in this puzzle. - contains necessary initial conditions to pass the coverage tests.
- set
edit mode
tosolution mode
instead ofproblem mode
.
- contains all the required
url
: draw the board in puzz.link and useFile → Export URL
to get the board URL.config
(Optional): the configuration of the solver, which will be passed to the solver when it is created, and the keys ofconfig
are the same asparameters
keys.test
(Optional): whether the example is a test case, the default value isTrue
, and cannot be used together withurl
way.- Lots of examples can be found at pzplus.
parameters
(Optional): the parameters of the solver, which will be passed to the solver when it is created.
-
Free to PR now ^_^
- Run the tests (with default
unittest
features) with uv:
uv run coverage run -m unittest
- Check the HTML version of coverage report with uv:
uv run coverage html
- This project is dual-licensed under Apache 2.0 and GPL 3.0 (or any later version). You can choose between one of them if you use this project.