(done) 自学 MPI (4) Environment Management Routines

url: https://hpc-tutorials.llnl.gov/mpi/environment_management_routines/


环境管理函数(例程)

这组例程用于查询和设置MPI执行环境,其用途包括初始化和终止MPI环境、查询进程标识、查询MPI库版本等。下面将介绍一些常用的例程。

例程包括:
1.MPI_Init
2.MPI_Comm_size
3.MPI_Comm_rank
4.MPI_Abort
5.MPI_Get_processor_name
6.MPI_Get_version
7.MPI_Initialized
8.MPI_Wtime
9.MPI_Wtick
10.MPI_Finalize

关于它们的具体介绍直接看参考链接,这里就不多讲了。

下面是一段 C 的样本代码(test.cpp),代码里的注释很有价值:

// test.cpp
// required MPI include file
#include "mpi.h"
#include <stdio.h>

int main(int argc, char *argv[]) {
int  numtasks, rank, len, rc;
// MPI_MAX_PROCESSOR_NAME是MPI定义的常量,表示主机名称的最大长度
char hostname[MPI_MAX_PROCESSOR_NAME];

// initialize MPI
// 初始化MPI环境
// argc:指向参数个数的指针(通常传递main函数的argc地址)
// argv:指向参数向量的指针(通常传递main函数的argv地址)
// 设置MPI环境,为进程间通信做准备
// 必须在使用任何其他MPI函数之前调用
// 所有MPI进程都会执行这个调用
MPI_Init(&argc,&argv);

// get number of tasks
// 获取通信域中的进程总数
// comm:通信域(这里是MPI_COMM_WORLD,表示包含所有进程的全局通信域)
// size:输出参数,返回通信域中的进程总数
// 让每个进程知道总共有多少个进程在并行执行
// 在代码中,numtasks变量将存储进程总数
// 如果有4个进程运行程序,所有进程的numtasks值都是4
MPI_Comm_size(MPI_COMM_WORLD,&numtasks);

// get my rank
// 取当前进程在通信域中的唯一标识符(排名)
// comm:通信域
// rank:输出参数,返回当前进程的排名(从0开始)
// 为每个进程提供一个唯一的ID,用于区分不同的进程
// 排名范围是0到size-1(size来自MPI_Comm_size)
// 在4个进程中,排名分别是0、1、2、3
MPI_Comm_rank(MPI_COMM_WORLD,&rank);

// this one is obvious
// 获取运行当前进程的主机名称
// name:输出参数,存储主机名称的字符数组
// resultlen:输出参数,返回实际名称的长度
// 获取运行进程的计算机主机名
// 在集群环境中,可以知道进程运行在哪台机器上
MPI_Get_processor_name(hostname, &len);
printf ("Number of tasks= %d My rank= %d Running on %s\n", numtasks,rank,hostname);


    // do some work with message passing


// done with MPI
// 清理MPI环境
// 清理MPI环境,释放所有MPI资源
// 必须在MPI程序结束前调用
// 调用后不能再使用任何MPI函数
// 注意:所有MPI进程都必须调用此函数
MPI_Finalize();
}

编译运行命令如下:

sudo apt-get update
sudo apt-get install mpich
sudo apt-get install openmpi-bin openmpi-doc libopenmpi-dev
mpicxx test.cpp
mpirun -np 4 ./a.out

我的电脑上运行结果如下:
在这里插入图片描述


内容概要:本文系统阐述了企业新闻发稿在生成式引擎优化(GEO)时代下的全渠道策略与效果评估体系,涵盖当前企业传播面临的预算、资源、内容与效果评估四大挑战,并深入分析2025年新闻发稿行业五大趋势,包括AI驱动的智能化转型、精准化传播、首发内容价值提升、内容资产化及数据可视化。文章重点解析央媒、地方官媒、综合门户和自媒体四类媒体资源的特性、传播优势与发稿策略,提出基于内容适配性、时间节奏、话题设计的策略制定方法,并构建涵盖品牌价值、销售转化与GEO优化的多维评估框架。此外,结合“传声港”工具实操指南,提供AI智能投放、效果监测、自媒体管理与舆情应对的全流程解决方案,并针对科技、消费、B2B、区域品牌四大行业推出定制化发稿方案。; 适合人群:企业市场/公关负责人、品牌传播管理者、数字营销从业者及中小企业决策者,具备一定媒体传播经验并希望提升发稿效率与ROI的专业人士。; 使用场景及目标:①制定科学的新闻发稿策略,实现从“流量思维”向“价值思维”转型;②构建央媒定调、门户扩散、自媒体互动的立体化传播矩阵;③利用AI工具实现精准投放与GEO优化,提升品牌在AI搜索中的权威性与可见性;④通过数据驱动评估体系量化品牌影响力与销售转化效果。; 阅读建议:建议结合文中提供的实操清单、案例分析与工具指南进行系统学习,重点关注媒体适配性策略与GEO评估指标,在实际发稿中分阶段试点“AI+全渠道”组合策略,并定期复盘优化,以实现品牌传播的长期复利效应。
【EI复现】基于主从博弈的新型城镇配电系统产消者竞价策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于主从博弈理论的新型城镇配电系统中产消者竞价策略的研究,结合IEEE33节点系统进行建模与仿真分析,采用Matlab代码实现。研究聚焦于产消者(兼具发电与用电能力的主体)在配电系统中的竞价行为,运用主从博弈模型刻画配电公司与产消者之间的交互关系,通过优化算法求解均衡策略,实现利益最大化与系统运行效率提升。文中详细阐述了模型构建、博弈机制设计、求解算法实现及仿真结果分析,复现了EI期刊级别的研究成果,适用于电力市场机制设计与智能配电网优化领域。; 适合人群:具备电力系统基础知识和Matlab编程能力,从事电力市场、智能电网、能源优化等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①学习主从博弈在电力系统中的建模方法;②掌握产消者参与电力竞价的策略优化技术;③复现EI级别论文的仿真流程与结果分析;④开展配电网经济调度与市场机制设计的相关课题研究。; 阅读建议:建议读者结合提供的Matlab代码,深入理解博弈模型的数学表达与程序实现细节,重点关注目标函数构建、约束条件处理及算法收敛性分析,可进一步拓展至多主体博弈或多时间尺度优化场景。
【BFO-BP】基于鳑鲏鱼优化算法优化BP神经网络的风电功率预测研究(Matlab代码实现)内容概要:本文研究了基于鳑鲏鱼优化算法(BFO)优化BP神经网络的风电功率预测方法,并提供了相应的Matlab代码实现。通过将生物启发式优化算法与传统BP神经网络相结合,利用鳑鲏鱼算法优化BP网络的初始权重和阈值,有效提升了模型的收敛速度与预测精度,解决了传统BP神经网络易陷入局部最优、训练效率低等问题。该方法在风电功率预测这一典型非线性时序预测任务中展现出良好的适用性和优越性,有助于提升风电并网的稳定性与调度效率。; 适合人群:具备一定机器学习与优化算法基础,从事新能源预测、电力系统调度或智能算法研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于风电场短期或超短期功率预测,提高电网调度的准确性;②作为智能优化算法与神经网络结合的典型案例,用于学习BFO等群智能算法在实际工程问题中的优化机制与实现方式;③为类似非线性系统建模与预测问题提供可复现的技术路线参考。; 阅读建议:建议读者结合Matlab代码深入理解算法实现细节,重点关注BFO算法的种群初始化、适应度函数设计、参数更新机制及其与BP网络的耦合方式,同时可通过更换数据集或对比其他优化算法(如PSO、GA)进一步验证模型性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值