###spark版### Spark Graphx 进行团伙的识别(community detection)

2024-05-07 14:58

本文主要是介绍###spark版### Spark Graphx 进行团伙的识别(community detection),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在使用Spark Graphx,拿Graphx做了点实验。对大规模图常见的分析方法有连通图挖掘,团伙挖掘等。在金融科技领域,尤其风控领域,会有各种重要的关联网络,并且这种网络图十分庞大。 所以,Spark Graphx这种分布式计算框架十分适合这种场景。下面以设备间关联网络(节点数亿级别)为例,采用Graphx做一个设备团伙挖掘demo。团伙识别的算法采用的是Graphx自带的LabelPropagation算法。

下面的是Graphx示例代码(仅仅是demo):

其中输入文件格式:

A B weight

备注(A,B 代表设备id,String类型,weight:int,关联代表权重)

因为Graphx节点类型只支持Long,不支持String,所以,需要进行相应的转换,这里用到的广播变量进行idmap。

github链接: https://github.com/dylan-fan/spark_graphx_community_detection

[java] view plain copy
  1. package com.org.test  
  2.   
  3. import org.apache.spark.SparkConf  
  4. import org.apache.spark.SparkContext  
  5. import org.apache.spark.rdd.RDD  
  6. import org.apache.spark.graphx._  
  7. import scala.collection.mutable.Set  
  8.   
  9. object DeviceCom {  
  10.   def main(args: Array[String]) {  
  11.     if (args.length < 3) {  
  12.       println("usage: spark-submit com.org.test.DeviceCom <input> <output> <iternum>")  
  13.       System.exit(1)  
  14.     }  
  15.     val conf = new SparkConf()  
  16.     conf.setAppName("DeviceCom-" + System.getenv("USER"))  
  17.   
  18.     val sc = new SparkContext(conf)  
  19.   
  20.     val input = args(0)  
  21.   
  22.     val output = args(1)  
  23.   
  24.     val iternum = args(2).toInt  
  25.   
  26.     val vids = sc.textFile(input)  
  27.       .flatMap(line => line.split("\t").take(2))  
  28.       .distinct  
  29.       .zipWithUniqueId()  
  30.       .map(x => (x._1, x._2.toLong))  
  31.   
  32.     val vids_map = sc.broadcast(vids.collectAsMap())  
  33.   
  34.     val vids_rdd = vids.map {  
  35.       case (username, userid) =>  
  36.         (userid, username)  
  37.     }  
  38.   
  39.     val raw_edge = sc.textFile(input)  
  40.       .map(line => line.split("\t"))  
  41.     val col = raw_edge.collect()  
  42.   
  43.     val edges_rdd = sc.parallelize(col.map {  
  44.       case (x) =>  
  45.         (vids_map.value(x(0)), vids_map.value(x(1)))  
  46.     })  
  47.   
  48.     val g = Graph.fromEdgeTuples(edges_rdd, 1)  
  49.     val lp = lib.LabelPropagation.run(g, iternum).vertices  
  50.     val LpByUsername = vids_rdd.join(lp).map {  
  51.       case (id, (username, label)) =>  
  52.         (username, label)  
  53.     }  
  54.   
  55.     LpByUsername.map(x => x._1 + "\t" + x._2).saveAsTextFile(output)  
  56.   
  57.     sc.stop()  
  58.   }  
  59. }  


这里,只是采用Graphx做个demo(很简单啦),来测试Graphx在当前数据量级下的相关性能。实际设备团伙挖掘会更复杂,涉及到各种策略制定。

这篇关于###spark版### Spark Graphx 进行团伙的识别(community detection)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别

转发来源:https://swift.ctolib.com/ooooverflow-chinese-ocr.html chinese-ocr 基于CTPN(tensorflow)+CRNN(pytorch)+CTC的不定长文本检测和识别 环境部署 sh setup.sh 使用环境: python 3.6 + tensorflow 1.10 +pytorch 0.4.1 注:CPU环境

百度OCR识别结构结构化处理视频

https://edu.csdn.net/course/detail/10506

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述

气象站的种类和应用范围可以根据不同的分类标准进行详细的划分和描述。以下是从不同角度对气象站的种类和应用范围的介绍: 一、气象站的种类 根据用途和安装环境分类: 农业气象站:专为农业生产服务,监测土壤温度、湿度等参数,为农业生产提供科学依据。交通气象站:用于公路、铁路、机场等交通场所的气象监测,提供实时气象数据以支持交通运营和调度。林业气象站:监测林区风速、湿度、温度等气象要素,为林区保护和

企业如何进行员工的网络安全意识培训?

企业网络安全意识培训的重要性         企业网络安全意识培训是提升员工网络安全素质的关键环节。随着网络技术的快速发展,企业面临的网络安全威胁日益增多,员工的网络安全意识和技能水平直接关系到企业的信息安全和业务连续性。因此,企业需要通过系统的网络安全意识培训,提高员工对网络安全的认识和防范能力,从而降低企业在面对潜在安全风险时的损失和影响。 企业网络安全意识培训的方法         企

Pycharm配置conda环境(解决新版本无法识别可执行文件问题)

引言: 很多小伙伴在下载最新版本的pycharm或者更新到最新版本后为项目配置conda环境的时候,发现文件夹目录中无法显示可执行文件(一般为python.exe),以下就是本人遇到该问题后试验和解决该问题的一些方法和思路。 一般遇到该问题的人群有两种,一种是刚入门对pycharm进行conda环境配置的小白(例如我),不熟悉相关环境配置的操作和过程,还有一种是入坑pycharm有段时间的老手

使用JWT进行安全通信

在现代Web应用中,安全通信是至关重要的。JSON Web Token(JWT)是一种流行的安全通信方式,它允许用户和服务器之间安全地传输信息。JWT是一种紧凑的、URL安全的表示方法,用于在两方之间传输信息。本文将详细介绍JWT的工作原理,并提供代码示例帮助新人理解和实现JWT。 什么是JWT? JWT是一种开放标准(RFC 7519),它定义了一种紧凑且自包含的方式,用于在各方之间以JSO

神经网络第四篇:推理处理之手写数字识别

到目前为止,我们已经介绍完了神经网络的基本结构,现在用一个图像识别示例对前面的知识作整体的总结。本专题知识点如下: MNIST数据集图像数据转图像神经网络的推理处理批处理  MNIST数据集          mnist数据图像 MNIST数据集由0到9的数字图像构成。像素取值在0到255之间。每个图像数据都相应地标有“7”、“2”、“1”等数字标签。MNIST数据集中,

ccp之间是不可以直接进行+,-的,要用ccpSub和ccpAdd。

1.  http://www.cnblogs.com/buaashine/archive/2012/11/12/2765691.html  上面有好多的关于数学的方面的知识,cocos2dx可能会用到的 2.学到了   根据tilemap坐标得到层上物体的id int oneTiled=flagLayer->tileGIDt(tilePos);