Physics::Unit::Scalar::Implementation - This page discusses implementation issues of the Physics/Unit/Scalar.pm module.
Classes and objects derived from Physics::Unit::Scalar follow these rules:
This is called during compilation, and creates classes for each of the unit types defined in Physics::Unit.
Returns a reference to the Unit object that is used to define the quantity.
$arg can either be a class name or an object that derives from Physics::Unit::Scalar.
Get the class' MyUnit.
Get the class' DefaultUnit.
This takes an unblessed reference to a hash as an argument. The hash should have a value member and a MyUnit member.
This determines the proper type of Scalar that the object should be (based on MyUnit's type), 'normalizes' the Scalar, blesses it into the proper subtype, and returns it.
This is used by ScalarFactory and several of the arithmetic functions (whenever the arithmetic function actually changes the dimensionality of the unit, and thus the type of scalar).