19 #ifndef ValueTimeLine_h
20 #define ValueTimeLine_h
61 void add(
double begin,
double end, T value) {
67 myValues[begin] = std::make_pair(
true, value);
68 myValues[end] = std::make_pair(
false, value);
72 typename TimedValueMap::iterator endIt =
myValues.find(end);
75 myValues[begin] = std::make_pair(
true, value);
83 myValues[begin] = std::make_pair(
true, value);
97 typename TimedValueMap::const_iterator it =
myValues.upper_bound(time);
100 return it->second.second;
114 typename TimedValueMap::const_iterator afterIt =
myValues.upper_bound(time);
119 return afterIt->second.first;
133 typename TimedValueMap::const_iterator afterLow =
myValues.upper_bound(low);
134 typename TimedValueMap::const_iterator afterHigh =
myValues.upper_bound(high);
136 if (afterLow == afterHigh) {
137 return afterLow->first;
147 void fillGaps(T value,
bool extendOverBoundaries =
false) {
148 for (
typename TimedValueMap::iterator it =
myValues.begin(); it !=
myValues.end(); ++it) {
149 if (!it->second.first) {
150 it->second.second = value;
153 if (extendOverBoundaries && !
myValues.empty()) {
154 typename TimedValueMap::iterator it = --
myValues.end();
155 if (!it->second.first) {
158 value =
myValues.begin()->second.second;
160 myValues[-1] = std::make_pair(
false, value);