博客
关于我
ULPFEC在WebRTC中的实现
阅读量:276 次
发布时间:2019-03-01

本文共 1625 字,大约阅读时间需要 5 分钟。

ULPFEC在WebRTC中的实现

1. 前言

在基于IP网络的多媒体通信系统中,网络丢包对通信质量有严重影响。例如,视频可能出现马赛克、图像模糊或帧率下降,音频可能失真或出现噪声干扰。这显著影响用户体验。WebRTC通过丢包重传(NACK)和前向纠错(FEC)来应对网络丢包问题。本文聚焦于FEC,特别是ULPFEC(Uneven Level Protection Forward Error Correction)在WebRTC中的实现。

2. ULPFEC理论学习

ULPFEC由RFC5109定义,用于WebRTC中以RED格式封装在RTP中传输。ULPFEC通过XOR操作生成FEC数据包,并在接收端结合已接收数据包恢复丢失数据。其优势在于可根据数据包重要程度提供不同保护级别,从而高效利用带宽。

2.1 ULPFEC基本概念

ULPFEC数据包包含以下信息:

  • 序列号基准(SN base):用于标识FEC包保护的数据包序列号。
  • 偏移量掩码(mask):确定每个保护级别保护的数据包位置。
  • 保护长度(protection length):指示每个级别保护的数据包数量。

FEC包通过XOR运算生成校验码,接收端利用这些校验码恢复丢失数据。ULPFEC通过动态分配保护级别,平衡带宽利用和丢包保护能力。

2.2 ULPFEC报文格式

ULPFEC报文由头部和多个保护级别组成。头部包含:

  • E flag:扩展位,当前设置为0。
  • L flag:指示偏移掩码长度,0表示16位,1表示48位。
  • Recovery field:由RTP头部字段XOR后得到。
  • Length recovery field:由负载长度XOR后得到。

每个保护级别包含级别头部和负载。级别头部包括保护长度和偏移掩码,掩码确定数据包保护分布。

2.3 ULPFEC报文构造

FEC报文构造基于RFC3550定义的RTP头部,头部包含XOR运算后的RTP字段。FEC头部通过XOR生成,负载部分由对应数据包XOR后得到。

构造过程包括:

  • 确定FEC包数量。
  • 生成掩码表,确定数据包保护分布。
  • 生成FEC负载,填充头部信息。
  • 2.4 ULPFEC报文发送

    FEC报文以RED格式发送,包含Primary Data Block和Redundant Data Block。Primary Data Block为原始数据包,Redundant Data Block为FEC包。WebRTC采用RED封装,确保数据可靠传输。

    3. ULPFEC在WebRTC中的实现

    3.1 ULPFEC报文构建

    WebRTC中,FEC报文构建流程包括:

  • 数据包编码和后处理。
  • 检查是否启用RED和FEC。
  • 构造FEC包并解包为RED格式。
  • 发送原始数据包和FEC包。
  • 代码实现中,EncodeFec函数生成FEC包,GenerateFecPayloads填充负载,FinalizeFecHeaders修正头部。

    3.2 ULPFEC掩码表和掩码

    掩码表用于确定数据包保护分布。WebRTC支持均匀和非均匀保护:

    • 均匀保护:所有数据包等保护。
    • 非均匀保护:根据数据包重要性分配不同保护级别。

    保护模式包括:

  • kModeNoOverlay:分离重要和普通数据包保护。
  • kModeOverlay:叠加保护。
  • kModeBiasFirstPacket:均匀保护基础上强化首包保护。
  • 3.3 ULPFEC报文接收和数据包恢复

    接收过程包括:

  • 解包RED包,判断RTP或FEC包。
  • 插入数据包到合适列表。
  • 恢复丢失数据包。
  • 恢复过程包括:

  • 检查FEC包丢包数,决定恢复策略。
  • 使用XOR运算恢复丢失数据包。
  • 修复RTP头部和负载。
  • 4. 总结

    本文从理论到实现详细探讨了ULPFEC在WebRTC中的应用。通过理解其原理和代码实现,掌握了FEC在网络通信中的重要作用,为进一步研究音视频技术和模块化开发奠定了基础。

    转载地址:http://oeyx.baihongyu.com/

    你可能感兴趣的文章
    Mysql 分页语句 Limit原理
    查看>>
    MySql 创建函数 Error Code : 1418
    查看>>
    MySQL 创建新用户及授予权限的完整流程
    查看>>
    mysql 创建表,不能包含关键字values 以及 表id自增问题
    查看>>
    mysql 删除日志文件详解
    查看>>
    mysql 判断表字段是否存在,然后修改
    查看>>
    MySQL 到底能不能放到 Docker 里跑?
    查看>>
    mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
    查看>>
    MySQL 加锁处理分析
    查看>>
    mysql 协议的退出命令包及解析
    查看>>
    mysql 参数 innodb_flush_log_at_trx_commit
    查看>>
    mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
    查看>>
    MySQL 命令和内置函数
    查看>>
    MySQL 和 PostgreSQL,我到底选择哪个?
    查看>>
    mysql 四种存储引擎
    查看>>
    MySQL 在并发场景下的问题及解决思路
    查看>>
    MySQL 在控制台插入数据时,中文乱码问题的解决
    查看>>
    MySQL 基础架构
    查看>>
    MySQL 基础模块的面试题总结
    查看>>
    MySQL 处理插入重主键唯一键重复值办法
    查看>>