轮询分区的设置

终于可以写MPI了,没想到,刚开始就当头一棒,我按照之前的配置MPI环境,配置完成就报错

好家伙,仔细检查了每一个步骤都没找到问题,上网搜索了一些解决方案,也没有解决。所幸,在配置MPI环境时保存了之前的版本, 又重新配置了MPI环境,还好没问题,不得不说,有时候写代码真的跟玄学一样,但保存备份真的是一个无比好的习惯,赞颂。

目前正在计划实现下面两个阶段

创建网络阶段:主要是神经元的创建和 神经元的连接。

SNN分区阶段:主要是对SNN网络进行分区比如轮询方式,均匀的分配每一个神经元

这两个阶段都在ConnectionManager中实现

	// 神经元的邻接表
	std::vector<std::vector<int>> global_adjacency;
	// 本地的邻接表
	std::vector<std::vector<int>> local_adjcency;
	//本地的突触集合
	std::vector<int> local_node_gids;

	//本地神经元集合
	std::vector<  Neuron* > local_nodes;
	//本地突触集合
	std::vector< std::vector< Synapse* > > local_synapases;

主要是对这些变量进行修改。

目前已经实现了网络的创建阶段,又实现了一个简单的轮询分区阶段

void PartitionManager::perform_partitioning(const std::vector<std::vector<int>>& global_adjacency, std::vector<std::vector<int>>* local_adjacency, std::vector<int>* local_node_gids)
{

    partition.resize(global_adjacency.size());
    int nPart = kernel().mpi_manager.get_num_processes();
    int rank = kernel().mpi_manager.get_rank();
    for (int i = 0; i < partition.size(); i++) {
        partition[i] = i % nPart;
    }
    
    for (int ii = 0; ii < global_adjacency.size(); ii++)
    {
        if (rank == partition[ii])
        {
            local_node_gids->push_back(ii);
        }
        for (int jj = 0; jj < global_adjacency[ii].size(); jj++)
        {
            //如果与这个节点连接的节点也在该进程
            if (partition[global_adjacency[ii][jj]] == rank)
            {
                (*local_adjacency)[ii].push_back(global_adjacency[ii][jj]);
            }
        }
    }
}

我们将分区的数量与进程的数据保持了一致, 创建了如下

代码执行效果为:

还是很符合预期的。

现在最大的问题是:因为创建SNN网络的时候,种群之间的连接是随机的。如果每个进程都执行一次SNN创建,那么不同进程肯定得到不一样的邻接表。

目前的想法就是设立一个主进程。网络的创建在主进程中实现,然后再分发给其他进程。或者保证每个进程的SNN创建是相同的。

愁人啊

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/222842.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

netty07-粘包半包以及解决方案

粘包指的是发送方在发送数据时&#xff0c;多个数据包被合并成一个大的数据包发送到接收方&#xff0c;接收方在接收时无法准确地区分各个数据包的边界&#xff0c;从而导致数据粘在一起。 半包指的是发送方发送的数据包被拆分成了多个小的数据包&#xff0c;在接收方接收时&a…

C# Onnx 阿里达摩院开源DAMO-YOLO目标检测

效果 模型信息 Inputs ------------------------- name&#xff1a;images tensor&#xff1a;Float[1, 3, 192, 320] --------------------------------------------------------------- Outputs ------------------------- name&#xff1a;output tensor&#xff1a;Float…

批发订货系统一般有哪几种形式

批发订货系统一般有三种方式&#xff1a; 第一种是SaaS&#xff0c;这种方式软件厂商开一个账号&#xff0c;使用的企业仅使用里面的一个账号&#xff0c;给客户进行订货&#xff0c;有的甚至没有独立的小程序&#xff0c;需要进入软件厂商的APP进行订货&#xff0c;这种方法的…

从钓鱼邮件溯源到反制上线

背景 某天下午紧急接到一个溯源的活儿&#xff1a;客户收到一封可疑邮件&#xff0c;要求判断是否为钓鱼邮件&#xff0c;如果是钓鱼邮件&#xff0c;则要求尽可能找到人员信息。由于保密要求&#xff0c;所以部分信息必须厚码&#xff0c;请各位师傅见谅。 邮件内容如下&…

识别和修复网站上损坏链接的最佳实践

如果您有一个网站&#xff0c;我们知道您花了很多时间在它上面&#xff0c;以使其成为最好的资源。如果你的链接不起作用&#xff0c;你的努力可能是徒劳的。您网站上的断开链接可能会以两种方式损害您的业务&#xff1a; 它们对企业来说是可怕的&#xff0c;因为当消费者点击…

​DeepMind:开发出可以向人类学习的人工智能

Nature发表了一篇Google DeepMind的研究成果&#xff1a;研究人员在3D模拟环境中使用神经网络和强化学习&#xff0c;展示了AI智能体如何在没有直接从人类那里获取数据的情况下&#xff0c;通过观察来学习和模仿人类的行为。 这项研究被视为向人工通用智能&#xff08;AGI&…

Google难架马甲多

