SimpleMutlicopterMovement.java 5.62 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*
 * Copyright (c) 2005-2010 KOM – Multimedia Communications Lab
 *
 * This file is part of PeerfactSim.KOM.
 * 
 * PeerfactSim.KOM is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * any later version.
 * 
 * PeerfactSim.KOM is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with PeerfactSim.KOM.  If not, see <http://www.gnu.org/licenses/>.
 *
 */

package de.tud.kom.p2psim.impl.topology.movement.aerial;

import java.util.HashMap;
24
import java.util.LinkedHashMap;
25
26
import java.util.LinkedList;
import java.util.Map;
Julian Zobel's avatar
Julian Zobel committed
27
28
29

import org.joda.time.tz.ZoneInfoProvider;

30
import de.tud.kom.p2psim.api.topology.movement.UAVMovementModel;
31
import de.tud.kom.p2psim.impl.energy.components.StatelessMotorComponent;
32
33
34
import de.tud.kom.p2psim.impl.topology.component.UAVTopologyComponent;
import de.tud.kom.p2psim.impl.topology.util.PositionVector;
import de.tudarmstadt.maki.simonstrator.api.Time;
35
import de.tudarmstadt.maki.simonstrator.api.uavsupport.callbacks.ReachedLocationCallback;
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52

/**
 * Local movement logic specifically designs the movement for multicopter UAVs. 
 * This simple movement logic uses straight forward movement with the maximum speed available.
 * 
 * @author Julian Zobel
 * @version 1.0, 11.09.2018
 */
public class SimpleMutlicopterMovement implements UAVMovementModel  {

	private UAVTopologyComponent topologyComponent;

	private final double maxCruiseSpeed;
	private final double minCruiseSpeed;
	private double preferredCruiseSpeed;
	private double currentSpeed;
	
53
	private LinkedList<PositionVector> route = new LinkedList<>();
54
	private Map<PositionVector, ReachedLocationCallback> locationCallbacks = new LinkedHashMap<>();  // TODO callback interface
55
		
56
	private StatelessMotorComponent motor;
57
58
59
60
61
62
	
	public SimpleMutlicopterMovement(UAVTopologyComponent topologyComponent, double maxCruiseSpeed, double minCruiseSpeed) {
		this.topologyComponent = topologyComponent;
		this.maxCruiseSpeed = maxCruiseSpeed;
		this.minCruiseSpeed = minCruiseSpeed;
		this.preferredCruiseSpeed = this.maxCruiseSpeed;
63
					
64
65
	}
		
66
67
68
69
70
	@Override
	public void setMotorControl(StatelessMotorComponent motor) {
		this.motor = motor;
	}
	
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
	@Override
	public void setPreferredCruiseSpeed(double v_pref) {
		this.preferredCruiseSpeed = v_pref;		
	}

	@Override
	public double getMaxCruiseSpeed() {
		return maxCruiseSpeed;
	}

	@Override
	public double getMinCruiseSpeed() {
		return minCruiseSpeed;
	}

	@Override
	public double getCurrentSpeed() {
		return currentSpeed;
	}
90
91
	
	
92
93
94
95

	@Override
	public void move(long timeBetweenMovementOperations) {
		
96
		if(topologyComponent.isActive() && !route.isEmpty()) {
97
98
			PositionVector currentPosition= topologyComponent.getRealPosition();
			
99
			PositionVector targetPosition = route.getFirst();
100
101
102
			Double distanceToTargetPosition = targetPosition.distanceTo(currentPosition);
							
			// If target point is reached within a 1 meter margin, we remove that point from the list 
103
			if(distanceToTargetPosition < 0.1 || distanceToTargetPosition < currentSpeed)
104
105
			{						
				route.removeFirst();
106
				motor.requestThrust(16.3);
Julian Zobel's avatar
Julian Zobel committed
107
				topologyComponent.updateCurrentLocation(targetPosition); // triggers energy consumption for last distance
108
				currentSpeed = 0;
109
				motor.requestThrust(14.4); // now hover
110
				locationReached(targetPosition);
111
112
113
114
115
116
117
118
119
120
121
122
123
124
				return;
			}
			
			double timefactor = timeBetweenMovementOperations / Time.SECOND;
			
			currentSpeed = Math.min(distanceToTargetPosition, preferredCruiseSpeed);					
						
			PositionVector direction = new PositionVector(targetPosition);
			direction.subtract(currentPosition);
			direction.normalize();
			direction.multiplyScalar(currentSpeed * timefactor);

			PositionVector newPosition = new PositionVector(currentPosition);
			newPosition.add(direction);		
125
			
126
			motor.requestThrust(22);
Julian Zobel's avatar
Julian Zobel committed
127
			topologyComponent.updateCurrentLocation(newPosition);
128
129
130
			
		}
		
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
		//System.out.println(Simulator.getFormattedTime(Simulator.getCurrentTime()) + " | " +  topologyComponent);		
	}

	/**
	 * Trigger the callback function, if there is a valid callback 
	 * 
	 * @param position
	 */
	private void locationReached(PositionVector position) {
		if(locationCallbacks.containsKey(position)) {
			locationCallbacks.get(position).reachedLocation();
		}
	}
	
	@Override
	public void setTargetLocation(PositionVector target,
			ReachedLocationCallback reachedLocationCallback) {
		route.clear();
		route.add(target);
		if(reachedLocationCallback != null)
			locationCallbacks.put(target, reachedLocationCallback);
152
153
154
		
	}

155
156
157
158
159
160
161
162
	@Override
	public void setTargetLocationRoute(LinkedList<PositionVector> route,
			ReachedLocationCallback reachedLocationCallback) {
		this.route.clear();
		this.route.addAll(route);
		if(reachedLocationCallback != null)
			locationCallbacks.put(route.getLast(), reachedLocationCallback);
	}
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
	@Override
	public void addTargetLocation(PositionVector target,
			ReachedLocationCallback reachedLocationCallback) {
		route.add(target);
		if(reachedLocationCallback != null)
			locationCallbacks.put(target, reachedLocationCallback);
	}

	@Override
	public LinkedList<PositionVector> getTargetLocations() {
		
		LinkedList<PositionVector> copy = new LinkedList<>();
		for (PositionVector pv : route) {
			copy.add(pv.clone());		
		}
		
		return copy;
	}

	@Override
	public void removeTargetLocations() {
		route.clear();
		locationCallbacks.clear();
	}

	
	
191
192
	
}