CN102752212B - 一种传输速率控制方法 - Google Patents

一种传输速率控制方法 Download PDF

Info

Publication number
CN102752212B
CN102752212B CN201210239887.0A CN201210239887A CN102752212B CN 102752212 B CN102752212 B CN 102752212B CN 201210239887 A CN201210239887 A CN 201210239887A CN 102752212 B CN102752212 B CN 102752212B
Authority
CN
China
Prior art keywords
packet
receiving terminal
time
delay
individual data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201210239887.0A
Other languages
English (en)
Other versions
CN102752212A (zh
Inventor
胡加明
刘晓东
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Codyy Education Technology Co Ltd
Original Assignee
Suzhou Codyy Network Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Suzhou Codyy Network Technology Co Ltd filed Critical Suzhou Codyy Network Technology Co Ltd
Priority to CN201210239887.0A priority Critical patent/CN102752212B/zh
Publication of CN102752212A publication Critical patent/CN102752212A/zh
Application granted granted Critical
Publication of CN102752212B publication Critical patent/CN102752212B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明提供一种传输速率控制方法,本发明方法包括以下步骤。发送端以预设速率发送数据包到接收端,所述接收端缓存所述数据包并当开始播放所述数据包后,所述接收端比较所述缓存的数据包个数与接收端缓冲区预警值的大小。当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端。所述发送端比较所述接收到的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。

Description

一种传输速率控制方法
技术领域
本发明属于网络通信领域,尤其涉及一种传输速率控制方法。
背景技术
随着信息社会的飞速发展,各种各样的通信工具如飞信、QQ等被人们普遍使用,除了个人应用以外,一些企业版的即时通信方式也逐渐为大众所熟悉,譬如视频会议等。能否连续流畅地播放音视频数据,成为影响视频会议质量的关键因素。然而在现实应用中,音视频数据的传输中常存在抖动延时的现象,当延迟时间过长时,容易导致接收端播放音视频中断。而现有技术中,当接收端本地缓存的数据量不足以支持音视频连续播放时,发送端会在短时间内发送大量音视频数据到接收端,容易引起数据包拥塞,甚至导致其它网络应用卡死。
发明内容
本发明提供一种传输速率控制方法以解决上述问题。
本发明提供一种传输速率控制方法,包括以下步骤。发送端以预设速率发送数据包到接收端,所述接收端缓存所述数据包并当开始播放所述数据包后,所述接收端比较所述缓存的数据包个数与接收端缓冲区预警值的大小。当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端。所述发送端比较所述接收到的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。
本发明提供一种传输速率控制系统,包括发送端及接收端,所述发送端连接所述接收端。所述发送端,用于以预设速率发送数据包到所述接收端,还用于比较所述接收端发送的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。所述接收端,用于缓存数据包并当开始播放所述数据包后,比较所述缓存的数据包个数与接收端缓冲区预警值的大小,还用于当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,获取数据包网络延迟时间并发送给发送端。
相较于先前技术,根据本发明提供的传输速率控制方法,发送端以预设速率发送数据包到接收端,接收端开始播放数据包后,比较接收后缓存的数据包个数与接收端缓冲区预警值的大小。通过对接收端设置缓冲区预警值,可有效监控接收端的数据包个数。当接收端缓存的数据包大小小于或等于缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。如此,发送端根据接收到的数据包延迟时间控制发送速率,保证了音视频数据的连续播放。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本申请的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1所示为根据本发明的较佳实施例提供的传输速率控制方法的流程图;
图2所示为根据本发明的较佳实施例提供的传输速率控制系统的示意图。
具体实施方式
下文中将参考附图并结合实施例来详细说明本发明。需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。
图1所示为根据本发明的较佳实施例提供的传输速率控制方法。如图1所示,本发明的较佳实施例提供的传输速率控制方法包括步骤101~103。
步骤101:发送端以预设速率发送数据包到接收端,所述接收端缓存所述数据包并当开始播放所述数据包后,所述接收端比较所述缓存的数据包个数与接收端缓冲区预警值的大小。
具体而言,接收端于接收发送端发送的数据前预设自身的缓冲区大小,且接收端设置缓冲区播放值,所述缓冲区播放值小于或等于缓冲区大小。当接收端缓存的数据包个数第一次达到缓冲区播放值时,接收端开始播放所述数据包。于此,所述缓冲区播放值仅在数据包第一次开始播放前起限定作用,并不影响数据包之后的连续播放。所述接收端开始播放缓存的数据包后,将所述已播放的数据包从接收端的缓存中删除。于本实施例中,所述速率单位为个/秒,缓冲区计量单位为数据包个数。
此外,接收端存储缓冲区预警值对照表,所述对照表包括单个数据包播放时间、数据包网络延迟时间及缓冲区预警值。所述接收端根据数据包网络延迟时间确定缓冲区预警值。所述缓冲区预警值对照表格式例如下表所示。
在本实施例中,接收端第一次获取数据包网络延迟时间的方式为,所述接收端根据接收到的第一个数据包及第二个数据包的时间戳确定所述第一次的数据包网络延迟时间,所述接收端根据第一次获取的数据包网络延迟时间确定第一次缓冲区预警值。
步骤102:当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端。
具体而言,按照步骤101,当接收端缓存的数据包个数第一次达到缓冲区播放值时,接收端开始播放所述数据包。当接收端监控到本地缓存的数据包个数小于或者等于所述缓冲区预警值时,接收端根据缓存的最近一次接收的数据包及后续接收的首个数据包的时间戳获取所述数据包网络延迟时间。若接收端没有缓存的数据包,所述接收端根据后续接收的连续两个数据包的时间戳获取所述数据包网络延迟时间,且所述接收端将获取的数据包网络延迟时间发送给发送端。
步骤103:所述发送端比较所述接收到的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。
具体而言,发送端获取单个数据包播放时间的方式为,所述发送端本地待发送数据包中包括单个数据包播放时间信息,所述发送端解析本地待发送数据包后获得所述单个数据包播放时间,或者由接收端获取所述单个数据包播放时间后发送给发送端。所述接收端获取单个数据包播放时间的方式为,所述发送端向所述接收端发送的数据包中携带单个数据包播放时间信息,所述接收端接收并解析所述数据包后获得所述单个数据包播放时间,或者当发送端向接收端开始发送数据包后,所述接收端播放单个数据包后获取单个数据包播放时间。当接收端发送的数据包网络延迟时间大于单个数据包播放时间时,发送端计算发送速率的方式为:若以n表示数据包传输速率,所述传输速率可以为数据包网络延迟时间为零时发送端的发送速率,并由发送端预设,或者为数据包网络延迟时间为零时接收端的播放速率,并由接收端预设;T表示单个数据包播放时间,t表示数据包网络延迟时间,则(n-T*n/t)表示数据包传输存在网络延迟时,播放完缓冲数据期间网络能够传送的数据包个数。n+(n-T*n/t)表示在预设速率上加了修正后的发送数据包速率,来修正网络延时变化时少发送的数据包个数,即发送端调整后的发送速率V=n+(n-T*n/t)。
于此,当发送端比较接收到的数据包网络延迟时间小于或等于单个数据包播放时间时,所述发送端按所述预设速率发送所述数据包。
举例而言,若发送端在T1时刻以5个/秒的预设速率开始向接收端发送数据包,接收端接收并播放单个数据包后,获取单个数据包播放时间为200ms,且所述接收端根据接收到的第一个数据包及第二个数据包的时间戳确定第一次的数据包网络延迟时间为50ms。根据步骤101中的对照表,接收端确定缓冲区预警值为1个数据包。若接收端设定缓冲区播放值为5个数据包,当接收端缓存的数据包达到5个后,接收端开始播放数据包。
若T2时刻接收端监控到缓存的数据包个数小于缓冲区预警值(1个),且所述接收端该时刻无缓存的数据包。则所述接收端根据T2时刻起后续接收的连续两个数据包的时间戳,获取数据包网络延迟时间为500ms并发送给发送端,且接收端按照所述对照表将缓冲区预警值调整为3个数据包。于此,发送端比较接收到的数据包网络延迟时间(500ms)大于单个数据包播放时间(200ms),则发送端计算发送速率为5+(5-200*5/500)=8,并将发送速率调整为8个/秒。接下来在T3时刻,接收端监控到缓存的数据包大小达到缓冲区预警值(3个数据包),所述接收端根据缓存的最近一次接收的数据包及后续接收的首个数据包的时间戳,获取数据包网络延迟时间为100ms并发送给发送端,且所述接收端按照所述对照表调整缓冲区预警值为1个数据包。于此,发送端比较接收到的数据包网络延迟时间(100ms)小于单个数据包播放时间(200ms),则发送端按预设速率(5个/秒)发送所述数据包。
图2所示为根据本发明的较佳实施例提供的传输速率控制系统的示意图。如图2所示,本发明较佳实施例提供的传输速率控制系统包括发送端201及接收端202,所述发送端201连接所述接收端202。所述发送端201,用于以预设速率发送数据包到所述接收端202,还用于比较单个数据包播放时间及所述接收端202发送的数据包网络延迟时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端201根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。所述接收端202,用于缓存数据包并当开始播放所述数据包后,比较所述缓存的数据包个数与接收端202缓冲区预警值的大小,还用于当所述接收端202缓存的数据包个数小于或等于所述缓冲区预警值时,获取数据包网络延迟时间并发送给发送端201。关于上述系统的操作流程同上述方法所述,故于此不再赘述。
综上所述,根据本发明的较佳实施例提供的传输速率控制方法,发送端以预设速率发送数据包到接收端,接收端开始播放数据包后,比较接收后缓存的数据包个数与接收端缓冲区预警值的大小。通过对接收端设置缓冲区预警值,可有效监控接收端的数据包个数。当接收端缓存的数据包大小小于或等于缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端,发送端比较所述接收到的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率。如此,发送端根据接收到的数据包延迟时间控制发送速率,保证了音视频数据的连续播放。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (8)

1.一种传输速率控制方法,其特征在于,包括以下步骤:
发送端以预设速率发送数据包到接收端,所述接收端缓存所述数据包并当开始播放所述数据包后,所述接收端比较所述缓存的数据包个数与接收端缓冲区预警值的大小;
其中,所述预设速率为n并由发送端或接收端预设;
当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,所述接收端获取数据包网络延迟时间并发送给发送端;
所述发送端比较所述接收到的数据包网络延迟时间及单个数据包播放时间,当所述数据包网络延迟时间大于单个数据包播放时间时,所述发送端根据传输速率、单个数据包播放时间及数据包网络延迟时间计算并调整发送速率;
所述发送端根据公式V=n+(n-T*n/t)计算发送速率,其中V表示发送速率,n表示传输速率并由发送端或接收端预设,T表示单个数据包播放时间并由发送端解析本地数据包后获取,或由接收端播放数据包获取后发送给发送端,t表示数据包网络延迟时间。
2.根据权利要求1所述的方法,其特征在于,所述接收端存储缓冲区预警值对照表,所述对照表包括单个数据包播放时间、数据包网络延迟时间及缓冲区预警值。
3.根据权利要求1或2所述的方法,其特征在于,当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,所述接收端获取数据包网络延迟时间,并根据缓冲区预警值对照表调整自身缓冲区预警值。
4.根据权利要求2所述的方法,其特征在于,接收端获取单个数据包播放时间的方式为,所述发送端向所述接收端发送的数据包中携带单个数据包播放时间信息,所述接收端接收并解析所述数据包后获得所述单个数据包播放时间,或者所述发送端向所述接收端发送所述数据包后,所述接收端播放单个数据包获取所述单个数据包播放时间。
5.根据权利要求1所述的方法,其特征在于,当发送端比较接收到的数据包网络延迟时间小于或等于单个数据包播放时间时,所述发送端按所述预设速率发送所述数据包。
6.根据权利要求1所述的方法,其特征在于,接收端第一次获取数据包网络延迟时间的方式为,所述接收端根据接收到的第一个数据包及第二个数据包的时间戳确定所述第一次的数据包网络延迟时间,所述接收端根据第一次获取的数据包网络延迟时间第一次确定缓冲区预警值。
7.根据权利要求1所述的方法,其特征在于,当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,接收端根据缓存的最近一次接收的数据包及后续接收的首个数据包的时间戳获取所述数据包网络延迟时间。
8.根据权利要求1所述的方法,其特征在于,当所述接收端缓存的数据包个数小于或等于所述缓冲区预警值时,若接收端没有缓存的数据包,所述接收端根据后续接收的连续两个数据包的时间戳获取所述数据包网络延迟时间。
CN201210239887.0A 2012-07-12 2012-07-12 一种传输速率控制方法 Active CN102752212B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201210239887.0A CN102752212B (zh) 2012-07-12 2012-07-12 一种传输速率控制方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201210239887.0A CN102752212B (zh) 2012-07-12 2012-07-12 一种传输速率控制方法

Publications (2)

Publication Number Publication Date
CN102752212A CN102752212A (zh) 2012-10-24
CN102752212B true CN102752212B (zh) 2015-08-19

Family

ID=47032116

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210239887.0A Active CN102752212B (zh) 2012-07-12 2012-07-12 一种传输速率控制方法

Country Status (1)

Country Link
CN (1) CN102752212B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106254264A (zh) * 2016-08-05 2016-12-21 北京工业大学 一种非对称式网络传输协议设计方法

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103974339B (zh) 2013-01-28 2018-01-16 华为技术有限公司 一种数据缓存的方法和装置
US9549016B2 (en) * 2014-08-18 2017-01-17 Cisco Technology, Inc. Congestion control for media flows
CN104935643B (zh) * 2015-05-27 2018-08-21 河北远东通信系统工程有限公司 一种数字集群系统数据帧动态缓冲处理方法
CN105978821B (zh) * 2016-07-21 2019-09-06 杭州迪普科技股份有限公司 网络拥塞避免的方法及装置
CN108696451B (zh) * 2017-04-06 2021-09-14 上海诺基亚贝尔股份有限公司 一种用于控制流量的方法和装置
CN109327279A (zh) * 2017-08-01 2019-02-12 徐州天荣医疗通讯设备有限公司 一种用于医疗的低质量移动通信网络数据包大小控制方法
CN107566795B (zh) * 2017-09-04 2019-11-19 浙江大华技术股份有限公司 一种提高实时画面流畅度的方法、装置及系统
CN110531651B (zh) * 2019-07-30 2022-07-29 中国人民解放军陆军工程大学 一种适用于以太网传输的速率控制装置
CN114885360A (zh) * 2022-06-09 2022-08-09 中国联合网络通信集团有限公司 时延可靠性确定方法、接入网设备及存储介质
CN116033235B (zh) * 2022-12-13 2024-03-19 北京百度网讯科技有限公司 数据传输方法、数字人生产设备以及数字人显示设备

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1655547A (zh) * 2004-09-09 2005-08-17 上海川海信息科技有限公司 一种流媒体传输系统中的速率控制方法
CN101123573A (zh) * 2006-08-09 2008-02-13 普天信息技术研究院 在高速下行链路分组接入网络中分组数据单元的流控方法
CN101577672A (zh) * 2008-05-07 2009-11-11 中国移动通信集团公司 在流媒体业务中数据传输的方法、系统及装置

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
BRPI0822489B1 (pt) * 2008-03-12 2020-10-06 Telefonaktiebolaget Lm Ericsson (Publ) Método para adaptar uma taxa alvo atual de um sinal de vídeo transmitido de um provedor de vídeo para um receptor de vídeo, dispositivo para calcular uma nova taxa alvo de um sinal de vídeo transmitido a partir de um provedor de vídeo, e, meio legível por computador

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1655547A (zh) * 2004-09-09 2005-08-17 上海川海信息科技有限公司 一种流媒体传输系统中的速率控制方法
CN101123573A (zh) * 2006-08-09 2008-02-13 普天信息技术研究院 在高速下行链路分组接入网络中分组数据单元的流控方法
CN101577672A (zh) * 2008-05-07 2009-11-11 中国移动通信集团公司 在流媒体业务中数据传输的方法、系统及装置

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106254264A (zh) * 2016-08-05 2016-12-21 北京工业大学 一种非对称式网络传输协议设计方法
CN106254264B (zh) * 2016-08-05 2019-04-26 北京工业大学 一种非对称式网络传输协议设计方法

Also Published As

Publication number Publication date
CN102752212A (zh) 2012-10-24

Similar Documents

Publication Publication Date Title
CN102752212B (zh) 一种传输速率控制方法
CN102739548B (zh) 一种数据传输的速率控制方法
US9807452B2 (en) Practical delivery of high quality video using dynamic adaptive hypertext transport protocol (HTTP) streaming (DASH) without using HTTP in a broadcast network
US20140108622A1 (en) Streaming media transmission method, device, and system
EP2369840B1 (en) Channel switching method, device and system
US10645447B2 (en) Fast channel change method and server, and IPTV system
WO2012097643A1 (zh) Iptv系统中直播媒体流的方法和装置
CN101668310A (zh) 播放流媒体的方法和装置
WO2023035894A1 (zh) 一种数据处理方法、设备、可读存储介质和程序产品
CN108881931A (zh) 一种数据缓冲方法及网络设备
US20150095447A1 (en) Serving method of cache server, cache server, and system
CN102739547B (zh) 一种速率控制方法
US20220295127A1 (en) Consolidating content streams to conserve bandwidth
WO2017071670A1 (zh) 音视频同步方法、装置及系统
CN104168218B (zh) 抖动缓冲方法及装置
US9986010B2 (en) System and method for controlling video and/or audio streams in a web browser
KR20150146116A (ko) 이종망 기반 방송 서비스를 제공하는 방법 및 장치
WO2013189435A2 (zh) 基于播放状态信息同步的处理方法、系统及相关装置
CN105472404A (zh) 一种视频业务中的数据处理方法
CN104427381A (zh) 播放方法及装置
CN103327364A (zh) 一种用于音视频播放的无线传输方法及装置
EP2043372B1 (en) Method for audio and video synchronization, receiving and transmitting device
CA3026535C (en) Multimedia resource synchronous pushing method based on heterogeneous network
US20240015199A1 (en) Method and Apparatus for Delivering Musical, Theatrical, and Film Performance over Unreliable Channels
KR101738358B1 (ko) 디지털 방송에서 채널 전환에 따른 사용자 화면 단절 방지 장치 및 방법

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
C56 Change in the name or address of the patentee
CP01 Change in the name or title of a patent holder

Address after: Suzhou City, Jiangsu province 215121 Fengting Avenue Suzhou Industrial Park No. 666 Weiting Intelligent Industrial Park Building 8

Patentee after: Kuo Di education and science company limited

Address before: Suzhou City, Jiangsu province 215121 Fengting Avenue Suzhou Industrial Park No. 666 Weiting Intelligent Industrial Park Building 8

Patentee before: Suzhou Kuodi Network Technology Co., Ltd.