Implementation of an 'IData' whose container is based on a 'NumArray'. More...
Classes | |
| class | Internal |
Public Types | |
| typedef NumArrayDataT< DataType, RankValue > | ThatClass |
| typedef INumArrayDataT< DataType, RankValue > | DataInterfaceType |
| using | ExtentType = typename MDDimType<RankValue>::DimType |
| Public Types inherited from Arcane::INumArrayDataT< DataType, RankValue > | |
| typedef INumArrayDataT< DataType, RankValue > | ThatClass |
| using | ExtentType = typename MDDimType<RankValue>::DimType |
Public Member Functions | |
| NumArrayDataT (ITraceMng *trace) | |
| NumArrayDataT (const DataStorageBuildInfo &dsbi) | |
| NumArrayDataT (const NumArrayDataT< DataType, RankValue > &rhs) | |
| Integer | dimension () const override |
| Dimension. 0 for a scalar, 1 for a mono-dim array, 2 for a bi-dim array. | |
| Integer | multiTag () const override |
| Multi-tag. 0 if not multiple, 1 if multiple, 2 if multiple for MultiArray variables (obsolete). | |
| eDataType | dataType () const override |
| Data type. | |
| void | serialize (ISerializer *sbuf, IDataOperation *operation) override |
| Serializes the data by applying the operation. | |
| void | serialize (ISerializer *sbuf, Int32ConstArrayView ids, IDataOperation *operation) override |
| Serialize the data for the indices ids. | |
| MDSpan< DataType, ExtentType > | view () override |
| View of the data. | |
| MDSpan< const DataType, ExtentType > | view () const override |
| Constant view of the data. | |
| void | resize (Integer new_size) override |
| Resize the data. | |
| IData * | clone () override |
| Clone the data. The created instance must be destroyed by the 'delete' operator. | |
| IData * | cloneEmpty () override |
| Clone the data but without elements. The created instance must be destroyed by the 'delete' operator. | |
| Ref< IData > | cloneRef () override |
| Clone the data. | |
| Ref< IData > | cloneEmptyRef () override |
| Clone the data but without elements. | |
| DataStorageTypeInfo | storageTypeInfo () const override |
| Information about the data container type. | |
| Ref< DataInterfaceType > | cloneTrueRef () override |
| Clone the data. | |
| Ref< DataInterfaceType > | cloneTrueEmptyRef () override |
| Clone the data but without elements. | |
| void | fillDefault () override |
| Fills the data with its default value. | |
| void | setName (const String &name) override |
| Sets the name of the data (internal). | |
| Ref< ISerializedData > | createSerializedDataRef (bool use_basic_type) const override |
| Serialize the data. | |
| void | allocateBufferForSerializedData (ISerializedData *sdata) override |
| Allocate memory to read the serialized values sdata. | |
| void | assignSerializedData (const ISerializedData *sdata) override |
| Assign the serialized values sdata to the data. | |
| void | copy (const IData *data) override |
| Copy the data data into the current instance. | |
| void | swapValues (IData *data) override |
| Swap the values of data with those of the instance. | |
| void | computeHash (IHashAlgorithm *algo, ByteArray &output) const override |
| Compute a hash key on this data. | |
| ArrayShape | shape () const override |
| Array shape for a 1D or 2D data item. | |
| void | setShape (const ArrayShape &new_shape) override |
| Sets the array shape. | |
| void | setAllocationInfo (const DataAllocationInfo &v) override |
| Sets the allocation information. | |
| DataAllocationInfo | allocationInfo () const override |
| Allocation information. | |
| void | visit (IArray2DataVisitor *) |
| void | visit (IDataVisitor *visitor) override |
| Applies the visitor to the data. | |
| void | visitScalar (IScalarDataVisitor *) override |
| Apply the visitor to the data. | |
| void | visitArray (IArrayDataVisitor *) override |
| Apply the visitor to the data. | |
| void | visitArray2 (IArray2DataVisitor *) override |
| Apply the visitor to the data. | |
| IDataInternal * | _commonInternal () override |
| void | swapValuesDirect (ThatClass *true_data) |
| Public Member Functions inherited from Arcane::ReferenceCounterImpl | |
| void | addReference () |
| void | removeReference () |
| void | _internalAddReference () |
| bool | _internalRemoveReference () |
| Public Member Functions inherited from Arcane::IData | |
| virtual void | visitMultiArray2 (IMultiArray2DataVisitor *visitor) |
| Apply the visitor to the data. | |
Static Public Member Functions | |
| static DataStorageTypeInfo | staticStorageTypeInfo () |
Private Member Functions | |
| ARCCORE_DEFINE_REFERENCE_COUNTED_INCLASS_METHODS () | |
| INumArrayDataT< DataType, RankValue > * | _cloneTrue () const |
| INumArrayDataT< DataType, RankValue > * | _cloneTrueEmpty () const |
| void | _resizeDim1 (Int32 dim1_size) |
| Int64 | _getDim2Size () const |
| Span2< DataType > | _valueAsSpan2 () |
| Span2< const DataType > | _valueAsConstSpan2 () |
Private Attributes | |
| friend | Impl |
| NumArray< DataType, ExtentType > | m_value |
| Data. | |
| ITraceMng * | m_trace |
| ArrayShape | m_shape |
| Internal | m_internal |
| DataAllocationInfo | m_allocation_info |
Implementation of an 'IData' whose container is based on a 'NumArray'.
Definition at line 99 of file NumArrayData.cc.
| typedef INumArrayDataT<DataType, RankValue> Arcane::NumArrayDataT< DataType, RankValue >::DataInterfaceType |
Definition at line 110 of file NumArrayData.cc.
| using Arcane::NumArrayDataT< DataType, RankValue >::ExtentType = typename MDDimType<RankValue>::DimType |
Definition at line 111 of file NumArrayData.cc.
| typedef NumArrayDataT<DataType, RankValue> Arcane::NumArrayDataT< DataType, RankValue >::ThatClass |
Definition at line 109 of file NumArrayData.cc.
|
explicit |
Definition at line 222 of file NumArrayData.cc.
|
explicit |
Definition at line 242 of file NumArrayData.cc.
| Arcane::NumArrayDataT< DataType, RankValue >::NumArrayDataT | ( | const NumArrayDataT< DataType, RankValue > & | rhs | ) |
Definition at line 231 of file NumArrayData.cc.
|
override |
Definition at line 251 of file NumArrayData.cc.
|
inlineprivate |
Definition at line 211 of file NumArrayData.cc.
|
inlineprivate |
Definition at line 212 of file NumArrayData.cc.
|
inlineoverridevirtual |
Implements Arcane::IData.
Definition at line 191 of file NumArrayData.cc.
|
private |
Definition at line 299 of file NumArrayData.cc.
|
private |
Definition at line 286 of file NumArrayData.cc.
|
private |
Definition at line 333 of file NumArrayData.cc.
|
private |
Definition at line 317 of file NumArrayData.cc.
|
overridevirtual |
Allocate memory to read the serialized values sdata.
This method sets sdata->setBuffer(), which will contain the memory needed to read the serialized data.
Implements Arcane::IData.
Definition at line 390 of file NumArrayData.cc.
References ARCANE_FATAL, Arcane::ISerializedData::baseDataType(), dataType(), Arcane::ISerializedData::extents(), Arcane::ISerializedData::isMultiSize(), m_value, Arcane::ISerializedData::memorySize(), and Arcane::ISerializedData::setWritableBytes().
|
inlineoverridevirtual |
|
overridevirtual |
Assign the serialized values sdata to the data.
The buffer containing the serialization values must have be allocated by calling allocateBufferForSerializedData().
Implements Arcane::IData.
Definition at line 421 of file NumArrayData.cc.
|
inlineoverridevirtual |
Clone the data. The created instance must be destroyed by the 'delete' operator.
Implements Arcane::IData.
Definition at line 143 of file NumArrayData.cc.
|
inlineoverridevirtual |
Clone the data but without elements. The created instance must be destroyed by the 'delete' operator.
Implements Arcane::IData.
Definition at line 144 of file NumArrayData.cc.
|
inlineoverridevirtual |
Clone the data but without elements.
Implements Arcane::IData.
Definition at line 146 of file NumArrayData.cc.
References Arcane::makeRef().
|
inlineoverridevirtual |
Clone the data.
Implements Arcane::IData.
Definition at line 145 of file NumArrayData.cc.
References Arcane::makeRef().
|
inlineoverridevirtual |
Clone the data but without elements.
Implements Arcane::INumArrayDataT< DataType, RankValue >.
Definition at line 153 of file NumArrayData.cc.
References Arcane::makeRef().
|
inlineoverridevirtual |
Clone the data.
Implements Arcane::INumArrayDataT< DataType, RankValue >.
Definition at line 148 of file NumArrayData.cc.
References Arcane::makeRef().
|
overridevirtual |
Compute a hash key on this data.
The key is added to output. The length of the key depends on the algorithm used.
Implements Arcane::IData.
Definition at line 672 of file NumArrayData.cc.
References Arcane::asBytes(), Arcane::IHashAlgorithm::computeHash64(), Arcane::SpanImpl< T, SizeType, Extent >::data(), m_value, and Arcane::SpanImpl< T, SizeType, Extent >::size().
|
overridevirtual |
Copy the data data into the current instance.
The data data must be of the same type as the instance.
Implements Arcane::IData.
Definition at line 696 of file NumArrayData.cc.
References m_value.
|
overridevirtual |
Serialize the data.
For performance reasons, the returned instance may directly reference the memory area of this data. Consequently, it is only valid as long as this data is not modified. If you wish to modify this instance, you must first clone it (via IData::cloneRef()) and then serialize the cloned data.
If use_basic_type is true, the data is serialized for a basic type, namely DT_Byte, DT_Int16, DT_Int32, DT_Int64 or DT_Real. Otherwise, the type can be a POD, namely DT_Byte, DT_Int16, DT_Int32, DT_Int64, DT_Real, DT_Real2, DT_Real3, DT_Real2x2, DT_Real3x3.
Implements Arcane::IData.
Definition at line 355 of file NumArrayData.cc.
References Arcane::arcaneCreateSerializedDataRef(), dataType(), m_value, shape(), and Arcane::SpanImpl< T, SizeType, Extent >::size().
|
inlineoverridevirtual |
Data type.
Implements Arcane::IData.
Definition at line 137 of file NumArrayData.cc.
Referenced by allocateBufferForSerializedData(), and createSerializedDataRef().
|
inlineoverridevirtual |
Dimension. 0 for a scalar, 1 for a mono-dim array, 2 for a bi-dim array.
Implements Arcane::IData.
Definition at line 135 of file NumArrayData.cc.
|
overridevirtual |
Fills the data with its default value.
Implements Arcane::IData.
Definition at line 654 of file NumArrayData.cc.
References m_value.
|
inlineoverridevirtual |
Multi-tag. 0 if not multiple, 1 if multiple, 2 if multiple for MultiArray variables (obsolete).
Implements Arcane::IData.
Definition at line 136 of file NumArrayData.cc.
|
overridevirtual |
Resize the data.
This operation only makes sense for data of dimension 1 or more. If the new number of elements is greater than the old one, the values added to the data are not initialized.
Implements Arcane::IData.
Definition at line 345 of file NumArrayData.cc.
|
overridevirtual |
Serializes the data by applying the operation.
Implements Arcane::IData.
Definition at line 431 of file NumArrayData.cc.
References ARCANE_FATAL, ARCANE_THROW, Arcane::ISerializer::getSpan(), Arcane::Int32, Arcane::Int64, m_value, Arcane::ISerializer::mode(), Arcane::ISerializer::ModeGet, Arcane::ISerializer::ModePut, Arcane::ISerializer::putSpan(), Arcane::ISerializer::ReadAdd, Arcane::ISerializer::readMode(), Arcane::ISerializer::ReadReplace, and Arcane::ISerializer::reserveSpan().
|
overridevirtual |
Serialize the data for the indices ids.
This operation only makes sense for data of dimension 1 or more.
Implements Arcane::IData.
Definition at line 506 of file NumArrayData.cc.
References ARCANE_FATAL, ARCANE_THROW, Arcane::Array< T >::data(), Arcane::Span2Impl< T, SizeType, Extent1, Extent2 >::data(), Arcane::ISerializer::getSpan(), Arcane::Int32, Arcane::Int64, m_value, Arcane::ISerializer::mode(), Arcane::ISerializer::ModeGet, Arcane::ISerializer::ModePut, Arcane::ISerializer::putSpan(), Arcane::ISerializer::ReadAdd, Arcane::ISerializer::readMode(), Arcane::ISerializer::ReadReplace, Arcane::ISerializer::reserveSpan(), Arcane::Array< T >::resize(), Arcane::ConstArrayView< T >::size(), Arcane::SpanImpl< T, SizeType, Extent >::size(), and Arcane::Array< T >::view().
|
inlineoverridevirtual |
Sets the allocation information.
Implements Arcane::IData.
Definition at line 168 of file NumArrayData.cc.
|
overridevirtual |
Sets the name of the data (internal).
Implements Arcane::IData.
Definition at line 663 of file NumArrayData.cc.
|
inlineoverridevirtual |
|
inlineoverridevirtual |
Array shape for a 1D or 2D data item.
The shape is only considered for dimensions greater than 1. For a 1D data item, the shape is therefore by default {1}. For a 2D array, the shape defaults to {dim2_size}. It is possible to change the rank of the shape and its values as long as shape().totalNbElement()==dim2_size. For example, if the number of values dim2_size is 12, then it is possible to have { 12 }, { 6, 2 } or { 3, 2, 2 } as the shape.
The values are not preserved during a restart, so the shape must be repositioned in this case. It is up to the user to ensure that the shape is homogeneous across sub-domains.
Implements Arcane::IData.
Definition at line 166 of file NumArrayData.cc.
Referenced by createSerializedDataRef().
|
static |
Definition at line 262 of file NumArrayData.cc.
|
overridevirtual |
Information about the data container type.
Implements Arcane::IData.
Definition at line 277 of file NumArrayData.cc.
|
overridevirtual |
Swap the values of data with those of the instance.
The data IData must be of the same type as the instance. Only the values are swapped and other possible properties (such as the name, for example) are not modified.
Implements Arcane::IData.
Definition at line 708 of file NumArrayData.cc.
| void Arcane::NumArrayDataT< DataType, RankValue >::swapValuesDirect | ( | ThatClass * | true_data | ) |
Definition at line 720 of file NumArrayData.cc.
|
inlineoverridevirtual |
Constant view of the data.
Implements Arcane::INumArrayDataT< DataType, RankValue >.
Definition at line 141 of file NumArrayData.cc.
References m_value.
|
inlineoverridevirtual |
View of the data.
Implements Arcane::INumArrayDataT< DataType, RankValue >.
Definition at line 140 of file NumArrayData.cc.
References m_value.
|
inline |
Definition at line 170 of file NumArrayData.cc.
|
inlineoverridevirtual |
Applies the visitor to the data.
Implements Arcane::IData.
Definition at line 174 of file NumArrayData.cc.
References ARCANE_THROW.
|
inlineoverridevirtual |
Apply the visitor to the data.
If the data is not a 1D array, an exception NotSupportedException is thrown.
Implements Arcane::IData.
Definition at line 183 of file NumArrayData.cc.
References ARCANE_THROW.
|
inlineoverridevirtual |
Apply the visitor to the data.
If the data is not a 2D array, an exception NotSupportedException is thrown.
Implements Arcane::IData.
Definition at line 187 of file NumArrayData.cc.
References ARCANE_THROW.
|
inlineoverridevirtual |
Apply the visitor to the data.
If the data is not scalar, a NotSupportedException is thrown.
Implements Arcane::IData.
Definition at line 179 of file NumArrayData.cc.
References ARCANE_THROW.
|
private |
Definition at line 105 of file NumArrayData.cc.
|
private |
Definition at line 207 of file NumArrayData.cc.
|
private |
Definition at line 206 of file NumArrayData.cc.
|
private |
Definition at line 205 of file NumArrayData.cc.
|
private |
Definition at line 204 of file NumArrayData.cc.
|
private |
Data.
Definition at line 203 of file NumArrayData.cc.
Referenced by allocateBufferForSerializedData(), computeHash(), copy(), createSerializedDataRef(), fillDefault(), serialize(), serialize(), view(), and view().