42 const size_type unset = std::numeric_limits<size_type>::max();
43 distributor ios_ownership = omega.ios_sizes().ownership_by_dimension [base::_map_dim];
49 iter != last; iter++, dom_ie++) {
51 size_type ios_dis_ie = omega.ige2ios_dis_ige (base::_map_dim, 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++;
67 _ini_ioige2dis_ioige.resize (dom_ini_ownership, unset);
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;
71 _ini_ioige2dis_ioige [dom_ini_ie] = ios_mark [ios_ie];
77 _ioige2ini_dis_ioige.resize (dom_ownership, unset);
78 _ini_ioige2dis_ioige.reverse_permutation (_ioige2ini_dis_ioige);
197 const size_type unset = std::numeric_limits<size_type>::max();
202 communicator comm = omega.comm();
204 ips.
is().setstate (std::ios::badbit);
212 check_macro (version == 2,
"unsupported version="<<version<<
" domain format");
217 ini_oige.get_values (ips);
222 distributor ios_ige_ownership = omega.geo_element_ios_ownership (base::_map_dim);
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();
250 size_type dis_ige = omega.ios_ige2dis_ige (base::_map_dim, ios_ige);
251 tmp_oige [ios_ioige].set (orient, dis_ige);
254 distributor ige_ownership = omega.geo_element_ownership (base::_map_dim);
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);
280 _ini_ioige2dis_ioige.resize (ini_ioige_ownership, unset);
281 _ioige2ini_dis_ioige.resize ( ioige_ownership, unset);
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];
286 _ini_ioige2dis_ioige.dis_entry (ini_dis_ioige) = dis_ioige;
287 _ioige2ini_dis_ioige.dis_entry (dis_ioige) = ini_dis_ioige;
289 _ioige2ini_dis_ioige.dis_entry_assembly();
290 _ini_ioige2dis_ioige.dis_entry_assembly();
301 ops <<
"domain" << endl
302 << base::_name << endl
303 <<
"2 " << base::_map_dim <<
" " << dis_size() << endl;
305 distributor ini_ioige_ownership = _ini_ioige2dis_ioige.ownership();
306 distributor ige_ownership = omega.geo_element_ownership (base::_map_dim);
308 for (
size_type ioige = 0, noige = ioige_ownership.
size(); ioige < noige; ioige++) {
309 size_type ini_dis_ioige = _ioige2ini_dis_ioige [ioige];
311 size_type ige = operator[] (ioige).index();
312 size_type ios_dis_ige = omega.ige2ios_dis_ige (base::_map_dim, ige);
315 ini_oige.dis_entry_assembly();
316 ini_oige.put_values (ops);
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)