コンテンツにスキップ

Graph Modelling Language

出典: フリー百科事典『ウィキペディア(Wikipedia)』

2025年5月4日 (日) 22:57; ねこの森には帰れない (会話 | 投稿記録) による版(日時は個人設定で未設定ならUTC

(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
GML
開発者Graph Drawing
初版1995年 (30年前) (1995)
種別データ記述言語
拡張GraphML
オープン
フォーマット
yes
ウェブサイトgraphml.graphdrawing.org

Graph Modelling Language (GML)は、グラフをモデリングするためのASCII形式の階層型マークアップ言語である。グラフメタ言語とも呼ばれる。 GMLはGraphletGravistoの主要なファイル形式であり、他のいくつかのグラフ描画システムでもサポートされている。

頂点と辺の定義だけでなく、ラベルなどの属性も定義可能である。属性を自由に追加可能であり、ツールによっては追加属性を読み取って使用することがある。

入力ファイル形式

[編集]

GMLは、キーと値のペアで構成される。

キー

[編集]

キーは以下の種類に分けられる。

  • 大域的に定義されたもの
  • グラフ用に定義されたもの
  • ユーザーが定義するもの

また、safe/unsafeの区別が存在する。safe属性は小文字で、unsafe属性は大文字で始まる。

safe
グラフが変更されても変更されない
unsafe
グラフが変更されると削除される

キーの最大長は254である。

[編集]

値は以下の種類に分けられる。

  • 整数 - 符号付き32ビット(これを超える場合、文字列として表現する)
  • 浮動小数点数 - 倍精度
  • 文字列
  • リスト

リストは、キーと値のペアで構成される。同じリスト内での重複キーは有効であり、読み取りおよび書き込み中にこれらの重複順序が保持されることが保証される。これにより、配列およびリストのデータ構造を表すことができる。

コメント

[編集]

#で始まる行は無視される。

簡単なグラフの例

[編集]

グラフ用のキーとして、graphnodeedge等が定義済みである。

グラフ
最上位キーgraphで表され、その値はnodeキーとedgeキーを含むリストである。
ノード
全てのnodeには、グラフ内で一意のidを与える必要がある。
エッジ
全てのedgeには、sourcetargetを与える必要がある。このsourcetargetの値は、nodeidである。
graph [
	comment "これはグラフの例です。"
	directed 1
	id 42
	label "Graph"
	node [
		id 1
		label "A"
		WeiteresAttribut 42
	]
	node [
		id 2
		label "B"
		WeiteresAttribut 43
	]
	node [
		id 3
		label "C"
		WeiteresAttribut 44
	]
	edge [
		source 1
		target 2
		label "辺 AB"
	]
	edge [
		source 2
		target 3
		label "辺 BC"
	]
	edge [
		source 3
		target 1
		label "辺 CA"
	]
]

歴史

[編集]

1995年にパッサウで開催されたGraph Drawingで始まり、 1996年にバークレーで開催されたGraph Drawingで終了した取り組みの成果である。

当時は独自のデータ形式が乱立しており、グラフ構造を視覚化・分析する研究やツールのための共通形式を提供するため開発された。

現在ではより厳密に定義可能なフォーマットが登場しており、用途によって使い分けられている。

関連ツール

[編集]
  • NetworkX - Pythonのグラフライブラリ。GMLを読み書き可能。
  • yEd - Javaベースのグラフエディタ。GMLからのインポート、GMLへのエクスポートが可能。
  • Gephi - 大規模グラフを視覚化するソフトウェア。
  • Tulip - 大規模グラフを視覚化するソフトウェア。
  • Gravisto - グラフ描画エディターとアルゴリズム実装のためのJavaのオブジェクト指向フレームワーク。
  • Cytoscape - 分子相互作用ネットワークを視覚化するソフトウェア。
  • Mathematica - GMLからのインポート、GMLへのエクスポートが可能。
  • Graphviz - DOTファイル形式との相互変換を行うコマンドラインツールが含まれている。

外部リンク

[編集]