Files
Upsilon/apps/statistics/statistics_context.cpp
2019-02-21 11:29:35 +01:00

32 lines
964 B
C++

#include "statistics_context.h"
#include <assert.h>
#include <string.h>
#include <poincare/float.h>
using namespace Poincare;
using namespace Shared;
namespace Statistics {
const Expression StatisticsContext::expressionForSymbol(const SymbolAbstract & symbol, bool clone) {
if (symbol.type() == ExpressionNode::Type::Symbol && Symbol::isSeriesSymbol(symbol.name())) {
const char * seriesName = symbol.name();
assert(strlen(seriesName) == 2);
int series = (int)(seriesName[1] - '0') - 1;
assert(series >= 0 && series < DoublePairStore::k_numberOfSeries);
assert((seriesName[0] == 'V') || (seriesName[0] == 'N'));
int storeI = seriesName[0] == 'V' ? 0 : 1;
assert(m_seriesPairIndex >= 0);
assert(m_seriesPairIndex < m_store->numberOfPairsOfSeries(series));
return Float<double>::Builder(m_store->get(series, storeI, m_seriesPairIndex));
} else {
return m_parentContext->expressionForSymbol(symbol, clone);
}
}
}