Files
Upsilon/apps/sequence/sequence_store.h
Arthur Camouseigt 8434da60ef [sequence] Changed sequences behavior
Sequences can now be defined using specific terms form other sequences :
Un = n
Vn = u(3)

Initial values can also depend on other sequences.
Should there be a circular dependency, the sequences concerned will
display "undef" as value

Change-Id: I6fe1f3ff7b500f35d480ddefb42de729c327432e
2020-11-04 15:32:58 +01:00

51 lines
2.2 KiB
C++

#ifndef SEQUENCE_SEQUENCE_STORE_H
#define SEQUENCE_SEQUENCE_STORE_H
#include "../shared/function_store.h"
#include "../shared/global_context.h"
#include "sequence.h"
#include <stdint.h>
#include <escher.h>
namespace Sequence {
class SequenceStore : public Shared::FunctionStore {
public:
using Shared::FunctionStore::FunctionStore;
/* Sequence Store hold all its Sequences in an array. The Sequence pointers
* return by modelForRecord are therefore non-expirable. We choose to return
* Sequence * instead of ExpiringPointer<Sequence>. */
Sequence * modelForRecord(Ion::Storage::Record record) const { return static_cast<Sequence *>(privateModelForRecord(record)); }
Ion::Storage::Record::ErrorStatus addEmptyModel() override;
/* WARNING: after calling removeModel or removeAll, the sequence context
* need to invalidate its cache as the sequences evaluations might have
* changed */
int maxNumberOfModels() const override { return MaxNumberOfSequences; }
static int sequenceIndexForName(char name);
static const char * firstAvailableName(int * nameIndex = nullptr);
static constexpr const char * k_sequenceNames[MaxNumberOfSequences] = {
"u", "v", "w"
};
Sequence sequenceAtIndex(int i) { assert(i < MaxNumberOfSequences && i >= 0); return m_sequences[i]; }
private:
const char * modelExtension() const override { return Ion::Storage::seqExtension; }
/* We don't use model memoization for two reasons:
* - the number of Sequence is capped so we keep enough Sequences to store them all.
* - evaluating sequences require to evaluate all of them at the same time
* (as they might be co-dependent) which doesn't suit our ring memoization.
* To still make it work with the ExpressionModelStore, we force
* setMemoizedModelAtIndex to store u, v and w sequences in this order in
* m_sequences whatever the value of cacheIndex. We thus return a
* ExpressionModelHandle pointer after setting the model as it won't be the
* memoized model at cacheIndex. */
Shared::ExpressionModelHandle * setMemoizedModelAtIndex(int cacheIndex, Ion::Storage::Record record) const override;
Shared::ExpressionModelHandle * memoizedModelAtIndex(int cacheIndex) const override;
mutable Sequence m_sequences[MaxNumberOfSequences];
};
}
#endif