2017-02-16 11:20:40 +01:00
|
|
|
// -*- C++ -*-
|
|
|
|
|
|
|
|
#ifndef __index_base_h__
|
|
|
|
#define __index_base_h__
|
|
|
|
|
|
|
|
#include <cstdlib>
|
|
|
|
#include <string>
|
2017-02-16 16:06:23 +01:00
|
|
|
#include <vector>
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
#include "base_def.h"
|
|
|
|
#include "range_base.h"
|
2017-02-16 16:06:23 +01:00
|
|
|
#include "name.h"
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
namespace MultiArrayTools
|
|
|
|
{
|
2017-05-22 18:21:14 +02:00
|
|
|
|
2017-02-16 11:20:40 +01:00
|
|
|
class IndefinitIndexBase
|
|
|
|
{
|
|
|
|
public:
|
2017-02-22 00:43:38 +01:00
|
|
|
DEFAULT_MEMBERS(IndefinitIndexBase);
|
2017-02-22 19:06:23 +01:00
|
|
|
virtual ~IndefinitIndexBase();
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
virtual IndefinitIndexBase& operator=(size_t pos) = 0;
|
|
|
|
virtual IndefinitIndexBase& operator++() = 0;
|
|
|
|
virtual IndefinitIndexBase& operator--() = 0;
|
|
|
|
virtual IndefinitIndexBase& operator+=(int n) = 0;
|
|
|
|
virtual IndefinitIndexBase& operator-=(int n) = 0;
|
2017-02-17 18:10:03 +01:00
|
|
|
|
|
|
|
// Make this somehow better... !!!
|
|
|
|
//virtual bool operator==(const IndefinitIndexBase& i) = 0;
|
|
|
|
//virtual bool operator!=(const IndefinitIndexBase& i) = 0;
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
virtual size_t dim() const = 0;
|
2017-02-21 17:41:48 +01:00
|
|
|
virtual size_t pos() const;
|
2017-02-20 19:14:22 +01:00
|
|
|
|
2017-02-17 18:10:03 +01:00
|
|
|
virtual MultiRangeType rangeType() const = 0;
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
virtual void setPos(size_t pos);
|
2017-03-13 19:04:24 +01:00
|
|
|
virtual void setPosRel(int relPos);
|
2017-03-13 11:06:44 +01:00
|
|
|
|
2017-05-22 18:21:14 +02:00
|
|
|
virtual IndefinitIndexBase& toFirst();
|
|
|
|
virtual IndefinitIndexBase& toLast();
|
|
|
|
|
2017-03-08 20:10:11 +01:00
|
|
|
virtual size_t max() const = 0;
|
2017-03-13 19:04:24 +01:00
|
|
|
virtual int outOfRange() const;
|
2017-05-22 18:21:14 +02:00
|
|
|
virtual bool atEdge() const;
|
2017-02-21 17:41:48 +01:00
|
|
|
virtual bool toNull() const;
|
2017-02-22 13:34:32 +01:00
|
|
|
|
|
|
|
virtual void eval() = 0;
|
2017-03-13 16:24:00 +01:00
|
|
|
virtual void evalMajor();
|
2017-03-13 19:04:24 +01:00
|
|
|
virtual void evalMajor(int num);
|
2017-02-22 13:34:32 +01:00
|
|
|
virtual bool master();
|
|
|
|
|
|
|
|
virtual void subOrd(IndefinitIndexBase* major);
|
2017-03-13 11:06:44 +01:00
|
|
|
virtual size_t giveSubStepSize(IndefinitIndexBase* subIndex) = 0;
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
2017-03-13 19:04:24 +01:00
|
|
|
int mPos;
|
2017-05-22 18:21:14 +02:00
|
|
|
std::map<IndefinitIndexBase*,size_t> mMajor;
|
2017-02-16 11:20:40 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
template <class Index>
|
|
|
|
class IndexBase : public IndefinitIndexBase
|
|
|
|
{
|
|
|
|
public:
|
2017-02-22 00:43:38 +01:00
|
|
|
|
2017-02-28 11:27:23 +01:00
|
|
|
typedef IndefinitIndexBase IIB;
|
|
|
|
|
2017-02-22 00:43:38 +01:00
|
|
|
DEFAULT_MEMBERS(IndexBase);
|
|
|
|
IndexBase(RangeBase<Index> const* range);
|
2017-02-16 11:20:40 +01:00
|
|
|
|
2017-02-17 18:10:03 +01:00
|
|
|
//virtual size_t pos() const override; // = mPos; implement !!!
|
|
|
|
virtual size_t max() const override;
|
2017-02-21 17:41:48 +01:00
|
|
|
virtual bool toNull() const override;
|
|
|
|
|
|
|
|
virtual void assignRange(RangeBase<Index> const* range);
|
2017-02-22 13:34:32 +01:00
|
|
|
|
2017-03-01 10:41:29 +01:00
|
|
|
virtual void eval() override;
|
2017-02-28 19:29:52 +01:00
|
|
|
virtual void copyPos(const Index& in) = 0;
|
2017-02-16 11:20:40 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
// translate index into position
|
|
|
|
virtual size_t evaluate(const Index& in) const = 0;
|
2017-02-21 17:41:48 +01:00
|
|
|
RangeBase<Index> const* mRange;
|
2017-02-16 11:20:40 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#include "index_base.cc"
|
|
|
|
|
|
|
|
#endif
|