/
radioactivity.go
70 lines (61 loc) · 1.72 KB
/
radioactivity.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// 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"
)
// Radioactivity represents a rate of radioactive decay in becquerels.
type Radioactivity float64
const Becquerel Radioactivity = 1
// Unit converts the Radioactivity to a *Unit
func (r Radioactivity) Unit() *Unit {
return New(float64(r), Dimensions{
TimeDim: -1,
})
}
// Radioactivity allows Radioactivity to implement a Radioactivityer interface
func (r Radioactivity) Radioactivity() Radioactivity {
return r
}
// From converts the unit into the receiver. From returns an
// error if there is a mismatch in dimension
func (r *Radioactivity) From(u Uniter) error {
if !DimensionsMatch(u, Becquerel) {
*r = Radioactivity(math.NaN())
return errors.New("Dimension mismatch")
}
*r = Radioactivity(u.Unit().Value())
return nil
}
func (r Radioactivity) Format(fs fmt.State, c rune) {
switch c {
case 'v':
if fs.Flag('#') {
fmt.Fprintf(fs, "%T(%v)", r, float64(r))
return
}
fallthrough
case 'e', 'E', 'f', 'F', 'g', 'G':
p, pOk := fs.Precision()
w, wOk := fs.Width()
const unit = " Bq"
switch {
case pOk && wOk:
fmt.Fprintf(fs, "%*.*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), p, float64(r))
case pOk:
fmt.Fprintf(fs, "%.*"+string(c), p, float64(r))
case wOk:
fmt.Fprintf(fs, "%*"+string(c), pos(w-utf8.RuneCount([]byte(unit))), float64(r))
default:
fmt.Fprintf(fs, "%"+string(c), float64(r))
}
fmt.Fprint(fs, unit)
default:
fmt.Fprintf(fs, "%%!%c(%T=%g Bq)", c, r, float64(r))
}
}