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
|
package compressor
import (
"github.com/BurntSushi/toml"
"io/fs"
fp "path/filepath"
"strings"
"github.com/sam-anthony/volute/mass"
"github.com/sam-anthony/volute/util"
)
const root = "compressor/res/"
type Compressor struct {
Name string
FileName string
// MinX is the distance of the y-axis from left of image in pixels.
MinX int
// MinY is the distance of the x-axis from the top of the image in
//pixels.
MinY int
// MaxX is the distance of the end of the graph from the left of the
// image in pixels.
MaxX int
// MaxY is the distance of the top of the graph from the top of the
// image in pixels.
MaxY int
// MaxFlow is the mass flow rate at MaxX.
MaxFlow mass.FlowRate
// MaxPR is the pressure ratio at MaxY.
MaxPR float32
}
// [manufacturer][series][model]
var compressors = make(map[string]map[string]map[string]Compressor)
func init() {
// Walk root, looking for .toml files describing a compressor.
// Parse these toml files, create a Compressor and add it to compressors.
err := fp.WalkDir(root, func(path string, d fs.DirEntry, err error) error {
if err != nil {
return err
}
if fp.Ext(path) != ".toml" {
return nil
}
path = path[len(root):]
// manufacturer/series, model
manSer, mod := fp.Split(path)
manSer = fp.Clean(manSer) // Clean trailing slash
mod = mod[:len(mod)-len(".toml")] // Trim .toml extension
// manufacturer, series
man, ser := fp.Split(manSer)
man = fp.Clean(man) // Clean trailing slash
if _, ok := compressors[man]; !ok { // Manufacturer does NOT exist
compressors[man] = make(map[string]map[string]Compressor)
}
if _, ok := compressors[man][ser]; !ok { // Series does NOT exist
compressors[man][ser] = make(map[string]Compressor)
}
tomlFile := fp.Join(root, path)
var c Compressor
if _, err = toml.DecodeFile(tomlFile, &c); err != nil {
return err
}
c.FileName = strings.TrimSuffix(tomlFile, ".toml") + ".jpg"
c.MaxFlow, err = readMaxFlow(tomlFile)
if err != nil {
return err
}
compressors[man][ser][mod] = c
return nil
})
util.Check(err)
}
func Compressors() map[string]map[string]map[string]Compressor {
return compressors
}
func readMaxFlow(tomlFile string) (mass.FlowRate, error) {
flow := struct {
FlowVal float32
FlowUnit string
}{}
if _, err := toml.DecodeFile(tomlFile, &flow); err != nil {
return -1, err
}
unit, err := mass.FlowRateUnitFromString(flow.FlowUnit)
if err != nil {
return -1, err
}
return mass.FlowRate(flow.FlowVal) * unit, nil
}
|