#ifndef SHARED_CONTINUOUS_FUNCTION_CACHE_H #define SHARED_CONTINUOUS_FUNCTION_CACHE_H #include "../graph/graph/graph_view.h" #include #include #include namespace Shared { class ContinuousFunction; class ContinuousFunctionCache { private: /* The size of the cache is chosen to optimize the display of cartesian * functions */ static constexpr int k_sizeOfCache = Ion::Display::Width; public: static constexpr int k_numberOfAvailableCaches = 2; static constexpr int k_parametricStepFactor = k_sizeOfCache / int(Graph::GraphView::k_graphStepDenominator); static void PrepareForCaching(void * fun, ContinuousFunctionCache * cache, float tMin, float tStep); ContinuousFunctionCache() { clear(); } float step() const { return m_tStep; } void clear(); Poincare::Coordinate2D valueForParameter(const ContinuousFunction * function, Poincare::Context * context, float t); private: static constexpr float k_cacheHitTolerance = 1e-3; void invalidateBetween(int iInf, int iSup); void setRange(ContinuousFunction * function, float tMin, float tStep); int indexForParameter(const ContinuousFunction * function, float t) const; Poincare::Coordinate2D valuesAtIndex(const ContinuousFunction * function, Poincare::Context * context, float t, int i); void pan(ContinuousFunction * function, float newTMin); float m_tMin, m_tStep; float m_cache[k_sizeOfCache]; /* m_startOfCache is used to implement a circular buffer for easy panning * with cartesian functions. When dealing with parametric or polar functions, * m_startOfCache should be zero.*/ int m_startOfCache; }; } #endif