Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/drcbeatz/master-theorem
Web app to evaluate the time complexity of divide and conquer algorithms using the Master Theorem and visualize the results (Python/Django, Typescript/React, Postgres, Docker, AWS Elastic Beanstalk, AWS RDS, Github Actions CI).
https://github.com/drcbeatz/master-theorem
aws chartjs continuous-integration django django-rest-framework docker elasticbeanstalk github-actions master-theorem mdbootstrap postgresql pytest python rds-postgres react responsive-design rest-api typescript vite vitest
Last synced: 15 days ago
JSON representation
Web app to evaluate the time complexity of divide and conquer algorithms using the Master Theorem and visualize the results (Python/Django, Typescript/React, Postgres, Docker, AWS Elastic Beanstalk, AWS RDS, Github Actions CI).
- Host: GitHub
- URL: https://github.com/drcbeatz/master-theorem
- Owner: DrCBeatz
- Created: 2024-02-09T02:10:45.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-04-13T01:32:06.000Z (10 months ago)
- Last Synced: 2024-04-13T22:20:33.741Z (10 months ago)
- Topics: aws, chartjs, continuous-integration, django, django-rest-framework, docker, elasticbeanstalk, github-actions, master-theorem, mdbootstrap, postgresql, pytest, python, rds-postgres, react, responsive-design, rest-api, typescript, vite, vitest
- Language: Python
- Homepage: https://www.mastertheorem.io
- Size: 3.72 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Master Theorem Evaluation Web App
This web application allows users to evaluate recursive divide and conquer algorithms using the Master Theorem and determine their time complexity, providing valuable insights into algorithm performance.
Algorithms with the following recurrence relation (known as the Master Recurrence) can be evaluated using the Master Theorem:
`T(n) = aT(n/b) + f(n)`
where a > 0 and b > 1
- a = the number of recursive subproblems
- b = the factor by which the problem size is reduced
- k = the exponent of the work outside the recursion## Features
- Evaluate the time complexity of divide and conquer algorithms.
- Visualization of algorithm performance.
- Comparison between different algorithms through preset options.
- Python code and description of preset algorithms.## How to use the app:
1. Enter your own values for a, b, and k in the respective input fields.
2. Ensure the 'User Input' option is selected under 'Enter Values or Choose Algorithm'.
3. Click the 'Evaluate' button to see the results.Try the following sample inputs:
- a = 4, b = 2, k = 1
- a = 4, b = 2, k = 2
- a = 4, b = 2, k = 3You can also choose from various preset algorithms (e.g., binary search or merge sort) by clicking the 'Enter Values or Choose Algorithm' select field, then click 'Evaluate'. You'll be able to see sample code and a description of the algorithm below the evaluation.
## How to install locally
### Installation requirements:
- Docker CLI
- NPMAt the command line/terminal, type the following commands.
```bash
git clone https://github.com/drcbeatz/master-theorem.gitcd master-theorem
docker compose build
docker compose up -d
cd frontend
npm install
npm run dev
```(then click on the link to view the React front end in your web browser).
You can also run the backend tests in the root directory with the following command:
```bash
docker compose exec web pytest
```To run the front end tests, go to the 'frontend' directory and type the following command:
```bash
npm test
```## References
- Cormen, T. H., Leiserson, C. E., Rivest, R. L., & Stein, C. (2022). _Introduction to Algorithms_ (4th ed.). MIT Press.