65template<
class T1,
unsigned Dim,
class RHS,
class Op>
81 typedef typename RHS::PETE_Return_t T2;
87 T1 lhs_compressed_data;
88 T2 rhs_compressed_data;
89 LFI lhs_i(lhs_compressed_data);
90 RFI rhs_i(rhs_compressed_data);
101 typedef std::multimap< NDIndex<Dim> ,
LField<T1,Dim>* , std::less<NDIndex<Dim> > >
103 ac_recv_type recv_ac;
110 ASSIGNMSG(msg <<
"Processing send-loop for " << nprocs <<
" nodes." <<
endl);
116 bool* recvmsg =
new bool[nprocs];
118 for (iproc=0; iproc<nprocs; ++iproc) {
120 recvmsg[iproc] =
false;
126 for (lf_i = lhs.
begin_if(); lf_i != lf_e; ++lf_i) {
135 for (rv_i = range.first; rv_i != range.second; ++rv_i) {
143 int rnode = (*rv_i).second->getNode();
144 recvmsg[rnode] =
true;
151 for (rf_i = rhs.
begin_if(); rf_i != rf_e; ++rf_i) {
161 for (remote_i = range.first; remote_i != range.second; ++remote_i) {
166 int rnode = (*remote_i).second->getNode();
169 rhs_i = rf.
begin(intersection, rhs_compressed_data);
173 if (mess[rnode] == 0)
176 rhs_i.putMessage(*mess[rnode]);
183 for (iproc=0; iproc<nprocs; ++iproc)
184 if (recvmsg[iproc]) ++remaining;
190 for (iproc=0; iproc<nprocs; ++iproc) {
191 if (mess[iproc] != 0)
205 ASSIGNMSG(msg <<
" local lhs blocks and ");
208 for (lf_i = lhs.
begin_if(); lf_i != lf_e; ++lf_i) {
215 ASSIGNMSG(msg <<
"Assigning to local LField with owned = " << lo);
219 for (rf_i = rhs.
begin_if(); rf_i != rf_e; ++rf_i) {
226 ASSIGNMSG(msg <<
"Computing assignment of portion of rhs " << ro);
234 ASSIGNMSG(msg <<
"Checking for possible compressed-assign:");
235 ASSIGNMSG(msg <<
"\n rf.IsCompressed = " << c1);
236 ASSIGNMSG(msg <<
"\n lf.IsCompressed = " << c2);
237 ASSIGNMSG(msg <<
"\n ro.contains(lo) = " << c3);
241 if (c1 && c2 && c3) {
242 ASSIGNMSG(msg <<
"LHS, RHS both compressed, and rhs contains lhs, ");
250 ASSIGNMSG(msg <<
"Intersection is " << intersection <<
endl);
253 RFI rhs_i2 = rf.
begin(intersection);
259 if (rhs_i2.CanCompress(*rf.
begin(intersection)) &&
264 ASSIGNMSG(msg <<
"LHS BF is compressible, rhs_i2 compressed, ");
265 ASSIGNMSG(msg <<
"intersection contains ");
266 ASSIGNMSG(msg << la <<
", assignment ==> compress assign.");
281 ASSIGNMSG(msg <<
"Cannot do compressed assign, so do loop."<<
endl);
287 LFI lhs_i2 = lf.
begin(intersection);
301 ASSIGNMSG(msg <<
"Processing receive-loop for " << nprocs<<
" nodes."<<
endl);
304 while (remaining>0) {
312 int ndoms = rmess->
size() / (
Dim+3);
313 for (
int idom=0; idom<ndoms; ++idom) {
319 T2 rhs_compressed_data2;
320 RFI rhs_i2(rhs_compressed_data2);
321 rhs_i2.getMessage(*rmess);
325 PAssert( hit != recv_ac.end() );
333 (*rhs_i2 == *lf.
begin())) )
340 LFI lhs_i2 = lf.
begin(intersection);
347 recv_ac.erase( hit );
355 ASSIGNMSG(msg <<
"Filling GC's at end if necessary ..." <<
endl);
362 ASSIGNMSG(msg <<
"Trying to compress BareField at end ..." <<
endl);
T * value_type(const SliceIterator< T > &)
void assign(const BareField< T1, Dim > &clhs, RHS rhsp, Op op, ExprTag< false >)
void PETE_apply(const OpPeriodic< T > &, T &a, const T &b)
Inform & endl(Inform &inf)
std::string::iterator iterator
bool touches(const NDIndex< Dim > &) const
Message & putMessage(Message &m) const
bool contains(const NDIndex< Dim > &a) const
Message & getMessage(Message &m)
NDIndex< Dim > intersect(const NDIndex< Dim > &) const
bool containsAllPoints(const NDIndex< Dim > &b) const
void fillGuardCellsIfNotDirty() const
const NDIndex< Dim > & getDomain() const
ac_id_larray::const_iterator const_iterator_if
ac_id_larray::iterator iterator_if
bool compressible() const
Layout_t & getLayout() const
ac_id_larray::size_type size_if() const
const GuardCellSizes< Dim > & getGuardCellSizes() const
const NDIndex< Dim > & getOwned() const
const NDIndex< Dim > & getAllocated() const
bool IsCompressed() const
void Uncompress(bool fill_domain=true)
const iterator & begin() const
touch_range_dv touch_range_rdv(const NDIndex< Dim > &domain, const GuardCellSizes< Dim > &gc=gc0()) const
std::pair< touch_iterator_dv, touch_iterator_dv > touch_range_dv
bool send(Message *, int node, int tag, bool delmsg=true)
Message * receive_block(int &node, int &tag)
int next_tag(int t, int s=1000)
static Communicate * Comm