CN111225209B - 视频数据推流方法、装置、终端及存储介质 - Google Patents

视频数据推流方法、装置、终端及存储介质 Download PDF

Info

Publication number
CN111225209B
CN111225209B CN201811410166.5A CN201811410166A CN111225209B CN 111225209 B CN111225209 B CN 111225209B CN 201811410166 A CN201811410166 A CN 201811410166A CN 111225209 B CN111225209 B CN 111225209B
Authority
CN
China
Prior art keywords
current
sensitivity
bandwidth
region
determining
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
CN201811410166.5A
Other languages
English (en)
Other versions
CN111225209A (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.)
Douyin Vision Co Ltd
Douyin Vision Beijing Co Ltd
Original Assignee
Beijing ByteDance 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 Beijing ByteDance Network Technology Co Ltd filed Critical Beijing ByteDance Network Technology Co Ltd
Priority to CN201811410166.5A priority Critical patent/CN111225209B/zh
Publication of CN111225209A publication Critical patent/CN111225209A/zh
Application granted granted Critical
Publication of CN111225209B publication Critical patent/CN111225209B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/146Data rate or code amount at the encoder output
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/40Support for services or applications
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

本公开实施例公开了一种视频数据推流方法、装置、终端及存储介质,其中,所述方法包括:确定当前网络灵敏度;根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。本公开实施例可实现在带宽低、抖动大的弱网条件下,提升直播视频的画质和流畅度,进而提升用户的观看体验。

Description

