我的mpi学习实践
来源:互联网 发布:python ma优化 编辑:程序博客网 时间:2024/05/19 23:26
基本学习篇
参考<并行计算导论>一书,进行学习:
安装
mpich下载地址
按照INSTALL的步骤进行安装.
编译链接执行
编译:mpicc -c cpi.c
链接:mpicc -o cpi cpi.o
执行:mpiexec -n 3 cpi //-n代表单机上使用几个节点跑
\examples\有很多例子,可以跑一些结果试试.
计算积分的例子(第一个mpi程序)
/* 程序来源: MPICH examples/cpi.c */#include "mpi.h"#include <stdio.h>double f( double a ) { return (4.0 / (1.0 + a*a)); }int main( int argc, char *argv[]){int n, myid, numprocs, i, namelen;double PI25DT = 3.141592653589793238462643;double mypi, pi, h, sum, x;double startwtime, endwtime;char processor_name[MPI_MAX_PROCESSOR_NAME];14MPI_Init(&argc,&argv);MPI_Comm_size(MPI_COMM_WORLD,&numprocs);MPI_Comm_rank(MPI_COMM_WORLD,&myid);MPI_Get_processor_name(processor_name,&namelen);fprintf(stderr,"Process %d on %s\n", myid, processor_name);if (myid == 0) {n=10000;startwtime = MPI_Wtime();}MPI_Bcast(&n, 1, MPI_INT, 0, MPI_COMM_WORLD);h = 1.0 / (double) n;sum = 0.0;for (i = myid; i < n; i += numprocs) {x = h * ((double)i + 0.5);sum += f(x);}mypi = h * sum;MPI_Reduce(&mypi, &pi, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);if (myid == 0) {endwtime = MPI_Wtime();printf("pi is approximately %.16f, error is %.16f\n", pi, pi - PI25DT);printf("wall clock time = %f\n", endwtime-startwtime);}MPI_Finalize();return 0;}
0 0
- 我的mpi学习实践
- 我的 Intel MPI 笔记
- 我的第一个MPI并行程序
- MPI学习一 MPI基础及六个接口构成的MPI子集
- 【MPI学习3】MPI并行程序设计模式:不同通信模式MPI并行程序的设计
- 【MPI学习6】MPI并行程序设计模式:具有不连续数据发送的MPI程序设计
- 【MPI学习7】MPI并行程序设计模式:MPI的进程组和通信域
- 【MPI学习3】MPI并行程序设计模式:不同通信模式MPI并行程序的设计
- 【MPI学习6】MPI并行程序设计模式:具有不连续数据发送的MPI程序设计
- 【MPI学习7】MPI并行程序设计模式:MPI的进程组和通信域
- 我对设计模式的学习和实践的思考...
- 我的第一次UML学习和实践(上)
- 我的第一次UML学习和实践(下)
- 理论加实践,谈谈我对memcached的学习感悟!
- 大一下学期我的c++学习方面实践体会
- MPI学习二 MPI并行程序的两种基本模式
- MPI学习三 不同通信模式MPI并行程序的设计
- MPI学习六 具有不连续数据发送的MPI程序设计
- 小白学算法2.7——堆排序
- iOS开发 - Bitcode适配指南
- 电商架构及搜索引擎
- JVM调优总结 -Xms -Xmx -Xmn -Xss
- ABAP选择屏幕权限控制
- 我的mpi学习实践
- 计算机技术领域当前的主流技术及其社会需求调查报告
- 随机生成数字(ashx文件,调用上篇所写发送邮件代码)
- 获取当前JVM所有可设置的参数以及当前默认值
- 深度学习( Deep Learning )软件资源列表
- 华为OJ基础篇-字符串加解密
- java 基础(异常练习)
- iOS项目创建头文件的设置方法
- python dict list 排序专题