{"id":"https://openalex.org/W4379802123","doi":"https://doi.org/10.1007/s11227-023-05398-7","title":"Simplifying non-contiguous data transfer with MPI for Python","display_name":"Simplifying non-contiguous data transfer with MPI for Python","publication_year":2023,"publication_date":"2023-06-07","ids":{"openalex":"https://openalex.org/W4379802123","doi":"https://doi.org/10.1007/s11227-023-05398-7"},"language":"en","primary_location":{"id":"doi:10.1007/s11227-023-05398-7","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s11227-023-05398-7","pdf_url":"https://link.springer.com/content/pdf/10.1007/s11227-023-05398-7.pdf","source":{"id":"https://openalex.org/S32326811","display_name":"The Journal of Supercomputing","issn_l":"0920-8542","issn":["0920-8542","1573-0484"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Journal of Supercomputing","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://link.springer.com/content/pdf/10.1007/s11227-023-05398-7.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5092114311","display_name":"Klaus N\u00f6lp","orcid":null},"institutions":[{"id":"https://openalex.org/I120691247","display_name":"University of Hagen","ror":"https://ror.org/04tkkr536","country_code":"DE","type":"education","lineage":["https://openalex.org/I120691247"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Klaus N\u00f6lp","raw_affiliation_strings":["Technical Computer Science, FernUniversit\u00e4t in Hagen, Hagen, Germany"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Technical Computer Science, FernUniversit\u00e4t in Hagen, Hagen, Germany","institution_ids":["https://openalex.org/I120691247"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5011121841","display_name":"Lena Oden","orcid":"https://orcid.org/0000-0002-9670-5296"},"institutions":[{"id":"https://openalex.org/I120691247","display_name":"University of Hagen","ror":"https://ror.org/04tkkr536","country_code":"DE","type":"education","lineage":["https://openalex.org/I120691247"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Lena Oden","raw_affiliation_strings":["Technical Computer Science, FernUniversit\u00e4t in Hagen, Hagen, Germany"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Technical Computer Science, FernUniversit\u00e4t in Hagen, Hagen, Germany","institution_ids":["https://openalex.org/I120691247"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5092114311"],"corresponding_institution_ids":["https://openalex.org/I120691247"],"apc_list":{"value":2390,"currency":"EUR","value_usd":2990},"apc_paid":{"value":2390,"currency":"EUR","value_usd":2990},"fwci":0.8923,"has_fulltext":true,"cited_by_count":3,"citation_normalized_percentile":{"value":0.69216702,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":91,"max":96},"biblio":{"volume":"79","issue":"17","first_page":"20019","last_page":"20040"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11181","display_name":"Advanced Data Storage Technologies","score":0.9945999979972839,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T13650","display_name":"Computational Physics and Python Applications","score":0.9761999845504761,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.9071731567382812},{"id":"https://openalex.org/keywords/python","display_name":"Python (programming language)","score":0.8859022855758667},{"id":"https://openalex.org/keywords/stencil","display_name":"Stencil","score":0.872321367263794},{"id":"https://openalex.org/keywords/speedup","display_name":"Speedup","score":0.607520580291748},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.6074337363243103},{"id":"https://openalex.org/keywords/benchmark","display_name":"Benchmark (surveying)","score":0.5116515755653381},{"id":"https://openalex.org/keywords/copying","display_name":"Copying","score":0.4101276695728302},{"id":"https://openalex.org/keywords/computational-science","display_name":"Computational science","score":0.34623146057128906},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3205620348453522}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9071731567382812},{"id":"https://openalex.org/C519991488","wikidata":"https://www.wikidata.org/wiki/Q28865","display_name":"Python (programming language)","level":2,"score":0.8859022855758667},{"id":"https://openalex.org/C76752949","wikidata":"https://www.wikidata.org/wiki/Q7607499","display_name":"Stencil","level":2,"score":0.872321367263794},{"id":"https://openalex.org/C68339613","wikidata":"https://www.wikidata.org/wiki/Q1549489","display_name":"Speedup","level":2,"score":0.607520580291748},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.6074337363243103},{"id":"https://openalex.org/C185798385","wikidata":"https://www.wikidata.org/wiki/Q1161707","display_name":"Benchmark (surveying)","level":2,"score":0.5116515755653381},{"id":"https://openalex.org/C2779151265","wikidata":"https://www.wikidata.org/wiki/Q1156791","display_name":"Copying","level":2,"score":0.4101276695728302},{"id":"https://openalex.org/C459310","wikidata":"https://www.wikidata.org/wiki/Q117801","display_name":"Computational science","level":1,"score":0.34623146057128906},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3205620348453522},{"id":"https://openalex.org/C205649164","wikidata":"https://www.wikidata.org/wiki/Q1071","display_name":"Geography","level":0,"score":0.0},{"id":"https://openalex.org/C13280743","wikidata":"https://www.wikidata.org/wiki/Q131089","display_name":"Geodesy","level":1,"score":0.0},{"id":"https://openalex.org/C199539241","wikidata":"https://www.wikidata.org/wiki/Q7748","display_name":"Law","level":1,"score":0.0},{"id":"https://openalex.org/C17744445","wikidata":"https://www.wikidata.org/wiki/Q36442","display_name":"Political science","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1007/s11227-023-05398-7","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s11227-023-05398-7","pdf_url":"https://link.springer.com/content/pdf/10.1007/s11227-023-05398-7.pdf","source":{"id":"https://openalex.org/S32326811","display_name":"The Journal of Supercomputing","issn_l":"0920-8542","issn":["0920-8542","1573-0484"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Journal of Supercomputing","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1007/s11227-023-05398-7","is_oa":true,"landing_page_url":"https://doi.org/10.1007/s11227-023-05398-7","pdf_url":"https://link.springer.com/content/pdf/10.1007/s11227-023-05398-7.pdf","source":{"id":"https://openalex.org/S32326811","display_name":"The Journal of Supercomputing","issn_l":"0920-8542","issn":["0920-8542","1573-0484"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319900","host_organization_name":"Springer Science+Business Media","host_organization_lineage":["https://openalex.org/P4310319900","https://openalex.org/P4310319965"],"host_organization_lineage_names":["Springer Science+Business Media","Springer Nature"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Journal of Supercomputing","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Quality Education","score":0.8100000023841858,"id":"https://metadata.un.org/sdg/4"}],"awards":[{"id":"https://openalex.org/G5563633617","display_name":null,"funder_award_id":"800858","funder_id":"https://openalex.org/F4320320300","funder_display_name":"European Commission"},{"id":"https://openalex.org/G7842005466","display_name":null,"funder_award_id":"Horizon 2020","funder_id":"https://openalex.org/F4320320300","funder_display_name":"European Commission"},{"id":"https://openalex.org/G8715391269","display_name":null,"funder_award_id":"800858","funder_id":"https://openalex.org/F4320332999","funder_display_name":"Horizon 2020 Framework Programme"}],"funders":[{"id":"https://openalex.org/F4320320300","display_name":"European Commission","ror":"https://ror.org/00k4n6c32"},{"id":"https://openalex.org/F4320332999","display_name":"Horizon 2020 Framework Programme","ror":"https://ror.org/00k4n6c32"}],"has_content":{"pdf":true,"grobid_xml":false},"content_urls":{"pdf":"https://content.openalex.org/works/W4379802123.pdf"},"referenced_works_count":19,"referenced_works":["https://openalex.org/W1825216778","https://openalex.org/W2245493112","https://openalex.org/W2750596392","https://openalex.org/W2891956870","https://openalex.org/W2969804086","https://openalex.org/W2971787243","https://openalex.org/W3003257820","https://openalex.org/W3005695646","https://openalex.org/W3035965352","https://openalex.org/W3046317092","https://openalex.org/W3099878876","https://openalex.org/W3102457131","https://openalex.org/W3160781636","https://openalex.org/W3164436820","https://openalex.org/W3175437177","https://openalex.org/W3205179929","https://openalex.org/W3207945374","https://openalex.org/W4200005452","https://openalex.org/W4281717161"],"related_works":["https://openalex.org/W1800827217","https://openalex.org/W2028067303","https://openalex.org/W27867058","https://openalex.org/W3122909934","https://openalex.org/W2804132206","https://openalex.org/W2020484966","https://openalex.org/W4286980019","https://openalex.org/W2795117532","https://openalex.org/W2795273189","https://openalex.org/W1985658314"],"abstract_inverted_index":{"Abstract":[0],"Python":[1,13],"is":[2,35,90],"becoming":[3],"increasingly":[4],"popular":[5],"in":[6,57,110],"scientific":[7],"computing.":[8],"The":[9],"package":[10],"MPI":[11,93,100,135],"for":[12,126],"(mpi4py)":[14],"allows":[15],"writing":[16],"efficient":[17],"parallel":[18],"programs":[19],"that":[20,89],"scale":[21],"across":[22],"multiple":[23],"nodes.":[24,116],"However,":[25],"it":[26],"does":[27],"not":[28],"support":[29,50],"non-contiguous":[30,55],"data":[31],"via":[32],"slices,":[33],"which":[34],"a":[36,72,83,87,106,111,140],"well-known":[37],"feature":[38],"of":[39,54,108],"NumPy.":[40],"In":[41,71,96],"this":[42],"work,":[43],"we":[44,77],"therefore":[45],"evaluate":[46],"several":[47],"methods":[48],"to":[49,121],"the":[51,62,65,69,79,99],"direct":[52],"transfer":[53],"arrays":[56],"mpi4py.":[58],"This":[59],"significantly":[60],"simplifies":[61],"code,":[63],"while":[64],"performance":[66,128],"basically":[67],"stays":[68],"same.":[70],"PingPong-,":[73],"Stencil-":[74],"and":[75,86],"Lattice-Boltzmann-Benchmark,":[76],"compare":[78],"common":[80],"manual":[81,123,129],"copying,":[82],"NumPy-Copy":[84],"design":[85,88,103],"based":[91],"on":[92,113],"derived":[94,101],"datatypes.":[95],"one":[97],"case,":[98],"datatype":[102],"could":[104],"achieve":[105],"speedup":[107],"15%":[109],"Stencil-Benchmark":[112],"four":[114],"compute":[115],"Our":[117],"designs":[118],"are":[119],"superior":[120],"naive":[122],"copies,":[124],"but":[125],"maximum":[127],"copies":[130],"with":[131],"pre-allocated":[132],"buffers":[133],"or":[134],"persistent":[136],"communication":[137],"will":[138],"be":[139],"better":[141],"choice.":[142]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":2}],"updated_date":"2026-05-05T08:41:31.759640","created_date":"2025-10-10T00:00:00"}
