Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/4s4v1n/smart-calculation-v1.0
Calculator implementation with gui.
https://github.com/4s4v1n/smart-calculation-v1.0
calculator cpp gui gui-application math
Last synced: about 1 month ago
JSON representation
Calculator implementation with gui.
- Host: GitHub
- URL: https://github.com/4s4v1n/smart-calculation-v1.0
- Owner: 4s4v1n
- License: gpl-3.0
- Created: 2022-04-25T06:16:07.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2023-09-06T12:54:58.000Z (over 1 year ago)
- Last Synced: 2024-11-10T18:12:19.582Z (3 months ago)
- Topics: calculator, cpp, gui, gui-application, math
- Language: C++
- Homepage:
- Size: 185 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Smart Calculation v1.0
data:image/s3,"s3://crabby-images/e43d1/e43d17d9f3ccf4430ef990fb852eeb786f41c78f" alt="preview"
## Content
This project implements a calculator with a graphical interface. It supports both standard mathematical operations and the calculation of some elementary functions, the construction of graphs of functions, the calculation of the value of a function at a specific point, and a loan calculator. For calculations, the calculator uses the reverse Polish notation algorithm, while all graphics are written in Qt.
Appearance of the calculator
data:image/s3,"s3://crabby-images/9cc6e/9cc6e845ae86bf90c3b2e18659cdac5dc730af9e" alt="start"## Basic Calculator
The main page contains numbers, operations, functions, constants, special characters and 'x'.
The numbers `0-9` are responsible for entering the corresponding number.
The constant `π` is defined as 3.14, `e` as 2.72 .`AC` - erases the entire input string, `←` - deletes the last character in the input string, `√` - square root function.
All operations are intuitive.
Correct input is required, namely:1) The number of opening and closing brackets is the same. `(2+3)*2` - correct notation, `((2+3)*2` - incorrect notation.
2) The arguments of all functions are indicated in brackets. `sin(x)` is valid, `sinx` is invalid.
3) There are no unintended literals in the expression record.
Work example:data:image/s3,"s3://crabby-images/c1795/c1795869d8600f92b8b5d011d3b0250d0265f348" alt="Main"
## Graphs of function and value at point
In addition to calculating standard mathematical expressions, this calculator supports plotting functions and calculating the value of a function at a certain point.
You can plot or calculate the value of a function if you have `x` in the input string.1) When calculating a value at a function point, you will be prompted to enter it, a value will be substituted in place of `x` and the calculation will be performed.
2) When plotting a function, you will be prompted to specify the domain of the function and the range of values. In the future, the resulting graph can be scaled and moved.
Examples:data:image/s3,"s3://crabby-images/f1640/f1640fe38700594ba8146de050056e57bac3099b" alt="graph"
data:image/s3,"s3://crabby-images/8b415/8b415fbbdccd9e774c7b54e4f24bc29296aa1059" alt="other_graph"## Credit calculator
Additionally, the implementation of a loan calculator is presented, similar to most online loan calculators.
To select it, switch the calculator's mode to the status bar.data:image/s3,"s3://crabby-images/7f4da/7f4dae8e1da01be65055178ee76394741f829871" alt="credit_png"
Input data:1) `Credit sum` - loan amount, in any currency.
2) `Credit term` - credit term - numerically.
3) `Term type` - term type, namely months or years.
4) `Percent` - percentage per annum on the loan.
5) `Monthly payment type` - payment type, namely authentic or differential.
Output:1) `Monthly payment` - monthly payment on the loan (in the case of differential payments, the amount for the first and last months is indicated).
2) `Overpayment` - overpayment on the loan.
3) `Full payment` - the total payment on the loan.
After entering the data, you must click on the `calculate` button - then the calculations will be made.
Work example:data:image/s3,"s3://crabby-images/edb16/edb1660349841e31c61c23132c36c6933ce4d6eb" alt="credit_gif"