Skip to content

Latest commit

 

History

History
58 lines (41 loc) · 3.31 KB

README.md

File metadata and controls

58 lines (41 loc) · 3.31 KB

Visual Novel Recommender

COP3530 Final Project

How to run program

Dependencies:

  • Rust

    • If using VSCode, use the rust-analyzer extension. Any rust-compatible IDE will work (e.g. RustRover).
    • A standalone install of rust will also work fine (no IDE needed)
  • npm (Node.js)

  • React

    • Type npm install react into your terminal

Steps

  1. Clone this repo locally
    • If you have git installed, run git clone https://github.com/timacias/VisualNovelRecommender in your terminal
  2. Open up your terminal and go to the “my_rust_backend” folder
  3. Run with cargo run --release. This will take a bit. Once you see “listening on 127.0.0.1” in your terminal, that means that the backend has created the graph and is ready for usage.
    • To build a debug binary, use cargo run, this will be significantly slower.
  4. Open a new terminal and move to “my_react_frontend” (this folder is within "my_rust_backend")
  5. Ensure react has been installed via npm
    • If using a Unix shell, type PORT=3001 npm start
    • If using a Windows shell, type npm run build
      • If serve is not installed, type npm install -g serve
      • Then serve -s build
  • Note: npm start creates a debug build, npm run build creates a release build
    • On Unix shells, a release build of the frontend can be created by following the Windows instructions

Disclaimers

The database is from June 24th, 2024. Details of the novels such as tags are added by users so some novels (especially newer ones) may have incomplete information. As a result, some NSFW novels may pass into our database because they have not been tagged properly for the database to recognize it as NSFW.

Any novel with a tag categorized as ‘ero’ was classified as NSFW.

Please note that any NSFW novel that shows up on the website is due to the Visual Novel API Kana. In the algorithms in the backend, only SFW novels can be used.

Our program only displays the top 3 tags in a novel for visual clarity, but we use all of a novel's tags in our weight and path-finding calculations.

Graph edges are based on similarity score (see 'Extra Details'). An edge will only be created in the graph of novels if a certain similarity percentage is met.

On some very rare occasions, the Dijkstra and Bellman-Ford algorithms will result in different paths. This is expected when multiple valid paths are possible with the same distance/weight traveled.


Extra Details

Weight Calculations:

  • Each novel has three attributes which are sets: staff, seiyuu (voice actor), and tags. When compared to another novel, the cardinality of the intersection of each set is found and added to an “intersection_index”. Afterward, each attribute is compared to find which set is smaller and is added to “smallest_sizes”. This is so we can get a percentage of similarities found within the limitations of the variation between the size of each attribute’s set.
  • We find the percentage similarity by doing intersection_index/smallest_sizes * 100.0. Finally, since we are doing the shortest path algorithms, we have to subtract the percentage by 100 so that in these algorithms, the more similar novels are considered before others.

Legal

This program is released under the GNU Affero General Public License, version 3 or later.