网络编码

✍ dations ◷ 2025-07-27 00:36:03 #图论,编码理论,电脑网络,信息论,有限域

网络编码是一种通过中继节点对接收到的信息进行编码来达到提高多播网络容量的技术。Rudolf Ahlswede, Ning Cai, Shuo-Yen Robert Li, Raymond W. Yeung在2000年首次提出网络编码的概念。

在右图的网络拓扑中,s节点试图向 t 1 , t 2 {\displaystyle t_{1},t_{2}} 组播两条消息x,y。设每条消息占用的带宽为1,每个节点之间的网络带宽也为1,那么每个节点之间只能同时传输一条消息。线路cd上会需要同时传输x,y,这在一般的传输方案中是行不通的,所以需要网络编码在c处将x,y异或,合成一条消息然后发送。

假设网络是有向的,执行线性网络编码时每个节点收到所有连入线路的数据后,再执行编码,然后把数据从连出线路发出。新的数据包括执行线性编码所用的系数以及合成后的数据。

例如组播源发送三条封包, p 1 = 1 {\displaystyle p_{1}=1} p 2 = 2 {\displaystyle p_{2}=2} p 3 = 3 {\displaystyle p_{3}=3} 。封包经过一系列的中间节点,目标节点收到的封包是 ( ( 5 , 8 , 1 ) , 24 ) , ( ( 2 , 3 , 7 ) , 29 ) , ( ( 9 , 6 , 5 ) , 36 ) {\displaystyle ((5,8,1),24),((2,3,7),29),((9,6,5),36)} 。目标节点对下列矩阵求解,可得 p 1 , p 2 , p 3 {\displaystyle p_{1},p_{2},p_{3}} 的值。

= { 24 = 5 p 1 + 8 p 2 + p 3 29 = 2 p 1 + 3 p 2 + 7 p 3 36 = 9 p 1 + 6 p 2 + 5 p 3 {\displaystyle {\begin{bmatrix}24\\29\\36\end{bmatrix}}={\begin{bmatrix}5&8&1\\2&3&7\\9&6&5\end{bmatrix}}{\begin{bmatrix}p_{1}\\p_{2}\\p_{3}\end{bmatrix}}\Rightarrow {\begin{cases}24=5p_{1}+8p_{2}+p_{3}&\\29=2p_{1}+3p_{2}+7p_{3}&\\36=9p_{1}+6p_{2}+5p_{3}&\end{cases}}} = 1 {\displaystyle {\begin{bmatrix}p_{1}\\p_{2}\\p_{3}\end{bmatrix}}={\begin{bmatrix}5&8&1\\2&3&7\\9&6&5\end{bmatrix}}^{-1}{\begin{bmatrix}24\\29\\36\end{bmatrix}}}

随机线性网络编码可以取得更好的组播传输速率,较为实用。在实际网络中,节点会将来自连入线路的封包缓存起来,当节点需要发送封包时再将缓存的封包执行网络编码,然后发出。

例如节点A有2个上游节点X,Y,X向A发送了封包 ( ( 2 , 2 , 1 ) , 2 x 1 + 2 x 2 + x 3 ) {\displaystyle ((2,2,1),2x_{1}+2x_{2}+x_{3})} ( 2 x 1 + 2 x 2 + x 3 {\displaystyle 2x_{1}+2x_{2}+x_{3}} 是数据体,(2,2,1)是对数据体执行线性编码时所用的系数),Y向A发送了封包 ( ( 1 , 5 , 4 ) , x 1 + 5 x 2 + 4 x 3 ) {\displaystyle ((1,5,4),x_{1}+5x_{2}+4x_{3})} 。当A需要发送数据时,便把缓存的这两个封包取出来,随机选择2个系数(如2和1),获得新的数据体 ( 2 x 1 + 2 x 2 + x 3 ) × 2 + ( x 1 + 5 x 2 + 4 x 3 ) × 1 = 5 x 1 + 9 x 2 + 6 x 3 {\displaystyle (2x_{1}+2x_{2}+x_{3})\times 2+(x_{1}+5x_{2}+4x_{3})\times 1=5x_{1}+9x_{2}+6x_{3}} 和新的合成系数 ( 2 , 2 , 1 ) × 2 + ( 1 , 5 , 4 ) × 1 = ( 5 , 9 , 6 ) {\displaystyle (2,2,1)\times 2+(1,5,4)\times 1=(5,9,6)} 。所以A就把合成后的数据体 5 x 1 + 9 x 2 + 6 x 3 {\displaystyle 5x_{1}+9x_{2}+6x_{3}} 连同合成系数(5,9,6),向下游节点发送出去。

相关

  • 子孙桶子孙桶是中式婚礼传统嫁妆中的马桶,有子孙连绵的寓意。由于妇女排泄和生子都须经过阴部,所以中国很多地区马桶又象征繁衍后代,称嫁妆中的马桶为“子孙桶”。此外,旧时妇女生产都
  • 牛 (消歧义)牛(学名:Bovini),即是牛族,为牛亚科下的一个族,是人类的家畜之一。牛还可以指:
  • 欧典院线欧典 电影公司在英国和爱尔兰运营, UCI电影院 也属于欧典院线。欧典这一知名品牌,于1930年最初进入英国。第一家欧典影院是由Oscar Deutsch在1928年在斯塔福德开始运营,最初
  • 新田站 (咸镜北道)新田站(韩语:신전역)是朝鲜民主主义人民共和国咸镜北道会宁市的一个铁路车站,属于咸北线。咸北线
  • 克利斯登·奈加特克利斯登·奈加特(挪威语:Kristen Nygaard,1926年8月27日-2002年8月10日),挪威计算机科学家,社会活动家,图灵奖和冯·诺伊曼奖获得者,Simula的创始人,面向对象技术的先驱。克利斯登·
  • 无情者哈拉尔哈拉尔三世(Harald Hardrada,意即“无情者哈拉尔”),又称哈拉尔·西居尔松(Harald Sigurdsson),是11世纪挪威的国王,1046年-1066年在位。哈拉尔约1015年出生,是挪威东部酋长西格德·希
  • 日本FM联盟JAPAN FM LEAGUE(ジャパン エフエム リーグ;简称JFL),即“日本FM联盟”,是日本的私营FM广播电台所组成的广播联播网之一。成立于1993年10月1日,目前有5个成员台,分别为FM North Wav
  • 崩坏3《崩坏3》图标《崩坏3》是由中国大陆游戏开发商米哈游开发的的手机与PC平台3D动作游戏。崩坏学园系列的第3作,游戏沿用了前作《崩坏学园2》角色。故事背景、剧情和世界观与《
  • 安德里亚斯·麦斯令尔安德里亚斯·麦斯令尔(德语:Andreas Maislinger;1955年2月26日-),奥地利政治学家,出生于萨尔茨堡旁边的圣格奥根。他在1992年成立奥地利国外服务协会。该组织在中国的据点有齐齐哈
  • 云林站坐标:31°34′53″N 120°23′26″E / 31.58136°N 120.39053°E / 31.58136; 120.39053云林站位于中国江苏省无锡市锡山区东安路与团结路交叉口东侧,临近沪宁高速公路,是无锡