SimpleMutlicopterMovement.java 5.69 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
	@Override
Julian Zobel's avatar
Julian Zobel committed
72
	public void setPreferredSpeed(double v_pref) {
73
74
75
76
77
78
79
		this.preferredCruiseSpeed = v_pref;		
	}

	@Override
	public double getCurrentSpeed() {
		return currentSpeed;
	}
80
81
	
	
82
83
84
85

	@Override
	public void move(long timeBetweenMovementOperations) {
		
86
		if(topologyComponent.isActive() && !route.isEmpty()) {
87
88
			PositionVector currentPosition= topologyComponent.getRealPosition();
			
89
			PositionVector targetPosition = route.getFirst();
90
91
92
			Double distanceToTargetPosition = targetPosition.distanceTo(currentPosition);
							
			// If target point is reached within a 1 meter margin, we remove that point from the list 
93
			if(distanceToTargetPosition < 0.1 || distanceToTargetPosition < currentSpeed)
94
95
			{						
				route.removeFirst();
96
				motor.requestThrust(16.3);
Julian Zobel's avatar
Julian Zobel committed
97
				topologyComponent.updateCurrentLocation(targetPosition); // triggers energy consumption for last distance
98
				currentSpeed = 0;
99
				motor.requestThrust(14.4); // now hover
100
				locationReached(targetPosition);
101
102
103
104
105
106
107
108
109
110
111
112
113
114
				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);		
115
			
116
			motor.requestThrust(22);
Julian Zobel's avatar
Julian Zobel committed
117
			topologyComponent.updateCurrentLocation(newPosition);
118
119
120
			
		}
		
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
		//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);
142
143
144
		
	}

145
146
147
148
149
150
151
152
	@Override
	public void setTargetLocationRoute(LinkedList<PositionVector> route,
			ReachedLocationCallback reachedLocationCallback) {
		this.route.clear();
		this.route.addAll(route);
		if(reachedLocationCallback != null)
			locationCallbacks.put(route.getLast(), reachedLocationCallback);
	}
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
	@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();
	}

Julian Zobel's avatar
WIP    
Julian Zobel committed
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
	@Override
	public double verticalAscentMaxVelocity() {
		return maxCruiseSpeed;
	}

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

	@Override
	public double minimumVelocity() {		
		return 0;
	}

194
195
	
	
196
197
	
}