SNAP复杂网络处理平台

2024-08-28 22:58
文章标签 平台 处理 网络 复杂 snap

本文主要是介绍SNAP复杂网络处理平台,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SNAP复杂网络处理平台

简介:这是斯坦福提供的,用于处理复杂网络的平台库,核心是使用C++编写的,效率相对很高,提供了C++和Python的接口,源代码可以在snap网站下载,也可以在github上下载。

C++

编译,安装与测试

需要安装两个相关的软件,用于绘图,GnuplotGraphviz这两个的安装都很简单,在ubuntu上只需要一行安装命令即可,具体的可百度。

在ubuntu环境下,在snap根目录下执行make all,执行完成之后,进入到example文件夹下,可以使用已经提供的接口,例如,使用下列命令生成一个小世界网络。

cd examples/graphgen 
./graphgen -g:w -n:1000 -k:4 -p:0.1 -o:smallworld.txt

生成指定度分布的幂律图

查看文件,发现只需要提供nodes和exponent即可生成,速度极快,可能采用的是文章《Efficient and Simple Generation of Random Simple Connected Graphs with Prescribed Degree Sequence》类似的方法,使用命令为:

./graphgen -g:p -n:100000 -p:1.5 -o:t1.5.txt

-n表示nodes数

-p表示exponent(指数)

-o表示输出文件

查看源码,在examples中的graphgen.cpp中,可以使用已经提供的生成图方式。生成幂律图对应以下函数。

G = TSnap::GenRndPowerLaw(N, P, true);

经测试,生成的图符合分布!

附graphgen.cpp文件源码

#include "stdafx.h"int main(int argc, char* argv[]) {Env = TEnv(argc, argv, TNotify::StdNotify);Env.PrepArgs(TStr::Fmt("Graph generators. build: %s, %s. Time: %s", __TIME__, __DATE__, TExeTm::GetCurTm()));TExeTm ExeTm;Tryconst TStr OutFNm = Env.GetIfArgPrefixStr("-o:", "output.txt", "Output graph filename");const TStr Plot = Env.GetIfArgPrefixStr("-g:", "e", "Which generator to use:""\n\tf: Complete graph. Required parameters: n (number of nodes)""\n\ts: Star graph. Required parameters: n (number of nodes)""\n\t2: 2D Grid. Required parameters: n (number of rows), m (number of columns)""\n\te: Erdos-Renyi (G_nm). Required parameters: n (number of nodes), m (number of edges)""\n\tk: Random k-regular graph. Required parameters: n (number of nodes), k (degree of every node)""\n\tb: Albert-Barabasi Preferential Attachment. Required parameters: n (number of nodes), k (edges created by each new node)""\n\tp: Random Power-Law graph. Required parameters: n (number of nodes), p (power-law degree exponent)""\n\tc: Copying model by Kleinberg et al. Required parameters: n (number of nodes), p (copying probability Beta)""\n\tw: Small-world model. Required parameters: n (number of nodes), k (each node is connected to k nearest neighbors in ring topology), p (rewiring probability)\n");const int N = Env.GetIfArgPrefixInt("-n:", 1000, "Number of nodes");const int M = Env.GetIfArgPrefixInt("-m:", 5000, "Number of edges");const double P = Env.GetIfArgPrefixFlt("-p:", 0.1, "Probability/Degree-exponent");const int K = Env.GetIfArgPrefixInt("-k:", 3, "Degree");if (Env.IsEndOfRun()) { return 0; }TExeTm ExeTm;TInt::Rnd.PutSeed(0); // initialize random seedprintf("Generating...\n");PUNGraph G;TStr DescStr;if (Plot == "f") {G = TSnap::GenFull<PUNGraph>(N);DescStr = TStr::Fmt("Undirected complete graph.");} elseif (Plot == "s") {G = TSnap::GenStar<PUNGraph>(N, false);DescStr = TStr::Fmt("Undirected star graph (1 center node connected to all other nodes).");} elseif (Plot == "2") {G = TSnap::GenGrid<PUNGraph>(N, M, false);DescStr = TStr::Fmt("Undirected 2D grid of %d rows and %d columns.", N, M);} elseif (Plot == "e") {G = TSnap::GenRndGnm<PUNGraph>(N, M, false);DescStr = TStr::Fmt("Undirected Erdos-Renyi random graph.");} elseif (Plot == "k") {G = TSnap::GenRndDegK(N, K);DescStr = TStr::Fmt("Undirected k-regular random graph (every node has degree K).");} elseif (Plot == "b") {G = TSnap::GenPrefAttach(N, K);DescStr = TStr::Fmt("Undirected Albert-Barabasi Preferential Attachment graph (each new node creades k preferentially attached edges).");} elseif (Plot == "p") {G = TSnap::GenRndPowerLaw(N, P, true);DescStr = TStr::Fmt("Random Graph with Power-Law degree distribution with exponent P.");} elseif (Plot == "c") {G = TSnap::ConvertGraph<PUNGraph>(TSnap::GenCopyModel(N, P));DescStr = TStr::Fmt("Copying model by Kleinberg et al. Node u comes, selects a random v, and with prob P it links to v, with 1-P links u links to neighbor of v. Power-law degree slope is 1/(1-P).");} elseif (Plot == "w") {G = TSnap::GenSmallWorld(N, K, P);DescStr = TStr::Fmt("Watts-Strogatz Small-world model. Every node links to K other nodes.");}printf("done.\n");TSnap::SaveEdgeList(G, OutFNm, DescStr);Catchprintf("\nrun time: %s (%s)\n", ExeTm.GetTmStr(), TSecTm::GetCurTm().GetTmStr().CStr());return 0;
}

Python

与C++仅接口的调用形式不同,核心实现使用的是C++

重点总结

SNAP这个平台一直以来没有发现,这应该是非常优秀的一个平台,速度极快,有时间可以好好研究一下。

这篇关于SNAP复杂网络处理平台的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~