mirror of
https://github.com/gonum/gonum.git
synced 2025-10-27 01:00:26 +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