-
Notifications
You must be signed in to change notification settings - Fork 5
/
LineInput.java
231 lines (210 loc) · 7.04 KB
/
LineInput.java
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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
/*
* © 2021. TU Dortmund University,
* Institute of Energy Systems, Energy Efficiency and Energy Economics,
* Research group Distribution grid planning and operation
*/
package edu.ie3.datamodel.models.input.connector;
import edu.ie3.datamodel.io.extractor.HasType;
import edu.ie3.datamodel.models.OperationTime;
import edu.ie3.datamodel.models.StandardUnits;
import edu.ie3.datamodel.models.input.NodeInput;
import edu.ie3.datamodel.models.input.OperatorInput;
import edu.ie3.datamodel.models.input.connector.type.LineTypeInput;
import edu.ie3.datamodel.models.input.system.characteristic.OlmCharacteristicInput;
import edu.ie3.util.geo.GeoUtils;
import java.util.Objects;
import java.util.UUID;
import javax.measure.quantity.Length;
import org.locationtech.jts.geom.LineString;
import tech.units.indriya.ComparableQuantity;
/**
* Describes an electrical grid line that connects two {@link
* edu.ie3.datamodel.models.input.NodeInput}s
*/
public class LineInput extends ConnectorInput implements HasType {
/** Type of this line, containing default values for lines of this kind */
private final LineTypeInput type;
/** Length of this line */
private final ComparableQuantity<Length> length;
/** Coordinates of this line */
private final LineString geoPosition;
/** Description of an optional weather dependent operation curve */
private final OlmCharacteristicInput olmCharacteristic;
/**
* Constructor for an operated line
*
* @param uuid of the input entity
* @param id of the asset
* @param operator of the asset
* @param operationTime Time for which the entity is operated
* @param nodeA Grid node at one side of the line
* @param nodeB Grid node at the other side of the line
* @param parallelDevices overall amount of parallel lines to automatically construct (e.g.
* parallelDevices = 2 will build a total of two lines using the specified parameters)
* @param type of line
* @param length of this line
* @param geoPosition Coordinates of this line
* @param olmCharacteristic Description of an optional weather dependent operation curve
*/
public LineInput(
UUID uuid,
String id,
OperatorInput operator,
OperationTime operationTime,
NodeInput nodeA,
NodeInput nodeB,
int parallelDevices,
LineTypeInput type,
ComparableQuantity<Length> length,
LineString geoPosition,
OlmCharacteristicInput olmCharacteristic) {
super(uuid, id, operator, operationTime, nodeA, nodeB, parallelDevices);
this.type = type;
this.length = length.to(StandardUnits.LINE_LENGTH);
this.geoPosition = GeoUtils.buildSafeLineString(geoPosition);
this.olmCharacteristic = olmCharacteristic;
}
/**
* Constructor for an operated, always on line
*
* @param uuid of the input entity
* @param id of the asset
* @param nodeA Grid node at one side of the line
* @param nodeB Grid node at the other side of the line
* @param parallelDevices overall amount of parallel lines to automatically construct (e.g.
* parallelDevices = 2 will build a total of two lines using the specified parameters)
* @param type of line
* @param length of this line
* @param geoPosition Coordinates of this line
* @param olmCharacteristic Description of an optional weather dependent operation curve
*/
public LineInput(
UUID uuid,
String id,
NodeInput nodeA,
NodeInput nodeB,
int parallelDevices,
LineTypeInput type,
ComparableQuantity<Length> length,
LineString geoPosition,
OlmCharacteristicInput olmCharacteristic) {
super(uuid, id, nodeA, nodeB, parallelDevices);
this.type = type;
this.length = length.to(StandardUnits.LINE_LENGTH);
this.geoPosition = GeoUtils.buildSafeLineString(geoPosition);
this.olmCharacteristic = olmCharacteristic;
}
@Override
public LineTypeInput getType() {
return type;
}
public ComparableQuantity<Length> getLength() {
return length;
}
public LineString getGeoPosition() {
return geoPosition;
}
public OlmCharacteristicInput getOlmCharacteristic() {
return olmCharacteristic;
}
@Override
public LineInputCopyBuilder copy() {
return new LineInputCopyBuilder(this);
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof LineInput lineInput)) return false;
if (!super.equals(o)) return false;
return type.equals(lineInput.type)
&& length.equals(lineInput.length)
&& geoPosition.equals(lineInput.geoPosition)
&& olmCharacteristic.equals(lineInput.olmCharacteristic);
}
@Override
public int hashCode() {
return Objects.hash(super.hashCode(), type, length, geoPosition, olmCharacteristic);
}
@Override
public String toString() {
return "LineInput{"
+ "uuid="
+ getUuid()
+ ", id="
+ getId()
+ ", operator="
+ getOperator().getUuid()
+ ", operationTime="
+ getOperationTime()
+ ", nodeA="
+ getNodeA().getUuid()
+ ", nodeB="
+ getNodeB().getUuid()
+ ", noOfParallelDevices="
+ getParallelDevices()
+ ", type="
+ type.getUuid()
+ ", length="
+ length
+ ", geoPosition="
+ geoPosition
+ ", olmCharacteristic="
+ olmCharacteristic
+ '}';
}
/**
* A builder pattern based approach to create copies of {@link LineInput} entities with altered
* field values. For detailed field descriptions refer to java docs of {@link LineInput}
*
* @version 0.1
* @since 05.06.20
*/
public static class LineInputCopyBuilder extends ConnectorInputCopyBuilder<LineInputCopyBuilder> {
private LineTypeInput type;
private ComparableQuantity<Length> length;
private LineString geoPosition;
private OlmCharacteristicInput olmCharacteristic;
private LineInputCopyBuilder(LineInput entity) {
super(entity);
this.type = entity.getType();
this.length = entity.getLength();
this.geoPosition = entity.getGeoPosition();
this.olmCharacteristic = entity.getOlmCharacteristic();
}
@Override
public LineInput build() {
return new LineInput(
getUuid(),
getId(),
getOperator(),
getOperationTime(),
getNodeA(),
getNodeB(),
getParallelDevices(),
type,
length,
geoPosition,
olmCharacteristic);
}
public LineInputCopyBuilder geoPosition(LineString geoPosition) {
this.geoPosition = geoPosition;
return this;
}
public LineInputCopyBuilder type(LineTypeInput type) {
this.type = type;
return this;
}
public LineInputCopyBuilder length(ComparableQuantity<Length> length) {
this.length = length;
return this;
}
public LineInputCopyBuilder olmCharacteristic(OlmCharacteristicInput olmCharacteristic) {
this.olmCharacteristic = olmCharacteristic;
return this;
}
@Override
protected LineInputCopyBuilder thisInstance() {
return this;
}
}
}