视频数据推流方法、装置、终端及存储介质
技术领域
本公开实施例涉及互联网技术领域,尤其涉及一种视频数据推流方法、装置、终端及存储介质。
背景技术
近年来,网络技术的不断发展让我们的生活越来越丰富多彩。有了网络这个便利的载体,使得视频交互应用在人们的日常生活中非常流行,并且更多的用户喜欢通过直播这种方式进行相互之间的展示和交流。
直播过程中,需要由主播端将直播视频数据推送到服务器,其他用户在自己的终端上从服务器上拉取直播视频数据进行播放。然而,由于受到网络的不稳定因素影响,例如在带宽低、抖动大的弱网条件下,直接影响直播视频数据的传输,造成视频模糊、卡顿等不良现象,影响直播视频的画质和流畅度,从而影响用户的观看体验。
公开内容
本公开实施例提供一种视频数据推流方法、装置、终端及存储介质,以达到在带宽低、抖动大的弱网条件下,提高直播视频的画质和流畅度,进而提升用户观看体验的目的。
第一方面,本公开实施例提供了一种视频数据推流方法,该方法包括:
确定当前网络灵敏度;
根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
可选的,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区。
可选的,在所述确定当前网络灵敏度之前,所述方法还包括:
对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况和当前网络带宽,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
可选的,所述根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域,包括:
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区;
如果当前缓存情况为空,则确定当前缓存所属的区域为带宽滞后富余区。
可选的,所述根据当前缓存所属的区域调整编码策略,包括:
如果当前缓存所属的区域为带宽受限区,则减少编码码率;
如果当前缓存所属的区域为带宽提前富余区或带宽滞后富余区,则增加编码码率。
可选的,在减少编码码率之前,所述方法还包括:
判断当前网络带宽是否小于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述减少编码码率的操作。
可选的,在增加编码码率之前,所述方法还包括:
如果当前缓存所属的区域为带宽提前富余区,则判断当前网络带宽是否大于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述增加编码码率的操作;或者
如果当前缓存所属的区域为带宽滞后富余区,则判断当前缓存为空的持续时间是否超过预设时长,并且在判断为是时,执行所述增加编码码率的操作。
可选的,所述减少编码码率包括:
取码率b和当前帧的码率x中的最大值作为减少后的目标编码码率;
所述码率b的计算公式为:b=(m-x*y*p),其中,x为当前帧的码率,y为当前缓存中存储的视频时长与预设的灵敏度的极大值的比值,m为当前带宽与当前针对所述编码器已设的编码码率相比的最小值,p为缓存不为空的次数与统计总次数的比值,其中,所述统计总次数为视频数据推流的过程中,截止到当前为止,对各个目标时间段内的视频发送信息进行统计的总次数;所述缓存不为空的次数为在所述统计的过程中,针对各个目标时间段统计得到的缓存情况不为空的次数。
可选的,所述增加编码码率包括:
将当前网络带宽值与当前针对所述编码器已设的编码码率值和当前缓存的帧率的比值相加,得到的结果即为增加后的目标编码码率。
可选的,在依据调整后的编码策略指示编码器对视频数据进行编码发送之后,所述方法还包括:
根据调整后的编码码率确定目标网络带宽;
根据所述目标网络带宽和预设的灵敏度极值,在依据所述灵敏度极值确定的区间内确定目标网络灵敏度,其中,所述灵敏度极值包括灵敏度极大值和灵敏度极小值;
将所述目标网络灵敏度更新为新的当前网络灵敏度,以便依据该新的当前网络灵敏度和缓存情况确定缓存所属的区域。
可选的,所述依据调整后的编码策略指示编码器对视频数据进行编码发送,包括:
依据调整后的编码策略确定丢帧策略,并基于所述丢帧策略指示丢帧模块在所述编码器编码前对视频数据进行均匀丢帧,其中,丢帧策略与对视频的画质与流畅度的需求有关;
依据调整后的编码策略,指示编码器对经丢帧后的视频数据进行编码发送。
可选的,所述对目标时间段内的视频数据发送信息进行统计,包括:
确定在目标时间段之前确定的历史网络灵敏度是否达到预设阈值,并在达到预设阈值之后,对目标时间段内的视频数据发送信息进行统计。
第二方面,本公开实施例还提供了一种视频数据推流装置,该装置包括:
灵敏度确定模块,用于确定当前网络灵敏度;
区域确定模块,用于根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
策略调整模块,用于根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
可选的,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区。
可选的,所述装置还包括:
统计确定模块,用于对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况和当前网络带宽,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
可选的,所述区域确定模块具体用于:
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区;
如果当前缓存情况为空,则确定当前缓存所属的区域为带宽滞后富余区。
可选的,所述策略调整模块还用于:
如果当前缓存所属的区域为带宽受限区,则减少编码码率;
如果当前缓存所属的区域为带宽提前富余区或带宽滞后富余区,则增加编码码率。
可选的,所述策略调整模块还包括:
降低编码码率单元,用于判断当前网络带宽是否小于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述减少编码码率的操作。
可选的,所述策略调整模块还包括增加编码码率单元,所述用于增加编码码率单元用于:
如果当前缓存所属的区域为带宽提前富余区,则判断当前网络带宽是否大于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述增加编码码率的操作;或者
如果当前缓存所属的区域为带宽滞后富余区,则判断当前缓存为空的持续时间是否超过预设时长,并且在判断为是时,执行所述增加编码码率的操作。
可选的,减少编码码率包括:
取码率b和当前帧的码率x中的最大值作为减少后的目标编码码率;
所述码率b的计算公式为:b=(m-x*y*p),其中,x为当前帧的码率,y为当前缓存中存储的视频时长与预设的灵敏度极大值的比值,m为当前带宽与当前针对所述编码器已设的编码码率相比的最小值,p为缓存不为空的次数与统计总次数的比值,其中,所述统计总次数为视频数据推流的过程中,截止到当前为止,对各个目标时间段内的视频发送信息进行统计的总次数;所述缓存不为空的次数为在所述统计的过程中,针对各个目标时间段统计得到的缓存情况不为空的次数。
可选的,增加编码码率包括:
将当前网络带宽值与当前针对所述编码器已设的编码码率值和当前缓存的帧率的比值相加,得到的结果即为增加后的目标编码码率。
可选的,所述装置还包括网络灵敏度更新模块,所述网络灵敏度更新模块用于:
根据调整后的编码码率确定目标网络带宽;
根据所述目标网络带宽和预设的灵敏度极值,在依据所述灵敏度极值确定的区间内确定目标网络灵敏度,其中,所述灵敏度极值包括灵敏度极大值和灵敏度极小值;
将所述目标网络灵敏度更新为新的当前网络灵敏度,以便依据该新的当前网络灵敏度和缓存情况确定缓存所属的区域。
可选的,所述策略调整模块还用于:
依据调整后的编码策略确定丢帧策略,并基于所述丢帧策略指示丢帧模块在所述编码器编码前对视频数据进行均匀丢帧,其中,丢帧策略与对视频的画质与流畅度的需求有关;
依据调整后的编码策略,指示编码器对经丢帧后的视频数据进行编码发送。
可选的,所述装置还包括判断模块,所述判断模块用于:
确定在目标时间段之前确定的历史网络灵敏度是否达到预设阈值,并在达到预设阈值之后,对目标时间段内的视频数据发送信息进行统计。
第三方面,本公开实施例还提供了一种终端,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本公开任一实施例所述的视频数据推流方法。
第四方面,本公开实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本公开任一实施例所述的视频数据推流方法。
本公开实施例公开了一种视频数据推流方法、装置、终端及存储介质,通过已确定当前网络灵敏度和当前缓存情况,进而确定当前缓存所属的区域,并根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,由此可实现在带宽低、抖动大的弱网条件下,提升直播视频的画质和流畅度,进而提升用户的观看体验。
附图说明
图1是本公开实施例提供的视频数据推流方法的流程图;
图2是本公开实施例提供的视频数据推流方法的流程图;
图3是本公开实施例提供的视频数据推流方法的流程图;
图4是本公开实施例提供的视频数据推流装置的结构示意图;
图5是本公开实施例提供的终端的结构示意图。
具体实施方式
下面结合附图和实施例对本公开作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本公开,而非对本公开的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本公开相关的部分而非全部结构。
下面参考图1,其示出了本公开实施例提供的一种视频数据推流方法的流程图,本实施例可适用于在带宽低、抖动大的弱网条件下进行直播推流的情况,该方法可以由视频数据推流装置来执行,该装置可以采用软件和/或硬件的方式实现,并可配置于终端中,例如带有摄像装置的智能设备。如图1所示,该视频数据推流方法具体包括:
S110、确定当前网络灵敏度。
其中,确定当前网络灵敏度也即是确定在当前网络状态下传输一定大小的数据所需要的时间,示例性的,所述一定大小的数据为60帧视频数据,在当前网络状态下传输该60帧视频数据需要2秒,则确定网络灵敏度为2秒。由于网络灵敏度与预先设定的带宽之间存在对应关系,因此,可以根据预设时间内网络灵敏度的变化情况评估预设时间内的平均网络带宽。示例性的,预设时间段为10秒,10秒内确定的网络灵敏度分别为3秒、2秒、2秒、3秒,而3秒对应的网络带宽4M,2秒对应的网络带宽为5M,则10秒内平均网络带宽为4.5M,以判断一段时间内的网络状态。
具体的,确定当前网络灵敏度时,针对网络直播初始阶段,默认网络状态较好,其对应的当前网络灵敏度为默认值,例如1秒;而针对网络直播过程中,则需要实时确定当前网络灵敏度。例如,可以根据当前网络带宽和预先设定的带宽与灵敏度对应关系,来确定当前网络灵敏度。
S120、根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域。
在一种实施方式中,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区。其中,针对自适应区、带宽受限区和带宽提前富裕区,每个区域各自对应一个根据步骤S110确定的当前网络灵敏而确定的灵敏度区间,示例性的,自适应区对应的第一灵敏度区间为(X,2X],带宽受限区对应的第二灵敏度区间为(2X,+∞),带宽提前富裕区对应的第三灵敏度区间为(0,X],其中X表示确定的当前网络灵敏度。由于当前网络灵敏度不断更新的,因此各区域划分也是动态变化的。
进一步的,由于当前缓存情况至少包括当前缓存中存储的视频大小和视频时长,因此,根据当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域,具体包括:
如果当前缓存中存储的视频时长,位于依据当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区,表明当前网络状态抖动小、不影响视频直播,可不必调整编码码率;
如果当前缓存中存储的视频时长,位于依据当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区,表明网络带宽过小,需要降低编码码率,以缓解网络拥堵;
如果当前缓存中存储的视频时长,位于依据当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区,表明缓存不为空的情况下带宽富余,可以增加编码码率,以充分利用带宽;
除此之外,如果当前缓存中存储的视频大小为零,即当前缓存为空,则确定当前缓存所属的区域为带宽滞后富余区,表明缓存为空的情况下带宽富余,也可以增加编码码率,以充分利用带宽。
优选的,当前缓存情况可以通过如下方式统计得到:对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
其中,统计视频数据发送信息包括统计目标时间段内第一帧视频进入的时间、最后一帧视频进入时间、目标时间段内所包括的视频帧的总数量以及每一帧视频数据的大小。通过第一帧视频进入的时间和最后一帧视频进入时间可确定目标时间段内的视频数据发送时长,根据每一帧视频数据大小与视频帧数量确定当前缓存情况,此外,还可以根据发送时长与当前缓存情况确定当前网络带宽。
S130、根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
不同的区域对应不同的灵敏度区间,由于网络灵敏度与网络状态相对应,因此不同的区域对应不同的网络状态,例如,自适应区对应小幅度抖动的网络状态,宽带受限区对应宽带过小的网络状态,因此,不同的区域对应不同的编码策略,其中,所述编码策略包括减小编码码率或增加编码码率。由此,可根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码并发送到服务器。
本实施例中,针对在带宽低、抖动大的弱网条件下,通过已确定当前网络灵敏度和当前缓存情况,进而确定当前缓存所属的区域,并根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,由此可提升直播视频的画质和流畅度,进而提升用户的观看体验。
下面参考图2,其示出了本公开实施例提供的一种视频数据推流方法的流程图,本实施例是在上述实施例的基础上进一步进行优化。如图2所示,该视频数据推流方法包括:
S210、确定当前网络灵敏度。
S220、根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域。
S230、根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
在指示编码器对视频数据进行编码发送之后,执行步骤S240-S260以更新当前网络灵敏度,以便根据更新后的当前网络灵敏度继续执行上述步骤。
S240、根据调整后的编码码率确定目标网络带宽。
示例性的,可将调整后的编码码率作为目标网络带宽。
S250、根据所述目标网络带宽和预设的灵敏度极值,在依据所述灵敏度极值确定的区间内确定目标网络灵敏度,其中,所述灵敏度极值包括灵敏度极大值和灵敏度极小值。
其中,网络状态(例如网络带宽)与网络灵敏度是相对应的,具体的,网络状态越好,则网络灵敏度的值越小,因此,可根据网络状态与网络灵敏度的对应关系,确定网络灵敏度。示例性的,可预先根据网络状态可能出现的极限情况,例如网络允许出现的最高或最低带宽的情况,确定网络灵敏度极值,并根据网络灵敏度极值确定网络灵敏度变化区间,例如区间为[0.2,2],单位为秒,因此,可根据确定的目标网络带宽从区间[0.2,2]中,按照在两个极值对应的带宽之间线性变化的方式,来确定与其对应的目标网络灵敏度,例如1秒。
S260、将所述目标网络灵敏度更新为新的当前网络灵敏度。
本实施例中,将每次调整码率后确定的目标网络灵敏度作为新的当前网络灵敏度,以便在下一次确定当前缓存所属的区域时,依据该新的当前网络灵敏度和缓存情况来确定。
在本实施例中,根据与调整后编码码率对应的目标网络带宽和预设的灵敏度极值,确定目标网络灵敏度并将其更新为新的当前网络灵敏度,以便依据该新的当前网络灵敏度和缓存情况确定缓存所属的区域,可提高视频数据的编码效率。
下面参考图3,其示出了本公开实施例提供的一种视频数据推流方法的流程图,本实施例是在上述实施例的基础上进一步进行优化。如图3所示,该视频数据推流方法包括:
S310、对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况和当前网络带宽,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
由于在主播直播过程中,产生的视频帧数据实时进入发送队列中,如果每次都对新进入的视频帧数据进行统计并按本公开实施例提供的方法来处理,则会占用大量系统资源,且效率低下,直播视频也会产生抖动。因此,需要确定在目标时间段之前确定的历史网络灵敏度是否达到预设阈值,并在达到预设阈值之后,对目标时间段内的视频数据发送信息进行统计。其中,历史网络灵敏度用于表征间隔多长时间开始对缓存的视频数据发送信息进行统计,也即,在当前对目标时间段内的视频数据发送信息进行统计之前确定的网络灵敏度中,判断是否有达到预设阈值的,当有达到预设阈值的历史网络灵敏度时,才进行视频数据发送信息的统计操作。示例性的,网络状态差时,其对应的历史网络灵敏度的预设阈值为5秒,则在历史网络灵敏度达到5秒时开始统计视频数据发送信息。
S320、确定当前网络灵敏度。
S330、根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域。
本实施例中,如果判断当前缓存属于自适应区,则表明当前网络状态抖动小、不影响视频直播,因此,对属于自适应区的当前缓存不需要进行码率调整,可直接发送到编码器进行编码,并在编码后发送到服务器。
而当前缓存如果不属于自适应区,网络状态影响视频直播,因此需要调整编码策略。示例性的,如果确定当前缓存所属的区域为带宽受限区,则执行S340;如果确定当前缓存所属的区域为带宽提前富余区或带宽滞后富余区,则执行S350。
S340、当前缓存属于带宽受限区时,减少编码码率。
在判断当前缓存所属的区域为带宽受限区后,在减少编码码率之前,优选的,还可以判断当前网络带宽是否小于当前针对编码器已设的编码码率,并且在判断为是时,再减少编码码率,从而避免不必要的操作,缓解网络状态,确保视频数据的传输。
示例性的,减少编码码率包括:取码率b和当前帧的码率x中的最大值作为减少后的目标编码码率,其中码率b的计算公式为:b=(m-x*y*p),其中,x为当前帧的码率,y为当前缓存中存储的视频时长与预设的灵敏度的极大值的比值,m为当前带宽与当前针对所述编码器已设的编码码率相比的最小值,p为缓存不为空的次数与统计总次数的比值,其中,所述统计总次数为视频数据推流的过程中,截止到当前为止,对各个目标时间段内的视频发送信息进行统计的总次数;所述缓存不为空的次数为在所述统计的过程中,针对各个目标时间段统计得到的缓存情况不为空的次数,其中,当前帧的码率x为当前总码率中一帧图片占用的码率,其值等于当前针对编码器已设的编码码率值和当前缓存的帧率的比值。
S350、当前缓存属于带宽提前富余区或带宽滞后富余区时,增加编码码率。
在判断当前缓存所属的区域为带宽提前富余区后,在增加编码码率之前,优选的,还可以判断当前网络带宽是否大于当前针对编码器已设的编码码率,并且在判断为是时,再增加编码码率,从而避免不必要的操作,并提高网络利用率。
相应的,在判断当前缓存所属的区域为带宽滞后富余区后,在增加编码码率之前,优选的,还可以判断当前缓存为空的持续时间是否超过预设时长,并且在判断为是时,再增加编码码率,而如果当前缓存只是短时间内为空,并且同时增加了编码码率,则很快又会造成网络拥堵,因此,当判断出当前缓存为空的持续时间超过预设时长时才增加编码码率,从而在确保网络状态保持良好的基础上进一步提高网络利用率。
示例性的,所述增加编码码率包括:将当前网络带宽值与当前针对所述编码器已设的编码码率值和当前缓存的帧率的比值相加,也即是将当前网络带宽值与当前帧的码率相加,得到的结果即为增加后的目标编码码率。
S360、依据调整后的编码策略确定丢帧策略,并基于所述丢帧策略指示丢帧模块在所述编码器编码前对视频数据进行均匀丢帧,其中,丢帧策略与对视频的画质与流畅度的需求有关。
编码策略调整后,会在一定程度上影响视频的帧数和画质,为了满足用户对画质的需求,可以通过丢帧策略来同时提高画质。此外,对画质的提高还要同时考虑到用户对流畅度的需求,因此,通过在画质和流畅度的需求之间来平衡最合适的丢帧策略,实现同时满足用户对画质和流畅度的需求。优选的,在编码器对视频数据编码前对其进行均匀丢帧,以进一步提高直播视频的画质与流畅度。
S370、依据调整后的编码策略,指示编码器对经丢帧后的视频数据进行编码发送。
如果当前缓存属于带宽受限区、带宽提前富余区或带宽滞后富余区,则按照调整后的目标编码码率进行编码。并在完成编码后,将视频数据发送到服务器,以便观看直播的用户进行拉流。
本实施例中,通过统计目标时间段内的视频数据发送信息确定当前缓存,并结合当前网络灵敏度确定当前缓存所属区域,根据各区域所各自对应的编码策略调整编码码率,并对当前缓存进行均匀丢帧操作,以满足用户对视频的画质与流畅度的需求,将丢帧后的视频数据以调整后的编码码率进行编码发送,由此可在弱网条件下直播时,提升直播视频的画质和流畅度,进而提升观看直播用户的观看体验。
下面参考图4,其示出了本公开实施例提供的一种视频数据推流装置的结构示意图,本实施例可适用于在带宽低、抖动大的弱网条件下进行直播推流的情况。如图4所示,所述视频数据推流装置包括:
灵敏度确定模块410,用于确定当前网络灵敏度;
区域确定模块420,用于根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
策略调整模块430,用于根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
本实施例中,针对在带宽低、抖动大的弱网条件下,区域确定模块根据灵敏度确定模块确定的当前网络灵敏度以及当前缓存情况确定当前缓存所属的区域,策略调整模块根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,由此可提升直播视频的画质和流畅度,进而提升用户的观看体验。
在上述实施例的基础上,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区。
在上述实施例的基础上,所述装置还包括:
统计确定模块,用于对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况和当前网络带宽,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
在上述实施例的基础上,所述区域确定模块具体用于:
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区;
如果当前缓存情况为空,则确定当前缓存所属的区域为带宽滞后富余区。
在上述实施例的基础上,所述策略调整模块还用于:
如果当前缓存所属的区域为带宽受限区,则减少编码码率;
如果当前缓存所属的区域为带宽提前富余区或带宽滞后富余区,则增加编码码率。
在上述实施例的基础上,所述策略调整模块还包括:
降低编码码率单元,用于判断当前网络带宽是否小于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述减少编码码率的操作。
在上述实施例的基础上,所述策略调整模块还包括增加编码码率单元,所述用于增加编码码率单元用于:
如果当前缓存所属的区域为带宽提前富余区,则判断当前网络带宽是否大于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述增加编码码率的操作;或者
如果当前缓存所属的区域为带宽滞后富余区,则判断当前缓存为空的持续时间是否超过预设时长,并且在判断为是时,执行所述增加编码码率的操作。
在上述实施例的基础上,减少编码码率包括:
取码率b和当前帧的码率x中的最大值作为减少后的目标编码码率;
所述码率b的计算公式为:b=(m-x*y*p),其中,x为当前帧的码率,y为当前缓存中存储的视频时长与预设的灵敏度的极大值的比值,m为当前带宽与当前针对所述编码器已设的编码码率相比的最小值,p为缓存不为空的次数与统计总次数的比值,其中,所述统计总次数为视频数据推流的过程中,截止到当前为止,对各个目标时间段内的视频发送信息进行统计的总次数;所述缓存不为空的次数为在所述统计的过程中,针对各个目标时间段统计得到的缓存情况不为空的次数。
在上述实施例的基础上,增加编码码率包括:
将当前网络带宽值与当前针对所述编码器已设的编码码率值和当前缓存的帧率的比值相加,得到的结果即为增加后的目标编码码率。
在上述实施例的基础上,所述装置还包括网络灵敏度更新模块,所述网络灵敏度更新模块用于:
根据调整后的编码码率确定目标网络带宽;
根据所述目标网络带宽和预设的灵敏度极值,在依据所述灵敏度极值确定的区间内确定目标网络灵敏度,其中,所述灵敏度极值包括灵敏度极大值和灵敏度极小值;
将所述目标网络灵敏度更新为新的当前网络灵敏度,以便依据该新的当前网络灵敏度和缓存情况确定缓存所属的区域。
在上述实施例的基础上,所述策略调整模块还用于:
依据调整后的编码策略确定丢帧策略,并基于所述丢帧策略指示丢帧模块在所述编码器编码前对视频数据进行均匀丢帧,其中,丢帧策略与对视频的画质与流畅度的需求有关;
依据调整后的编码策略,指示编码器对经丢帧后的视频数据进行编码发送。
在上述实施例的基础上,所述装置还包括判断模块,所述判断模块用于:
确定在目标时间段之前确定的历史网络灵敏度是否达到预设阈值,并在达到预设阈值之后,对目标时间段内的视频数据发送信息进行统计。
本公开实施例所提供的视频数据推流装置可执行本公开实施例所提供的视频数据推流方法,具备执行方法相应的功能模块和有益效果。
下面参考图5,其示出了适于用来实现本公开实施例的终端500的结构示意图。本公开实施例中的终端设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图5示出的终端仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图5所示,终端500可以包括处理装置(例如中央处理器、图形处理器等)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储装置508加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理,例如实现本公开实施例所提供的视频数据推流方法,包括:
确定当前网络灵敏度;
根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
在RAM 503中,还存储有终端500操作所需的各种程序和数据。处理装置501、ROM502以及RAM 503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
通常,以下装置可以连接至I/O接口505:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置506;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置507;包括例如磁带、硬盘等的存储装置508;以及通信装置509;此外,还包括例如摄像头等用于视频拍摄的摄像装置510。通信装置509可以允许终端500与其他设备进行无线或有线通信以交换数据。虽然图5示出了具有各种装置的终端500,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置59从网络上被下载和安装,或者从存储装置508被安装,或者从ROM 502被安装。在该计算机程序被处理装置501执行时,执行本公开实施例的方法中限定的上述功能。
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
上述计算机可读介质可以是上述终端中所包含的;也可以是单独存在,而未装配入该终端中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该终端执行时,使得该终端:确定当前网络灵敏度;根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的模块或单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,模块或单元的名称在某种情况下并不构成对该模块或单元本身的限定,例如,降低编码码率单元还可以被描述为“在判断当前网络带宽小于当前针对编码器已设的编码码率时,执行减少编码码率的操作的单元”。
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (14)

1.一种视频数据推流方法,其特征在于,包括:
确定当前网络灵敏度,其中,确定所述当前网络灵敏度是确定在当前网络状态下传输一定大小的数据所需要的时间;
根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区;
所述根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域,包括:
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区;
如果当前缓存情况为空,则确定当前缓存所属的区域为带宽滞后富余区。
2.根据权利要求1所述的方法,其特征在于,在所述确定当前网络灵敏度之前,所述方法还包括:
对目标时间段内的视频数据发送信息进行统计,根据统计结果确定当前缓存情况和当前网络带宽,其中,所述视频数据发送信息至少包括发送时间、发送大小和发送数量。
3.根据权利要求2所述的方法,其特征在于,针对自适应区、带宽受限区和带宽提前富裕区,每个区域各自对应一个根据当前网络灵敏而确定的灵敏度区间,所述自适应区对应的第一灵敏度区间为(X,2X],所述带宽受限区对应的第二灵敏度区间为(2X,+∞),所述带宽提前富裕区对应的第三灵敏度区间为(0,X],其中X表示确定的当前网络灵敏度。
4.根据权利要求2或3所述的方法,其特征在于,所述根据当前缓存所属的区域调整编码策略,包括:
如果当前缓存所属的区域为带宽受限区,则减少编码码率;
如果当前缓存所属的区域为带宽提前富余区或带宽滞后富余区,则增加编码码率。
5.根据权利要求4所述的方法,其特征在于,在减少编码码率之前,所述方法还包括:
判断当前网络带宽是否小于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述减少编码码率的操作。
6.根据权利要求4所述的方法,其特征在于,在增加编码码率之前,所述方法还包括:
如果当前缓存所属的区域为带宽提前富余区,则判断当前网络带宽是否大于当前针对所述编码器已设的编码码率,并且在判断为是时,执行所述增加编码码率的操作;或者
如果当前缓存所属的区域为带宽滞后富余区,则判断当前缓存为空的持续时间是否超过预设时长,并且在判断为是时,执行所述增加编码码率的操作。
7.根据权利要求4所述的方法,其特征在于,所述减少编码码率包括:
取码率b和当前帧的码率x中的最大值作为减少后的目标编码码率;
所述码率b的计算公式为:b=(m-x*y*p),其中,x为当前帧的码率,y为当前缓存中存储的视频时长与预设的灵敏度极大值的比值,m为当前带宽与当前针对所述编码器已设的编码码率相比的最小值,p为缓存不为空的次数与统计总次数的比值,其中,所述统计总次数为视频数据推流的过程中,截止到当前为止,对各个目标时间段内的视频发送信息进行统计的总次数;所述缓存不为空的次数为在所述统计的过程中,针对各个目标时间段统计得到的缓存情况不为空的次数。
8.根据权利要求4所述的方法,其特征在于,所述增加编码码率包括:
将当前网络带宽值与当前针对所述编码器已设的编码码率值和当前缓存的帧率的比值相加,得到的结果即为增加后的目标编码码率。
9.根据权利要求1所述的方法,其特征在于,在依据调整后的编码策略指示编码器对视频数据进行编码发送之后,所述方法还包括:
根据调整后的编码码率确定目标网络带宽;
根据所述目标网络带宽和预设的灵敏度极值,在依据所述灵敏度极值确定的区间内确定目标网络灵敏度,其中,所述灵敏度极值包括灵敏度极大值和灵敏度极小值;
将所述目标网络灵敏度更新为新的当前网络灵敏度,以便依据该新的当前网络灵敏度和缓存情况确定缓存所属的区域。
10.根据权利要求1所述的方法,其特征在于,所述依据调整后的编码策略指示编码器对视频数据进行编码发送,包括:
依据调整后的编码策略确定丢帧策略,并基于所述丢帧策略指示丢帧模块在所述编码器编码前对视频数据进行均匀丢帧,其中,丢帧策略与对视频的画质与流畅度的需求有关;
依据调整后的编码策略,指示编码器对经丢帧后的视频数据进行编码发送。
11.根据权利要求2所述的方法,其特征在于,所述对目标时间段内的视频数据发送信息进行统计,包括:
确定在目标时间段之前确定的历史网络灵敏度是否达到预设阈值,并在达到预设阈值之后,对目标时间段内的视频数据发送信息进行统计。
12.一种视频数据推流装置,其特征在于,包括:
灵敏度确定模块,用于确定当前网络灵敏度,其中,确定所述当前网络灵敏度是确定在当前网络状态下传输一定大小的数据所需要的时间;
区域确定模块,用于根据所述当前网络灵敏度和当前缓存情况,确定当前缓存所属的区域;
策略调整模块,用于根据当前缓存所属的区域调整编码策略,依据调整后的编码策略指示编码器对视频数据进行编码发送,其中,不同的区域对应不同的编码策略,所述区域包括自适应区、带宽受限区、带宽提前富裕区和带宽滞后富裕区;
所述区域确定模块具体用于:
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第一灵敏度区间范围内,则确定当前缓存所属的区域为自适应区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第二灵敏度区间范围内,则确定当前缓存所属的区域为带宽受限区;
如果所述当前缓存中存储的视频时长,位于依据所述当前网络灵敏度确定的第三灵敏度区间范围内,则确定当前缓存所属的区域为带宽提前富余区;
如果当前缓存情况为空,则确定当前缓存所属的区域为带宽滞后富余区。
13.一种终端,其特征在于,所述终端包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-11中任一所述的视频数据推流方法。
14.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-11中任一所述的视频数据推流方法。
CN201811410166.5A 2018-11-23 2018-11-23 视频数据推流方法、装置、终端及存储介质 Active CN111225209B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811410166.5A CN111225209B (zh) 2018-11-23 2018-11-23 视频数据推流方法、装置、终端及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811410166.5A CN111225209B (zh) 2018-11-23 2018-11-23 视频数据推流方法、装置、终端及存储介质

Publications (2)

Publication Number Publication Date
CN111225209A CN111225209A (zh) 2020-06-02
CN111225209B true CN111225209B (zh) 2022-04-12

Family

ID=70828652

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811410166.5A Active CN111225209B (zh) 2018-11-23 2018-11-23 视频数据推流方法、装置、终端及存储介质

Country Status (1)

Country Link
CN (1) CN111225209B (zh)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112954354B (zh) * 2021-02-01 2022-07-22 北京字跳网络技术有限公司 视频的转码方法、装置、设备和介质
CN113055698A (zh) * 2021-03-09 2021-06-29 百果园技术(新加坡)有限公司 视频参数调节方法、装置、设备及介质
CN113556571A (zh) * 2021-07-20 2021-10-26 苏州景昱医疗器械有限公司 视频处理方法、装置、电子设备及计算机可读存储介质
CN115842928B (zh) * 2021-09-18 2024-03-12 腾讯科技(深圳)有限公司 视频码率切换方法、装置、计算机设备和存储介质
CN114040245B (zh) * 2021-11-04 2023-12-29 广州博冠信息科技有限公司 视频播放方法、装置、计算机存储介质和电子设备
CN114640886B (zh) * 2022-02-28 2023-09-15 深圳市宏电技术股份有限公司 自适应带宽的音视频传输方法、装置、计算机设备及介质

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101945262A (zh) * 2009-06-24 2011-01-12 日立民用电子株式会社 无线影像传送系统、内容比特率控制方法
CN102333089A (zh) * 2011-09-26 2012-01-25 南京邮电大学 基于超文本传输协议流化的多码率媒体流自适应控制方法
CN106993237A (zh) * 2017-04-13 2017-07-28 中北大学 基于mpeg‑dash协议的动态自适应码率选择方法
CN106998268A (zh) * 2017-04-05 2017-08-01 网宿科技股份有限公司 一种基于推流终端网络状况的优化方法和系统以及推流终端
CN107241381A (zh) * 2016-03-28 2017-10-10 网络性能研究集团有限责任公司 无线网络中接入点客户端交互定向自适应控制方法与装置

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9585062B2 (en) * 2010-07-15 2017-02-28 Dejero Labs Inc. System and method for implementation of dynamic encoding rates for mobile devices
US20150271072A1 (en) * 2014-03-24 2015-09-24 Cisco Technology, Inc. Method and apparatus for rate controlled content streaming from cache
CN105530449B (zh) * 2014-09-30 2019-01-22 阿里巴巴集团控股有限公司 编码参数调整方法及装置
US9756112B2 (en) * 2015-02-11 2017-09-05 At&T Intellectual Property I, L.P. Method and system for managing service quality according to network status predictions

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101945262A (zh) * 2009-06-24 2011-01-12 日立民用电子株式会社 无线影像传送系统、内容比特率控制方法
CN102333089A (zh) * 2011-09-26 2012-01-25 南京邮电大学 基于超文本传输协议流化的多码率媒体流自适应控制方法
CN107241381A (zh) * 2016-03-28 2017-10-10 网络性能研究集团有限责任公司 无线网络中接入点客户端交互定向自适应控制方法与装置
CN106998268A (zh) * 2017-04-05 2017-08-01 网宿科技股份有限公司 一种基于推流终端网络状况的优化方法和系统以及推流终端
CN106993237A (zh) * 2017-04-13 2017-07-28 中北大学 基于mpeg‑dash协议的动态自适应码率选择方法

