github.com/gopherd/gonum@v0.0.4/unit/absorbedradioactivedose.go (about) 1 // Code generated by "go generate github.com/gopherd/gonum/unit”; DO NOT EDIT. 2 3 // Copyright ©2014 The Gonum Authors. All rights reserved. 4 // Use of this source code is governed by a BSD-style 5 // license that can be found in the LICENSE file. 6 7 package unit 8 9 import ( 10 "errors" 11 "fmt" 12 "math" 13 "unicode/utf8" 14 ) 15 16 // AbsorbedRadioactiveDose is a measure of absorbed dose of ionizing radiation in grays. 17 type AbsorbedRadioactiveDose float64 18 19 const Gray AbsorbedRadioactiveDose = 1 20 21 // Unit converts the AbsorbedRadioactiveDose to a *Unit. 22 func (a AbsorbedRadioactiveDose) Unit() *Unit { 23 return New(float64(a), Dimensions{ 24 LengthDim: 2, 25 TimeDim: -2, 26 }) 27 } 28 29 // AbsorbedRadioactiveDose allows AbsorbedRadioactiveDose to implement a AbsorbedRadioactiveDoseer interface. 30 func (a AbsorbedRadioactiveDose) AbsorbedRadioactiveDose() AbsorbedRadioactiveDose { 31 return a 32 } 33 34 // From converts the unit into the receiver. From returns an 35 // error if there is a mismatch in dimension. 36 func (a *AbsorbedRadioactiveDose) From(u Uniter) error { 37 if !DimensionsMatch(u, Gray) { 38 *a = AbsorbedRadioactiveDose(math.NaN()) 39 return errors.New("unit: dimension mismatch") 40 } 41 *a = AbsorbedRadioactiveDose(u.Unit().Value()) 42 return nil 43 } 44 45 func (a AbsorbedRadioactiveDose) Format(fs fmt.State, c rune) { 46 switch c { 47 case 'v': 48 if fs.Flag('#') { 49 fmt.Fprintf(fs, "%T(%v)", a, float64(a)) 50 return 51 } 52 fallthrough 53 case 'e', 'E', 'f', 'F', 'g', 'G': 54 p, pOk := fs.Precision() 55 w, wOk := fs.Width() 56 const unit = " Gy" 57 switch { 58 case pOk && wOk: 59 fmt.Fprintf(fs, "%*.*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), p, float64(a)) 60 case pOk: 61 fmt.Fprintf(fs, "%.*"+string(c), p, float64(a)) 62 case wOk: 63 fmt.Fprintf(fs, "%*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), float64(a)) 64 default: 65 fmt.Fprintf(fs, "%"+string(c), float64(a)) 66 } 67 fmt.Fprint(fs, unit) 68 default: 69 fmt.Fprintf(fs, "%%!%c(%T=%g Gy)", c, a, float64(a)) 70 } 71 }