在 C++ 中计算两个向量的点积
本文将演示在 C++ 中计算两个向量的点积的多种方法。
点积是两个向量的相应元素的乘积之和。假设我们有两个向量-{1,2,3}
和 {4,5,6}
,这两个向量的点积是 1*4+2*5+3*6=32
。
使用 std::inner_product
在 C++ 中计算两个向量的点积
std::inner_product
是 C++ 数值算法库的一部分,包含在 <numeric>
头中。该方法计算两个范围的乘积之和,第一个范围用 begin
/end
迭代器指定,第二个范围只用 begin
指定。该函数还将 init
作为第四个参数来初始化累加器的值。返回值是给定范围的最终点积值。注意 std::inner_product
总是按照给定的顺序执行操作。
#include <iostream>
#include <vector>
#include <numeric>
#include <iterator>
using std::cout;
using std::endl;
using std::vector;
using std::copy;
int main(){
vector<int> vec1 { 1, 2, 3, 4, 5 };
vector<int> vec2 { 2, 4, 6, 8, 10 };
copy(vec1.begin(), vec1.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
copy(vec2.begin(), vec2.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
cout << "Scalar product is: "
<< inner_product(vec1.begin(), vec1.end(), vec2.begin(), 0);
cout << endl;
return EXIT_SUCCESS;
}
输出:
1; 2; 3; 4; 5;
2; 4; 6; 8; 10;
Scalar product is: 110
使用 std::transform_reduce
在 C++ 中计算两个向量的点积
与之前的方法不同,std::transform_reduce
可以不按顺序对范围进行操作,从而使性能最大化。std::transform_reduce
本质上是 std::inner_product
算法的并行化版本。下面的例子演示了函数的执行,其参数与前面的例子中传递的参数相同。
#include <iostream>
#include <vector>
#include <numeric>
#include <iterator>
using std::cout;
using std::endl;
using std::vector;
using std::copy;
using std::inner_product;
int main(){
vector<int> vec1 { 1, 2, 3, 4, 5 };
vector<int> vec2 { 2, 4, 6, 8, 10 };
copy(vec1.begin(), vec1.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
copy(vec2.begin(), vec2.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
cout << "Scalar product is: "
<< std::transform_reduce(vec1.begin(),
vec1.end(), vec2.begin(), 0);
return EXIT_SUCCESS;
}
输出:
1; 2; 3; 4; 5;
2; 4; 6; 8; 10;
Scalar product is: 110
使用 std::transform_reduce
和 std::execution::par
计算两个向量的点积
另外,还可以为 std::transform_reduce
算法指定一个执行策略。这种方法为程序员提供了更多的控制,因为程序流程可以通过定义的执行规则进行定制。尽管使用 transform_reduce
可以提高性能,但在指定并行执行策略时,应时刻注意潜在的竞争条件。
#include <iostream>
#include <vector>
#include <numeric>
#include <iterator>
#include <execution>
using std::cout;
using std::endl;
using std::vector;
using std::copy;
using std::inner_product;
int main(){
vector<int> vec1 { 1, 2, 3, 4, 5 };
vector<int> vec2 { 2, 4, 6, 8, 10 };
copy(vec1.begin(), vec1.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
copy(vec2.begin(), vec2.end(),
std::ostream_iterator<int>(cout,"; "));
cout << endl;
cout << "Scalar product is: "
<< std::transform_reduce(std::execution::par,
vec1.begin(), vec1.end(),
vec2.begin(), 0);
return EXIT_SUCCESS;
}
输出:
1; 2; 3; 4; 5;
2; 4; 6; 8; 10;
Scalar product is: 110
相关文章
在 C++ 中通过掷骰子生成随机值
发布时间:2023/04/09 浏览次数:169 分类:C++
-
本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。
在 C++ 中使用模板的链表
发布时间:2023/04/09 浏览次数:158 分类:C++
-
本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。
在 C++ 中添加定时延迟
发布时间:2023/04/09 浏览次数:142 分类:C++
-
本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。
在 C++ 中创建查找表
发布时间:2023/04/09 浏览次数:155 分类:C++
-
本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。
如何在 C++ 中把字符串转换为小写
发布时间:2023/04/09 浏览次数:63 分类:C++
-
介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码
如何在 C++ 中确定一个字符串是否是数字
发布时间:2023/04/09 浏览次数:163 分类:C++
-
本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。
如何在 c++ 中查找字符串中的子字符串
发布时间:2023/04/09 浏览次数:65 分类:C++
-
本文介绍了在 C++ 中检查一个字符串是否包含子字符串的多种方法。使用 find 方法在 C++ 中查找字符串中的子字符串
如何在 C++ 中把字符串转换为 Char 数组
发布时间:2023/04/09 浏览次数:107 分类:C++
-
本文介绍了在 C++ 中把字符串转换为 char 数组的多种方法。使用 std::basic_string::c_str 方法将字符串转换为 char 数组