Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
Simonstrator
API
Commits
7850d53e
Commit
7850d53e
authored
Jul 20, 2017
by
Tobias Meuser
Browse files
Fixed bugs in serialization and added manipulation of edges
parent
e0b6b9a6
Changes
13
Hide whitespace changes
Inline
Side-by-side
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/EdgeController.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api
;
public
interface
EdgeController
{
void
setObservedArea
(
double
pStartX
,
double
pStartY
,
double
pEndX
,
double
pEndY
);
void
init
();
void
setEdgeMaxSpeed
(
String
pEdgeID
,
double
pMaxSpeed
);
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/SimulationSetupExtractor.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api
;
import
java.util.List
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information.Position
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork.RoadNetwork
;
public
interface
SimulationSetupExtractor
{
void
setObservedArea
(
double
pStartX
,
double
pStartY
,
double
pEndX
,
double
pEndY
);
void
init
();
List
<
Position
>
getAllIntersections
(
boolean
pCluster
);
double
getScenarioWidth
();
double
getScenarioHeight
();
RoadNetwork
getRoadNetwork
();
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/VehicleController.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api
;
import
java.util.List
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information.Position
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork.RoadNetworkEdge
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork.RoadNetworkRoute
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork.exception.NoAdditionalRouteAvailableException
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork.exception.NoExitAvailableException
;
public
interface
VehicleController
{
void
setObservedArea
(
double
pStartX
,
double
pStartY
,
double
pEndX
,
double
pEndY
);
Position
getVehiclePosition
(
String
pVehicleID
);
Position
getVehiclePosition
(
double
pStep
,
String
pVehicleID
);
boolean
nextStep
();
List
<
String
>
getAllVehicles
();
List
<
String
>
getAllVehicles
(
double
pStep
);
RoadNetworkRoute
getCurrentRoute
(
String
pVehicleID
);
double
getMaximumAvailablePrediction
();
void
rerouteVehicle
(
String
pVehicle
,
RoadNetworkRoute
pRoute
);
RoadNetworkRoute
findNewRoute
(
String
pVehicle
)
throws
NoAdditionalRouteAvailableException
;
RoadNetworkRoute
findNewRoute
(
String
pVehicle
,
List
<
RoadNetworkEdge
>
pEdgesToAvoid
,
boolean
pKeepDestination
)
throws
NoAdditionalRouteAvailableException
,
NoExitAvailableException
;
double
getStep
();
double
getStart
();
void
init
();
double
getVehicleSpeed
(
String
pVehicleID
);
void
stopVehicle
(
String
pVehicle
);
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/information/LocationUtils.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information
;
import
java.util.HashMap
;
import
java.util.Map
;
public
class
LocationUtils
{
private
static
boolean
_saveID
=
false
;
private
static
Map
<
String
,
Long
>
_ids
=
new
HashMap
<>();
private
static
long
_currentID
=
0
;
public
static
long
calculateID
(
String
pID
)
{
long
numericalID
=
-
1
;
if
(!
_saveID
)
{
try
{
String
[]
split
=
pID
.
split
(
"_"
);
for
(
int
i
=
0
;
i
<
split
.
length
;
i
++)
{
numericalID
*=
100000
;
numericalID
+=
Integer
.
valueOf
(
split
[
i
]);
}
}
catch
(
NumberFormatException
e
)
{
_saveID
=
true
;
}
}
if
(
_saveID
)
{
synchronized
(
_ids
)
{
if
(!
_ids
.
containsKey
(
pID
))
{
_ids
.
put
(
pID
,
_currentID
++);
}
numericalID
=
_ids
.
get
(
pID
);
}
}
return
numericalID
;
}
public
static
double
calculateDistance
(
Position
start
,
Position
end
)
{
return
Math
.
sqrt
(
Math
.
pow
(
end
.
getY
()
-
start
.
getY
(),
2
)
+
Math
.
pow
(
end
.
getX
()
-
start
.
getX
(),
2
))
/
1000.0
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/information/NoDublicatePositionComparator.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information
;
import
java.util.Comparator
;
public
class
NoDublicatePositionComparator
implements
Comparator
<
Position
>
{
@Override
public
int
compare
(
Position
pPos1
,
Position
pPos2
)
{
int
compare
=
Double
.
compare
(
pPos1
.
getY
(),
pPos2
.
getY
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
pPos1
.
getX
(),
pPos2
.
getX
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
pPos1
.
getAlt
(),
pPos2
.
getAlt
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
pPos1
.
getHeading
(),
pPos2
.
getHeading
());
}
}
}
return
compare
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/information/Position.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information
;
import
java.io.Serializable
;
public
class
Position
implements
Serializable
,
Comparable
<
Position
>
{
/**
*
*/
private
static
final
long
serialVersionUID
=
-
5007352031660976321L
;
public
static
final
double
EQUAL_DISTANCE
=
0.0
;
private
static
final
double
EQUAL_HEADING
=
5
;
private
static
final
double
EQUAL_ALT
=
10
;
private
double
_y
;
private
double
_x
;
private
double
_heading
;
private
double
_alt
;
private
double
_speed
;
public
Position
(
double
pX
,
double
pY
,
double
pAlt
,
double
pHeading
,
double
pSpeed
)
{
_x
=
pX
;
_y
=
pY
;
_alt
=
pAlt
;
_heading
=
pHeading
;
_speed
=
pSpeed
;
}
public
Position
(
double
pX
,
double
pY
,
double
pAlt
,
double
pHeading
)
{
this
(
pX
,
pY
,
pAlt
,
pHeading
,
0
);
}
public
double
getY
()
{
return
_y
;
}
public
void
setY
(
double
pY
)
{
_y
=
pY
;
}
public
double
getX
()
{
return
_x
;
}
public
void
setX
(
double
pX
)
{
_x
=
pX
;
}
public
double
getHeading
()
{
return
_heading
;
}
public
void
setHeading
(
double
pHeading
)
{
_heading
=
pHeading
;
}
public
double
getAlt
()
{
return
_alt
;
}
public
void
setAlt
(
double
pAlt
)
{
_alt
=
pAlt
;
}
public
double
getSpeed
()
{
return
_speed
;
}
public
void
setSpeed
(
double
pSpeed
)
{
_speed
=
pSpeed
;
}
@Override
public
String
toString
()
{
return
_y
+
"/"
+
_x
+
" ("
+
_heading
+
")"
;
}
@Override
public
int
hashCode
()
{
return
0
;
}
@Override
public
boolean
equals
(
Object
pObj
)
{
if
(
pObj
instanceof
Position
)
{
Position
start
=
(
Position
)
pObj
;
double
difference
=
LocationUtils
.
calculateDistance
(
start
,
this
);
if
(
difference
<=
EQUAL_DISTANCE
)
{
if
(
Math
.
abs
(
getAlt
()
-
start
.
getAlt
())
<
EQUAL_ALT
)
{
if
(
Math
.
abs
(
getHeading
()
-
start
.
getHeading
())
<
EQUAL_HEADING
)
{
return
true
;
}
}
}
}
return
false
;
}
@Override
public
int
compareTo
(
Position
pPosition
)
{
if
(
Math
.
abs
(
_y
-
pPosition
.
getY
())
<
1
/
1000.0
&&
Math
.
abs
(
_x
-
pPosition
.
getX
())
<
1
/
1000.0
&&
Math
.
abs
(
_alt
-
pPosition
.
getAlt
())
<=
EQUAL_ALT
&&
Math
.
abs
(
_heading
-
pPosition
.
getHeading
())
<=
EQUAL_HEADING
)
{
if
(
equals
(
pPosition
))
{
return
0
;
}
}
int
compare
=
Double
.
compare
(
_y
,
pPosition
.
getY
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
_x
,
pPosition
.
getX
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
_alt
,
pPosition
.
getAlt
());
if
(
compare
==
0
)
{
compare
=
Double
.
compare
(
_heading
,
pPosition
.
getHeading
());
}
}
}
return
compare
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/information/Route.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information
;
import
java.util.ArrayList
;
import
java.util.List
;
public
class
Route
{
private
List
<
Street
>
_waypoints
;
public
Route
()
{
_waypoints
=
new
ArrayList
<>();
}
public
List
<
Street
>
getStreets
()
{
return
_waypoints
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/api/information/Street.java
0 → 100755
View file @
7850d53e
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.information
;
public
class
Street
{
private
String
_edgeID
;
public
Street
(
String
pEdgeID
)
{
_edgeID
=
pEdgeID
;
}
public
String
getEdgeID
()
{
return
_edgeID
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/roadnetwork/RoadNetwork.java
View file @
7850d53e
...
...
@@ -21,15 +21,19 @@
package
de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.EdgeController
;
public
class
RoadNetwork
{
private
Map
<
String
,
RoadNetworkEdge
>
_roadNetwork
;
public
RoadNetwork
(
SerializableRoadNetwork
pRoadNetwork
)
{
public
RoadNetwork
(
SerializableRoadNetwork
pRoadNetwork
,
EdgeController
pEdgeController
)
{
_roadNetwork
=
new
HashMap
<>();
for
(
SerializableRoadNetworkEdge
edge
:
pRoadNetwork
.
getAvailableEdges
())
{
_roadNetwork
.
put
(
edge
.
getEdgeID
(),
new
RoadNetworkEdge
(
edge
));
_roadNetwork
.
put
(
edge
.
getEdgeID
(),
new
RoadNetworkEdge
(
edge
,
pEdgeController
));
}
for
(
SerializableRoadNetworkEdge
edge
:
pRoadNetwork
.
getAvailableEdges
())
{
...
...
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/roadnetwork/RoadNetworkEdge.java
View file @
7850d53e
...
...
@@ -24,23 +24,33 @@ import java.util.ArrayList;
import
java.util.Collections
;
import
java.util.List
;
import
de.tudarmstadt.maki.simonstrator.api.component.vehicular.api.EdgeController
;
public
class
RoadNetworkEdge
{
private
String
_edgeID
;
private
double
_angle
;
private
int
_laneAmount
;
private
double
_
m
axSpeed
=
0
;
private
double
_
originalM
axSpeed
=
0
;
private
List
<
RoadNetworkEdge
>
_accessibleEdges
=
new
ArrayList
<>();
public
RoadNetworkEdge
(
SerializableRoadNetworkEdge
pEdge
)
{
private
final
EdgeController
_edgeController
;
public
RoadNetworkEdge
(
SerializableRoadNetworkEdge
pEdge
,
EdgeController
pEdgeController
)
{
_edgeController
=
pEdgeController
;
_edgeID
=
pEdge
.
getEdgeID
();
_angle
=
pEdge
.
getAngle
();
_laneAmount
=
pEdge
.
getLaneAmount
();
_maxSpeed
=
pEdge
.
getMaxSpeed
();
_originalMaxSpeed
=
pEdge
.
getMaxSpeed
();
}
public
RoadNetworkEdge
(
String
pEdgeID
,
double
pAngle
)
{
public
RoadNetworkEdge
(
String
pEdgeID
,
double
pAngle
,
EdgeController
pEdgeController
)
{
_edgeController
=
pEdgeController
;
_edgeID
=
pEdgeID
;
_angle
=
pAngle
;
...
...
@@ -55,8 +65,8 @@ public class RoadNetworkEdge {
return
_angle
;
}
public
double
getMaxSpeed
()
{
return
_
m
axSpeed
;
public
double
get
Original
MaxSpeed
()
{
return
_
originalM
axSpeed
;
}
public
int
getLaneAmount
()
{
...
...
@@ -67,9 +77,9 @@ public class RoadNetworkEdge {
_laneAmount
++;
}
public
void
setMaxSpeed
(
double
pMaxSpeed
)
{
if
(
pMaxSpeed
>
_
m
axSpeed
)
{
_
m
axSpeed
=
pMaxSpeed
;
public
void
set
Original
MaxSpeed
(
double
pMaxSpeed
)
{
if
(
pMaxSpeed
>
_
originalM
axSpeed
)
{
_
originalM
axSpeed
=
pMaxSpeed
;
}
}
...
...
@@ -84,7 +94,7 @@ public class RoadNetworkEdge {
}
public
String
getDescription
()
{
return
"id: "
+
_edgeID
+
", lanes: "
+
_laneAmount
+
", speed limit: "
+
_
m
axSpeed
;
return
"id: "
+
_edgeID
+
", lanes: "
+
_laneAmount
+
", speed limit: "
+
_
originalM
axSpeed
;
}
@Override
...
...
@@ -95,4 +105,8 @@ public class RoadNetworkEdge {
public
boolean
isInternal
()
{
return
_edgeID
.
startsWith
(
":"
);
}
public
void
changeEdgeMaxSpeed
(
double
pMaxSpeed
)
{
_edgeController
.
setEdgeMaxSpeed
(
getEdgeID
(),
pMaxSpeed
);
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/roadnetwork/RoadNetworkRoute.java
View file @
7850d53e
...
...
@@ -93,4 +93,13 @@ public class RoadNetworkRoute {
}
return
buffer
.
toString
();
}
public
boolean
containsEdges
(
List
<
RoadNetworkEdge
>
pBlocked
)
{
for
(
RoadNetworkEdge
roadNetworkEdge
:
pBlocked
)
{
if
(
containsEdge
(
roadNetworkEdge
))
{
return
true
;
}
}
return
false
;
}
}
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/roadnetwork/SerializableRoadNetwork.java
View file @
7850d53e
...
...
@@ -22,6 +22,7 @@ package de.tudarmstadt.maki.simonstrator.api.component.vehicular.roadnetwork;
import
java.io.Serializable
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
...
...
@@ -33,6 +34,7 @@ public class SerializableRoadNetwork implements Serializable {
private
Map
<
String
,
SerializableRoadNetworkEdge
>
_roadNetwork
;
public
SerializableRoadNetwork
(
RoadNetwork
pRoadNetwork
)
{
_roadNetwork
=
new
HashMap
<>();
for
(
RoadNetworkEdge
edge
:
pRoadNetwork
.
getAvailableEdges
())
{
_roadNetwork
.
put
(
edge
.
getEdgeID
(),
new
SerializableRoadNetworkEdge
(
edge
));
}
...
...
src/de/tudarmstadt/maki/simonstrator/api/component/vehicular/roadnetwork/SerializableRoadNetworkEdge.java
View file @
7850d53e
...
...
@@ -42,7 +42,7 @@ public class SerializableRoadNetworkEdge implements Serializable {
_edgeID
=
pEdge
.
getEdgeID
();
_angle
=
pEdge
.
getAngle
();
_laneAmount
=
pEdge
.
getLaneAmount
();
_maxSpeed
=
pEdge
.
getMaxSpeed
();
_maxSpeed
=
pEdge
.
get
Original
MaxSpeed
();
for
(
RoadNetworkEdge
edge
:
pEdge
.
getAccessibleEdges
())
{
_accessibleEdgeIDs
.
add
(
edge
.
getEdgeID
());
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment