欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++集體數(shù)據(jù)交換實現(xiàn)示例講解

 更新時間:2022年11月20日 08:59:41   作者:無水先生  
這篇文章主要介紹了C++集體數(shù)據(jù)交換實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧

一、說明

到目前為止介紹的功能共享一對一的關(guān)系:即一個進程發(fā)送和一個進程接收。鏈接是通過標簽建立的。本節(jié)介紹在多個進程中調(diào)用相同參數(shù)但執(zhí)行不同操作的函數(shù)。對于一個進程,函數(shù)可能會發(fā)送數(shù)據(jù),對于另一個進程,它可能會接收數(shù)據(jù)。這些功能稱為集體操作。

二、示例和代碼

示例 47.9。使用 gather() 從多個進程接收數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <vector>
#include <string>
#include <iterator>
#include <algorithm>
#include <iostream>
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  if (world.rank() == 0)
  {
    std::vector<std::string> v;
    boost::mpi::gather<std::string>(world, "", v, 0);
    std::ostream_iterator<std::string> out{std::cout, "\n"};
    std::copy(v.begin(), v.end(), out);
  }
  else if (world.rank() == 1)
  {
    boost::mpi::gather(world, std::string{"Hello, world!"}, 0);
  }
  else if (world.rank() == 2)
  {
    boost::mpi::gather(world, std::string{"Hello, moon!"}, 0);
  }
}

Example47.9

示例 47.9 在多個進程中調(diào)用函數(shù) boost::mpi::gather()。函數(shù)是發(fā)送還是接收取決于參數(shù)。

等級為 1 和 2 的進程使用 boost::mpi::gather() 發(fā)送數(shù)據(jù)。它們將發(fā)送的數(shù)據(jù)作為參數(shù)傳遞——字符串“Hello, world!”和“你好,月亮!” – 以及數(shù)據(jù)應(yīng)傳輸?shù)降倪M程的級別。由于 boost::mpi::gather() 不是成員函數(shù),因此還必須傳遞 communicator world。

等級為 0 的進程調(diào)用 boost::mpi::gather() 來接收數(shù)據(jù)。由于數(shù)據(jù)必須存儲在某個地方,因此傳遞了一個 std::vector<std::string> 類型的對象。請注意,您必須將此類型與 boost::mpi::gather() 一起使用。不支持其他容器或字符串類型。

排名 0 的進程必須傳遞與排名 1 和 2 的進程相同的參數(shù)。這就是排名 0 的進程也傳遞 world、要發(fā)送的字符串和 0 到 boost::mpi::gather() 的原因。

如果您使用三個進程啟動示例 47.9,您好,世界!和你好,月亮!被顯示。如果仔細查看輸出,您會注意到首先寫入了一個空行。第一行是等級為 0 的進程傳遞給 boost::mpi::gather() 的空字符串。 v 中有三個字符串,它們是從等級為 0、1 和 2 的進程接收的。向量中元素的索引對應(yīng)于進程的等級。如果多次運行該示例,您將始終得到一個空字符串作為向量中的第一個元素,“Hello, world!”作為第二個元素和“你好,月亮!”作為第三個。

請注意,您不得使用超過三個進程運行示例 47.9。例如,如果您使用 -n 4 啟動 mpiexec,則不會顯示任何數(shù)據(jù)。該程序?qū)炱?,必須使?CTRL+C 中止。

必須對所有進程執(zhí)行集體操作。如果您的程序調(diào)用諸如 boost::mpi::gather() 之類的函數(shù),您必須確保該函數(shù)在所有進程中都被調(diào)用。否則就違反了 MPI 標準。因為像 boost::mpi::gather() 這樣的函數(shù)必須被所有進程調(diào)用,所以每個進程的調(diào)用通常沒有不同,如示例 47.9 所示。將前面的示例與執(zhí)行相同操作的示例 47.10 進行比較。

示例 47.10。使用 gather() 從所有進程收集數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <vector>
#include <string>
#include <iterator>
#include <algorithm>
#include <iostream>
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  std::string s;
  if (world.rank() == 1)
    s = "Hello, world!";
  else if (world.rank() == 2)
    s = "Hello, moon!";
  std::vector<std::string> v;
  boost::mpi::gather(world, s, v, 0);
  std::ostream_iterator<std::string> out{std::cout, "\n"};
  std::copy(v.begin(), v.end(), out);
}

