mirror of
https://github.com/gonum/gonum.git
synced 2025-10-27 17:21:18 +08:00
Moved unit types to different files
This commit is contained in:
59
dimless.go
Normal file
59
dimless.go
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Dimless represents a dimensionless constant
|
||||||
|
type Dimless float64
|
||||||
|
|
||||||
|
const (
|
||||||
|
One Dimless = 1.0
|
||||||
|
)
|
||||||
|
|
||||||
|
// Unit converts the Dimless to a unit
|
||||||
|
func (d Dimless) Unit() *Unit {
|
||||||
|
return New(float64(d), Dimensions{})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Dimless allows Dimless to implement a Dimlesser interface
|
||||||
|
func (d Dimless) Dimless() Dimless {
|
||||||
|
return d
|
||||||
|
}
|
||||||
|
|
||||||
|
// From converts the unit to a dimless. Returns an error if there
|
||||||
|
// is a mismatch in dimension
|
||||||
|
func (d *Dimless) From(u *Unit) error {
|
||||||
|
if !DimensionsMatch(u, One) {
|
||||||
|
(*d) = Dimless(math.NaN())
|
||||||
|
return errors.New("Dimension mismatch")
|
||||||
|
}
|
||||||
|
(*d) = Dimless(u.Unit().Value())
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d Dimless) Format(fs fmt.State, c rune) {
|
||||||
|
switch c {
|
||||||
|
case 'v':
|
||||||
|
if fs.Flag('#') {
|
||||||
|
fmt.Fprintf(fs, "%T(%v)", d, float64(d))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fallthrough
|
||||||
|
case 'e', 'E', 'f', 'F', 'g', 'G':
|
||||||
|
p, pOk := fs.Precision()
|
||||||
|
if !pOk {
|
||||||
|
p = -1
|
||||||
|
}
|
||||||
|
w, wOk := fs.Width()
|
||||||
|
if !wOk {
|
||||||
|
w = -1
|
||||||
|
}
|
||||||
|
fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(d))
|
||||||
|
default:
|
||||||
|
fmt.Fprintf(fs, "%%!%c(%T=%g)", c, d, float64(d))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
61
length.go
Normal file
61
length.go
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Length represents a length in meters
|
||||||
|
type Length float64
|
||||||
|
|
||||||
|
const (
|
||||||
|
Meter Length = 1.0
|
||||||
|
Centimeter Length = 0.01
|
||||||
|
)
|
||||||
|
|
||||||
|
// Unit converts the Length to a unit
|
||||||
|
func (l Length) Unit() *Unit {
|
||||||
|
return New(float64(l), Dimensions{MassDim: 1})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Length allows length to implement a Lengther interface
|
||||||
|
func (l Length) Length() Length {
|
||||||
|
return l
|
||||||
|
}
|
||||||
|
|
||||||
|
// From converts a uniter to a length. Returns an error if there
|
||||||
|
// is a mismatch in dimension
|
||||||
|
func (l *Length) From(u Uniter) error {
|
||||||
|
if !DimensionsMatch(u, Meter) {
|
||||||
|
(*l) = Length(math.NaN())
|
||||||
|
return errors.New("Dimension mismatch")
|
||||||
|
}
|
||||||
|
(*l) = Length(u.Unit().Value())
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (l Length) Format(fs fmt.State, c rune) {
|
||||||
|
switch c {
|
||||||
|
case 'v':
|
||||||
|
if fs.Flag('#') {
|
||||||
|
fmt.Fprintf(fs, "%T(%v)", l, float64(l))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fallthrough
|
||||||
|
case 'e', 'E', 'f', 'F', 'g', 'G':
|
||||||
|
p, pOk := fs.Precision()
|
||||||
|
if !pOk {
|
||||||
|
p = -1
|
||||||
|
}
|
||||||
|
w, wOk := fs.Width()
|
||||||
|
if !wOk {
|
||||||
|
w = -1
|
||||||
|
}
|
||||||
|
fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(l))
|
||||||
|
fmt.Fprint(fs, " m")
|
||||||
|
default:
|
||||||
|
fmt.Fprintf(fs, "%%!%c(%T=%g m)", c, l, float64(l))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
70
mass.go
Normal file
70
mass.go
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
package unit
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Represents a mass in kilograms
|
||||||
|
type Mass float64
|
||||||
|
|
||||||
|
const (
|
||||||
|
Yottagram Mass = 1e12
|
||||||
|
Zettagram Mass = 1e18
|
||||||
|
Exagram Mass = 1e15
|
||||||
|
Petagram Mass = 1e12
|
||||||
|
Teragram Mass = 1e9
|
||||||
|
Gigagram Mass = 1e6
|
||||||
|
Megagram Mass = 1e3
|
||||||
|
Kilogram Mass = 1.0
|
||||||
|
Gram Mass = 1e-3
|
||||||
|
Milligram Mass = 1e-6
|
||||||
|
Microgram Mass = 1e-9
|
||||||
|
)
|
||||||
|
|
||||||
|
// Mass converts the Mass to a unit
|
||||||
|
func (m Mass) Unit() *Unit {
|
||||||
|
return New(float64(m), Dimensions{MassDim: 1})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mass allows Mass to implement a Masser interface
|
||||||
|
func (m Mass) Mass() Mass {
|
||||||
|
return m
|
||||||
|
}
|
||||||
|
|
||||||
|
// From converts the unit to a mass. Returns an error if there
|
||||||
|
// is a mismatch in dimension
|
||||||
|
func (m *Mass) From(u Uniter) error {
|
||||||
|
if !DimensionsMatch(u, Kilogram) {
|
||||||
|
(*m) = Mass(math.NaN())
|
||||||
|
return errors.New("Dimension mismatch")
|
||||||
|
}
|
||||||
|
(*m) = Mass(u.Unit().Value())
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m Mass) Format(fs fmt.State, c rune) {
|
||||||
|
switch c {
|
||||||
|
case 'v':
|
||||||
|
if fs.Flag('#') {
|
||||||
|
fmt.Fprintf(fs, "%T(%v)", m, float64(m))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fallthrough
|
||||||
|
case 'e', 'E', 'f', 'F', 'g', 'G':
|
||||||
|
p, pOk := fs.Precision()
|
||||||
|
if !pOk {
|
||||||
|
p = -1
|
||||||
|
}
|
||||||
|
w, wOk := fs.Width()
|
||||||
|
if !wOk {
|
||||||
|
w = -1
|
||||||
|
}
|
||||||
|
fmt.Fprintf(fs, "%*.*"+string(c), w, p, float64(m))
|
||||||
|
fmt.Fprint(fs, " kg")
|
||||||
|
default:
|
||||||
|
fmt.Fprintf(fs, "%%!%c(%T=%g kg)", c, m, float64(m))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user