42 const size_type unset = std::numeric_limits<size_type>::max();
49 iter != last; iter++, dom_ie++) {
52 size_type dom_dis_ie = first_dom_dis_ie + dom_ie;
53 ios_mark.dis_entry (ios_dis_ie) = dom_dis_ie;
55 ios_mark.dis_entry_assembly();
60 for (
size_type ios_ie = 0, ios_ne = ios_mark.size(); ios_ie < ios_ne; ios_ie++) {
61 if (ios_mark [ios_ie] != unset) dom_ini_size++;
69 for (
size_type ios_ie = 0, ios_ne = ios_mark.size(); ios_ie < ios_ne; ios_ie++) {
70 if (ios_mark [ios_ie] == unset)
continue;
197 const size_type unset = std::numeric_limits<size_type>::max();
204 ips.
is().setstate (std::ios::badbit);
212 check_macro (version == 2,
"unsupported version="<<version<<
" domain format");
217 ini_oige.get_values (ips);
224 for (
size_type ini_ioige = 0, ini_noige = ini_oige.size();
225 ini_ioige < ini_noige; ini_ioige++) {
226 size_type ios_ige = ini_oige [ini_ioige].index();
227 ios_owner [ini_ioige] = ios_ige_ownership.
find_owner (ios_ige);
233 ini_oige.repartition (
236 ios_ioige2ini_dis_ioige,
237 ini_ioige2ios_dis_ioige);
243 distributor ios_ioige_ownership = ios_oige.ownership();
245 for (
size_type ios_ioige = 0, ios_noige = ios_ioige_ownership.
size();
246 ios_ioige < ios_noige; ios_ioige++) {
248 size_type ios_dis_ige = ios_oige [ios_ioige].index();
251 tmp_oige [ios_ioige].set (orient, dis_ige);
256 for (
size_type ios_ioige = 0, ios_noige = ios_ioige_ownership.
size();
257 ios_ioige < ios_noige; ios_ioige++) {
258 size_type ige = tmp_oige [ios_ioige].index();
259 partition [ios_ioige] = ige_ownership.
find_owner (ige);
264 tmp_oige.repartition (
268 ios_ioige2dis_ioige);
272 for (
size_type ioige = 0, noige = ioige_ownership.
size(); ioige < noige; ioige++) {
273 size_type dis_ige = operator[] (ioige).index();
275 operator[] (ioige).set_index (ige);
282 for (
size_type ios_ioige = 0, ios_noige = ios_ioige_ownership.
size();
283 ios_ioige < ios_noige; ios_ioige++) {
284 size_type ini_dis_ioige = ios_ioige2ini_dis_ioige [ios_ioige];
285 size_type dis_ioige = ios_ioige2dis_ioige [ios_ioige];
301 ops <<
"domain" << endl
308 for (
size_type ioige = 0, noige = ioige_ownership.
size(); ioige < noige; ioige++) {
311 size_type ige = operator[] (ioige).index();
315 ini_oige.dis_entry_assembly();
316 ini_oige.put_values (ops);
const_iterator_ioige ioige_begin() const
const_iterator_ioige ioige_end() const
disarray< size_type, distributed > _ioige2ini_dis_ioige
size_type dis_size() const
disarray< size_type, distributed > _ini_ioige2dis_ioige
base::const_iterator_ioige const_iterator_ioige
base::size_type size_type
base::orientation_type orientation_type
check_macro(expr1.have_homogeneous_space(Xh1), "dual(expr1,expr2); expr1 should have homogeneous space. HINT: use dual(interpolate(Xh, expr1),expr2)")
bool dis_scatch(idiststream &ips, const communicator &comm, std::string ch)
distributed version of scatch(istream&,string)