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中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(详细信

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

Redis Cluster模式配置

《RedisCluster模式配置》:本文主要介绍RedisCluster模式配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录分片 一、分片的本质与核心价值二、分片实现方案对比 ‌三、分片算法详解1. ‌范围分片(顺序分片)‌2. ‌哈希分片3. ‌虚