57     int myNumPtcles = pattr.
size();
 
   58     int numPtcles = pattr.
size();
 
   63       int otherNumPtcles = 0;
 
   64       for (
int pe = 1; pe < npes; pe++) {
 
   66         msg->
get(otherNumPtcles);
 
   68         numPtcles += otherNumPtcles;
 
   76       msg->
put(myNumPtcles);
 
   84     spap(pattr, 0, numPtcles - 1, 1, docomm);
 
   89     spap(pattr, 0, pattr.
size() - 1, 1, docomm);
 
  110   spap(pattr, i, i, 1, docomm);
 
  118           int ibase, 
int ibound, 
int istride, 
bool docomm) {
 
  133   bool okParameters = 
true;
 
  135     (*PtclDbgInform) << 
"spap() error: ibase (= " << ibase
 
  136                     << 
") < lowest index value (= " << 0 << 
")" << 
endl;
 
  137     okParameters = 
false;
 
  142     (*PtclDbgInform) << 
"spap() error: istride < 0 not implemented yet." 
  144     okParameters = 
false;
 
  147     if ((ibound < ibase) && !((ibase == 0) && (ibound == -1))) {
 
  148       (*PtclDbgInform) << 
"spap() error: ibase (= " << ibase
 
  149                        << 
") > ibound (=  " << ibound
 
  150                        << 
") not implemented yet." << 
endl;
 
  151       okParameters = 
false;
 
  155     if (((ibound - ibase) != 0) && !((ibase == 0) && (ibound == -1))) {
 
  156       (*PtclDbgInform) << 
"spap() error: istride = 0 but (ibound - ibase) = " 
  157                        << (ibound - ibase) << 
endl;
 
  158       okParameters = 
false;
 
  165   if (!okParameters) 
return; 
 
  171     int myNumPtcles = pattr.
size();
 
  173     int* numsPtcles = 
new int[npes];
 
  175     for (
int pe=0; pe<npes; pe++) {
 
  177       if (pe == mype) numsPtcles[pe] = myNumPtcles;
 
  183       int otherNumPtcles = 0;
 
  184       for (
int pe=1; pe<npes; pe++) {
 
  186         msg->
get(otherNumPtcles);
 
  188         numsPtcles[pe] = numsPtcles[pe - 1] + otherNumPtcles;
 
  191       msg2->
putmsg((
void *)numsPtcles, 
sizeof(
int), npes);
 
  196       msg->
put(myNumPtcles);
 
  204     int myPtcleIndexBegin, myPtcleIndexEnd;
 
  206       myPtcleIndexBegin = 0;
 
  207       myPtcleIndexEnd = myNumPtcles - 1;
 
  210       myPtcleIndexBegin = numsPtcles[mype - 1];
 
  211       myPtcleIndexEnd = myPtcleIndexBegin + myNumPtcles - 1;
 
  214     Index myRange(myPtcleIndexBegin, myPtcleIndexEnd, 1);
 
  215     Index requestedRange(ibase, ibound, istride);
 
  216     for (
int pe=0; pe < npes; pe++) {
 
  218         if (myNumPtcles > 0) {
 
  219           if (myRange.
touches(requestedRange)) {
 
  221             int mybase = myRequestedRange.
first();
 
  222             int mybound = myRequestedRange.
last();
 
  224                           << 
" GLOBAL ptcle index subrange (" << mybase
 
  225                           << 
" : " << mybound << 
" : " << istride
 
  229                                   ((p+item*istride) <= mybound)); item++) {
 
  233                                << pattr[p + item*istride] << 
" ";
 
  248     delete [] numsPtcles;
 
  255     int myNumPtcles = pattr.
size();
 
  257       WARNMSG(
endl << 
"spap(): Currently, if docomm=false you must specify " 
  258               << 
"an Inform object having INFORM_ALL_NODES as its " 
  259               << 
"printing-node specifier if you want to see output from " 
  260               << 
"any processor calling [e,s]pap(); the Inform object " 
  261               << 
"you're trying to use has " 
  263               << 
"N.B.: If you called setInform() and didn't also call " 
  264               << 
"setPtclDbgInform() you are getting the FldDbgInform object " 
  265               << 
"you set with setInform, which you may not have constructed " 
  266               << 
"with INFORM_ALL_NODES." << 
endl << 
endl);
 
  269     if (myNumPtcles > 0) {
 
  271                     << 
" LOCAL ptcle index range (" << ibase
 
  272                     << 
" : " << ibound << 
" : " << istride << 
")...." << 
endl;
 
  273       int length = (ibound - ibase)/istride + 1;
 
  276                             (item < length)); item++) {
 
  278                          << pattr[p + item*istride] << 
" ";
 
  285                     << 
" has no particles ...." << 
endl;
 
Inform & endl(Inform &inf)
void spap(ParticleAttrib< T > &pattr, int ibase, int ibound, int istride, bool docomm)
void pap(ParticleAttrib< T > &pattr, bool docomm)
void epap(ParticleAttrib< T > &pattr, int i, bool docomm)
void setPtclDbgInform(Inform &inform)
Index intersect(const Index &) const
bool touches(const Index &a) const
bool send(Message *, int node, int tag, bool delmsg=true)
virtual int broadcast_others(Message *, int, bool delmsg=true)
Message * receive_block(int &node, int &tag)
Message & put(const T &val)
Message & putmsg(void *, int, int=0)
Message & get(const T &cval)
int next_tag(int t, int s=1000)
static Communicate * Comm