24#include <arccore/message_passing/Messages.h>
27#include <alien/kernels/simple_csr/SimpleCSRVector.h>
44 template <
typename ValueT>
45 BlockVectorWriterBaseT<ValueT>::BlockVectorWriterBaseT(IVector& vector)
47 , m_vector_impl(nullptr)
48 , m_block(vector.impl()->block())
49 , m_vblock(vector.impl()->vblock())
53 using namespace Alien;
55 m_vector.impl()->
template get<BackEnd::tag::simplecsr>(
false);
56 m_values = v.fullValues();
62 template <
typename ValueT>
63 LocalBlockVectorWriterT<ValueT>::LocalBlockVectorWriterT(
IVector& vector)
64 : BlockVectorWriterBaseT<ValueT>(vector)
69 template <
typename ValueT>
70 void BlockVectorWriterBaseT<ValueT>::end()
72 IMessagePassingMng* parallelMng = m_vector_impl->distribution().parallelMng();
73 m_changed = Arccore::MessagePassing::mpAllReduce(
74 parallelMng, Arccore::MessagePassing::ReduceMax, m_changed);
75 if (m_finalized or not m_changed)
78 m_vector_impl->updateTimestamp();
83 template <
typename ValueT>
84 BlockVectorWriterBaseT<ValueT>& BlockVectorWriterBaseT<ValueT>::operator=(
93 template <
typename ValueT>
94 BlockVectorWriterT<ValueT>::BlockVectorWriterT(
IVector& vector)
95 : BlockVectorWriterBaseT<ValueT>(vector)
98 using Base = BlockVectorWriterBaseT<ValueT>;
99 m_local_offset = Base::m_vector.impl()->distribution().offset();
Interface for all vectors.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --