CN115001632A - 一种信息传输方法、装置、电子设备及可读存储介质 - Google Patents
一种信息传输方法、装置、电子设备及可读存储介质 Download PDFInfo
- Publication number
- CN115001632A CN115001632A CN202210653459.6A CN202210653459A CN115001632A CN 115001632 A CN115001632 A CN 115001632A CN 202210653459 A CN202210653459 A CN 202210653459A CN 115001632 A CN115001632 A CN 115001632A
- Authority
- CN
- China
- Prior art keywords
- data packet
- retransmission
- retransmission request
- maximum
- lost 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.)
- Pending
Links
- 230000005540 biological transmission Effects 0.000 title claims abstract description 81
- 238000000034 method Methods 0.000 title claims abstract description 80
- 238000009877 rendering Methods 0.000 claims description 27
- 238000009432 framing Methods 0.000 claims description 9
- 230000000694 effects Effects 0.000 abstract description 14
- 101100465000 Mus musculus Prag1 gene Proteins 0.000 description 9
- 238000004422 calculation algorithm Methods 0.000 description 9
- 238000010586 diagram Methods 0.000 description 9
- 238000004590 computer program Methods 0.000 description 6
- 238000012545 processing Methods 0.000 description 6
- 238000004364 calculation method Methods 0.000 description 5
- 238000004891 communication Methods 0.000 description 5
- 101000741965 Homo sapiens Inactive tyrosine-protein kinase PRAG1 Proteins 0.000 description 4
- 102100038659 Inactive tyrosine-protein kinase PRAG1 Human genes 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 230000001360 synchronised effect Effects 0.000 description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 238000012935 Averaging Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 230000003111 delayed effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000011541 reaction mixture Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/12—Arrangements for detecting or preventing errors in the information received by using return channel
- H04L1/16—Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
- H04L1/1607—Details of the supervisory signal
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/80—Responding to QoS
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Multimedia (AREA)
- Detection And Prevention Of Errors In Transmission (AREA)
Abstract
本申请提供一种信息传输方法、装置、电子设备及可读存储介质,所述方法包括:接收第二设备发送的第一信息,所述第一信息包括多个数据包;确定所述多个数据包中的丢失数据包;确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。本申请可以提升重传效果。
Description
技术领域
本申请涉及通信技术领域,尤其涉及一种信息传输方法、装置、电子设备及可读存储介质。
背景技术
在实时通讯技术(Web Real Time Communications,Web RTC)实时音视频***中,发送端产生的数据,在经过编码器编码后,会被封装成有序排列的一个个小数据包,然后发送到网络中,接收端接收到数据包后,会根据包的序列号进行排序,如果发现有丢失的数据包,则会立即发送丢包重传(Non-acknowledge,Nack)包,请求发送端重新补发该数据包,重传效果较差。
发明内容
本申请提供一种信息传输方法、装置、电子设备及可读存储介质,以解决重传效果较差的问题。
第一方面,本申请实施例提供了一种信息传输方法,应用于第一设备,包括:
接收第二设备发送的第一信息,所述第一信息包括多个数据包;
确定所述多个数据包中的丢失数据包;
确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
第二方面,本申请实施例还提供一种信息传输方法,应用于第二设备,其特征在于,包括:
向第一设备发送第一信息,所述第一信息包括多个数据包;
在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
第三方面,本申请实施例还提供一种信息传输装置,应用于第一设备,包括:
第一接收模块,用于接收第二设备发送的第一信息,所述第一信息包括多个数据包;
第一确定模块,用于确定所述多个数据包中的丢失数据包;
第二确定模块,用于确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
第一发送模块,用于基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
第四方面,本申请实施例还提供一种信息传输装置,应用于第二设备,包括:
第二发送模块,用于向第一设备发送第一信息,所述第一信息包括多个数据包;
第二接收模块,用于在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
重传模块,用于根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
第五方面,本申请实施例还提供了一种电子设备,包括处理器和存储器,所述存储器存储可在所述处理器上运行的程序或指令,所述程序或指令被所述处理器执行时实现如第一方面所述的信息传输方法的步骤,或者实现如第二方面所述的信息传输方法的步骤。
第六方面,本申请实施例还提供了一种可读存储介质,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时实现如第一方面所述的信息传输方法的步骤,或者实现如第二方面所述的信息传输方法的步骤。
本申请实施例中,在信息传输过程中存在数据包丢失的情况下,通过确定丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的,并基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包,这样,可根据丢失数据包的数据内容确定每一丢失数据包的最大重传请求次数,即可根据丢失数据包的数据内容为每一丢失数据包差异化地设置可重传次数,而非对所有丢失数据包均设置同样的重传次数,从而提升重传效果。
附图说明
为了更清楚地说明本申请的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的信息传输方法的流程示意图之一;
图2是本申请实施例提供的数据包丢失重传的示意图;
图3是本申请实施例提供的信息传输方法的流程示意图之二;
图4是本申请实施例提供的信息传输方法的流程示意图之三;
图5是本申请实施例提供的视频帧渲染时间的示意图之一;
图6是本申请实施例提供的视频帧渲染时间的示意图之二;
图7是本申请实施例提供的信息传输装置的结构示意图之一;
图8是本申请实施例提供的信息传输装置的结构示意图之二;
图9是本申请实施例提供的电子设备的结构示意图之一;
图10是本申请实施例提供的电子设备的结构示意图之二。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本申请实施例中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、***、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。此外,本申请中使用“和/或”表示所连接对象的至少其中之一,例如A和/或B和/或C,表示包含单独A,单独B,单独C,以及A和B都存在,B和C都存在,A和C都存在,以及A、B和C都存在的7种情况。
请参阅图1,图1是本申请实施例提供的信息传输方法的流程示意图之一,该方法应用于第一设备。如图1所示,所述信息传输方法包括以下步骤:
步骤101、接收第二设备发送的第一信息,所述第一信息包括多个数据包。
其中,在视频投放、直播等场景下,上述第一设备为数据接收端,上述第二设备为数据发送端,由上述第一设备接收第一设备发送的数据并进行处理;在视频通话等场景下,双方都会向对端传输数据,那么每一端在接收对端发送的数据时为数据接收端,每一端向对端发送数据时为数据发送端。
可以理解,上述第一信息可以包括音频数据和视频数据等,在语音通话、语音会议等场景下,上述第一信息可以仅包括音频数据,在视频会议、视频直播等场景下,上述第一信息可以包括音频数据和视频数据,并且,在数据传输过程中,还可加入填充(Padding)数据包。
步骤102、确定所述多个数据包中的丢失数据包。
步骤103、确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的。
在数据传输过程中,上述第二设备可将数据封装成有序排列的多个数据包,然后发送到上述第一设备,上述第一设备接收到多个数据包后,再按照数据包的序列号将多个数据包进行排序,若存在序列号不连续,上述接收到的多个数据包中不存在的序列号即为丢失数据包的序列号。也即,可通过多个数据包的序列号是否连续确定是否存在丢失数据包,在多个数据包的序列号不连续的情况下,即可确定存在丢失数据包,且丢失数据包的序列号即为上述不连续序列号中缺失的序列号,从而通过序列号确定丢失数据包。
例如,如图2所示,上述第二设备按照数据发送队列将数据包发送至上述第一设备,而上述第一设备的数据接收队列中缺失序列号为“5”的数据包,那么可以通过NACK请求包向第二设备申请重传序列号为“5”的数据包。
现有技术中,通常对所有的丢失数据包设置同样的最大重传请求次数,超过该最大重传请求次数后,不论是否已获取到丢失数据包,均不再对丢失数据包进行重传。
本实施例中,可根据丢失数据包的数据内容确定对应的最大重传请求次数,且最大重传请求次数多的丢失数据包的可重传次数大于最大重传请求次数少的丢失数据包的可重传次数。具体的,对于包含重要内容的丢失数据包可设置较大的最大重传请求次数,通过多次重传确保包含重要内容的丢失数据包可以重传成功;而对于不包含重要内容或数据内容的重要程度较低的丢失数据包可设置较小的最大重传请求次数,减少功耗。例如,对于丢失的关键帧数据包的最大重传请求次数可大于丢失的填充数据包的最大重传请求次数,从而按照丢失数据包的数据内容差异化地为每一丢失数据包设置上述最大重传请求次数,提升重传效果。
步骤104、基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
具体的,上述重传请求中可包括丢失数据包的序列号,从而第二设备可根据重传请求中的序列号确定需重传的数据包。在丢失数据包的已重传次数未超过其最大重传请求次数的情况下,可向上述第二设备发送重传请求,以使上述第二设备可以按照序列号确定上述丢失数据包,并重传该丢失数据包;或者,不论丢失数据包的已重传次数是否超过其最大重传请求次数,均向上述第二设备发送重传请求,重传请求中可包括上述最大重传请求次数,由第二设备判断丢失数据包的已重传次数是否超过其最大重传请求次数,并在丢失数据包的已重传次数未超过其最大重传请求次数的情况下,重传上述丢失数据包,这样,使第二设备可在上述最大重传请求次数内重传上述丢失数据包。
可选地,上述重传请求还可包括丢失数据包的重传优先级,重传优先级级别高的数据包的重传顺序早于重传优先级级别低的数据包的重传顺序,也即重传优先级级别越高的数据包在重传时的顺序越靠前,以使重传优先级级别高的数据包可以先重传。
具体的,上述重传请求可以NACK请求包的形式发送至第二设备,并在NACK请求包中记载丢失数据包的序列号以告知第二设备丢失的数据包,以及在NACK请求包中记载丢失数据包的重传优先级,以告知第二设备该丢失的数据包的重传优先级,例如,该丢失的数据包的优先级级别。
上述第二设备接收到上述第一设备发送的重传请求后,可以基于上述序列号确定丢失的数据包,并获取该丢失的数据包的重传优先级,例如,5号数据包、13号数据包以及15号数据包丢失的情况下,由上述第一设备确认上述5号数据包的优先级最高,上述15号数据包的优先级第二高,上述13号数据包的优先级最低,那么,上述第二设备在将上述5号数据包、13号数据包以及15号数据包***数据发送队列中进行重传时,在上述数据发送队列中,上述丢失数据包发送的先后顺序应为:上述5号数据包,13号数据包,15号数据包,以确保优先级高的数据包可以优先重传。
本申请实施例中,在信息传输过程中存在数据包丢失的情况下,通过确定丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的,并基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包,这样,可根据丢失数据包的数据内容确定每一丢失数据包的最大重传请求次数,即可根据丢失数据包的数据内容为每一丢失数据包差异化地设置可重传次数,而非对所有丢失数据包均设置同样的重传次数,从而提升重传效果。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是根据所述丢失数据包的数据内容确定的。
具体的,在对丢失数据包进行重传过程中,可将重传优先级较高的数据包***传输队列中的较前位置,重传优先级较低的数据包***传输队列中的较后位置,这样,重传优先级高的数据包的重传顺序早于重传优先级低的数据包的重传顺序,也即优先级越大的数据包在重传时的重传时间间隔越短,以使优先级高的数据包可以先重传,从而确保重传优先级更高的数据包可优先重传,提升重传效果。
其中,重传优先级级别高的丢失数据包的重传顺序早于重传优先级级别低的丢失数据包的重传顺序,也即重传优先级级别高的丢失数据包的重传时间间隔小于重传优先级级别低的丢失数据包的重传时间间隔,从而可优先重传重传优先级级别高的丢失数据包,即优先确保重传优先级级别高的丢失数据包可重传成功。
其中,上述数据内容可包括上述丢失数据包的具体数据类型,例如,上述数据包可以是音频数据包、视频数据包或Padding数据包等。
需要说明的是,本申请实施例可以预先设置各种数据内容之间的优先级,例如,将音频数据包的优先级设置为最高优先级,将视频数据包的优先级设置为第二高优先级,将Padding数据包的优先级设置为最低优先级。
并且,在同一类型数据内容的多个丢失数据包之间,可以按照各自的序列号对同一优先级的多个数据包的重传顺序排序,例如,在存在两个音频数据包丢失的情况下,序列号小的音频数据包的重传顺序早于序列号大的音频数据包的重传顺序。
另外,同一数据内容的多个丢失数据包之间的重传顺序可以由上述第一设备确定好后在重传优先级中告知第二设备,上述第一设备也可以仅按照数据包的数据内容确定一个优先级告知第二设备,由第二设备自己将同一优先级的多个数据包按照序列号确定其重传顺序。
需要说明的是,对于存在多个视频数据包丢失的情况下,可由上述第一设备基于其接收到的其他视频数据包以及丢失数据包的序列号,确定丢失数据包是否为关键帧数据包,在确定丢失数据包的重传优先级时,可确定丢失的关键帧数据包的优先级高于丢失的非关键帧数据包的优先级。并且,本申请实施例中,对于存在多个非关键帧数据包丢失的情况下,可以在多个丢失非关键帧数据包之间设置不同的优先级,例如,可将已接收到的数据包按序列号排序并分为多段,位于不同段的丢失非关键帧数据包设置不同的优先级。
可选地,步骤103中确定所述丢失数据包的最大重传请求次数,包括:
确定所述丢失数据包的重传优先级;
获取当前的接收链路延时和丢包率;
基于所述接收链路延时、所述丢包率和所述重传优先级,确定所述丢失数据包的最大重传请求次数;
步骤104中所述基于所述最大重传请求次数,向所述第二设备发送重传请求,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求。
其中,上述丢失数据包的重传优先级可根据丢失数据包的数据内容确定。
具体的,上述丢失数据包的最大重传请求次数与接收链路延时成反比,即其他变量固定的情况下,接收链路延时越大,上述丢失数据包的最大重传请求次数越小;上述丢失数据包的最大重传请求次数与重传优先级成正比,即其他变量固定的情况下,重传优先级越高,上述丢失数据包的最大重传请求次数越大,上述重传优先级可使用优先级数表示,当然,若使用优先级数越小表示其优先级越高,那么上述丢失数据包的最大重传请求次数与优先级数成反比,若使用优先级数越大表示其优先级越高,那么上述丢失数据包的最大重传请求次数与优先级数成正比;在上述丢包率小于一定阈值的情况下,上述丢失数据包的最大重传请求次数与上述丢包率成正比,即其他变量固定的情况下,丢包率越大,上述丢失数据包的最大重传请求次数越大;在上述丢包率大于或等于一定阈值的情况下,上述丢失数据包的最大重传请求次数与上述丢包率成反比,即其他变量固定的情况下,丢包率越大,上述丢失数据包的最大重传请求次数越小。
其中,向所述第二设备发送重传请求之前,可判断上述丢失数据包的已重传请求次数是否小于上述最大重传请求次数,若小于,则向上述第二设备发送重传请求。上述丢失数据包的已重传请求次数可理解为已向第二设备发送重传该丢失数据包请求的次数,具体的,上述第一设备每向上述第二设备发送一次重传请求,可以记录重传请求对应的丢失数据包的已请求次数,这样,在下一次发送对于该丢失数据包的重传请求之前,可以判断该丢失数据包的已重传请求次数是否超过上述最大重传请求次数,从而确保该丢失数据包在上述最大重传请求次数内进行重传。
该实施方式中,基于所述接收链路延时、所述丢包率和所述重传优先级,确定所述丢失数据包的最大重传请求次数,并在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求,也即可以根据所述接收链路延时、所述丢包率和所述优先级,灵活地确定所述丢失数据包的最大重传请求次数,使得可以优先重传优先级更高的所述丢失数据包,满足重传需求的同时,差异性地基于所述接收链路延时、所述丢包率和所述优先级确定所述丢失数据包的最大重传请求次数,使得数据包的重传能力可以尽量满足视频不丢包的需求。
可选地,在步骤101中接收第二设备发送的第一信息之后,步骤104中向所述第二设备发送重传请求之前,所述方法还可以包括如下步骤:
接收第二设备发送的第二信息;
所述在所述已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求,包括:
在所述第二信息不包括关键帧数据包的情况下,若所述已重传请求次数小于所述最大重传请求次数,向所述第二设备发送重传请求。
可以理解,在上述第二设备的数据发送队列中,上述第二信息位于上述第一信息之后,例如,上述第二信息可以是上述第一信息的下一视频帧序列的多个数据包。
需要说明的是,在上述第二信息中包括关键帧数据包的情况下,可将上述最大重传请求次数设置为0,这样,不论上述丢失数据包之前是否已重传过,此时都不需要再向上述第二设备请求重传上述丢失数据包,以使上述第一信息之后的信息中的数据包可以尽快解码及渲染,提高所述信息传输整体的流畅度。
该实施方式中,在所述第二信息不包括关键帧数据包的情况下,若所述已重传请求次数小于所述最大重传请求次数,向所述第二设备发送重传请求,可在不影响处理所述第二信息的同时,尽量使上述第一信息的数据包可以完整接收到,提升所述信息重传的效果。
可选地,所述第一信息包括多个视频帧,且每一视频帧包括至少两个数据包;
在步骤101中接收第二设备发送的第一信息之后,所述方法还包括:
在目标视频帧包括的至少两个数据包中不存在丢失数据包的情况下,确定所述目标视频帧在网络传输中的抖动时延,所述目标视频帧为所述多个视频帧中的任意一个视频帧;
确定所述目标视频帧的均匀出帧的最小时延;
基于所述抖动时延和所述最小时延,确定所述目标视频帧的目标抖动时延;
基于所述目标抖动时延,对所述目标视频帧包括的至少两个数据包进行解码和渲染。
需要说明的是,上述目标视频帧为上述第一信息中不存在丢失数据包的任意一个视频帧,对于不存在丢失数据包的视频帧进行视频组帧,即按照上述目标抖动时延进行解码和渲染。
其中,在对视频进行组帧前,可判断接收到的每一视频帧中是否存在丢失数据包,不存在丢失数据包的视频帧才进行视频组帧,对于存在丢失数据包的视频帧,可以向上述第二设备发送重传请求,直至不存在丢失数据包时,进行视频组帧。
具体的,上述目标视频帧在网络传输中的抖动时延可以使用卡尔曼滤波算法确定,在上述第一信息中存在较多丢失数据包的情况下,使用卡尔曼滤波算法确定的抖动时延通常为0,以达到立即渲染视频帧的效果。但这种即时渲染,没有将接收到的视频帧在一定时间内均匀分布地渲染,渲染视频帧的快慢节奏不一致,易导致视频渲染长卡顿的发生,例如,弱网环境下,传输链路时延较大,可能导致丢失较多数据包,而通过卡尔曼滤波算法计算导致视频渲染长卡顿现象。
具体的,上述最小时延可以基于当前的网络环境状况确定,例如,通过当前的接收链路延时、在一段时间内上述第二设备发送信息的发送帧间隔、在一段时间内上述第一设备接收信息的接收帧间隔等,确定视频帧的均匀出帧的最小时延。
具体的,上述目标抖动时延可为上述抖动时延和上述最小时延中的较大者,这样,即使在弱网环境中,上述目标视频帧在网络传输中的抖动时延较小,可按照上述最小时延进行视频帧的解码和渲染,从而避免直接基于上述抖动时延进行视频帧的解码和渲染导致的长卡顿现象。通过确定上述目标视频帧的均匀出帧的最小时延,使得最终确定的上述目标抖动时延可以大于或等于上述最小时延,基于上述目标抖动时延进行数据包的解码和渲染,也可以确保视频帧均匀分布地渲染,即保持视频渲染的快慢节奏一致,从而有效避免视频渲染长卡顿现象的发生。
可选地,所述确定所述目标视频帧的均匀出帧的最小时延,包括:
获取预设时间内所述第二设备发送所述第一信息的最大发送帧间隔和平均发送帧间隔,以及所述第一设备的最大接收帧间隔和平均接收帧间隔;
获取当前的接收链路的卡顿阈值;
基于所述卡顿阈值、所述最大发送帧间隔、所述平均发送帧间隔、所述最大接收帧间隔和所述平均接收帧间隔,确定所述最小时延。
其中,上述最大发送帧间隔可通过在上述预设时间内,记录所有相邻帧之间的发送时间间隔,选取其中最大者作为上述最大发送帧间隔,上述平均发送帧间隔可通过计算所有相邻帧之间的发送时间间隔的均值得到;上述最大接收帧间隔可通过在上述预设时间内,记录所有相邻帧之间的接收时间间隔,选取其中最大者作为上述最大接收帧间隔,上述平均接收帧间隔可通过计算所有相邻帧之间的接收时间间隔的均值得到。
其中,上述卡顿阈值可通过对当前的接收链路监测得到,具体的,在当前网络环境下,监测到最低可允许的视频帧率为Fmin帧每秒,那么卡顿阈值记为Tas=1/Fmin*1000(单位:毫秒)。
另外,本申请实施例中可以按照实际应用场景,设置上述卡顿阈值的上限系数Ws,例如,在实时性要求较高的场景,上限系数Ws可设置为1,即将超过上述卡顿阈值Tas*1的帧间隔视为卡顿,在实时性要求较低的场景,上限系数可设置为大于1的值,如2,即将超过上述卡顿阈值2倍Tas*2的帧间隔才视为卡顿。
具体的,将上述最大发送帧间隔记为Tsm,上述平均发送帧间隔记为Tavg_send,上述最大接收帧间隔记为Trm,平均接收帧间隔Tavg_recv。本申请实施例中还可以记录最近两次视频帧渲染的时间间隔作为当前的视频帧渲染时间间隔Tstall。
在上述平均发送帧间隔Tavg_send<Tas,且当前的视频帧渲染时间间隔Tstall>Tas,且最大发送帧间隔Tsm<Tas*Ws时,令Te=Tas;其他情况下,令Te=Tstall*St(St为控制系数,默认值为0.8,可根据场景需要调整大小);进而,确定均匀出帧需要的最小延时:Tz=max(Tsm-Tavgsend-Te/2,Trm-Tavg_recv-Te/2)。
该实施方式中,基于所述卡顿阈值、所述最大发送帧间隔、所述平均发送帧间隔、所述最大接收帧间隔和所述平均接收帧间隔,确定所述最小时延,可以使所述最小时延符合当前的网络环境,提升所述最小时延的准确性。
请参阅图3,图3是本申请实施例提供的信息传输方法的流程示意图之二,该方法应用于第二设备。如图3所示,所述信息传输方法包括以下步骤:
步骤301、向第一设备发送第一信息,所述第一信息包括多个数据包;
步骤302、在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
步骤303、根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
本申请实施例中,所述第二设备根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的,这样,所述第二设备可在所述最大请求次数内重传所述丢失数据包,最大重传请求次数越大则可重传次数越多,从而提升数据包的重传效果。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是所述第一设备根据所述丢失数据包的数据内容确定的。
可选地,步骤303中所述根据所述重传请求对所述丢失数据包进行重传,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,根据所述重传请求对所述丢失数据包进行重传。
需要说明的是,本申请实施例提供的信息传输方法应用于第二设备,与图1所述实施例中的方法对应,具体的实现流程及涉及的相关概念可以是参照上述图1所述方法实施例中的描述,为避免重复,本实施例不再赘述。
为更好地理解,以下通过一个具体的实施例对本申请提供的信息传输方法进行具体说明,如图4所示,所述信息传输方法包括以下步骤:
步骤1、视频发送端依次按照序列号发送视频数据包;
步骤2、视频接收端开始接收视频数据包;
步骤3、视频接收端缓存接收到的视频数据;
步骤4、视频接收端判断缓存队列中的视频数据是否满足视频组帧条件:如果已满足,执行步骤11,否则,执行步骤5;
步骤5、视频接收端每接收到一个视频数据包,判断接收到的视频数据包是否有丢失;如果有丢失,则执行步骤6,如果没有丢失,则不做处理;
步骤6、视频接收端根据丢失数据序列号,判断丢失数据内容,以此判断丢失数据包的重要性,并设置重传优先级Lrn(n越小表示优先级越大,n越大表示优先级越小,例如,Lr1表示的优先级高于Lr2表示的优先级);
其中,重传优先级Lrn可按照如下方式确定:
(1)如果丢失数据包为音频数据包,则按照Web RTC现有逻辑,设置重传包优先级为最高优先级Lr1;
(2)如果丢失数据包为视频重传包,且丢失数据包属于视频关键帧,则设置重传优先级为Lr2,需尽快重传,才能保证所有视频正常解码;
(3)如果丢失数据包为视频重传包,且丢失数据包不属于视频关键帧,则将已接收到的视频数据缓存队列分为N段(每两个分段之间的包序号连续),缓存队列从前往后,优先级依次可设置为Lr3……Lr(N+2),其中,N的大小可根据场景需要,灵活控制;
(4)WebRTC可开启RTX协议,Padding数据包设置重传优先级为Lr(N+3);
步骤7、视频接收端通过Webrtc***获取当前接收丢包率Lv、视频接收链路延时Rv、重传优先级Lrn,计算该包发送Nack请求的最大次数Nr;
其中,丢失数据包的最大次数Nr计算方式如下:
(1)通过WebRTC实时音视频***,获取到当前视频接收端的实时丢包率Lv、当前链路延时Rv、重传优先级Lrn和丢失数据包序列号;
(2)在当前链路延时Rv小于一定阈值时,重传次数Nr=X*(Rv*a)*(b/Lv)*(c/n);
在当前链路延时Rv大于或等于一定阈值时,重传次数Nr=X*(Rv*a)*(Lv*b)*(c/n);
其中,X为Web RTC默认重传次数(10次),a为链路延时伸缩系数,b为当前丢包率伸缩系数,c为重传优先级伸缩系数,n为重传优先级Lrn的大小;
(3)如果已经收到下一个视频帧序列的关键帧数据包,且当前视频帧序列数据包还未收集完成,那么设置当前视频帧序列数据包的所有丢失数据包的最大重传请求次数为0,不再重传旧的帧序列集数据包,优先满足传输最新视频帧序列数据包;
步骤8、视频接收端判断当前包序列号是否已经重传超过了其最大重传请求次数Nr,如果已经超过,则不重传,结束流程;如果未超过,则执行步骤9;
步骤9、视频接收端在Nack包中设置重传数据包优先级,向发送端发送Nack包,请求重传该数据包,并记录该数据包已经发送过的Nack请求次数;
步骤10、视频发送端接收到Nack请求包后,获取设置的重传优先级Lrn,根据Lrn,将需要重传的数据包,***到数据发送队列相应位置,继续执行步骤1;
其中,数据包重传示例如图2所示,在接收端发现5号数据包丢失时,向发送端发送Nack请求包申请重传5号数据包。
步骤11、此步骤承接上述步骤4,如果视频接收端接收到的缓存视频数据,已经满足视频组帧条件,此时接收端开始将接收到的数据包进行组帧处理;
步骤12、将接收到的视频帧通过卡尔曼滤波算法,计算当前视频帧在网络传输中引起的抖动延时Tk;将接收到的视频帧通过本申请实施例的自研抗抖动算法,计算当前视频帧在网络传输中引起的抖动延时Tz;
其中,使用本申请实施例的自研抗抖动算法计算抖动延时Tz的具体过程如下:
(1)记录一段时间Tc的视频发送帧间隔Gsend集合;
其中,视频发送时间,指接收到的当前视频帧中最后一个数据包abs_send_time的时间值(abs_send_time为Web RTC现有逻辑中的绝对发送时间值);视频发送时间帧间隔,即为接收到的两个相邻视频帧的视频发送时间的差值;
(2)记录一段时间Tc的视频接收帧间隔Grecv集合;
其中,视频接收时间,指接收到的当前视频帧中最后一个数据包的接收绝对时间;视频接收时间帧间隔,即为接收到的两个相邻视频帧的视频接收时间的差值;
(3)记录一段时间Tc的视频最大发送帧间隔Tsm;
其中,视频最大发送帧间隔Tsm即为视频发送帧间隔Gsend集合中的最大帧间隔;
(4)记录一段时间Tc的视频最大接收帧间隔Trm;
其中,视频最大接收帧间隔Trm即为视频接收帧间隔Grecv集合中的最大帧间隔;
(5)计算一段时间Tc内,视频帧发送帧间隔平均值Tavg_send,计算方式为Tavg_send=Gsend集合值之和/Gsend集合中元素的数量;
(6)计算一段时间Tc内,接收端接收间隔平均值Tavg_recv,计算方式为Tavg_recv=Grecv集合值之和/Grecv集合中元素的数量;
(7)记录最近一次视频渲染卡顿时长Tstall,Tstall为最近两次渲染视频帧之差;
(8)根据视频帧平均发送帧间隔,确定最大出帧间隔阈值Te:
i.定义弱网下最低可允许的视频帧率为Fmin帧每秒;
ii.定义弱网卡顿阈值:Tas=1/Fmin*1000(单位:毫秒);
iii.定义弱网卡顿阈值上限系数Ws,Ws默认为2,可根据场景需要调整大小;
iv.视频帧平均发送帧间隔Tavg_send<Tas,且统计卡顿时长Tstall>Tas,且视频帧最大发送间隔Tsm<Tas*Ws时,Te=Tas;
v.其他条件下,Te=Tstall*St,St为控制系数,默认值为0.8,可根据场景需要调整大小;
(9)计算均匀出帧需要的最小延时:Tz=max(Tsm-Tavgsend-Te/2,Trm-Tavg_recv-Te/2);
步骤13、获取Tk和Tz两个值中较大的值作为抖动缓冲器(jitter buffer)的抖动延时Tf;
即,Tf=max(Tz,Tk);
步骤14、按照WebRTC现有流程,根据步骤13计算得到的Tf,结合解码延时Tdecode、渲染延时Trender、音视频同步延时时间,计算得到当前帧的最终渲染延时时间Td;
具体的,通过比较Tf-Tdecode-Trender与音视频同步延时时间的大小,取二者中较大者作为当前帧的最终渲染延时时间Td,其中,解码延时Tdecode和音视频同步延时时间可以基于WebRTC现有逻辑算法确定,渲染延时Trender在WebRTC现有逻辑固定为10ms。
步骤15、通过Td时间,判断是否达到解码时间(解码时间:Td-Tdecode-Trender),达到解码时间后,将视频帧送入解码器进行解码;
步骤16、解码完成后,将得到的视频原始数据,交给渲染器进行视频渲染,流程结束。
在上述丢包场景下,基于WebRTC原生的卡尔曼滤波计算得到视频帧渲染时间如图5所示,基于本申请实施例中的自研抗抖动算法得到视频帧渲染时间如图6所示,可见,在丢包场景下,基于自研抗抖动算法得到的视频帧渲染时间更加均匀,能有效避免长卡顿。
本申请实施例中,在发生数据丢包的场景下,通过丢包序列号,计算丢失数据包的重传优先级;并根据丢失包的不同优先级、不同链路丢包率、不同链路延时,动态计算,以得到差异化的Nack最大请求次数,确保重要的数据包在满足网络质量要求的前提下,尽可能多次数地重传。在发送端根据Nack请求包中设置的优先级,将重传数据包及时***到相应的位置,达到优先级高的数据包优先发送的要求。
并且,在视频接收端,根据本申请实施例提供的自研抗抖动网络延时算法,结合WebRTC原生卡尔曼滤波算法,在丢包场景下,通过增加少量延时,使得到的视频帧能够均匀地渲染,避免视频出现长卡顿,提高了视频的流畅度和稳定性,提高了用户的观看体验。
参见图7,图7是本申请实施例提供的一种信息传输装置的结构示意图。如图7所示,信息传输装置700包括:
第一接收模块701,用于接收第二设备发送的第一信息,所述第一信息包括多个数据包;
第一确定模块702,用于确定所述多个数据包中的丢失数据包。
第二确定模块703,用于确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
第一发送模块704,用于基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是根据所述丢失数据包的数据内容确定的。
可选地,所述第二确定模块703,包括:
第一确定单元,用于确定所述丢失数据包的重传优先级;
第一获取单元,用于获取当前的接收链路延时和丢包率;
第二确定单元,用于基于所述接收链路延时、所述丢包率和所述重传优先级,确定所述丢失数据包的最大重传请求次数;
所述第一发送模块704,包括:
发送单元,用于在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求。
可选地,所述信息传输装置700,还包括:
第三接收模块,用于接收第二设备发送的第二信息;
所述发送单元,还用于:
在所述第二信息不包括关键帧数据包的情况下,若所述已重传请求次数小于所述最大重传请求次数,向所述第二设备发送重传请求。
可选地,所述第一信息包括多个视频帧,且每一视频帧包括至少两个数据包;
所述信息传输装置700,还包括:
第三确定模块,用于在目标视频帧包括的至少两个数据包中不存在丢失数据包的情况下,确定所述目标视频帧在网络传输中的抖动时延,所述目标视频帧为所述多个视频帧中的任意一个视频帧;
第四确定模块,用于确定所述目标视频帧的均匀出帧的最小时延;
第五确定模块,用于基于所述抖动时延和所述最小时延,确定所述目标视频帧的目标抖动时延;
解码模块,用于基于所述目标抖动时延,对所述目标视频帧包括的至少两个数据包进行解码和渲染。
可选地,所述第四确定模块,包括:
第二获取单元,用于获取预设时间内所述第二设备发送所述第一信息的最大发送帧间隔和平均发送帧间隔,以及所述第一设备的最大接收帧间隔和平均接收帧间隔;
第三获取单元,用于获取当前的接收链路的卡顿阈值;
第三确定单元,用于基于所述卡顿阈值、所述最大发送帧间隔、所述平均发送帧间隔、所述最大接收帧间隔和所述平均接收帧间隔,确定所述最小时延。
信息传输装置700能够实现本申请实施例中图1方法实施例的各个过程,以及达到相同的有益效果,为避免重复,这里不再赘述。
参见图8,图8是本申请实施例提供的一种信息传输装置的结构示意图。如图8所示,信息传输装置800包括:
第二发送模块801,用于向第一设备发送第一信息,所述第一信息包括多个数据包;
第二接收模块802,用于在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
重传模块803,用于根据所述重传请求,对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是所述第一设备根据所述丢失数据包的数据内容确定的。
可选地,所述重传模块803,包括:
重传单元,用于在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,根据所述重传请求对所述丢失数据包进行重传。
信息传输装置800能够实现本申请实施例中图2方法实施例的各个过程,以及达到相同的有益效果,为避免重复,这里不再赘述。
本申请实施例还提供一种电子设备。由于电子设备解决问题的原理与本申请实施例中图1所示的信息传输方法相似,因此该电子设备的实施可以参见方法的实施,重复之处不再赘述。如图9所示,本申请实施例的电子设备,包括存储器920,收发机910,处理器900;
存储器920,用于存储计算机程序;收发机910,用于在所述处理器900的控制下收发数据;处理器900,用于读取所述存储器920中的计算机程序并执行以下操作:
接收第二设备发送的第一信息,所述第一信息包括多个数据包;
确定所述多个数据包中的丢失数据包;
确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
其中,在图9中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器900代表的一个或多个处理器和存储器920代表的存储器的各种电路链接在一起。总线架构还可以将诸如***设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口。收发机910可以是多个元件,即包括发送机和收发机,提供用于在传输介质上与各种其他装置通信的单元。处理器900负责管理总线架构和通常的处理,存储器920可以存储处理器900在执行操作时所使用的数据。
处理器900可以是中央处理器(Central Processing Unit,CPU)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或复杂可编程逻辑器件(Complex Programmable LogicDevice,CPLD),处理器也可以采用多核架构。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是根据所述丢失数据包的数据内容确定的。
可选地,所述确定所述丢失数据包的最大重传请求次数,包括:
确定所述丢失数据包的重传优先级;
获取当前的接收链路延时和丢包率;
基于所述接收链路延时、所述丢包率和所述重传优先级,确定所述丢失数据包的最大重传请求次数;
所述基于所述最大重传请求次数,向所述第二设备发送重传请求,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求。
可选地,处理器900,还用于读取所述存储器920中的计算机程序并执行以下操作:
接收第二设备发送的第二信息;
所述在所述已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求,包括:
在所述第二信息不包括关键帧数据包的情况下,若所述已重传请求次数小于所述最大重传请求次数,向所述第二设备发送重传请求。
可选地,所述第一信息包括多个视频帧,且每一视频帧包括至少两个数据包;
处理器900,还用于读取所述存储器920中的计算机程序并执行以下操作:
在目标视频帧包括的至少两个数据包中不存在丢失数据包的情况下,确定所述目标视频帧在网络传输中的抖动时延,所述目标视频帧为所述多个视频帧中的任意一个视频帧;
确定所述目标视频帧的均匀出帧的最小时延;
基于所述抖动时延和所述最小时延,确定所述目标视频帧的目标抖动时延;
基于所述目标抖动时延,对所述目标视频帧包括的至少两个数据包进行解码和渲染。
可选地,所述确定所述目标视频帧的均匀出帧的最小时延,包括:
获取预设时间内所述第二设备发送所述第一信息的最大发送帧间隔和平均发送帧间隔,以及所述第一设备的最大接收帧间隔和平均接收帧间隔;
获取当前的接收链路的卡顿阈值;
基于所述卡顿阈值、所述最大发送帧间隔、所述平均发送帧间隔、所述最大接收帧间隔和所述平均接收帧间隔,确定所述最小时延。
本申请实施例提供的电子设备,可以执行上述图1所示的方法实施例,其实现原理和技术效果类似,本实施例此处不再赘述。
本申请实施例还提供一种电子设备。由于电子设备解决问题的原理与本申请实施例中图2所示的信息传输方法相似,因此该电子设备的实施可以参见方法的实施,重复之处不再赘述。如图10所示,本申请实施例的电子设备,包括存储器1020,收发机1010,处理器1000;
存储器1020,用于存储计算机程序;收发机1010,用于在所述处理器1000的控制下收发数据;处理器1000,用于读取所述存储器1020中的计算机程序并执行以下操作:
向第一设备发送第一信息,所述第一信息包括多个数据包;
在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
根据所述重传请求,对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
其中,在图10中,总线架构可以包括任意数量的互联的总线和桥,具体由处理器1000代表的一个或多个处理器和存储器1020代表的存储器的各种电路链接在一起。总线架构还可以将诸如***设备、稳压器和功率管理电路等之类的各种其他电路链接在一起,这些都是本领域所公知的,因此,本文不再对其进行进一步描述。总线接口提供接口。收发机1010可以是多个元件,即包括发送机和收发机,提供用于在传输介质上与各种其他装置通信的单元。处理器1000负责管理总线架构和通常的处理,存储器1020可以存储处理器1000在执行操作时所使用的数据。
处理器1000可以是中央处理器(Central Processing Unit,CPU)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或复杂可编程逻辑器件(Complex Programmable LogicDevice,CPLD),处理器也可以采用多核架构。
可选地,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是所述第一设备根据所述丢失数据包的数据内容确定的。
可选地,所述根据所述重传请求对所述丢失数据包进行重传,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,根据所述重传请求对所述丢失数据包进行重传。
本申请实施例提供的电子设备,可以执行上述图2所示的方法实施例,其实现原理和技术效果类似,本实施例此处不再赘述。
本申请实施例还提供一种可读存储介质,所述可读存储介质上存储有程序或指令,该程序或指令被处理器执行时实现上述图1或图2所述方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
其中,所述处理器为上述实施例中所述的电子设备中的处理器。所述可读存储介质,包括计算机可读存储介质,如计算机只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等。
本申请实施例另提供了一种芯片,所述芯片包括处理器和通信接口,所述通信接口和所述处理器耦合,所述处理器用于运行程序或指令,实现上述图1或图2所述方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
应理解,本申请实施例提到的芯片还可以称为***级芯片、***芯片、芯片***或片上***芯片等。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。此外,需要指出的是,本申请实施方式中的方法和装置的范围不限按示出或讨论的顺序来执行功能,还可包括根据所涉及的功能按基本同时的方式或按相反的顺序来执行功能,例如,可以按不同于所描述的次序来执行所描述的方法,并且还可以添加、省去、或组合各种步骤。另外,参照某些示例所描述的特征可在其他示例中被组合。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以计算机软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,或者网络设备等)执行本申请各个实施例所述的方法。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本申请的保护之内。
Claims (13)
1.一种信息传输方法,应用于第一设备,其特征在于,包括:
接收第二设备发送的第一信息,所述第一信息包括多个数据包;
确定所述多个数据包中的丢失数据包;
确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
2.如权利要求1所述的方法,其特征在于,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是根据所述丢失数据包的数据内容确定的。
3.如权利要求2所述的方法,其特征在于,所述确定所述丢失数据包的最大重传请求次数,包括:
确定所述丢失数据包的重传优先级;
获取当前的接收链路延时和丢包率;
基于所述接收链路延时、所述丢包率和所述重传优先级,确定所述丢失数据包的最大重传请求次数;
所述基于所述最大重传请求次数,向所述第二设备发送重传请求,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求。
4.如权利要求3所述的方法,其特征在于,在接收第二设备发送的第一信息之后,向所述第二设备发送重传请求之前,所述方法还包括:
接收第二设备发送的第二信息;
所述在所述已重传请求次数小于所述最大重传请求次数的情况下,向所述第二设备发送重传请求,包括:
在所述第二信息不包括关键帧数据包的情况下,若所述已重传请求次数小于所述最大重传请求次数,向所述第二设备发送重传请求。
5.如权利要求1至4中任一项所述的方法,其特征在于,所述第一信息包括多个视频帧,且每一视频帧包括至少两个数据包;
在接收第二设备发送的第一信息之后,所述方法还包括:
在目标视频帧包括的至少两个数据包中不存在丢失数据包的情况下,确定所述目标视频帧在网络传输中的抖动时延,所述目标视频帧为所述多个视频帧中的任意一个视频帧;
确定所述目标视频帧的均匀出帧的最小时延;
基于所述抖动时延和所述最小时延,确定所述目标视频帧的目标抖动时延;
基于所述目标抖动时延,对所述目标视频帧包括的至少两个数据包进行解码和渲染。
6.如权利要求5所述的方法,其特征在于,所述确定所述目标视频帧的均匀出帧的最小时延,包括:
获取预设时间内所述第二设备发送所述第一信息的最大发送帧间隔和平均发送帧间隔,以及所述第一设备的最大接收帧间隔和平均接收帧间隔;
获取当前的接收链路的卡顿阈值;
基于所述卡顿阈值、所述最大发送帧间隔、所述平均发送帧间隔、所述最大接收帧间隔和所述平均接收帧间隔,确定所述最小时延。
7.一种信息传输方法,应用于第二设备,其特征在于,包括:
向第一设备发送第一信息,所述第一信息包括多个数据包;
在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
8.如权利要求7所述的方法,其特征在于,所述重传请求包括所述丢失数据包的重传优先级,重传优先级级别越高则重传时间间隔越短,所述重传优先级是所述第一设备根据所述丢失数据包的数据内容确定的。
9.如权利要求7所述的方法,其特征在于,所述根据所述重传请求对所述丢失数据包进行重传,包括:
在所述丢失数据包的已重传请求次数小于所述最大重传请求次数的情况下,根据所述重传请求对所述丢失数据包进行重传。
10.一种信息传输装置,应用于第一设备,其特征在于,包括:
第一接收模块,用于接收第二设备发送的第一信息,所述第一信息包括多个数据包;
第一确定模块,用于确定所述多个数据包中的丢失数据包;
第二确定模块,用于确定所述丢失数据包的最大重传请求次数,所述最大重传请求次数是根据所述丢失数据包的数据内容确定的;
第一发送模块,用于基于所述最大重传请求次数,向所述第二设备发送重传请求,以使所述第二设备在所述最大重传请求次数内重传所述丢失数据包。
11.一种信息传输装置,应用于第二设备,其特征在于,包括:
第二发送模块,用于向第一设备发送第一信息,所述第一信息包括多个数据包;
第二接收模块,用于在所述多个数据包中存在丢失数据包的情况下,接收所述第一设备发送的重传请求;
重传模块,用于根据所述重传请求对所述丢失数据包进行重传,其中,所述重传请求是所述第一设备基于最大重传请求次数发送的,所述最大重传请求次数是所述第一设备根据所述丢失数据包的数据内容确定的。
12.一种电子设备,其特征在于,包括处理器和存储器,所述存储器存储可在所述处理器上运行的程序或指令,所述程序或指令被所述处理器执行时实现如权利要求1至6中任一项所述的信息传输方法的步骤,或者实现如权利要求7至9中任一项所述的信息传输方法的步骤。
13.一种可读存储介质,其特征在于,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时实现如权利要求1至6中任一项所述的信息传输方法的步骤,或者实现如权利要求7至9中任一项所述的信息传输方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210653459.6A CN115001632A (zh) | 2022-06-09 | 2022-06-09 | 一种信息传输方法、装置、电子设备及可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210653459.6A CN115001632A (zh) | 2022-06-09 | 2022-06-09 | 一种信息传输方法、装置、电子设备及可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115001632A true CN115001632A (zh) | 2022-09-02 |
Family
ID=83032329
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210653459.6A Pending CN115001632A (zh) | 2022-06-09 | 2022-06-09 | 一种信息传输方法、装置、电子设备及可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115001632A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117061827A (zh) * | 2023-08-17 | 2023-11-14 | 广州开得联软件技术有限公司 | 图像帧处理方法、装置、设备及存储介质 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1130839A1 (en) * | 2000-03-02 | 2001-09-05 | Matsushita Electric Industrial Co., Ltd. | Method and apparatus for retransmitting video data frames with priority levels |
CN102013962A (zh) * | 2009-09-04 | 2011-04-13 | 华为技术有限公司 | 数据传输方法及设备 |
CN103814582A (zh) * | 2013-11-05 | 2014-05-21 | 华为技术有限公司 | 视频业务数据传输方法、数据接收装置和数据发送装置 |
CN105450969A (zh) * | 2014-06-16 | 2016-03-30 | 联想(北京)有限公司 | 一种实时视频数据传输方法及电子设备 |
CN107147481A (zh) * | 2017-07-19 | 2017-09-08 | 北京数码视讯科技股份有限公司 | 丢包重传方法、装置及电子设备 |
CN107294661A (zh) * | 2016-03-30 | 2017-10-24 | 中兴通讯股份有限公司 | 混合自动重传请求最大重传次数的调整方法、装置及基站 |
CN111740808A (zh) * | 2019-03-25 | 2020-10-02 | 华为技术有限公司 | 一种数据传输方法及装置 |
CN113422923A (zh) * | 2021-06-22 | 2021-09-21 | 苏州市科远软件技术开发有限公司 | 重传次数的确定方法、装置、电子设备及存储介质 |
-
2022
- 2022-06-09 CN CN202210653459.6A patent/CN115001632A/zh active Pending
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1130839A1 (en) * | 2000-03-02 | 2001-09-05 | Matsushita Electric Industrial Co., Ltd. | Method and apparatus for retransmitting video data frames with priority levels |
CN102013962A (zh) * | 2009-09-04 | 2011-04-13 | 华为技术有限公司 | 数据传输方法及设备 |
CN103814582A (zh) * | 2013-11-05 | 2014-05-21 | 华为技术有限公司 | 视频业务数据传输方法、数据接收装置和数据发送装置 |
CN105450969A (zh) * | 2014-06-16 | 2016-03-30 | 联想(北京)有限公司 | 一种实时视频数据传输方法及电子设备 |
CN107294661A (zh) * | 2016-03-30 | 2017-10-24 | 中兴通讯股份有限公司 | 混合自动重传请求最大重传次数的调整方法、装置及基站 |
CN107147481A (zh) * | 2017-07-19 | 2017-09-08 | 北京数码视讯科技股份有限公司 | 丢包重传方法、装置及电子设备 |
CN111740808A (zh) * | 2019-03-25 | 2020-10-02 | 华为技术有限公司 | 一种数据传输方法及装置 |
CN113422923A (zh) * | 2021-06-22 | 2021-09-21 | 苏州市科远软件技术开发有限公司 | 重传次数的确定方法、装置、电子设备及存储介质 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117061827A (zh) * | 2023-08-17 | 2023-11-14 | 广州开得联软件技术有限公司 | 图像帧处理方法、装置、设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10542064B2 (en) | Method, server side and system for computing bandwidth of network transmission of streaming media | |
CN107342848B (zh) | 一种自适应码流传输方法、装置及设备 | |
EP2090038B1 (en) | Method, device and software application for scheduling the transmission of data system packets | |
CN110881135B (zh) | 一种对连麦传输协议优化的方法、装置、设备及介质 | |
CN110049011A (zh) | 用于媒体数据递送控制的方法和装置 | |
JP2001274861A (ja) | データ伝送方法および装置 | |
JP2024509728A (ja) | データ再送処理方法、装置、コンピュータ機器及びコンピュータプログラム | |
CN112104562B (zh) | 拥塞控制方法及装置、通信网络、计算机存储介质 | |
US10230651B2 (en) | Effective intra-frame refresh in multimedia communications over packet networks | |
US7739399B2 (en) | Device and process for adjusting the bit rate of a stream of contents and associated products | |
CN112995048B (zh) | 数据中心网络的阻塞控制与调度融合方法及终端设备 | |
MX2011013684A (es) | Metodo y dispositivo para el empuje rapido de torrente de transmision unidireccional en cambio rapido de canal. | |
US7203184B2 (en) | Data transmitter, data receiver, and data transmitting/receiving method | |
CN115001632A (zh) | 一种信息传输方法、装置、电子设备及可读存储介质 | |
CN110602568B (zh) | 一种基于rtp的视频流传输丢包重传方法、设备及存储设备 | |
CN104427405B (zh) | 用于发送编码视频流的装置及其发送方法 | |
CN111163362A (zh) | 一种自适应重传等待时间的视频接收方法及*** | |
CN116318545A (zh) | 视频数据传输方法、装置、设备及存储介质 | |
CN111917525B (zh) | 一种数据传输方法、装置、设备和可读存储介质 | |
JP3927486B2 (ja) | ストリーミング配信装置、ストリーミング配信システム、及びストリーミング配信方法 | |
CN114979793A (zh) | 一种直播数据传输方法、装置、***、设备和介质 | |
Kritzner et al. | Priority based packet scheduling with tunable reliability for wireless streaming | |
CN116996649B (zh) | 投屏方法、装置、存储介质及电子设备 | |
CN117221244A (zh) | 数据传输控制方法、装置、电子设备及存储介质 | |
CN117220838A (zh) | 数据包的传输方法、装置、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |