10. Solution: Initialize Priors Function
There is more than on way to initialize priors, here is one possible approach.
Start Quiz:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
//initialize priors assumimg vehicle at landmark +/- 1.0 meters position stdev
std::vector<float> initialize_priors(int map_size, std::vector<float> landmark_positions,
float position_stdev);
int main() {
//set standard deviation of position:
float position_stdev = 1.0f;
//set map horizon distance in meters
int map_size = 25;
//initialize landmarks
std::vector<float> landmark_positions {5, 10, 20};
// initialize priors
std::vector<float> priors = initialize_priors(map_size, landmark_positions,
position_stdev);
//print values to stdout
for (unsigned int p = 0; p < priors.size(); p++) {
std::cout << priors[p] << endl;
}
return 0;
};
std::vector<float> initialize_priors(int map_size, std::vector<float> landmark_positions,
float position_stdev) {
//initialize priors assumimg vehicle at landmark +/- 1.0 meters position stdev
//set all priors to 0.0
std::vector<float> priors(map_size, 0.0);
//set each landmark positon +/1 to 1.0/9.0 (9 possible postions)
float normalization_term = landmark_positions.size() * (position_stdev * 2 + 1);
for (unsigned int i = 0; i < landmark_positions.size(); i++){
int landmark_center = landmark_positions[i];
priors[landmark_center] = 1.0f/normalization_term;
priors[landmark_center - 1] = 1.0f/normalization_term;
priors[landmark_center + 1] = 1.0f/normalization_term;
}
return priors;
}
INSTRUCTOR NOTE:
For simplicity we assumed a position standard deviation of 1.0 and coded a solution for initializing priors accordingly. A more robust approach would be to create a function that accepts a position standard deviation as an argument and adjusts initialization and normalization based on its value.
For example the current solution for a position standard deviation of 1.0 and a control standard deviation of 1.0 is:
for (unsigned int i = 0; i < landmark_positions.size(); i++){
int landmark_center = landmark_positions[i];
priors[landmark_center] = 1.0f/normalization_term;
priors[landmark_center - 1] = 1.0f/normalization_term;
priors[landmark_center + 1] = 1.0f/normalization_term;
}
A solution for a position standard deviation of 2.0 and a control standard deviation of 1.0 is:
for (unsigned int i = 0; i < landmark_positions.size(); i++){
int landmark_center = landmark_positions[i];
priors[landmark_center] = 1.0f/normalization_term;
priors[landmark_center - 2] = 1.0f/normalization_term;
priors[landmark_center + 2] = 1.0f/normalization_term;
priors[landmark_center - 1] = 1.0f/normalization_term;
priors[landmark_center + 1] = 1.0f/normalization_term;
}
A robust implementation of this would make these changes automatically based on the position standard deviation value and avoid tedious recoding.