Skip to content

Latest commit

 

History

History
86 lines (53 loc) · 2.51 KB

README.md

File metadata and controls

86 lines (53 loc) · 2.51 KB

Rush Hour

Par Guillaume Ortega et Edouard Menayde.

Getting started

Build

Using make

Execute make to build the project.

Using cmake

Execute ./build.sh to build the project.

Execute cd build/ to move the build project.

Usage

  • ./rush-hour solve <file_path>
  • ./rush-hour generate <difficulty_level> <output_path>
  • ./rush-hour info

The solve method solves a given puzzle and display the needed moves to solve it.

The generate method generates a puzzle of a difficulty between 1 and 4 included and writes it to the output path.

The info method shows the size of the struct/classes used in the project.

Performance analysis and memory usage

Using perf we can analyse the performance of our program for a given situation to solve.

Using mprof (provided by package http://jmdana.github.io/memprof/) we can measure memory usage overtime.

Profiling for version 0.1 We can see History:exists is the function were our program spends most of the time.

Profiling for version 0.4 We can see unordered_set:find takes less time than History:exists.

Changelog

v0.1

Initial release.

v0.2

Memory improvement : Moved out the vector of possible moves from the situation to only computing it and returning it when needed.

Bug fix : Bad checks for car movement on the edge of the puzzle which resulted in buggy moves.

v0.3

Memory improvement : Switching all ints / shorts to int8_t.

Bug fix : Bad move computing results in SIGSEV

We had a 2D array of int8_t contiguous to a vector in memory.

We used the bracket syntax to write to our 2D array like that :

parking[i][j] = 0

Unfortunately this syntax does not do bound checking and our get_moves function generated illegal moves which resulted in writing to the vector memory directly when wanting to write to the 2D array. This write resulted in the size operator of the vector to return big integers which made our loop looping over the vector continuously looping until it hit a memory violation.

The fix was to use the .at() syntax over the bracket syntax. Using that syntax in the get_moves function led directly to the bug creating the bad moves in the first place.

v0.4

Perf improvement : Use set to store explored situations. Results in higher memory use.

v0.5

Perf improvement : Use deque instead of vector to store situations needed to be explored.