您為所有流程中的集體操作調(diào)用函數(shù)。通常函數(shù)的定義方式很清楚必須執(zhí)行哪個操作,即使所有進程都傳遞相同的參數(shù)。

示例 47.10 使用 boost::mpi::gather() 來收集數(shù)據(jù)。數(shù)據(jù)在其等級作為最后一個參數(shù)傳遞給 boost::mpi::gather() 的過程中收集。此進程收集它從所有進程接收的數(shù)據(jù)。存儲數(shù)據(jù)的向量僅供收集數(shù)據(jù)的進程使用。

boost::mpi::gather() 從所有進程收集數(shù)據(jù)。這包括收集數(shù)據(jù)的過程。在示例 47.10 中,這是等級為 0 的進程。該進程在 s 中向自身發(fā)送一個空字符串。空字符串存儲在 v 中。正如您將在以下示例中看到的,集合操作始終包括所有進程。

您可以使用任意數(shù)量的進程運行示例 47.10,因為每個進程都會調(diào)用 boost::mpi::gather()。如果您使用三個進程運行該示例,結(jié)果將與前面的示例類似。

示例 47.11。在所有進程中使用 scatter() 分散數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <vector>
#include <string>
#include <iostream>
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  std::vector<std::string> v{"Hello, world!", "Hello, moon!",
    "Hello, sun!"};
  std::string s;
  boost::mpi::scatter(world, v, s, 0);
  std::cout << world.rank() << ": " << s << '\n';
}

Example47.11

示例 47.11 介紹了函數(shù) boost::mpi::scatter()。它與 boost::mpi::gather() 相反。 boost::mpi::gather() 將來自多個進程的數(shù)據(jù)收集到一個進程中,而 boost::mpi::scatter() 將來自一個進程的數(shù)據(jù)分散到多個進程中。

示例 47.11 將來自排名為 0 的進程的 v 中的數(shù)據(jù)分散到所有進程,包括它自己。等級為 0 的進程接收到字符串“Hello, world!”在 s 中,排名為 1 的進程收到“你好,月亮!”在 s 中,等級為 2 的進程收到“Hello, sun!”秒。

示例 47.12。使用 broadcast() 向所有進程發(fā)送數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <string>
#include <iostream>
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  std::string s;
  if (world.rank() == 0)
    s = "Hello, world!";
  boost::mpi::broadcast(world, s, 0);
  std::cout << s << '\n';
}

boost::mpi::broadcast() 將數(shù)據(jù)從一個進程發(fā)送到所有進程。此函數(shù)與 boost::mpi::scatter() 之間的區(qū)別在于將相同的數(shù)據(jù)發(fā)送到所有進程。在示例 47.12 中,所有進程都收到字符串“Hello, world!”在 s 中寫下你好,世界!到標準輸出流。

示例 47.13。使用 reduce() 收集和分析數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <string>
#include <iostream>
std::string min(const std::string &lhs, const std::string &rhs)
{
  return lhs.size() < rhs.size() ? lhs : rhs;
}
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  std::string s;
  if (world.rank() == 0)
    s = "Hello, world!";
  else if (world.rank() == 1)
    s = "Hello, moon!";
  else if (world.rank() == 2)
    s = "Hello, sun!";
  std::string result;
  boost::mpi::reduce(world, s, result, min, 0);
  if (world.rank() == 0)
    std::cout << result << '\n';
}

boost::mpi::reduce() 從多個進程收集數(shù)據(jù),如 boost::mpi::gather()。但是,數(shù)據(jù)不存儲在向量中。 boost::mpi::reduce() 需要一個函數(shù)或函數(shù)對象,它將用于分析數(shù)據(jù)。

如果您使用三個進程運行示例 47.13,則排名為 0 的進程會收到字符串“Hello, sun!”結(jié)果。對 boost::mpi::reduce() 的調(diào)用收集并分析所有進程傳遞給它的字符串。它們使用函數(shù) min() 進行分析,該函數(shù)作為第四個參數(shù)傳遞給 boost::mpi::reduce()。 min() 比較兩個字符串并返回較短的一個。

