You can either come up with your own topic or pick one from the ones below. The topics below are just examples, you can modify them if you want. The final topic will be decided with the help of, and approved by, the course assistant.
Graphs and pathfinding
-
How to find the fastest way possible out of a labyrinth. The labyrinth could be ASCII-art or a picture.
-
How to find the fastest/shortest path between two nodes in a grapth. The nodes could be for isntance street addresses, bus stops or coordinates. See this article if interested: http://theory.stanford.edu/~amitp/GameProgramming/AStarComparison.html
-
Compare at least two different path finding algorithms, one of which differs clearly from what you have learnt in Data structures and algorithms course. Eg. JPS, IDA*, fringe search (complicated). A-star is not sufficient for the demanding algorithm.
-
Maps for pathfinding can be found at Moving AI Lab and the downloads site for the National Land Survey of Finland.
-
Implement visualization of the path and covered nodes / jump points at early stage of development. Otherwise it is difficult to see whether the algorithm is correct. Although there may be data of certain paths and their lengths with your maps, a correct length does not guarantee that the algorithm works like it should. Visualization helps both checking the correctness of a complete work and finding errors during the development.
-
Public transit data https://developers.google.com/transit/gtfs/ or https://digitransit.fi/en/developers/ and open map data https://www.openstreetmap.org have also been popular.
Data compression
- How to compress a given file as efficiently as possible? A desired outcome would be at least a 40-60 % reduction in size. And the file has to be inflatable back to the original. How well can your implementation fare compared to existing solutions?
- Compare two compression algorithms, e.g. Huffman vs Lempel Ziv
Games
-
Chess, Go, expanded naughts and crosses (5-in-a-row, large board) and so on are fun and challenging games. Can you create an AI that can play against a human opponent as well as against itself? How good is it?
-
You can find a java template for a chess bot using xboard and the Lichess api from here: https://github.com/TiraLabra/chess
-
Rock-paper-scissors ia a very familiar game. Can you create an AI that beats a person? How about Rock-Paper-Scissors-Lizard-Spock. Note that this topic is pretty challenging for the background knowledge of typical students taking the course.
-
A solver for the well-known 15 puzzle. The 15 puzzle can be a bit challenging. Can you create a program that solves any 15 puzzle very fast? How about bigger play areas?
-
Minesweeper is another popular puzzle. Why not create a solver/helper using the project template avaialble at https://github.com/TiraLabra/minesweeper. You can find solutions suitable for this course e.g. here: https://dash.harvard.edu/handle/1/14398552
-
halite AI. Or any other similar online AI challenge.
Machine learning
-
Computational creativity Creativity can be implemented e.g. with genetic algorithms or Markov chains. A Markov chain is a stochastic process where each state depends only on the previous state or a fixed number of previous states. You can generate for example natural like words or sentences with them. Generated words can be used, in addition to a vocabulary, for breaking passwords. Some previous projects have been on Markov chains for composing music.
-
Eigenface face recognition. See https://en.wikipedia.org/wiki/Eigenface Prerequisites: at least Linear algebra 1+2. You are allowed to use any available libraries for matrix operations, if the basic method is expanded to achieve adequate complexity. Discuss with a course assistant.
Dungeon generator
- A fairly popular topic is creating dungeons for games such as Rogue or NetHack. There exist several algorithms that can be implemented or you could just roll your own. Generation can be either entirely done before hand or be dynamic.
Data structure comparisons
- There are many different data structures that do basically the same thing. Which of them is best for some given problems? Compare some (for example 4) different data structures and see what happens.
Encryption and security
-
Security is a very important topic in the modern world. There are many different ways to encrypt or hash data for many different reasons. This website has many ideas related to this topic: http://rumkin.com/tools/cipher/index.php
-
There are many ways to attack compressed, encrypted or hashed data. The above link contains some ideas for this as well. Or how about using frequency analysis to analyze an encrypted file? You can decrypt a file that has been encrypted with a substitution cipher, if the text is long enough, and you know the language of the text. This is also very closely related to Huffman compression: http://rumkin.com/tools/cipher/frequency.php
Signal processing (images, sound)
- Implement one or more signal processign algorithms and report on your findings. Note that this may require some background knowledge of linear algebra.
Something else
-
The logistics company FastFreight wants to minimize the space wasted when packing containers. How can you calculate how to pack containers as efficiently as possible given a number of packages with given sizes?
-
Design and implement a regular expression engine. Why? Read this for an answer: https://web.archive.org/web/20181227172507/https://blog.stevenlevithan.com/archives/10-reasons-to-learn-and-use-regular-expressions
-
Spell checker. Using distance measures for strings, you can find out the most probable correct word, when you know what kind of spelling mistakes people typically do. Start here: https://en.wikipedia.org/wiki/Damerau%E2%80%93Levenshtein_distance