Skip to content

Find the best town for Nine Tiles Panic by brute force.

License

Notifications You must be signed in to change notification settings

136s/nine_tiles_panic

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

nine_tiles_panic

This program shearches the best towns for the Nine Tiles Panic (Oink Games, 2019) by brute-force.

Installation

pip install git+https://github.com/136s/nine_tiles_panic.git

Usage

To search all possible town and calculate those towns' point, run

python -m nine_tiles_panic

then success_pattern.db which contians town pattern and point is created.

To check the face of a town, run

from nine_tiles_panic import View
View("206745813361230035").draw()

then get below image.

town of 206745813361230035

This town can be seen at the official site.

Classes

TileFace

TileFace class has roads and the number of tile objects:

  • dog
  • citizen (girl)
  • citizen (boy)
  • house
  • UFO
  • agent (off road)
  • alien (off road, captured)

Tile

Tile class has a front face and a back face. And this class generates tile sets:

  • original tile set
  • synonym tile set: five types of tiles with unique roads (used to judge if a town can be generated)

The tile number are 0 to 8. The front face is marked True or "0", and the back face is marked False or "1". The tile angles are 0 to 3 clockwise.

Road

Road class has both initial and terminal edge of road and the road objects:

  • the direction agent faces
  • the direction alien faces
  • number of hamburger

The edge number of roads is:

+-0-+
1   3
+-2-+

Town

Town class has tile faces, paths (= road of town) and point calculation methods.

The tile "position" number is:

+-------+
| 0 1 2 |
| 3 4 5 |
| 6 7 8 |
+-------+

The tile "direction" number is:

  • front face: 0 to 3 (equals to its angle)
  • back face: 4 to 7 (equals to its angle + 4)

A town instance is made from the "pattern" which length is 18. The first 9 characters represent the number of the tile to be placed in that "position", and the next nine characters represent the "direction" of that tile.

Example:

The 0-th position is #2 tile.
|
206745813361230035
         |
         The #2 tile is front face which rotates 270 degree.

Path

Path class has both initial and terminal end of path, length and the path objects:

  • agent
  • alien
  • hamburger

The path edge is:

+-0-+--4-+-8-+
1   3    7  11
+-2-+--6-+10-+
13  15  19  23
+-14+-18-+22-+
25  27  31  35
+-26+-30-+34-+

Difference between Road and Path:

  • Road: tile roads to be used for judging to complete a town
  • Path: town roads used to calculate scores for completed town

Agent, Alien, Hamburger

Agent class has its face and whether it is captureing an alien.

Alien class has its face, whether it is captured by an agent and whether it is eating a hamburger.

Hamburger class has whether it is eaten by an alien.

View

View class draws a tile face or a town. If the input is TileFace or Town, draw pseudo image by its infomation. If the input is string, draw real image by the string.

Search algorithm

A. Search all pattern

Pattern combinations: $9!\times8^9 = 48{,}704{,}929{,}136{,}640$

from nine_tiles_panic import Search, Town
for pattern in Search.search_all():
    points = Town(pattern).get_theme_point()
    print(pattern, points)

B. Search by road synonym

All unique synonym towns: 63,660 (pattern list (1.2 MiB))

from nine_tiles_panic import Search, Town
for _ in Search.search_synonym("synonym_pattern.txt"):
    # The text file of synonym patterns will be generated.
    pass
with open("synonym_pattern.txt") as f:
    for line in f:
        pattern_synonym = line.split("\n")[0]
        for pattern, points in Search.search_point_from_synonym(pattern_synonym):
            print(pattern, points)

or

from nine_tiles_panic import Search
for pattern, points in Search.search_point():
    print(pattern, points)

Concept:

flowchart LR
A[Road synonym tile] 
--> B{Can complete\n a town?} 
--> | Yes | C[Convert to\n original tiles]
--> D{Follow the tile\n constraints?} 
--> | Yes | E[Calculate point]
Loading

C. Search by road synonym and calculate points at each steps

All unique towns: 526,070,976

from nine_tiles_panic import Search, Town
for _ in Search.search_synonym("synonym_pattern.txt"):
    # The text file of synonym patterns will be generated.
    pass
with open("synonym_pattern.txt") as f:
    for line in f:
        pattern_synonym = line.split("\n")[0]
        with Search.text_io("synonym_pattern/{}.txt".format(pattern_synonym)) as f:
            for pattern in Search.convert_synonym_original(pattern_synonym):
                _ = f.write(pattern + "\n")
            # The text file of original patterns will be generated in `{pattern_synonym}.txt`.
with open("synonym_pattern.txt") as f:
    for line in f:
        pattern_synonym = line.split("\n")[0]
        for pattern, points in Search.search_point_from_pattern_file(pattern_synonym):
            print(pattern, points)

or

from nine_tiles_panic import Search
for pattern, points in Search.search_point_2():
    print(pattern, points)

Concept:

flowchart LR
A[Road synonym tile] 
--> B{Can complete\n a town?} 
--> | Yes | C[Calculate\n town synonym point]
--> D[Convert to\n original tiles]
--> E{Follow the tile\n constraints?} 
--> | Yes | F[Calculate point]
Loading

License

  • Original game: (C) 2019 Oink Games Inc.
    • Game Design: Jean-Claude Pellin, Jens Merkl
    • Artwork: Hiroko Izumida, Jun Sasaki
  • The source code except game design and artwork: MIT License

About

Find the best town for Nine Tiles Panic by brute force.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages