OpenMP环境配置222

2024-01-22 23:04
文章标签 配置 环境 222 openmp

本文主要是介绍OpenMP环境配置222,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OpenMP环境配置

MPI环境配置

欧拉黎曼函数的K阶近似OpenMP

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <omp.h>#include<time.h>
#include <windows.h>        //window环境下调用Sleep()函数包含此头文件double zeta_approximation(int s, int k)
{double result = 0.0;#pragma omp parallel for reduction(+:result)for (int i = 1; i <= k; i++) {for (int j = 1; j <= k; j++){//result += 1.0 / (pow(n, k) * pow(k, n));result += pow(-1, i+1) / pow(i+j, s);}}return result * pow(2, s);
}int main()
{int s = 20;int k = 3000;clock_t start = 0;clock_t end   = 0;double approximation = 0.0;start = clock();for (int i = 1; i <= k; i++) {for (int j = 1; j <= k; j++){//result += 1.0 / (pow(n, k) * pow(k, n));approximation += pow(-1, i + 1) / pow(i + j, s);}}approximation = approximation * pow(2, s);end = clock();printf("zeta(%d, %d) ≈ %f\n", s, k, approximation);printf("总的cpU时间 = %f\n", (end - start) / (double)CLOCKS_PER_SEC);omp_set_num_threads(4);  // 设置线程数量approximation = 0.0;start = 0;end = 0;start = clock();approximation = zeta_approximation(s, k);end = clock();printf("Zetaop(%d, %d) ≈ %f\n", s, k, approximation);printf("总的CPU时间 = %f\n", (end - start) / (double)CLOCKS_PER_SEC);return 0;
}

uuuu

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <mpi.h>
#include <time.h>double zeta_approximation(int s, int k, int rank, int num_procs)
{double result = 0.0;int start = rank * (k / num_procs) + 1;int end = (rank + 1) * (k / num_procs);if (rank == num_procs - 1) {end = k;}for (int i = start; i <= end; i++) {for (int j = 1; j <= k; j++) {result += pow(-1, i + 1) / pow(i + j, s);}}return result;
}int main(int argc, char** argv)
{int s = 20;int k = 3000;double approximation = 0.0;double total_approximation = 0.0;int rank, num_procs;MPI_Init(&argc, &argv);MPI_Comm_rank(MPI_COMM_WORLD, &rank);MPI_Comm_size(MPI_COMM_WORLD, &num_procs);double start_time = MPI_Wtime();approximation = zeta_approximation(s, k, rank, num_procs);MPI_Reduce(&approximation, &total_approximation, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);double end_time = MPI_Wtime();if (rank == 0) {printf("Zetaop(%d, %d) ≈ %f\n", s, k, total_approximation * pow(2, s));printf("总的CPU时间 = %f\n", end_time - start_time);}MPI_Finalize();return 0;
}

欧拉黎曼函数的K阶近似MPI

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <mpi.h>double zeta_approximation(int s, int k, int rank, int num_procs)
{double result = 0.0;int start = rank * (k / num_procs) + 1;int end = (rank + 1) * (k / num_procs);if (rank == num_procs - 1) {end = k;}for (int i = start; i <= end; i++) {for (int j = 1; j <= k; j++) {result += pow(-1, i + 1) / pow(i + j, s);}}return result;
}int main(int argc, char** argv)
{int s = 20;int k = 800;double approximation = 0.0;double total_approximation = 0.0;int rank, num_procs;MPI_Init(&argc, &argv);MPI_Comm_rank(MPI_COMM_WORLD, &rank);MPI_Comm_size(MPI_COMM_WORLD, &num_procs);double start_time = MPI_Wtime();approximation = zeta_approximation(s, k, rank, num_procs);MPI_Reduce(&approximation, &total_approximation, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);double end_time = MPI_Wtime();if (rank == 0) {printf("Zetaop(%d, %d) ≈ %f\n", s, k, total_approximation * pow(2, s));printf("总的CPU时间 = %f\n", end_time - start_time);}MPI_Finalize();return 0;
}

生命游戏(Game of life)

#include <omp.h>
#include <stdio.h>
#include <stdlib.h>#define M 10  // 行数
#define N 10  // 列数int count_alive_neighbors(int* grid, int row, int col)
{int count = 0;// 检查相邻细胞的生死状态for (int i = row - 1; i <= row + 1; i++) {for (int j = col - 1; j <= col + 1; j++) {if (i >= 0 && i < M && j >= 0 && j < N && !(i == row && j == col)) {count += grid[i * N + j];}}}return count;
}void update_grid(int* old_grid, int* new_grid)
{
#pragma omp parallel for collapse(2)for (int i = 0; i < M; i++) {for (int j = 0; j < N; j++) {int alive_neighbors = count_alive_neighbors(old_grid, i, j);if (old_grid[i * N + j]) {// 活细胞的规则if (alive_neighbors < 2 || alive_neighbors > 3) {new_grid[i * N + j] = 0;  // 死亡}else {new_grid[i * N + j] = 1;  // 存活}}else {// 死细胞的规则if (alive_neighbors == 3) {new_grid[i * N + j] = 1;  // 繁殖为活细胞}else {new_grid[i * N + j] = 0;  // 保持死亡}}}}
}void print_grid(int* grid)
{for (int i = 0; i < M; i++) {for (int j = 0; j < N; j++) {printf("%d ", grid[i * N + j]);}printf("\n");}printf("\n");
}int main()
{int* grid     = (int*)malloc(M * N * sizeof(int));int* new_grid = (int*)malloc(M * N * sizeof(int));// 初始化细胞状态,随机填充0和1for (int i = 0; i < M * N; i++) {grid[i] = rand() % 2;}printf("初始状态:\n");print_grid(grid);int max_steps = 10;  // 最大迭代次数for (int step = 0; step < max_steps; step++) {update_grid(grid, new_grid);printf("第 %d 回合:\n", step + 1);print_grid(new_grid);// 将新的数组代替旧数组int* temp = grid;grid = new_grid;new_grid = temp;}free(grid);free(new_grid);return 0;
}

参考资料

[1]
[2]
[3]

这篇关于OpenMP环境配置222的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/634522

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次