TTLbasedCacheDecisionStrategy.java 6.49 KB
Newer Older
Tobias Meuser's avatar
Tobias Meuser committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/*
 * 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.vehicular.caching.decision;

Björn Richerzhagen's avatar
Björn Richerzhagen committed
23
import java.util.Arrays;
24
25
import java.util.Collections;
import java.util.Comparator;
Tobias Meuser's avatar
Tobias Meuser committed
26
27
28
29
30
31
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import de.tudarmstadt.maki.simonstrator.api.Time;
32
import de.tudarmstadt.maki.simonstrator.api.component.sensor.environment.data.RoadProperty;
33
34
import de.tudarmstadt.maki.simonstrator.api.component.sensor.environment.data.VectoralProperty;
import de.tudarmstadt.maki.simonstrator.api.component.sensor.environment.data.jam.VectoralJamProperty;
35
36
import de.tudarmstadt.maki.simonstrator.api.component.transition.TransferState;
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.decision.AbstractCacheDecisionStrategy;
Tobias Meuser's avatar
Tobias Meuser committed
37
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.decision.CacheDecisionStrategy;
38
39
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.decision.CacheDecisionStrategyParameters;
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.decision.CacheSizeAwareCacheDecisionStrategy;
Tobias Meuser's avatar
Tobias Meuser committed
40
41
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.information.AvailableInformationAttributes;
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.information.PointInformation;
42
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.information.RoadInformation;
43
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.relevance.impl.SimpleQoIBasedImpactFunction;
Tobias Meuser's avatar
Tobias Meuser committed
44

45
public class TTLbasedCacheDecisionStrategy extends AbstractCacheDecisionStrategy implements CacheSizeAwareCacheDecisionStrategy {
Tobias Meuser's avatar
Tobias Meuser committed
46
47
	private static final long SCALING = Time.SECOND;

48
49
	private static final double ACCURACY_FACTOR = 100000;

50
51
	private final Map<CacheDecisionStrategyParameters, String> _params;

Tobias Meuser's avatar
Tobias Meuser committed
52
53
54
55
56
57
	private long ttl = 300 * Time.SECOND / SCALING;
	private double accuracy = 1;

	private double costWrongKeep = 1;
	private double costWrongChange = 1;

58
59
	private Object _lastDecision = false;

60
61
62
63
64
65
	private int _maxCacheSize = Integer.MAX_VALUE;

	@TransferState(value = { "Params" })
	public TTLbasedCacheDecisionStrategy(Map<CacheDecisionStrategyParameters, String> pParams) {
		_params = pParams;
		for (Entry<CacheDecisionStrategyParameters, String> param : pParams.entrySet()) {
Tobias Meuser's avatar
Tobias Meuser committed
66
			switch (param.getKey()) {
67
			case ACCURACY:
Tobias Meuser's avatar
Tobias Meuser committed
68
69
				accuracy = Double.valueOf(param.getValue());
				break;
70
			case COST_RATIO:
71
72
73
74
				double ratio = Double.valueOf(param.getValue());
				costWrongChange = 2 / (ratio + 1);
				costWrongKeep = 2 - costWrongChange;
				break;
Tobias Meuser's avatar
Tobias Meuser committed
75
76
77
78
79
80
			default:
				break;
			}
		}
	}

81
82
83
84
85
86
87
88
	public double getCostWrongChange() {
		return costWrongChange;
	}

	public double getCostWrongKeep() {
		return costWrongKeep;
	}

Tobias Meuser's avatar
Tobias Meuser committed
89
90
91
92
	@Override
	public <T extends PointInformation> T decideOnCorrectInformation(
			List<T> pSimilarPointInformation) {
		if (pSimilarPointInformation.size() == 1) {
93
			T decision = pSimilarPointInformation.get(0);
94
95
			addAggregationInformation(pSimilarPointInformation, decision);

96
97
			_lastDecision = decision.getValue();
			return decision;
Tobias Meuser's avatar
Tobias Meuser committed
98
99
100
		} else if (pSimilarPointInformation.size() == 0) {
			return null;
		}
101

102
103
104
105
106
107
		Collections.sort(pSimilarPointInformation, new Comparator<T>() {

			@Override
			public int compare(T pArg0, T pArg1) {
				return Long.compare(pArg0.getDetectionDate(), pArg1.getDetectionDate());
			}
108

109
		});
Tobias Meuser's avatar
Tobias Meuser committed
110
111
112
113
114
115
116
117
118

		Object value = pSimilarPointInformation.get(0).getValue();
		boolean differentValue = false;
		for (T t : pSimilarPointInformation) {
			if (!value.equals(t.getValue())) {
				differentValue = true;
			}
		}

119
		SimpleQoIBasedImpactFunction<T> impactFunction = new SimpleQoIBasedImpactFunction<>(pSimilarPointInformation, accuracy, _maxCacheSize);
Tobias Meuser's avatar
Tobias Meuser committed
120

121
		Map<Object, Double> weight = new HashMap<>();
122

123
124
		for (T t : pSimilarPointInformation) {
			double impact = impactFunction.calculateImpact(t);
Tobias Meuser's avatar
Tobias Meuser committed
125

126
			double sumImpact = 0;
127

128
			Object currentValue = t.getValue();
129

130
131
132
			if (currentValue instanceof VectoralJamProperty) {
				currentValue = ((VectoralJamProperty) currentValue).getMostProbableValue();
			}
Tobias Meuser's avatar
Tobias Meuser committed
133

134
135
			if (weight.containsKey(currentValue)) {
				sumImpact = weight.get(currentValue);
Tobias Meuser's avatar
Tobias Meuser committed
136
			}
137
			sumImpact += impact;
Tobias Meuser's avatar
Tobias Meuser committed
138

139
140
			weight.put(currentValue, sumImpact);
		}
Tobias Meuser's avatar
Tobias Meuser committed
141

142
143
		double maxWeight = -1;
		Object maxValue = null;
Tobias Meuser's avatar
Tobias Meuser committed
144

145
146
147
148
149
150
		for (Object key : weight.keySet()) {
			if (weight.get(key) > maxWeight) {
				maxWeight = weight.get(key);
				maxValue = key;
			}
		}
Tobias Meuser's avatar
Tobias Meuser committed
151

152
153
154
155
		long maxTimestamp = -1;
		T maxFitting = null;
		for (T t : pSimilarPointInformation) {
			long timestamp = t.getDetectionDate();
156

157
158
159
			Object currentValue = t.getValue();
			if (currentValue instanceof VectoralProperty) {
				currentValue = ((VectoralProperty)currentValue).getMostProbableValue();
Tobias Meuser's avatar
Tobias Meuser committed
160
			}
161

162
163
164
165
166
			if (currentValue.equals(maxValue) && timestamp > maxTimestamp) {
				maxTimestamp = timestamp;
				maxFitting = t;
			}
		}
167

168
169
170
171
		if (maxFitting.getValue() instanceof VectoralProperty) {
			VectoralProperty vectoralProperty = ((VectoralProperty)maxFitting.getValue()).clone();
			double[] valueProbabilities = vectoralProperty.getValueProbabilities();
			Arrays.fill(valueProbabilities, 0);
172

173
174
175
176
177
			double sum = 0;
			for (Object key : weight.keySet()) {
				valueProbabilities[vectoralProperty.getIndexForValue(key)] = weight.get(key);
				sum += weight.get(key);
			}
178

179
180
			for (int i = 0; i < valueProbabilities.length; i++) {
				valueProbabilities[i] /= sum;
181
			}
Tobias Meuser's avatar
Tobias Meuser committed
182

183
184
185
186
			RoadInformation roadInformation = new RoadInformation(vectoralProperty);
			roadInformation.copyAttributes((RoadInformation)maxFitting);
			maxFitting = (T) roadInformation;
		}
187

188
		_lastDecision = maxFitting.getValue();
Tobias Meuser's avatar
Tobias Meuser committed
189

190
		addAggregationInformation(pSimilarPointInformation, maxFitting);
Tobias Meuser's avatar
Tobias Meuser committed
191

192
193
		return maxFitting;
	}
194

195
196
197
198
199
200
201
	public Map<CacheDecisionStrategyParameters, String> getParams() {
		return _params;
	}

	@Override
	public void setCacheSize(int pCacheSize) {
		_maxCacheSize = pCacheSize;
Tobias Meuser's avatar
Tobias Meuser committed
202
203
	}
}