(原)测试intel的并行计算pafor
转载请注明出处:
http://www.cnblogs.com/darkknightzh/p/4988264.html
参考网址:
关于mt19937:http://www.cnblogs.com/egmkang/archive/2012/09/06/2673253.html
代码如下:
#include "stdafx.h"
#include <iostream>
#include <random> // mt19937的头文件
#include <ppl.h> // parfor的头文件
#include <windows.h> // QueryPerformanceFrequency等函数的头文件 using namespace concurrency; // parfor使用
using namespace std; // 分配内存
void AllocMatrix(double** m, size_t n)
{
*m = new double[n*n];
memset(*m, , sizeof(double)*n*n);
} // 初始化矩阵内容
template <class Gen>
void IniMatrix(double* m, size_t n, Gen& gen)
{
for (size_t i = ; i < n; ++i)
{
for (size_t j = ; j < n; ++j)
{
m[i*n + j] = static_cast<double>(gen());
}
}
} // 释放内存
void FreeMatrix(double** m)
{
if (nullptr != *m)
{
delete[](*m);
(*m) = nullptr;
}
} // 矩阵相乘,使用for
void matrixMultiplyFor(double* res, const double* m1, const double* m2, size_t n)
{
for (size_t i = ; i < n; i++)
{
for (size_t j = i; j < n; j++)
{
double temp = ;
for (size_t k = ; k < n; k++)
{
temp += m1[i * n + k] * m2[k * n + j];
}
res[i*n + j] = temp;
}
}
} // 矩阵相乘,外层使用parfor
void matrixMultiplyParForOuter(double* res, const double* m1, const double* m2, size_t n)
{
parallel_for(size_t(), n, [&](size_t i)
{
for (size_t j = i; j < n; j++)
{
double temp = ;
for (size_t k = ; k < n; k++)
{
temp += m1[i * n + k] * m2[k * n + j];
}
res[i*n + j] = temp;
}
});
} // 矩阵相乘,内层使用parfor
void matrixMultiplyParForInner(double* res, const double* m1, const double* m2, size_t n)
{
for (size_t i = ; i < n; i++)
{
parallel_for(size_t(i), n, [&](size_t j)
{
double temp = ;
for (size_t k = ; k < n; k++)
{
temp += m1[i * n + k] * m2[k * n + j];
}
res[i*n + j] = temp;
});
}
} // 测试矩阵相乘,使用for的时间
double testmatrixMultiplyFor(double* res, const double* m1, const double* m2, size_t n)
{
LARGE_INTEGER nFreq, nBeginTime, nEndTime;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&nBeginTime); matrixMultiplyFor(res, m1, m2, n); QueryPerformanceCounter(&nEndTime);
return (double)(nEndTime.QuadPart - nBeginTime.QuadPart) * / (double)nFreq.QuadPart;
} // 测试矩阵相乘,外层使用parfor的时间
double testmatrixMultiplyParForOuter(double* res, const double* m1, const double* m2, size_t n)
{
LARGE_INTEGER nFreq, nBeginTime, nEndTime;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&nBeginTime); matrixMultiplyParForOuter(res, m1, m2, n); QueryPerformanceCounter(&nEndTime);
return (double)(nEndTime.QuadPart - nBeginTime.QuadPart) * / (double)nFreq.QuadPart;
} // 测试矩阵相乘,内层使用parfor的时间
double testmatrixMultiplyParForInner(double* res, const double* m1, const double* m2, size_t n)
{
LARGE_INTEGER nFreq, nBeginTime, nEndTime;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&nBeginTime); matrixMultiplyParForInner(res, m1, m2, n); QueryPerformanceCounter(&nEndTime);
return (double)(nEndTime.QuadPart - nBeginTime.QuadPart) * / (double)nFreq.QuadPart;
} // 主函数
int _tmain(int argc, _TCHAR* argv[])
{
const size_t n = ;
double* dM1 = NULL;
double* dM2 = NULL;
double* dRes1 = NULL;
double* dRes2 = NULL;
double* dRes3 = NULL; random_device rd;
mt19937 gen(rd()); AllocMatrix(&dM1, n);
AllocMatrix(&dM2, n);
IniMatrix(dM1, n, gen);
IniMatrix(dM2, n, gen); AllocMatrix(&dRes1, n);
AllocMatrix(&dRes2, n);
AllocMatrix(&dRes3, n); double dTimeFor = testmatrixMultiplyFor(dRes1, dM1, dM2, n);
double dTimeParForOuter = testmatrixMultiplyParForOuter(dRes2, dM1, dM2, n);
double dTimeParForInner = testmatrixMultiplyParForInner(dRes3, dM1, dM2, n); printf("time(ms)\nfor: %f \nparforOunter: %f \nparforInner: %f\n", dTimeFor, dTimeParForOuter, dTimeParForInner); FreeMatrix(&dM1);
FreeMatrix(&dM2);
FreeMatrix(&dRes1);
FreeMatrix(&dRes2);
FreeMatrix(&dRes3); return ;
}
debug:
time(ms)
for: 7761.769099
parforOunter: 3416.670736
parforInner: 3423.701265
release:
time(ms)
for: 3884.167485
parforOunter: 1062.581817
parforInner: 1083.642302
说明:此处测试outer和inner是因为,matlab里面,使用outer形式的并行计算,使用parfor后,如果循环比对类似这种三角形式,最终有些核先跑完结果,有些核后跑完结果,导致出现,一个核累死累活的跑程序,另外N-1个核围观的状态,使最终的计算时间变长(不过在matlab中未测试outer和inner使用parfor的时间对比)。
但是,在C++里面,不知道是否优化的原因,outer使用parfor比inner使用parfor要快。此处测试了n=2048,结果也是outer比inner的形式要快。
(原)测试intel的并行计算pafor的更多相关文章
- (原)测试 Java中Synchronized锁定对象的用法
今天再android_serial_port中看到了关键字 synchronized;因为刚好在学java和android,所以就查了一下它的用法: 于是把代码中的一小段代码拿了出来,做了一下修改,测 ...
- 【原】C++11并行计算 — 数组求和
本文转载请注明出处 -- polobymulberry-博客园 0x00 - 前言 最近想优化ORB-SLAM2,准备使用并行计算来提高其中ORB特征提取的速度.之前对并行计算方面一窍不通.借此机会, ...
- Intel MKL函数,如何得到相同的计算结果?【转】
在运行程序时,我们总希望多次运行的结果,是完全一致,甚至在不同的机器与不同的OS中,程序运行的结果每一位都完全相同. 事实上,程序往往很难保证做到这一点. 为什么呢? 我们先看一个简单的例子: 当程序 ...
- 手机发烫是为何—— App 电量测试定位方法
为什么要做电量测试 随着移动互联网的快速发展,手机的实用性.娱乐性越来越强.日常使用中发现,安装了应用后,即使不怎么使用,电量也会消耗很快.但如果恢复出场设置充满电后,手机可以待机很长时间.真相只有一 ...
- MongoDB 副本集丢失数据的测试
在MongoDB副本集的测试中发现了一个丢数据的案例. 1. 概要描述 测试场景为:一主一从一验证 测试案例 step1 :关闭从副本: step 2 :向主副本中插入那条数据: step 3 :关闭 ...
- (原创)发布一个c++11开发的轻量级的并行Task库TaskCpp
TaskCpp简介 TaskCpp是c++11开发的一个跨平台的并行task库,它的设计思路来源于微软的并行计算库ppl和intel的并行计算库tbb,关于ppl和tbb我在前面有介绍.既然已经有了这 ...
- 【AR实验室】mulberryAR:并行提取ORB特征
本文转载请注明出处 —— polobymulberry-博客园 0x00 - 前言 在[AR实验室]mulberryAR : ORBSLAM2+VVSION末尾提及了iPhone5s真机测试结果,其中 ...
- tfs 分支
集团-IT部张强 11:15:211.主干时刻处于稳定状态,随时可以发布.设专门人员对主干代码进行管理,普通开发人员只读. 2.为开发任务建立开发分支.常规的可以以小组为单位建立分支,较大的任务可以建 ...
- 单元测试_JUnit4的应用与实践
本文实例为:JUnit4+Eclipse+CVS的实践 目录 1.测试环境搭建 1.1 JDK安装部署 1.2 Eclipse安装部署 1.3 Eclipse添加JUnit4 1.4 CVS项目文件引 ...
随机推荐
- org.hibernate.service.jndi.JndiException: Error parsing JNDI name []
我的hibernate.cfg.xml文件如下: <?xml version="1.0" encoding="UTF-8"?> <!DOCTY ...
- 使用MSSM管理工具登录LOCALDB
调试程序没有安装 sql server时,可以使用localdb.这是一个简易的sql server数据库,用于本地测试是很方便,省去安装SQL SERVER的工作 电脑上安装了VS2013 VS20 ...
- python 画正弦曲线
要画正弦曲线先设定一下x的取值范围,从0到2π.要用到numpy模块. numpy.pi 表示π numpy.arange( 0 , 2π ,0.01) 从0到2π,以0.01步进. 令 x=num ...
- 在JasperReport中填充JavaBean(4)
使用Parameters参数对象传递字符串的示例,本节将演示打印List接口中Userinfo.java实体类的示例,打印的数据源不是来自于Parameters对象,而是JRBeanCollectio ...
- LoadRunner利用ODBC编写MySql脚本
最近做了几周的LoadRunner测试,有一些心得,记录下来,以便以后查找. LoadRunner测试数据库是模拟客户端去连接数据库服务器,因此,需要协议(或者说驱动的支持).LoadRunner本身 ...
- js各种进制数之间的转换
计算机中常用的进制数有二进制.八进制.十进制.十六进制 一.十进制 to 其他 var x = 10; // 或定义其他值均可 x.toString(n); // n 代表要转换到的进制,比如n可以为 ...
- 'ascii' codec can't decode byte 0xef in position 0: ordinal not in range(128)——引用
在Django视图函数中经常出现类似于'ascii' codec can't decode byte 0xef in position 0: ordinal not in range(128)的错误. ...
- Codeforces 366C Dima and Salad
http://codeforces.com/problemset/problem/366/C 题意:在一个冰箱里有n种水果,并且这些水果每一种都有一个美味度和一个卡路里的属性, 小明要从这些水果中选出 ...
- codechef Prime Distance On Tree(树分治+FFT)
题目链接:http://www.codechef.com/problems/PRIMEDST/ 题意:给出一棵树,边长度都是1.每次任意取出两个点(u,v),他们之间的长度为素数的概率为多大? 树分治 ...
- Qt自定义带游标的slider,在滑块正上方显示当前值(非常有意思,继承QSlider之后增加一个QLabel,然后不断移动它)
首先自定义QSlider的子类MyCustomSlider,如下所示. mycustomslider.h #ifndef MYCUSTOMSLIDER_H #define MYCUSTOMSLIDER ...