如果您使用三個以上的進程運行示例 47.13,則會顯示一個空字符串,因為排名大于 2 的所有進程都會將一個空字符串傳遞給 boost::mpi::reduce()。將顯示空字符串,因為它比“Hello, sun!”短

示例 47.14。使用 all_reduce() 收集和分析數(shù)據(jù)

#include <boost/mpi.hpp>
#include <boost/serialization/string.hpp>
#include <string>
#include <iostream>
std::string min(const std::string &lhs, const std::string &rhs)
{
  return lhs.size() < rhs.size() ? lhs : rhs;
}
int main(int argc, char *argv[])
{
  boost::mpi::environment env{argc, argv};
  boost::mpi::communicator world;
  std::string s;
  if (world.rank() == 0)
    s = "Hello, world!";
  else if (world.rank() == 1)
    s = "Hello, moon!";
  else if (world.rank() == 2)
    s = "Hello, sun!";
  std::string result;
  boost::mpi::all_reduce(world, s, result, min);
  std::cout << world.rank() << ": " << result << '\n';
}

Example47.14

示例 47.14 使用函數(shù) boost::mpi::all_reduce(),它像 boost::mpi::reduce() 一樣收集和分析數(shù)據(jù)。這兩個函數(shù)之間的區(qū)別在于 boost::mpi::all_reduce() 將分析結(jié)果發(fā)送到所有進程,而 boost::mpi::reduce() 使結(jié)果僅可用于排名作為傳遞的進程最后一個參數(shù)。因此,沒有排名傳遞給 boost::mpi::all_reduce()。如果您使用三個進程運行示例 47.14,每個進程都會寫入 Hello, sun!到標準輸出流。

到此這篇關(guān)于C++集體數(shù)據(jù)交換實現(xiàn)示例講解的文章就介紹到這了,更多相關(guān)C++集體數(shù)據(jù)交換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++?常量成員函數(shù)學習筆記

    C++?常量成員函數(shù)學習筆記

    這篇文章主要為大家介紹了C++?常量成員函數(shù)學習筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • 詳解c/c++鏈式堆棧描述進制轉(zhuǎn)換問題示例

    詳解c/c++鏈式堆棧描述進制轉(zhuǎn)換問題示例

    這篇文章主要為大家介紹了c/c++鏈式堆棧描述進制轉(zhuǎn)換問題示例解析有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • 利用C/C++實現(xiàn)貪吃蛇游戲

    利用C/C++實現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細介紹了利用C/C++實現(xiàn)貪吃蛇游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 詳解C++編程中的文件流與字符串流

    詳解C++編程中的文件流與字符串流

    這篇文章主要介紹了C++編程中的文件流與字符串流,是C++入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • 一起來看看C語言線性表的線性鏈表

    一起來看看C語言線性表的線性鏈表

    這篇文章主要為大家詳細介紹了C語言線性表的線性鏈表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C語言深入探究斐波那契數(shù)列

    C語言深入探究斐波那契數(shù)列

    斐波那契數(shù)一般指斐波那契數(shù)列。 斐波那契數(shù)列(Fibonacci sequence),又稱黃金分割數(shù)列,因數(shù)學家萊昂納多·斐波那契(Leonardo Fibonacci)以兔子繁殖為例子而引入,故又稱為兔子數(shù)列
    2022-05-05
  • C++實現(xiàn)簡單的學生管理系統(tǒng)

    C++實現(xiàn)簡單的學生管理系統(tǒng)

    本文給大家分享的是使用C++實現(xiàn)的簡單的學生管理系統(tǒng)的代碼,主要是通過鏈表來實現(xiàn),非常簡潔,有需要的小伙伴可以參考下。
    2015-07-07
  • window調(diào)用api列出當前所有進程示例

    window調(diào)用api列出當前所有進程示例

    這篇文章主要介紹了window調(diào)用api列出當前所有進程示例,需要的朋友可以參考下
    2014-04-04
  • static全局變量與普通的全局變量的區(qū)別詳細解析

    static全局變量與普通的全局變量的區(qū)別詳細解析

    以下是對static全局變量與普通的全局變量的區(qū)別進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-09-09
  • C++11中的stoi & stod用法

    C++11中的stoi & stod用法

    這篇文章主要介紹了C++11中的stoi & stod用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論