numo


Namenumo JSON
Version 0.2.5 PyPI version JSON
download
home_pagehttps://github.com/furkancosgun/numo
SummaryA Python library for mathematical operations, unit conversions, currency conversions, and translations
upload_time2024-12-26 18:31:31
maintainerNone
docs_urlNone
authorFurkan Coşgun
requires_python>=3.8
licenseNone
keywords
VCS
bugtrack_url
requirements aiohttp
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 🔢 Numo: Your Smart Mathematical Companion

[![PyPI version](https://badge.fury.io/py/numo.svg)](https://badge.fury.io/py/numo)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Python 3.8+](https://img.shields.io/badge/python-3.8+-blue.svg)](https://www.python.org/downloads/)

> 🚀 Numo is a powerful text-based calculator and unit converter that brings mathematics to life through natural language processing. Whether you're a student, developer, or data scientist, Numo makes complex calculations feel natural and intuitive.

## ✨ Key Features

### 🧮 Mathematical Functions
- **Basic Operations**
  - Arithmetic operations (`+`, `-`, `*`, `/`, `^`)
  - Parentheses support for complex expressions
  - Automatic decimal precision handling

- **Advanced Mathematics**
  - Trigonometric functions (`sin`, `cos`, `tan`, etc.)
  - Logarithmic functions (`log`, `log10`, `exp`)
  - Root calculations (`sqrt`, `cbrt`)

- **Statistical Analysis**
  - Basic statistics (`mean`, `median`, `mode`)
  - Variance and standard deviation
  - Quartiles and percentiles

- **Vector Operations**
  - Vector magnitude calculation
  - Dot product computation
  - Angle between vectors

- **Financial Tools**
  - Compound interest calculator
  - Simple interest calculator
  - Payment (PMT) calculator

- **Advanced Features**
  - Combinatorics (`permutation`, `combination`)
  - Percentage calculations
  - Custom rounding functions

### 📏 Unit Conversions
- **Physical Measurements**
  - Length (meters, feet, miles, etc.)
  - Weight (kilograms, pounds, etc.)
  - Volume (liters, gallons, etc.)
  - Area (square meters, acres, etc.)

- **Time & Speed**
  - Time units (seconds to years)
  - Speed conversions (km/h, mph, etc.)
  - Angular measurements (degrees, radians)

- **Digital Units**
  - Storage (bytes to yottabytes)
  - Data rates (bps to TBps)
  - Both decimal (MB) and binary (MiB) units

- **Scientific Units**
  - Pressure (pascal, bar, psi, etc.)
  - Electrical (volt, ampere, watt, etc.)
  - Power (horsepower, kilowatt, etc.)

- **Display Units**
  - Screen measurements (px, pt, em)
  - Resolution (dpi, ppi)
  - Typography units (pica)

### 🌍 Language Translation
- **Comprehensive Support**
  - 100+ languages supported
  - Natural language processing
  - Automatic language detection

- **Easy Syntax**
  - Simple format: "text in language"
  - Supports full sentences
  - Maintains formatting

### 💾 Variable Management
- **Smart Storage**
  - Dynamic variable assignment
  - Expression evaluation
  - Persistent storage between sessions

- **Advanced Features**
  - Complex expression support
  - Mathematical constants (`pi`, `e`, etc.)
  - Function results storage

## 🚀 Quick Start

### Installation

```bash
# Clone the repository
git clone https://github.com/furkancosgun/numo.git
cd numo

# Create and activate virtual environment
python -m venv .venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt
```

### Basic Usage

```python
from numo import Numo

# Initialize Numo
numo = Numo()

# Mathematical calculations
await numo.calculate("2 * (3 + 4)")  # Returns: "14.00"
await numo.calculate("sin(pi/2)")    # Returns: "1.00"

# Unit conversions
await numo.calculate("5.5 km to miles")  # Returns: "3.42 miles"
await numo.calculate("100 MB to GB")     # Returns: "0.10 GB"

# Language translation
await numo.calculate("Hello world in spanish")  # Returns: "hola mundo"

# Variable management
await numo.calculate([
    "radius = 5",
    "area = pi * radius^2",
    "area"  # Returns: "78.54"
])
```

## 📚 Detailed Examples

### 🧮 Mathematical Functions
```python
# Statistical Analysis
mean(1, 2, 3, 4)     # Returns: 2.50
std(1, 2, 3)         # Returns: 1.00
percentile(75, 1, 2, 3, 4)  # Returns: 3.00

# Vector Mathematics
vector_magnitude(3, 4)         # Returns: 5.00
vector_dot(1, 2, 3, 4)        # Returns: 11.00
vector_angle(1, 0, 0, 1)      # Returns: 90.00

# Financial Calculations
compound_interest(1000, 5, 2)  # Returns: 1102.50
pmt(1000, 5, 12)             # Returns: 85.47

# Advanced Operations
permutation(5, 2)    # Returns: 20.00
combination(5, 2)    # Returns: 10.00
percent_change(100, 150)  # Returns: 50.00
```

### 📏 Unit Conversions
```python
# Length & Distance
"5.5 meters to feet"      # Returns: 18.04 feet
"1 mile to kilometers"    # Returns: 1.61 kilometers
"100 yards to meters"     # Returns: 91.44 meters

# Weight & Mass
"150 pounds to kg"        # Returns: 68.04 kg
"1000 grams to ounces"    # Returns: 35.27 ounces
"2 tons to kilograms"     # Returns: 1814.37 kilograms

# Digital Storage
"1.5 GB to MB"           # Returns: 1536.00 MB
"1 TiB to GiB"           # Returns: 1024.00 GiB
"500 MB to bytes"        # Returns: 524288000 bytes

# Data Transfer Rates
"100 Mbps to Gbps"       # Returns: 0.10 Gbps
"1 GBps to Mbps"         # Returns: 8192.00 Mbps

# Scientific Units
"1 bar to psi"           # Returns: 14.50 psi
"760 mmHg to atm"        # Returns: 1.00 atm
"100 hp to kW"           # Returns: 74.57 kW
```

## 🤝 Contributing

We love your input! We want to make contributing to Numo as easy and transparent as possible, whether it's:

- Reporting a bug
- Discussing the current state of the code
- Submitting a fix
- Proposing new features
- Becoming a maintainer

### Development Process

1. Fork the repo and create your branch from `main`
2. Add tests if you've added code that should be tested
3. Update documentation if you've changed APIs
4. Ensure the test suite passes
5. Make sure your code follows the style guidelines
6. Issue your pull request!

## 📝 License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

## 🌟 Show Your Support

If you find Numo helpful, please consider giving us a star on GitHub! It helps us know that you find the project useful and encourages further development.

## 📬 Contact

Have questions? Feel free to [open an issue](https://github.com/furkancosgun/numo/issues)!

---

<p align="center">
Made with ❤️ by Furkan Cosgun
</p>




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/furkancosgun/numo",
    "name": "numo",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": null,
    "author": "Furkan Co\u015fgun",
    "author_email": "furkan51cosgun@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/39/c1/4fae7d3aa59e8b83325cb30246835cc741607a9770abd9b6089113539a16/numo-0.2.5.tar.gz",
    "platform": null,
    "description": "# \ud83d\udd22 Numo: Your Smart Mathematical Companion\n\n[![PyPI version](https://badge.fury.io/py/numo.svg)](https://badge.fury.io/py/numo)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n[![Python 3.8+](https://img.shields.io/badge/python-3.8+-blue.svg)](https://www.python.org/downloads/)\n\n> \ud83d\ude80 Numo is a powerful text-based calculator and unit converter that brings mathematics to life through natural language processing. Whether you're a student, developer, or data scientist, Numo makes complex calculations feel natural and intuitive.\n\n## \u2728 Key Features\n\n### \ud83e\uddee Mathematical Functions\n- **Basic Operations**\n  - Arithmetic operations (`+`, `-`, `*`, `/`, `^`)\n  - Parentheses support for complex expressions\n  - Automatic decimal precision handling\n\n- **Advanced Mathematics**\n  - Trigonometric functions (`sin`, `cos`, `tan`, etc.)\n  - Logarithmic functions (`log`, `log10`, `exp`)\n  - Root calculations (`sqrt`, `cbrt`)\n\n- **Statistical Analysis**\n  - Basic statistics (`mean`, `median`, `mode`)\n  - Variance and standard deviation\n  - Quartiles and percentiles\n\n- **Vector Operations**\n  - Vector magnitude calculation\n  - Dot product computation\n  - Angle between vectors\n\n- **Financial Tools**\n  - Compound interest calculator\n  - Simple interest calculator\n  - Payment (PMT) calculator\n\n- **Advanced Features**\n  - Combinatorics (`permutation`, `combination`)\n  - Percentage calculations\n  - Custom rounding functions\n\n### \ud83d\udccf Unit Conversions\n- **Physical Measurements**\n  - Length (meters, feet, miles, etc.)\n  - Weight (kilograms, pounds, etc.)\n  - Volume (liters, gallons, etc.)\n  - Area (square meters, acres, etc.)\n\n- **Time & Speed**\n  - Time units (seconds to years)\n  - Speed conversions (km/h, mph, etc.)\n  - Angular measurements (degrees, radians)\n\n- **Digital Units**\n  - Storage (bytes to yottabytes)\n  - Data rates (bps to TBps)\n  - Both decimal (MB) and binary (MiB) units\n\n- **Scientific Units**\n  - Pressure (pascal, bar, psi, etc.)\n  - Electrical (volt, ampere, watt, etc.)\n  - Power (horsepower, kilowatt, etc.)\n\n- **Display Units**\n  - Screen measurements (px, pt, em)\n  - Resolution (dpi, ppi)\n  - Typography units (pica)\n\n### \ud83c\udf0d Language Translation\n- **Comprehensive Support**\n  - 100+ languages supported\n  - Natural language processing\n  - Automatic language detection\n\n- **Easy Syntax**\n  - Simple format: \"text in language\"\n  - Supports full sentences\n  - Maintains formatting\n\n### \ud83d\udcbe Variable Management\n- **Smart Storage**\n  - Dynamic variable assignment\n  - Expression evaluation\n  - Persistent storage between sessions\n\n- **Advanced Features**\n  - Complex expression support\n  - Mathematical constants (`pi`, `e`, etc.)\n  - Function results storage\n\n## \ud83d\ude80 Quick Start\n\n### Installation\n\n```bash\n# Clone the repository\ngit clone https://github.com/furkancosgun/numo.git\ncd numo\n\n# Create and activate virtual environment\npython -m venv .venv\nsource .venv/bin/activate  # On Windows: .venv\\Scripts\\activate\n\n# Install dependencies\npip install -r requirements.txt\n```\n\n### Basic Usage\n\n```python\nfrom numo import Numo\n\n# Initialize Numo\nnumo = Numo()\n\n# Mathematical calculations\nawait numo.calculate(\"2 * (3 + 4)\")  # Returns: \"14.00\"\nawait numo.calculate(\"sin(pi/2)\")    # Returns: \"1.00\"\n\n# Unit conversions\nawait numo.calculate(\"5.5 km to miles\")  # Returns: \"3.42 miles\"\nawait numo.calculate(\"100 MB to GB\")     # Returns: \"0.10 GB\"\n\n# Language translation\nawait numo.calculate(\"Hello world in spanish\")  # Returns: \"hola mundo\"\n\n# Variable management\nawait numo.calculate([\n    \"radius = 5\",\n    \"area = pi * radius^2\",\n    \"area\"  # Returns: \"78.54\"\n])\n```\n\n## \ud83d\udcda Detailed Examples\n\n### \ud83e\uddee Mathematical Functions\n```python\n# Statistical Analysis\nmean(1, 2, 3, 4)     # Returns: 2.50\nstd(1, 2, 3)         # Returns: 1.00\npercentile(75, 1, 2, 3, 4)  # Returns: 3.00\n\n# Vector Mathematics\nvector_magnitude(3, 4)         # Returns: 5.00\nvector_dot(1, 2, 3, 4)        # Returns: 11.00\nvector_angle(1, 0, 0, 1)      # Returns: 90.00\n\n# Financial Calculations\ncompound_interest(1000, 5, 2)  # Returns: 1102.50\npmt(1000, 5, 12)             # Returns: 85.47\n\n# Advanced Operations\npermutation(5, 2)    # Returns: 20.00\ncombination(5, 2)    # Returns: 10.00\npercent_change(100, 150)  # Returns: 50.00\n```\n\n### \ud83d\udccf Unit Conversions\n```python\n# Length & Distance\n\"5.5 meters to feet\"      # Returns: 18.04 feet\n\"1 mile to kilometers\"    # Returns: 1.61 kilometers\n\"100 yards to meters\"     # Returns: 91.44 meters\n\n# Weight & Mass\n\"150 pounds to kg\"        # Returns: 68.04 kg\n\"1000 grams to ounces\"    # Returns: 35.27 ounces\n\"2 tons to kilograms\"     # Returns: 1814.37 kilograms\n\n# Digital Storage\n\"1.5 GB to MB\"           # Returns: 1536.00 MB\n\"1 TiB to GiB\"           # Returns: 1024.00 GiB\n\"500 MB to bytes\"        # Returns: 524288000 bytes\n\n# Data Transfer Rates\n\"100 Mbps to Gbps\"       # Returns: 0.10 Gbps\n\"1 GBps to Mbps\"         # Returns: 8192.00 Mbps\n\n# Scientific Units\n\"1 bar to psi\"           # Returns: 14.50 psi\n\"760 mmHg to atm\"        # Returns: 1.00 atm\n\"100 hp to kW\"           # Returns: 74.57 kW\n```\n\n## \ud83e\udd1d Contributing\n\nWe love your input! We want to make contributing to Numo as easy and transparent as possible, whether it's:\n\n- Reporting a bug\n- Discussing the current state of the code\n- Submitting a fix\n- Proposing new features\n- Becoming a maintainer\n\n### Development Process\n\n1. Fork the repo and create your branch from `main`\n2. Add tests if you've added code that should be tested\n3. Update documentation if you've changed APIs\n4. Ensure the test suite passes\n5. Make sure your code follows the style guidelines\n6. Issue your pull request!\n\n## \ud83d\udcdd License\n\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.\n\n## \ud83c\udf1f Show Your Support\n\nIf you find Numo helpful, please consider giving us a star on GitHub! It helps us know that you find the project useful and encourages further development.\n\n## \ud83d\udcec Contact\n\nHave questions? Feel free to [open an issue](https://github.com/furkancosgun/numo/issues)!\n\n---\n\n<p align=\"center\">\nMade with \u2764\ufe0f by Furkan Cosgun\n</p>\n\n\n\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "A Python library for mathematical operations, unit conversions, currency conversions, and translations",
    "version": "0.2.5",
    "project_urls": {
        "Homepage": "https://github.com/furkancosgun/numo"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e1125d2cb8eb908fb17af12cb03de7e9c20f09abcc97b4f49558d6f73f475705",
                "md5": "d4c1188a696af1296534800316bb171e",
                "sha256": "923929302e5a0c8f016285645937de2de84798b29ee64cbf1091af14c5c41a45"
            },
            "downloads": -1,
            "filename": "numo-0.2.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "d4c1188a696af1296534800316bb171e",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 31293,
            "upload_time": "2024-12-26T18:31:30",
            "upload_time_iso_8601": "2024-12-26T18:31:30.436459Z",
            "url": "https://files.pythonhosted.org/packages/e1/12/5d2cb8eb908fb17af12cb03de7e9c20f09abcc97b4f49558d6f73f475705/numo-0.2.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "39c14fae7d3aa59e8b83325cb30246835cc741607a9770abd9b6089113539a16",
                "md5": "98bc75ab8da20bb0ffb060bc354a8275",
                "sha256": "d610b3c99d8b15bd720b788276db995eb2ef5b7b6efec27964ded76fd3e1c175"
            },
            "downloads": -1,
            "filename": "numo-0.2.5.tar.gz",
            "has_sig": false,
            "md5_digest": "98bc75ab8da20bb0ffb060bc354a8275",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 25237,
            "upload_time": "2024-12-26T18:31:31",
            "upload_time_iso_8601": "2024-12-26T18:31:31.724009Z",
            "url": "https://files.pythonhosted.org/packages/39/c1/4fae7d3aa59e8b83325cb30246835cc741607a9770abd9b6089113539a16/numo-0.2.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-26 18:31:31",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "furkancosgun",
    "github_project": "numo",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "aiohttp",
            "specs": [
                [
                    ">=",
                    "3.8.0"
                ]
            ]
        }
    ],
    "lcname": "numo"
}
        
Elapsed time: 0.37117s