今年谷歌上架的难度可谓是地狱级别。 可是国内马甲这么多&#xff0c;总要摸索出一些套路来。 这里总结几条开源aab混淆策略。 1、as自带混淆是必要的&#xff0c;否则就是源码提包&#xff0c;相当于到谷歌门口举个牌子说我是马甲包。 不仅要驳回&#xff0c;还要被封号。…

【Trino权威指南(第二版)】Trino介绍:trino解决大数带来的问题

文章目录 一. 大数据带来的问题二. Trino来救场1. 为性能和规模而生2. SQL-on-Anything3. 数据存储与查询计算资源分离 三. Trino使用场景 一. 大数据带来的问题 数据现状 数据存储机制日益多样&#xff1a;关系型数据库、NoSQL数据库、文档数据库、键值存储和对象存储系统等。…

Python中的并发编程(1)并发相关概念

并发和并行 并发和并行 并发指逻辑上同时处理多件事情&#xff0c;并行指实际上同时做多件事情。 并发不一定通过并行实现&#xff0c;也可以通过多任务实现。例如&#xff1a;现代操作系统都可以同时执行多个任务&#xff0c;比如同时听歌和玩游戏&#xff0c;但歌曲播放和游…

每日一练【查找总价格为目标值的两个商品】

一、题目描述 题目链接 购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况&#xff0c;返回任一结果即可。 示例 1&#xff1a; 输入&#xff1a;price [3, 9, 12, 15], target 18 输出&#xff1a;[3,15] …

【MVP矩阵】投影矩阵推导与实现

相机空间和NDC空间示意图&#xff08;来自奇乐编程学院&#xff09; 相机坐标系一般都是右手坐标系, 相机朝向是 z 的负半轴 裁剪空间和NDC空间示意图 投影矩阵推导 【本文仅用于自身备忘】 正交投影推导结果如下 透视投影推导结果如下 备注 一般情况下&#xff0c;透…

Java数据结构之《希尔排序》(难度系数85)

一、前言&#xff1a; 这是怀化学院的&#xff1a;Java数据结构中的一道难度中等的一道编程题(此方法为博主自己研究&#xff0c;问题基本解决&#xff0c;若有bug欢迎下方评论提出意见&#xff0c;我会第一时间改进代码&#xff0c;谢谢&#xff01;) 后面其他编程题只要我写完…

【国金属学会指导】第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024)

JPCS独立出版/高录用快检索/院士杰青云集 第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024) 2024 11th International Conference on Advanced Manufacturing Technology and Materials Engineering 第十一届先进制造技术与材料工程国际学术会议 (AMTME 2024) 定…

高质量科技期刊分级目录汇总(附下载)

中国科协自 2019 年以来&#xff0c;分批支持全国学会面向学科领域国内外科技期刊&#xff0c;编制发布高质量期刊分级目录&#xff0c;为科技工作者发表论文和科研机构开展学术评价提供参考。截至 2023 年 11 月底&#xff0c;已有 43 家全国学会完成了所在领域首版分级目录编…

用java比较两个二叉搜索树是否等价

一. 定义树的的节点 ​ 不同二叉树的叶节点上可以保存相同的值序列。例如&#xff0c;以下两个二叉树都保存了序列 1&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;5&#xff0c;8&#xff0c;13。 package com.wedoo.coderyeah.module.iot.algorithm;import lombok.…

车联网架构设计(二)_消息缓存

在上一篇博客车联网架构设计(一)_消息平台的搭建-CSDN博客中&#xff0c;我介绍了车联网平台需要实现的一些功能&#xff0c;并介绍了如何用EMQXHAPROXY来搭建一个MQTT消息平台。车联网平台的应用需要消费车辆发布的消息&#xff0c;同时也会下发消息给车辆&#xff0c;以实现车…

ModStartCMS v7.7.0 集成内容区块,文件选择顺序

ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用&#xff0c;支持后台一键快速安装&#xff0c;让开发者能快的实现业务功能开发。 系统完全开源&#xff0c;基于 Apache 2.0 开源协议&#xff0c;免费且不限制商业使用。 功能特性 丰富的模块市…

羊大师发现,广州可能真的要下雪了!

羊大师发现&#xff0c;广州可能真的要下雪了&#xff01; 关于这次广州可能要下雪的消息&#xff0c;来源于气象部门的初步预测。据气象部门表示&#xff0c;近期广州将受到较强的冷空气影响&#xff0c;降温幅度可达5-7摄氏度&#xff0c;且湿度较大&#xff0c;这都是下雪的…

动静态IP代理是怎么实现的?如何搭建稳定独享住宅IP?

首先&#xff0c;让我们来了解一下什么是动静态IP代理。动静态IP代理是一种网络代理服务&#xff0c;它可以通过设置IP代理服务器来隐藏用户的真实IP地址&#xff0c;从而保护用户的隐私和安全。 根据是否需要手动切换IP地址&#xff0c;可以将动静态IP代理分为动态代理和静态代…

C-11练习题

一、单项选择题(本大题共20小题,每小题2分,共40分。在每小题给出的四个备选项中选出一个正确的答案,并将所选项前的字母填写在答题纸的相应位置上。) 1,在C语言中,合法的长整型常数是(&#xff09; A. OxOL B. 4962710M C. 324562& D. 216D 2,设有定义: int a[10],*pa6,*q…