Also Published As

Publication number Publication date
CN111225209A (zh) 2020-06-02

Similar Documents

Publication Publication Date Title
CN111225209B (zh) 视频数据推流方法、装置、终端及存储介质
CN112437122B (zh) 通信方法、装置、计算机可读介质及电子设备
WO2019154221A1 (zh) 发送流数据的方法及数据发送设备
CN113992967B (zh) 一种投屏数据传输方法、装置、电子设备及存储介质
CN112954354B (zh) 视频的转码方法、装置、设备和介质
CN112312137A (zh) 一种视频传输方法、装置、电子设备及存储介质
CN111263153B (zh) 视频编码方法、装置、设备及存储介质
CN112312229A (zh) 一种视频传输方法、装置、电子设备及存储介质
CN113316263A (zh) 数据传输方法、装置、设备和存储介质
CN114786055A (zh) 一种预加载方法、装置、电子设备及介质
WO2023226757A1 (zh) 视频缓存方法、装置、设备及存储介质
WO2023169262A1 (zh) 一种视频动态下载方法、装置、电子设备及存储介质
CN112929704A (zh) 数据传输方法、装置、电子设备以及存储介质
CN113242446B (zh) 视频帧的缓存方法、转发方法、通信服务器及程序产品
CN114885209A (zh) 一种直播数据处理方法、计算设备及可读存储介质
CN110971943B (zh) 视频码率调整方法、装置、终端及存储介质
CN115776590A (zh) 动态画质视频播放方法、装置、电子设备及存储介质
CN114416013A (zh) 数据发送方法、装置、电子设备及计算机可读存储介质
US8791981B2 (en) Bit rate control apparatus and method thereof
CN112153322A (zh) 数据分发方法、装置、设备及存储介质
CN118055277A (zh) 视频处理方法、装置、设备与计算机存储介质
CN118055260A (zh) 视频处理方法、装置、设备与计算机存储介质
CN115297361B (zh) 转码任务的处理方法、装置、转码系统、电子设备及介质
CN117412140A (zh) 用于视频传输的方法及设备
CN118233400A (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
GR01 Patent grant
GR01 Patent grant
CP03 Change of name, title or address
CP03 Change of name, title or address

Address after: Room b-0035, 2 / F, building 3, yard 30, Shixing street, Shijingshan District, Beijing 100080

Patentee after: Douyin Vision Co.,Ltd.

Address before: Room b-0035, 2 / F, building 3, yard 30, Shixing street, Shijingshan District, Beijing 100080

Patentee before: Tiktok vision (Beijing) Co.,Ltd.

Address after: Room b-0035, 2 / F, building 3, yard 30, Shixing street, Shijingshan District, Beijing 100080

Patentee after: Tiktok vision (Beijing) Co.,Ltd.

Address before: Room b-0035, 2 / F, building 3, yard 30, Shixing street, Shijingshan District, Beijing 100080

Patentee before: BEIJING BYTEDANCE NETWORK TECHNOLOGY Co.,Ltd.