使用Gephi生成網(wǎng)絡(luò)圖

前言

Gephi是一款開源免費(fèi)跨平臺基于JVM的復(fù)雜網(wǎng)絡(luò)分析軟件, 其主要用于各種網(wǎng)絡(luò)和復(fù)雜系統(tǒng), 特別是在處理網(wǎng)絡(luò)關(guān)系數(shù)據(jù)這方面很有優(yōu)勢,下面是兩個不錯的例子

那么,我們拿到原始數(shù)據(jù)后, 怎么才能畫出這樣的圖表呢蝌焚?

布局文件生成

通過上面兩個例子可以分析出,這類圖表可以通過 sigma.js 畫出來,但是插件本身并不提供預(yù)處理數(shù)據(jù)&&布局功能,所以在繪制圖表的時候需要有一份數(shù)據(jù)文件來詳細(xì)的表明節(jié)點(diǎn)名稱,顏色,大小,橫坐標(biāo), 縱坐標(biāo),邊的起始節(jié)點(diǎn),這類數(shù)據(jù)一般用 gexf(xml格式) 或者 json來表示.

生成gexf需要用到布局算法, 常見的有 Force-directed_graph_drawing 力導(dǎo)向算法, 算法的核心思想是節(jié)點(diǎn)之間產(chǎn)生斥力,邊給兩個節(jié)點(diǎn)提供拉力,通過多次迭代最后維持一個穩(wěn)定狀態(tài),手動實(shí)現(xiàn)布局算法還是有一些復(fù)雜度的,好在gephi-tookit組件提供了API來處理數(shù)據(jù), 首先在maven項(xiàng)目中加入gephi的倉庫和依賴

<repositories>
     <repository>
            <id>gephi-snapshots</id>
            <name>Gephi Snapshots</name>
            <url>http://nexus.gephi.org/nexus/content/repositories/snapshots/</url>
     </repository>
     <repository>
            <id>gephi-releases</id>
            <name>Gephi Releases</name>
            <url>http://nexus.gephi.org/nexus/content/repositories/releases/</url>
     </repository>
</repositories>
<dependencies>
    <dependency>
            <groupId>org.gephi</groupId>
            <artifactId>gephi-toolkit</artifactId>
            <version>0.8.2</version>
    </dependency>
</dependencies>

添加依賴完成之后,參考這個 slide, 根據(jù)需求構(gòu)造一個有向圖,并調(diào)用布局算法, 最后導(dǎo)出成gexf和pdf文件

ProjectController pc = Lookup.getDefault().lookup(ProjectController.class);
pc.newProject();
Workspace workspace = pc.getCurrentWorkspace();

//Generate a new random graph into a container
Container container = Lookup.getDefault().lookup(ContainerFactory.class).newContainer();

GraphModel graphModel = Lookup.getDefault().lookup(GraphController.class).getModel();
DirectedGraph graph = graphModel.getDirectedGraph();

Node n0 = graphModel.factory().newNode("n0");
n0.getNodeData().setLabel("n0");
Node n1 = graphModel.factory().newNode("n1");
n1.getNodeData().setLabel("n1");
Edge edge = graphModel.factory().newEdge(n0, n1, 1f, true);


graph.addNode(n0);
graph.addNode(n1);
graph.addEdge(edge);


for(int i = 0 ; i < 100; i++) {
   Node ntmp = graphModel.factory().newNode("tmp" + i);
   Edge edgetmp = graphModel.factory().newEdge(n0, ntmp, 1f, true);

   graph.addNode(ntmp);
   graph.addEdge(edgetmp);
}

System.out.println("Nodes: " + graph.getNodeCount());
System.out.println("Edges: " + graph.getEdgeCount());

//Layout for 15 seconds
AutoLayout autoLayout = new AutoLayout(20, TimeUnit.SECONDS);
autoLayout.setGraphModel(graphModel);
YifanHuLayout firstLayout = new YifanHuLayout(null, new StepDisplacement(1f));
ForceAtlasLayout secondLayout = new ForceAtlasLayout(null);
AutoLayout.DynamicProperty adjustBySizeProperty = AutoLayout.createDynamicProperty("forceAtlas.adjustSizes.name", Boolean.TRUE, 0.1f);//True after 10% of layout time
AutoLayout.DynamicProperty repulsionProperty = AutoLayout.createDynamicProperty("forceAtlas.repulsionStrength.name", new Double(500.), 0f);//500 for the complete period
autoLayout.addLayout(firstLayout, 0.9f);
autoLayout.addLayout(secondLayout, 0.1f, new AutoLayout.DynamicProperty[]{adjustBySizeProperty, repulsionProperty});
autoLayout.execute();

//Export pdf & gexf
ExportController ec = Lookup.getDefault().lookup(ExportController.class);
try {

    File pdfFile = new File("/tmp/data.pdf");
    File gexfFile = new File("/tmp/data.gexf");

    pdfFile.getParentFile().mkdirs();
    gexfFile.getParentFile().mkdirs();
    ec.exportFile(pdfFile);
    ec.exportFile(gexfFile);
} catch (IOException ex) {
    ex.printStackTrace();
}

圖表繪制

在得到數(shù)據(jù)文件后可以參考這個 Online Demo 來繪制圖表岸夯。

參考資料

  1. http://gephi.github.io/
  2. http://www.slideshare.net/gephi/gephi-toolkit-tutorialtoolkit
  3. https://github.com/gephi/gephi/wiki/How-to-code-with-the-Toolkit

THE END

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市熄守,隨后出現(xiàn)的幾起案子弊仪,更是在濱河造成了極大的恐慌跳芳,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件掏湾,死亡現(xiàn)場離奇詭異裹虫,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)融击,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進(jìn)店門筑公,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人尊浪,你說我怎么就攤上這事匣屡。” “怎么了拇涤?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵捣作,是天一觀的道長。 經(jīng)常有香客問我鹅士,道長券躁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任掉盅,我火速辦了婚禮也拜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘趾痘。我一直安慰自己搪泳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布扼脐。 她就那樣靜靜地躺著,像睡著了一般奋刽。 火紅的嫁衣襯著肌膚如雪瓦侮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天佣谐,我揣著相機(jī)與錄音肚吏,去河邊找鬼。 笑死狭魂,一個胖子當(dāng)著我的面吹牛罚攀,可吹牛的內(nèi)容都是我干的党觅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼斋泄,長吁一口氣:“原來是場噩夢啊……” “哼杯瞻!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起炫掐,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤魁莉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后募胃,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體旗唁,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年痹束,在試婚紗的時候發(fā)現(xiàn)自己被綠了检疫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡祷嘶,死狀恐怖屎媳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情抹蚀,我是刑警寧澤剿牺,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站环壤,受9級特大地震影響晒来,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜郑现,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一湃崩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧接箫,春花似錦攒读、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至废累,卻和暖如春邓梅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背邑滨。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工日缨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掖看。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓匣距,卻偏偏與公主長得像面哥,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子毅待,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容