SketchCalc is an interactive web application that allows users to draw mathematical expressions directly on a canvas. The application uses machine learning to predict the drawn symbols and converts them into a formal mathematical expression. It then evaluates the expression to provide the calculated answer.
- Drawing Canvas: Users can draw mathematical symbols and expressions on a canvas using mouse input.
- Real-time Prediction: The application predicts the drawn symbols and converts them into mathematical notation.
- Bounding Box Calculation: Drawn symbols are enclosed in bounding boxes to isolate individual symbols.
- Integration and Differentiation: Supports integral and differential calculus with custom variables.
- Evaluation: The predicted mathematical expressions are evaluated to provide the answer.
- Custom Variables: Users can include custom variables in their expressions.
- Elapsed Time Measurement: The time taken to parse and evaluate the drawing is displayed.
- Drawing: Users draw mathematical expressions on the canvas.
- Path Storage: The paths of the drawings are stored and processed to determine bounding boxes.
- Prediction: Each bounding box is sent to a server that uses a machine learning model to predict the symbol.
- Display: The predicted symbols are displayed on the canvas.
- Calculation: The final expression is evaluated, and the result is displayed to the user.
- Draw an integral on the canvas, and the application will recognize it as an integral symbol, convert it to the proper mathematical notation, and calculate the result.
- Use custom variables in your expressions to evaluate them dynamically.
- Frontend: JavaScript, HTML5 Canvas, CSS
- Backend: Flask (for prediction API)
- Machine Learning: TensorFlow
- Clone the repository:
git clone https://github.com/Frost-Lord/SketchCalc.git cd SketchCalc
- Download the model and dataset
https://drive.google.com/drive/folders/1u9L_ByfnE8vfx2AMju7VChWGTsQkbbgm?usp=sharing Extract "model.keras" to -> ./ Extract "dataset" to -> ./
- Install dependencies:
pip install -r requirements.txt
- Run the server:
python web.py
- Open
index.html
in your browser to start drawing and calculating.
# Create a new virtual environment
python -m venv venv
# Activate the virtual environment
.\venv\Scripts\activate || source venv/bin/activate
# Install Tensorflow
python3 -m pip install tensorflow[and-cuda]
# Keras to tflite
python convert_to_tflite.py -i model.keras -o model.tflite