Composite Unit Measurements

A collection of specialized parsers designed for handling composite measurements.

V. Ladhe, Master of Computer Science.[https://shivam091.github.io]

Introduction

The composite_unit_measurements gem offers versatile parsers for efficiently parsing composite measurements. Leveraging the power of the [unit_measurements] (github.com/shivam091/unit_measurements) gem, it enables smooth handling of composite measurements in various units.

Minimum Requirements

Installation

To use composite_unit_measurements in your Rails application, add the following line to your Gemfile:

gem "composite_unit_measurements"

And then execute:

$ bundle install

Or otherwise simply install it yourself as:

$ gem install composite_unit_measurements

Usage

Each packaged parser includes the .parse method to parse composite measurements. You can use an appropriate parser to parse measurements and the final result of parser is returned in the leftmost unit of your measurement.

The result of each parser method returns an instance of measurement on which we can perform any functionality offered by unit_measurements.

This gem internally uses unit_measurements to perform conversions and arithmetic operations. You can build supported composite measurements using any unit alias.

Examples

Parsing length measurements:

CompositeUnitMeasurements::Length.parse("5 km 500 m") #=> 5.5 km

Parsing weight measurements:

CompositeUnitMeasurements::Weight.parse("4 kg 500 g") # 4.5 kg

Parsing time measurements:

CompositeUnitMeasurements::Time.parse("3 h 45 min") #=> 3.75 hr

Parsing volume measurements:

CompositeUnitMeasurements::Volume.parse("2 l 250 ml") #=> 2.25 l

Support for numeric types

Each parser can handle various numeric types, including scientific notation, rational numbers, and complex numbers.

CompositeUnitMeasurements::Length.parse("1+2i ft 12 in")    #=> 2.0+2.0i ft
CompositeUnitMeasurements::Length.parse("1.5 ft 12e2 in")   #=> 101.5 ft
CompositeUnitMeasurements::Length.parse("1 1/2 ft 1+2i in") #=> 1.5833333333333333+0.16666666666666669i ft
CompositeUnitMeasurements::Length.parse("2 ft 1+2i in")     #=> 2.0833333333333335+0.16666666666666669i ft
CompositeUnitMeasurements::Length.parse("1e-2 ft 1+2i in")  #=> 0.09333333333333334+0.16666666666666669i ft

Packaged parsers & supported composite measurements

The composite_unit_measurements gem supports parsing various composite measurements, including:

1. CompositeUnitMeasurements::Length - metre-centimetre (6 m 50 cm) - kilometre-metre (5 km 500 m) - foot-inch (5 ft 6 in) - mile-yard (20 mi 220 yd)

2. CompositeUnitMeasurements::Weight - kilogramme-gramme (4 kg 500 g) - pound-ounce (8 lb 12 oz) - stone-pound (2 st 6 lb) - tonne-kilogramme (1 t 500 kg)

3. CompositeUnitMeasurements::Time - hour-minute (3 h 45 min) - hour-minute-second-microsecond (12:60,3600:360000000) - minute-second (10 min 90 s) - week-day (8 wk 3 d) - month-day (2 mo 60 d) - second-millisecond (8 s 500 ms) - year-month (3 yr 4 mo)

4. CompositeUnitMeasurements::Volume - litre-millilitre (2 l 250 ml)

Specifing parsers

By default, composite_unit_measurements includes all packaged parsers automatically when required in your application. However, you can opt to use specific parsers as needed:

require "composite_unit_measurements/base"

require "composite_unit_measurements/length"
require "composite_unit_measurements/weight"

Contributing

Contributions to this project are welcomed! To contribute:

  1. Fork this repository

  2. Create a new branch (git checkout -b my-new-feature)

  3. Commit your changes (git commit -am "Add some feature")

  4. Push the changes to your branch (git push origin my-new-feature)

  5. Create new Pull Request

License

Copyright 2023 Harshal V. LADHE, Released under the MIT License.