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

相关文章

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信