vesper / unit-conversion
This package provides a powerful and flexible way to handle unit conversion in PHP. It supports parsing units from strings, performing conversions, and working with both simple and compound units.
Requires
- php: ^8.3
- illuminate/support: >=11.0 <13.0
Requires (Dev)
- phpunit/phpunit: ^11
This package is auto-updated.
Last update: 2025-05-17 15:26:28 UTC
README
Introduction
This package provides a powerful and flexible way to handle unit conversion in PHP. It supports parsing units from strings, performing conversions, and working with both simple and compound units.
Supported Conversions
Our library supports a wide range of unit conversions, covering both fundamental and derived physical quantities.
- π Length (Distance)
- π Area
- βοΈ Mass
- β³ Time
- π‘ Temperature
- β‘ Energy
- π₯ Power
- π Pressure
- π‘ Frequency
- ποΈ Force
- π Luminous Intensity
- π§ͺ Amount of Substance
- π₯€ Volume
Why Use This Library?
- Simple string-based unit parsing
- Supports SI prefixes and derived units
- Handles compound unit conversions (e.g., speed, density, force)
- Extendable - Easily add new units and dimensions
- Integration with Laravel
Installation
Install via Composer:
composer require vesper/unit-conversion
Usage
Parsing a Unit
use Vesper\UnitConversion\Parser; use Vesper\UnitConversion\Registry; $registry = new Registry(); $parser = new Parser($registry); $unit = $parser->parse('m/s'); // Returns an instance of Unit
Regular Conversion
use Vesper\UnitConversion\Converter; $converter = new Converter(); $cm = $parser->parse('cm'); $m = $parser->parse('m'); $result = $converter->convert($cm, $m, 100); // Converts 100cm to 1m
Compound Unit Conversion
$ms = $parser->parse('m/s'); $kmh = $parser->parse('km/h'); $result = $converter->convert($ms, $kmh, 10); // Converts 10m/s to 36km/h
Creating and Adding Custom Units
The RegistryBuilder
class provides a set of predefined units and allows for easy extension.
Using RegistryBuilder::build()
The build()
method initializes a Registry
instance with common units like length, mass, time, temperature, force, etc.
use Vesper\UnitConversion\Registry; use Vesper\UnitConversion\RegistryBuilder; $registry = new Registry(); RegistryBuilder::build($registry);
This method ensures that a wide range of units are available for use immediately.
Registering a Custom Unit
The register()
method is used to add new units to the registry, and alias()
allows you to specify alternative names.
use Vesper\UnitConversion\Registry; use Vesper\UnitConversion\Unit; use Vesper\UnitConversion\Dimension; use Vesper\UnitConversion\UnitPart; $registry = new Registry(); $registry->register( 'furlong', new Unit(new UnitPart(201.168, Dimension::LENGTH, 1) // 1 furlong = 201.168 meter ); $registry->alias('furlong', ['fur']);
Using registerSiUnit()
The registerSiUnit()
method allows you to define SI units along with their prefixed versions (e.g., kilogram, milligram, etc.).
use Vesper\UnitConversion\RegistryBuilder; use Vesper\UnitConversion\Unit; use Vesper\UnitConversion\UnitPart; use Vesper\UnitConversion\Dimension; RegistryBuilder::registerSiUnit( $registry, 'gram', // Base unit ['g'], // Aliases new Unit(new UnitPart(0.001, Dimension::MASS, 1)) // 1 gram = 0.001 kilogram );
This automatically registers gram
and generates prefixed versions like kilogram (kg)
, milligram (mg)
, etc.
Using in Laravel
This package provides a service provider, ConversionServiceProvider
, which is auto-discovered by Laravel. This means you donβt need to manually register it.
ConversionServiceProvider
include Converter
, Parser
and Registry
classes.
Additionally, a facade Converter
is provided for easy access.
Example Usage
use Vesper\UnitConversion\Converter; use Vesper\UnitConversion\Parser; class UnitController { public function __construct( protected Converter $converter, protected Parser $parser ) {} public function convert() { $from = $this->parser->parse('kg'); $to = $this->parser->parse('g'); $value = 5; return $this->converter->convert($from, $to, $value); // Converts 5kg to 5000g } }
License
This package is open-source and available under the MIT License. See the LICENSE file for more details.