Files
gonum/unit/equivalentradioactivedose.go
2019-03-11 10:32:40 +10:30

94 lines
2.9 KiB
Go

// Code generated by "go generate gonum.org/v1/gonum/unit”; DO NOT EDIT.
// Copyright ©2014 The Gonum Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package unit
import (
"errors"
"fmt"
"math"
"unicode/utf8"
)
// EquivalentRadioactiveDose is a measure of equivalent dose of ionizing radiation in sieverts.
type EquivalentRadioactiveDose float64
const (
Yottasievert EquivalentRadioactiveDose = 1e24
Zettasievert EquivalentRadioactiveDose = 1e21
Exasievert EquivalentRadioactiveDose = 1e18
Petasievert EquivalentRadioactiveDose = 1e15
Terasievert EquivalentRadioactiveDose = 1e12
Gigasievert EquivalentRadioactiveDose = 1e9
Megasievert EquivalentRadioactiveDose = 1e6
Kilosievert EquivalentRadioactiveDose = 1e3
Hectosievert EquivalentRadioactiveDose = 1e2
Decasievert EquivalentRadioactiveDose = 1e1
Sievert EquivalentRadioactiveDose = 1.0
Decisievert EquivalentRadioactiveDose = 1e-1
Centisievert EquivalentRadioactiveDose = 1e-2
Millisievert EquivalentRadioactiveDose = 1e-3
Microsievert EquivalentRadioactiveDose = 1e-6
Nanosievert EquivalentRadioactiveDose = 1e-9
Picosievert EquivalentRadioactiveDose = 1e-12
Femtosievert EquivalentRadioactiveDose = 1e-15
Attosievert EquivalentRadioactiveDose = 1e-18
Zeptosievert EquivalentRadioactiveDose = 1e-21
Yoctosievert EquivalentRadioactiveDose = 1e-24
)
// Unit converts the EquivalentRadioactiveDose to a *Unit
func (a EquivalentRadioactiveDose) Unit() *Unit {
return New(float64(a), Dimensions{
LengthDim: 2,
TimeDim: -2,
})
}
// EquivalentRadioactiveDose allows EquivalentRadioactiveDose to implement a EquivalentRadioactiveDoseer interface
func (a EquivalentRadioactiveDose) EquivalentRadioactiveDose() EquivalentRadioactiveDose {
return a
}
// From converts the unit into the receiver. From returns an
// error if there is a mismatch in dimension
func (a *EquivalentRadioactiveDose) From(u Uniter) error {
if !DimensionsMatch(u, Sievert) {
*a = EquivalentRadioactiveDose(math.NaN())
return errors.New("Dimension mismatch")
}
*a = EquivalentRadioactiveDose(u.Unit().Value())
return nil
}
func (a EquivalentRadioactiveDose) Format(fs fmt.State, c rune) {
switch c {
case 'v':
if fs.Flag('#') {
fmt.Fprintf(fs, "%T(%v)", a, float64(a))
return
}
fallthrough
case 'e', 'E', 'f', 'F', 'g', 'G':
p, pOk := fs.Precision()
w, wOk := fs.Width()
const unit = " Sy"
switch {
case pOk && wOk:
fmt.Fprintf(fs, "%*.*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), p, float64(a))
case pOk:
fmt.Fprintf(fs, "%.*"+string(c), p, float64(a))
case wOk:
fmt.Fprintf(fs, "%*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), float64(a))
default:
fmt.Fprintf(fs, "%"+string(c), float64(a))
}
fmt.Fprint(fs, unit)
default:
fmt.Fprintf(fs, "%%!%c(%T=%g Sy)", c, a, float64(a))
}
}