array: add reform function

This commit is contained in:
Christian Zimmermann 2025-01-21 17:04:10 -08:00
parent b3cbc61718
commit 8b2efdc522
4 changed files with 87 additions and 52 deletions

View file

@ -158,6 +158,16 @@ namespace CNORXZ
return operator()(yindexPtr(pack)); return operator()(yindexPtr(pack));
} }
template <typename T>
CArrayBase<T>& CArrayBase<T>::reform(const RangePtr& range)
{
CXZ_ASSERT(this->formatIsTrivial(),
"original format non-trivial; can only reform if trivial");
this->checkFormatCompatibility(range->begin());
mRange = range;
return *this;
}
/*=================================================================+ /*=================================================================+
| Implementations for protected CArrayBase member functions | | Implementations for protected CArrayBase member functions |
+=================================================================*/ +=================================================================*/

View file

@ -37,12 +37,12 @@ namespace CNORXZ
DEFAULT_MEMBERS(CArrayBase); /**< default constructors and assignments */ DEFAULT_MEMBERS(CArrayBase); /**< default constructors and assignments */
/** construct container on a range /** construct container on a range.
@param range @param range.
*/ */
CArrayBase(const RangePtr& range); CArrayBase(const RangePtr& range);
/** default destructor */ /** default destructor. */
virtual ~CArrayBase() = default; virtual ~CArrayBase() = default;
/** Return unique pointer copy of itself. */ /** Return unique pointer copy of itself. */
@ -51,104 +51,110 @@ namespace CNORXZ
/** const data element access. /** const data element access.
If the array's format is trivial or the index is already non-trivially formatted, If the array's format is trivial or the index is already non-trivially formatted,
this is equivalent to data()[i.pos()]. Otherwise, the array's format is applied. this is equivalent to data()[i.pos()]. Otherwise, the array's format is applied.
@tparam I index type @tparam I index type.
@tparam M meta data type @tparam M meta data type.
@param i index @param i index.
*/ */
template <typename I, typename M> template <typename I, typename M>
const T& operator[](const IndexInterface<I,M>& i) const; const T& operator[](const IndexInterface<I,M>& i) const;
/** const data element access /** const data element access.
performs compatibility checks Performs compatibility checks.
@tparam I index type @tparam I index type.
@tparam M meta data type @tparam M meta data type.
@param i index @param i index.
*/ */
template <typename I, typename M> template <typename I, typename M>
const T& at(const IndexInterface<I,M>& i) const; const T& at(const IndexInterface<I,M>& i) const;
/** const data element access /** const data element access.
@tparam I index type @tparam I index type.
@tparam M meta data type @tparam M meta data type.
@param pack static index pack @param pack static index pack.
*/ */
template <class... Indices> template <class... Indices>
const T& operator[](const SPack<Indices...>& pack) const; const T& operator[](const SPack<Indices...>& pack) const;
/** const data element access /** const data element access.
performs compatibility checks Performs compatibility checks.
@tparam I index type @tparam I index type.
@tparam M meta data type @tparam M meta data type.
@param i static index pack @param i static index pack.
*/ */
template <class... Indices> template <class... Indices>
const T& at(const SPack<Indices...>& pack) const; const T& at(const SPack<Indices...>& pack) const;
/** const data element access /** const data element access.
@param pack index pack @param pack index pack.
*/ */
const T& operator[](const DPack& pack) const; const T& operator[](const DPack& pack) const;
/** const data element access /** const data element access.
performs compatibility checks Performs compatibility checks.
@param i index pack @param i index pack.
*/ */
const T& at(const DPack& pack) const; const T& at(const DPack& pack) const;
/** create hypercubic slice from this container /** Create hypercubic slice from this container.
@tparam I type of index used to indicate slice edges @tparam I type of index used to indicate slice edges.
@tparam M index meta type @tparam M index meta type.
@param begin begin edge @param begin begin edge.
@param end end edge @param end end edge.
*/ */
template <typename I, typename M> template <typename I, typename M>
Sptr<CArrayBase<T>> sl(const IndexInterface<I,M>& begin, Sptr<CArrayBase<T>> sl(const IndexInterface<I,M>& begin,
const IndexInterface<I,M>& end) const; const IndexInterface<I,M>& end) const;
/** create operation on this container. /** Create operation on this container.
Caution: might modify the index format. Caution: might modify the index format.
@tparam Index type of operation index @tparam Index type of operation index.
@param i operation index @param i operation index.
*/ */
template <class Index> template <class Index>
COpRoot<T,Index> operator()(const Sptr<Index>& i) const; COpRoot<T,Index> operator()(const Sptr<Index>& i) const;
/** create operation on this container /** Create operation on this container.
@tparam Indices types of operation indices @tparam Indices types of operation indices.
@param pack pack of operation index @param pack pack of operation index.
*/ */
template <class... Indices> template <class... Indices>
inline decltype(auto) operator()(const SPack<Indices...>& pack) const; inline decltype(auto) operator()(const SPack<Indices...>& pack) const;
/** create operation on this container /** Create operation on this container.
@param pack pack of operation index @param pack pack of operation index.
*/ */
inline decltype(auto) operator()(const DPack& pack) const; inline decltype(auto) operator()(const DPack& pack) const;
/** get pointer to container data */ /** get pointer to container data. */
virtual const T* data() const = 0; virtual const T* data() const = 0;
/** get number of elements in the container */ /** get number of elements in the container. */
virtual SizeT size() const; virtual SizeT size() const;
/** get container range */ /** get container range. */
virtual RangePtr range() const; virtual RangePtr range() const;
/** get index pointing to first position */ /** get index pointing to first position. */
virtual const_iterator begin() const; virtual const_iterator begin() const;
/** get index pointing to position after last position */ /** get index pointing to position after last position. */
virtual const_iterator end() const; virtual const_iterator end() const;
/** get index pointing to first position */ /** get index pointing to first position. */
virtual const_iterator cbegin() const = 0; virtual const_iterator cbegin() const = 0;
/** get index pointing to position after last position */ /** get index pointing to position after last position. */
virtual const_iterator cend() const = 0; virtual const_iterator cend() const = 0;
/** check if container views the data, i.e. it does not own it */ /** check if container views the data, i.e. it does not own it. */
virtual bool isView() const = 0; virtual bool isView() const = 0;
/** Exchange container range.
Original format is required to be trivial in order to work.
@param range New container range.
*/
CArrayBase& reform(const RangePtr& range);
/** Perform compatibility checks /** Perform compatibility checks
@tparam Acc index type or index pack type @tparam Acc index type or index pack type
@param acc index or index pack. @param acc index or index pack.
@ -168,8 +174,8 @@ namespace CNORXZ
/** Get valid data index. /** Get valid data index.
Create well-formated index from index pack (unformatted) Create well-formated index from index pack (unformatted)
or index using trivial format. or index using trivial format.
@tparam Acc index type or index pack type @tparam Acc index type or index pack type.
@param acc index or index pack @param acc index or index pack.
*/ */
template <class Acc> template <class Acc>
const_iterator itLex(const Acc& acc) const; const_iterator itLex(const Acc& acc) const;
@ -178,8 +184,8 @@ namespace CNORXZ
Create well-formated index from index pack (unformatted) Create well-formated index from index pack (unformatted)
or index using trivial format. or index using trivial format.
Perform compatibility checks. Perform compatibility checks.
@tparam Acc index type or index pack type @tparam Acc index type or index pack type.
@param acc index or index pack @param acc index or index pack.
*/ */
template <class Acc> template <class Acc>
const_iterator itLexSave(const Acc& acc) const; const_iterator itLexSave(const Acc& acc) const;
@ -187,8 +193,8 @@ namespace CNORXZ
}; };
/** **** /** ****
Abstract container base class Abstract container base class.
read and write access to the data Read and write access to the data.
@tparam T data type @tparam T data type
*/ */

View file

@ -255,6 +255,17 @@ namespace CNORXZ
mBuf.resize(0); mBuf.resize(0);
mMap.resize(0); mMap.resize(0);
} }
template <typename T>
template <class RangeI, class RangeK>
RCArray<T>& RCArray<T>::reform(const Sptr<RRange<RangeI,RangeK>>& range)
{
mA->reform(range->local());
CXZ_ASSERT(mGeom->size() == range->geom()->size(), "tried to reform geo range");
mGlobal = range;
return *this;
}
/*==============+ /*==============+
| RArray | | RArray |

View file

@ -136,7 +136,15 @@ namespace CNORXZ
/** Clear data loaded from other ranks. */ /** Clear data loaded from other ranks. */
void clear() const; void clear() const;
/** Replace the container range. Geometry cannot be changed.
The original range format is required to be trivial.
@param range New container range.
*/
template <class RangeI, class RangeK>
RCArray& reform(const Sptr<RRange<RangeI,RangeK>>& range);
protected: protected:
ObjHandle<CArrayBase<T>> mA; ObjHandle<CArrayBase<T>> mA;
RangePtr mGeom; RangePtr mGeom;