图形描述语言GraphML(1):基本概念

本文介绍了GraphML,一种图形描述语言,用于定义图形结构。重点讲述了如何使用GraphML描述具有循环边(loop edge, selfloop edge, reflexive edge)的图形,这些循环边通过将edge的source和target属性设为相同值来定义。" 134413028,10220647,ODX与UDS$31服务:RoutineControl的深度解析,"['汽车诊断', 'UDS服务', 'ODX标准', 'ECU控制', '诊断工具']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<meta content="StarSuite 8 (Linux)" name="GENERATOR"> <meta content="*" name="AUTHOR"> <meta content="20071029;11490000" name="CREATED"> <meta content="Seaman Wang" name="CHANGEDBY"> <meta content="20080123;10540400" name="CHANGED"> <style type="text/css"> <!-- @page { size: 21cm 29.7cm; margin: 2cm } P { margin-bottom: 0.21cm } --> </style>

GraphML用于定义图形(graph,对于下面的一个简单图形,

用GraphML描述为:

<?xmlversion="1.0"encoding="UTF-8"?>
<graphmlxmlns="http://graphml.graphdrawing.org/xmlns"
xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation
="http://graphml.graphdrawing.org/xmlns
http://graphml.graphdrawing.org/xmlns/1.0/graphml.xsd"
>
<graphid="G"edgedefault="undirected">
<nodeid="n0"/>
<nodeid="n1"/>
<nodeid="n2"/>
<nodeid="n3"/>
<nodeid="n4"/>
<nodeid="n5"/>
<nodeid="n6"/>
<nodeid="n7"/>
<nodeid="n8"/>
<nodeid="n9"/>
<nodeid="n10"/>
<edgesource="n0"target="n2"/>
<edgesource="n1"target="n2"/>
<edgesource="n2"target="n3"/>
<edgesource="n3"target="n5"/>
<edgesource="n3"target="n4"/>
<edgesource="n4"target="n6"/>
<edgesource="n6"target="n5"/>
<edgesource="n5"target="n7"/>
<edgesource="n6"target="n8"/>
<edgesource="n8"target="n7"/>
<edgesource="n8"target="n9"/>
<edgesource="n8"target="n10"/>
</graph>
</graphml>

可以看出,GraphML中关于图形的一些基本概念如下:



需要注意以下几点:
<meta content="text/html; charset=utf-8" http-equiv="CONTENT-TYPE"> <meta content="StarSuite 8 (Linux)" name="GENERATOR"> <meta content="*" name="AUTHOR"> <meta content="20071029;11490000" name="CREATED"> <meta content="Seaman Wang" name="CHANGEDBY"> <meta content="20080123;11091500" name="CHANGED"> <style type="text/css"> <!-- @page { size: 21cm 29.7cm; margin: 2cm } P { margin-bottom: 0.21cm } H4 { margin-bottom: 0.21cm } H4.western { font-family: "Thorndale", "Times New Roman", serif } H4.cjk { font-family: "方正宋体"; font-style: normal } H4.ctl { font-family: "Lucidasans" } PRE.western { font-family: "Cumberland", "Courier New", monospace } PRE.cjk { font-family: "方正宋体", monospace } PRE.ctl { font-family: "方正宋体", monospace } CODE.western { font-family: "Cumberland", "Courier New", monospace } CODE.cjk { font-family: "方正宋体", monospace } --> </style>

1.Graph中的元素(element)没有顺序要求

如,下面的Graph是正确的:

<graphid="G"edgedefault="directed">
<nodeid="n0"/>
<edgesource="n0"target="n2"/>
<nodeid="n1"/>
<nodeid="n2"/>
</graph>
2.有向图和无向图可以混合定义。

Graph必须指定edgedefault属性(directed”或“undirected”)
Edge中也可以单独设置directed truefalse
3.对于只有一个端点(endpoint)Edge(称为循环边loop edge,自循环selfloop edge,或反射边reflexive edig),是通过为edgesource target 属性设置相同的值来定义的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值