-
Notifications
You must be signed in to change notification settings - Fork 0
/
input.go
137 lines (113 loc) · 2.51 KB
/
input.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
package RefET
import "strings"
type Input struct {
Value interface{}
Units string
}
// convertTemp is a method on the input to convert the temperature from Feherheit to Celsius
func (i Input) convertTemp() (v float64, err error) {
iU := strings.ToLower(i.Units)
if iU[0] == 'f' {
v, err = FToC(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
v, err = MakeFloat(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertRS is an input method to convert short wave radiation from langleys or watts to megajoules per day
func (i Input) convertRS() (v float64, err error) {
iU := strings.ToLower(i.Units)
if iU[0] == 'l' {
// langleys
v, err = LangToMJ(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
} else if iU[0] == 'w' {
// w/m-2
v, err = WattToMJ(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
v, err = MakeFloat(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertWS is an input method to convert wind speed from miles per hour into meters per second
func (i Input) convertWS() (v float64, err error) {
iU := strings.ToLower(i.Units)
if iU == "mph" {
// miles per hour
v, err = MphToMS(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
v, err = MakeFloat(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertWZ is an input method to convert windspeed height from feet into meters
func (i Input) convertWZ() (v float64, err error) {
iU := strings.ToLower(i.Units)
if iU[0] == 'f' {
// feet
v, err = FeetToMeters(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
v, err = MakeFloat(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertZ is an input method to convert elevation from feet into meters
func (i Input) convertZ() (v float64, err error) {
iU := strings.ToLower(i.Units)
if iU[0] == 'f' {
// feet
v, err = FeetToMeters(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
v, err = MakeFloat(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertLat is a method that converts the latitude from degrees into radians
func (i Input) convertLat() (v float64, err error) {
v, err = DegreesToRad(i.Value)
if err != nil {
return 0.0, err
}
return v, nil
}
// convertDate is a method that converts the date in format ("07-01-2000") into a day of the year
func (i Input) convertDate() (v int, err error) {
v, err = DateToDOY(i.Value)
if err != nil {
return 0, err
}
return v, nil
}