CN114222194A - 一种视频码流调整方法、装置及系统 - Google Patents

一种视频码流调整方法、装置及系统 Download PDF

Info

Publication number
CN114222194A
CN114222194A CN202111551164.XA CN202111551164A CN114222194A CN 114222194 A CN114222194 A CN 114222194A CN 202111551164 A CN202111551164 A CN 202111551164A CN 114222194 A CN114222194 A CN 114222194A
Authority
CN
China
Prior art keywords
video frame
information
video
determining
network
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
Application number
CN202111551164.XA
Other languages
English (en)
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.)
Zhejiang Dahua Technology Co Ltd
Original Assignee
Zhejiang Dahua 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 Zhejiang Dahua Technology Co Ltd filed Critical Zhejiang Dahua Technology Co Ltd
Priority to CN202111551164.XA priority Critical patent/CN114222194A/zh
Publication of CN114222194A publication Critical patent/CN114222194A/zh
Priority to CN202210893047.XA priority patent/CN115086779B/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/637Control signals issued by the client directed to the server or network components
    • H04N21/6373Control signals issued by the client directed to the server or network components for rate control, e.g. request to the server to modify its transmission rate
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/647Control signaling between network components and server or clients; Network processes for video distribution between server and clients, e.g. controlling the quality of the video stream, by dropping packets, protecting content from unauthorised alteration within the network, monitoring of network load, bridging between two different networks, e.g. between IP and wireless
    • H04N21/64723Monitoring of network processes or resources, e.g. monitoring of network load
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/647Control signaling between network components and server or clients; Network processes for video distribution between server and clients, e.g. controlling the quality of the video stream, by dropping packets, protecting content from unauthorised alteration within the network, monitoring of network load, bridging between two different networks, e.g. between IP and wireless
    • H04N21/64723Monitoring of network processes or resources, e.g. monitoring of network load
    • H04N21/64738Monitoring network characteristics, e.g. bandwidth, congestion level
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/647Control signaling between network components and server or clients; Network processes for video distribution between server and clients, e.g. controlling the quality of the video stream, by dropping packets, protecting content from unauthorised alteration within the network, monitoring of network load, bridging between two different networks, e.g. between IP and wireless
    • H04N21/64746Control signals issued by the network directed to the server or the client
    • H04N21/64761Control signals issued by the network directed to the server or the client directed to the server
    • H04N21/64769Control signals issued by the network directed to the server or the client directed to the server for rate control

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Computer Security & Cryptography (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本申请实施例提供一种视频码流调整方法、装置及系统,该方法包括:第一设备接收第一信息(第二设备在预设时长内的视频帧发送信息),以及获取第二信息(第一设备在预设时长内的视频帧接收信息和/或视频帧播放缓存信息);基于第一信息和第二信息,确定在预设时长内的网络拥塞情况;和/或,第一设备基于第二信息,确定在预设时长内的视频帧播放情况;以及基于视频帧播放情况和/或网络拥塞情况,确定码流调整策略,并向第二设备发送码流调整策略;进而第二设备可以基于码流调整策略对码流进行调整。如此,使得对视频的码流调整适配于播放设备和发送设备的网络情况,从而提升视频播放质量。

Description

一种视频码流调整方法、装置及系统
技术领域
本发明涉及视频技术领域,尤其涉及一种视频码流调整方法、装置及系统。
背景技术
随着无线网络技术以及视频技术的发展,视频播放应用的使用也越来越普遍。视频发送设备通常通过视频云平台向视频播放设备转发视频,因而视频发送设备与视频云平台之间形成了上行网络,视频播放设备与视频云平台之间形成了下行网络。然而视频发送设备无法感知下行网络的网络质量以及播放设备的视频播放质量,视频播放设备也无法感知上行网络的网络质量,使得视频发送设备和视频播放设备的感知隔离,导致两者码流调整策略配合较差,从而导致视频业务整体的播放体验较差,易出现播放卡顿和录像缺失等问题。
因此,如何提供一种合理的视频码流调整方法,以提升视频播放质量,是本申请亟需解决的问题。
发明内容
本发明实施例提供了一种视频码流调整方法及装置,用以改进视频的码流调整策略,以提升视频播放质量,从而有效提升用户体验。
第一方面,本申请实施例提供一种视频码流调整方法,应用于第一设备,该方法包括:接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;向所述第二设备发送所述码流调整策略,所述码流调整策略用于对码流进行调整。
在一种可能的设计中,基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况,包括:基于所述第一信息和所述第二信息,确定第一网络状态和/或第二网络状态;其中,所述第一网络状态与视频帧丢帧率关联,所述第二网络状态与视频帧时延关联;基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况。
在一种可能的设计中,所述视频发送信息包括视频帧发送数目,所述视频接收信息包括视频帧接收数目;基于所述第一信息和所述第二信息,确定第一网络状态,包括:基于所述视频帧发送数目和所述视频帧接收数目,确定所述预设时长内的视频帧丢帧率;若所述视频帧丢帧率大于第一阈值,则确定所述第一网络状态为过载状态;或者,若所述视频帧丢帧率为第二阈值,则确定所述第一网络状态为正常状态;或者,若所述视频帧丢帧率大于等于第二阈值且小于第一阈值,则确定所述第一网络状态为低载状态。
在一种可能的设计中,所述视频发送信息包括视频帧帧发送间隔,所述视频接收信息包括视频帧帧接收间隔;基于所述第一信息和所述第二信息,确定第二网络状态,包括:基于视频帧帧发送间隔和视频帧帧接收间隔,确定所述预设时长内的视频帧时延的变化趋势;若所述视频帧时延的变化趋势的量化值大于第三阈值,且在所述预设时长内网络带宽的过载次数超出第四阈值和/或所述网络带宽的过载时长超出第五阈值,则确定所述第二网络状态为过载状态;或者,若所述视频帧时延的变化趋势的量化值小于第六阈值,则确定第二网络状态为低载状态;或者,若所述视频帧时延的变化趋势的量化值小于等于第三阈值且大于等于第六阈值,且在所述预设时长内网络带宽的正常次数超出第七阈值和/或所述网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。
在一种可能的设计中,所述第三阈值和所述第六阈值是根据所述视频帧时延的变化趋势的量化值与所述第三阈值或所述第六阈值的差值的绝对值动态调整的。
在一种可能的设计中,基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况,包括:所述第一网络状态和/或所述第二网络状态为过载状态,则确定所述预设时长内的网络带宽处于过载状态;所述第一网络状态和所述第二网络状态均为正常状态,则确定所述预设时长内的网络带宽处于正常状态;所述第一网络状态为正常状态,所述第二网络状态为低载状态,则确定所述预设时长内的网络带宽处于低载状态。
在一种可能的设计中,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;基于所述第二信息,确定在所述预设时长内的视频帧播放情况,包括:根据所述视频帧接收间隔和所述视频帧缓存时间,确定所述预设时长内的帧播放抖动时间;若帧播放抖动时间小于等于第九阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动时间大于第九阈值,则确定在所述预设时长内视频播放卡顿。
在一种可能的设计中,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;基于所述第二信息,确定在所述预设时长内的视频帧播放情况,包括:根据所述视频帧接收间隔和所述视频帧缓存时间,统计所述预设时长内的帧播放抖动次数;若帧播放抖动次数小于等于第十阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动次数大于第十阈值,则确定在所述预设时长内视频播放卡顿。
在一种可能的设计中,基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略,包括:在所述预设时长内视频播放卡顿和/或网络带宽处于过载状态时,所述码流调整策略用于指示所述第二设备下调码流;或者,在所述预设时长内视频播放未卡顿和/或网络带宽处于正常状态时,所述码流调整策略用于指示所述第二设备上调码流。
第二方面,本申请实施例还提供了一种视频码流调整方法,该方法可以应用于第二设备,包括:发送第一信息,所述第一信息包括所述第二设备在预设时长内的视频帧发送信息;接收所述预设时长内的码流调整策略;基于所述码流调整策略,进行码流调整。
第三方面,一种视频码流调整系统,该系统包括第一设备、第二设备和服务器,其中:所述第一设备,用于通过服务器接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;以及,获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;通过所述服务器向所述第二设备发送所述码流调整策略;所述第二设备,用于通过所述服务器接收所述码流调整策略,并对码流进行调整。
第四方面,本申请实施例还提供一种视频码流调整装置,该装置包括:处理器和存储器;所述存储器用于存储计算机执行指令,当所述处理器执行所述指令时,使所述视频码流调整装置执行如上述第一方面以及第一方面任一项可能的设计所述的方法,或者,执行如上述第二方面以及第二方面任一项可能的设计所述的方法。
第五方面,本申请实施例还提供一种计算机可读存储介质,所述计算机可读存储介质包括指令,当所述指令在计算机上运行时,使得所述计算机执行如上述第一方面以及第一方面任一项可能的设计所述的方法,或者,执行如上述第二方面以及第二方面任一项可能的设计所述的方法。
本申请实施例提供一种视频码流调整方法,应用于第一设备,该方法包括:接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;向所述第二设备发送所述码流调整策略,所述码流调整策略用于对码流进行调整。
在本申请实施例中,第一设备(即视频播放设备)通过结合自身在预设时长内的视频帧接收信息和/或视频帧播放缓存信息、以及第二设备(即视频发送设备)在预设时长内的视频帧发送信息,确定在所述预设时长内的网络拥塞情况和/或视频帧播放情况;基于视频帧播放情况和/或网络拥塞情况,确定码流调整策略,并发送至第二设备;进而第二设备可以基于码流调整策略,对码流进行调整。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简要介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域的普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例适用的系统架构图;
图2为本申请实施例提供的端到端的数据流向示意图;
图3为本申请实施例提供的视频码流调整方法的流程示意图;
图4为本申请实施例提供的确定第一网络状态的流程示意图;
图5为本申请实施例提供的确定第二网络状态的流程示意图;
图6为本申请实施例提供的视频帧间隔时延拥塞检测的原理示意图;
图7为本申请实施例提供的结合第一网络状态和第二网络状态确定网络拥塞情况的流程示意图;
图8为本申请实施例提供的视频卡顿检测的流程示意图;
图9为本申请实施例提供的确定码流调整策略的流程示意图;
图10为本申请实施例提供的一种视频码流调整装置的结构示意图;
图11为本申请实施例提供的另一种视频码流调整装置的结构示意图;
图12为本申请实施例提供的一种电子设备的结构示意图。
具体实施方式
下面将结合附图对本发明作进一步地详细描述,显然,所描述的实施例仅仅是本发明一部份实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。
首先,结合具体的附图介绍一下本申请实施例适用的系统架构图。
图1示出了本申请实施例适用的一种系统架构图,该系统包括播放设备、发送设备和云平台。其中,发送设备与云平台可以通过无线网络连接,进而发送设备可以通过云平台向播放设备转发视频,形成了上行网络侧;播放设备和云平台之间可以通过有线网络或无线网络连接,进而云平台可以向播放设备下发视频,形成了下行网络侧。
应理解,播放设备可以手机、解码墙、智能电视、电脑等具备显示能力的设备,本申请实施例不作具体的限制。发送设备为具备视频编码能力、码流调整能力的设备,例如移动监控设备,本申请实施例不作具体的限制。
在本申请实施例中,播放设备可以接收第一信息,第一信息包括第二设备在预设时长内的视频帧发送信息;播放设备获取第二信息,第二信息包括第一设备在预设时长内的视频帧接收信息和/或视频帧播放缓存信息,基于第一信息和第二信息,确定在预设时长内的网络拥塞情况;和/或,基于第二信息,确定在预设时长内的视频帧播放情况;以及基于视频帧播放情况和/或网络拥塞情况,确定码流调整策略;向发送设备发送码流调整策略,发送设备基于码流调整策略对码流进行调整。如此,使得播放设备可以结合自身的视频帧接收信息和/或视频帧播放缓存信息,以及发送设备的视频帧发送信息,确定码流调整策略,使得对视频的码流调整适配于播放设备和发送设备的网络情况,从而提升视频播放质量。
图2示出了播放端和设备端之间的数据流向示意图。其中,播放端即前述的播放设备,设备端即前述的发送设备。其中,播放端包括解码播放应用、码流控制模块、码流评估模块、反馈处理模块、解码播放模块、网络接收模块;设备端包括流媒体应用、发送反馈处模块、控制处理模块、码流调整模块、编码模块、缓存模块。其中,设备端的发送反馈模块将设备端的帧发送信息,发送至播放端的网络接收模块;网络接收模块将帧发送信息进一步反馈给反馈处理模块;反馈处理模块获取播放端的帧接收信息和视频帧播放缓存信息,并将帧接收信息、视频帧播放缓存信息和帧发送信息,发送至码流评估模块;码流评估模块基于帧接收信息、视频帧播放缓存信息和帧发送信息,确定码流控制策略,并将码流控制策略发送码流控制模块;码流控制模块将码流控制策略发送至设备端的码流调整模块;码流调整模块基于码流控制策略,对当前视频的码流进行调整。其中,码流控制策略包括取流策略控制、码率策略控制和丢帧策略(例如,普通丢帧策略和SVC丢帧策略)控制。
图3为本发明实施例提供的一种视频码流调整方法的流程示意图,该方法的执行主体以第一设备(即图1的播放设备或图2的播放端)和第二设备(即图1的发送设备或图2的设备端)为例,该过程包括以下步骤:
S301:第二设备发送第一信息。相应的,第一设备接收第一信息。
其中,第一信息包括第二设备在预设时长内的视频帧发送信息。本申请实施例中,视频帧发送信息包括但不限于视频帧发送数目、视频帧编码数目、视频帧发送时间、视频帧编码时间、帧类型、帧序号、视频帧发送耗时。
S302:第一设备获取第二信息。
其中,第二信息包括第一设备在预设时长内的视频帧接收信息和/或视频帧播放缓存信息。本申请实施例中,视频帧接收信息包括但不限于视频帧接收数目、视频帧接收时间、帧类型、帧序号,视频帧播放缓存信息包括但不限于视频帧缓存数目、视频帧播放数目、帧类型、帧序号。
S303:第一设备基于第一信息和第二信息,确定在预设时长内的网络拥塞情况;和/或,基于第二信息,确定在预设时长内的视频帧播放情况。
需要说明的是,本申请实施例中确定网络拥塞情况的实施方式有多种,包括但不限于以下方式:
实施方式1,第一设备基于第一信息和第二信息,确定第一网络状态;基于第一网络状态,确定网络拥塞情况。
在一种可能的实施方式中,第一网络状态可以与视频帧丢帧率关联,若上述视频发送信息包括视频帧发送数目,视频接收信息包括视频帧接收数目;第一设备可以基于视频帧发送数目和视频帧接收数目,确定预设时长内的视频帧丢帧率;若视频帧丢帧率大于第一阈值,则确定第一网络状态为过载状态;或者,若视频帧丢帧率为第二阈值,则确定第一网络状态为正常状态;或者,若视频帧丢帧率大于等于第二阈值且小于第一阈值,则确定第一网络状态为低载状态。其中,在视频帧发送数目包括编码输入视频帧数目时,预设时长内的视频帧丢帧率loss=(编码输入视频帧数目-视频接收帧数目)/编码输入视频帧数目。
可以理解的是,“过载状态”是指网络带宽不足的状态,“正常状态”是指网络带宽正常使用的状态,“低载状态”是指网络带宽存在一定负荷的状态。相应的,第一网络状态为过载状态时,网络拥塞情况为网络带宽不足;第一网络状态为正常状态时,网络拥塞情况为网络带宽充足;第一网络状态为低载状态时,网络拥塞情况为网络带宽略微不足。
示例性的,请参见图4,第一阈值以10%为例,第二阈值以0为例,预设时长以5分钟为例。若编码输入视频帧数目为100帧,视频帧接收数目为50,则5分钟内的视频帧丢帧率loss=(编码输入视频帧数目-视频接收帧数目)/编码输入视频帧数目=(100-50)/100=50%,视频帧丢帧率loss大于10%,则确定第一网络状态为过载状态,即网络带宽不足;或者,若编码输入视频帧数目为100帧,视频帧接收数目为100,则5分钟内的视频帧丢帧率loss=(编码输入视频帧数目-视频接收帧数目)/编码输入视频帧数目=(100-100)/100=0,视频帧丢帧率loss为0,则确定第一网络状态为正常状态,即网络带宽充足;或者,若编码输入视频帧数目为100帧,视频帧接收数目为95,则5分钟内的视频帧丢帧率loss=(编码输入视频帧数目-视频接收帧数目)/编码输入视频帧数目=(100-95)/100=5%,视频帧丢帧率loss5%大于0且小于10%,则确定第一网络状态为低载状态,即网络带宽存在部分负载。
实施方式2,第二设备基于第一信息和第二信息,确定第二网络状态,并基于第二网络状态,确定网络拥塞情况。
请参见图5,在一种可能的实施方式中,第二网络状态与视频帧时延关联;上述视频发送信息包括视频帧帧发送间隔,视频接收信息包括视频帧帧接收间隔;第一设备基于第一信息和第二信息,确定第二网络状态的过程,包括以下步骤:
S501、基于视频帧帧发送间隔和视频帧帧接收间隔,确定预设时长内的视频帧时延的变化趋势的量化值。
进一步的,基于视频帧帧发送间隔和视频帧帧接收间隔,确定预设时长内的视频帧时延的变化趋势的量化值,包括:
S5011、基于视频帧帧发送间隔和视频帧帧接收间隔,确定视频帧间隔时延梯度值。
示例性的,视频帧间隔延迟梯度值(delta_ms)=视频帧帧接收间隔(recv_delta_ms)-视频帧帧发送间隔send_delta_ms。
S5012、根据预设时长内的视频帧间隔时延梯度值确定视频帧时延的变化趋势的量化值。
其中,基于视频帧组延迟梯度拥塞检测算法检测原理如下图6所示。其中,Frame(i)代表第i个视频帧组,Frame(i-1)代表第i-1个视频帧组,Frame(i+1)代表第i+1个视频帧组,每个视频帧组包含多个视频帧,比如将连续的视频帧按照3个1组进行划分,分为第1组,第2组,……,第i-1组,第i组。t(i)代表视频帧组i的最后一个帧的到达时间,t(i-1)代表视频帧组i-1的最后一个帧的到达时间,T(i)代表视频帧组i最后一个帧的发送时间,T(i-1)代表视频帧组i-1最后一个帧的发送时间。两个帧组之间的延迟变化d(i)满足如下公式:
d(i)=(t(i)–t(i-1))–(T(i)–T(i-1));
其中,d(i)为0,则网络没有拥塞,d(i)大于0则网络存在拥塞,d(i)小于0则网络拥塞正在恢复。
进一步的,第一设备可以结合一次指数平滑预测算法和最小二乘线性回归算法,将预设时长内的视频帧间隔延迟梯度值进行累加、平滑和线性回归,得到视频帧时延的变化趋势的量化值,并通过该变化趋势的量化值表征网络的拥塞程度。
S502、基于视频帧时延的变化趋势的量化值,确定第二网络状态。
其中,第一设备可以将视频帧时延的变化趋势的量化值与预设阈值相比较,确定第二网络状态;若视频帧时延的变化趋势的量化值大于第三阈值,且在预设时长内网络带宽的过载次数超出第四阈值和/或网络带宽的过载时长超出第五阈值,则确定第二网络状态为过载状态;或者,若视频帧时延的变化趋势的量化值小于第六阈值,则确定第二网络状态为低载状态;或者,若视频帧时延的变化趋势的量化值小于等于第三阈值且大于等于第六阈值,且在预设时长内网络带宽的正常次数超出第七阈值和/或网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。
示例1,预设时长以5分钟为例,第三阈值以10%为例,第四阈值以2次为例,第五阈值以1分钟为例。例如,若视频帧时延的变化趋势的量化值为15%,5分钟内网络带宽的过载次数为3次,网络带宽的过载时长为4分钟,则视频帧时延的变化趋势的量化值大于第三阈值,且在5分钟内网络带宽的过载次数超出第四阈值以及网络带宽的过载时长超出第五阈值,则确定第二网络状态为过载状态;又例如,若视频帧时延的变化趋势的量化值为15%,5分钟内网络带宽的过载次数为3次,则视频帧时延的变化趋势的量化值大于第三阈值,且在5分钟内网络带宽的过载次数超出第四阈值,则确定第二网络状态为过载状态;再例如,若视频帧时延的变化趋势的量化值为15%,网络带宽的过载时长为4分钟,则视频帧时延的变化趋势的量化值大于第三阈值,且在5分钟内网络带宽的过载时长超出第五阈值,则确定第二网络状态为过载状态。
示例2,预设时长以5分钟为例,第六阈值以5%为例。若视频帧时延的变化趋势的量化值1%,则视频帧时延的变化趋势的量化值小于第六阈值,则确定第二网络状态为低载状态。
示例3,预设时长以5分钟为例,第三阈值以10%为例,第四阈值以2次为例,第五阈值以1分钟为例,第六阈值以5%为例,第七阈值以50次为例,第八阈值以3分钟为例。例如,若视频帧时延的变化趋势的量化值为8%,5分钟内网络带宽的正常次数为55次,网络带宽的正常时长为4分钟,则视频帧时延的变化趋势的量化值小于第三阈值且大于第六阈值,且在5分钟内网络带宽的正常次数超出第七阈值和/或网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。又例如,若视频帧时延的变化趋势的量化值为8%,5分钟内网络带宽的正常次数为55次,则视频帧时延的变化趋势的量化值小于第三阈值且大于第六阈值,且在5分钟内网络带宽的正常次数超出第七阈值,则确定第二网络状态为正常状态。又例如,若视频帧时延的变化趋势的量化值为8%,网络带宽的正常时长为4分钟,则视频帧时延的变化趋势的量化值小于第三阈值且大于第六阈值,且在5分钟内网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。
相应的,第二网络状态为过载状态时,网络拥塞情况为网络带宽不足;第二网络状态为正常状态时,网络拥塞情况为网络带宽充足;第二网络状态为低载状态时,网络拥塞情况为网络带宽略微不足。
可选的,第一设备确定第二网络状态之后,还可以执行S503:根据视频帧时延的变化趋势的量化值与第三阈值或第六阈值的差值的绝对值动态调整上述第三阈值和第六阈值。如此,使得基于视频帧时延的网络拥塞检测方法可以适用于不同的应用场景。
其中,S503具体包括如下步骤:
S5031:确定视频帧时延变化值的变化趋势的量化值trend与动态阈值threshold_的差值的绝对值trend_deta。
S5032:根据差值的绝对值trend_deta,确定动态阈值的调整值。
示例性的,可以根据如下公式,确定动态阈值的调整值。
deta=k*(trend_deta-threshold_)*deta_t;其中,deta为阈值调整值,k为调整因子,trend_deta为视频帧时延变化值的变化趋势的量化值trend与动态阈值threshold_的差值的绝对值,deta_t为上一次动态阈值更新的时间差。其中,deta_t>=100毫秒。
其中,调整因子K是根据变化趋势的量化值trend与动态阈值threshold_的差值绝对值trend_deta确定的。例如,trend_deta<threshold_,则调整因子k=上调系数Kup(即增大K);trend_deta>=threshold_,则调整因子k=下调系数Kdown(即减小K)。
S5033:根据动态阈值的调整值,更新动态阈值。
应理解,动态阈值是指上述第三阈值和第六阈值。
实施方式3,第一设备基于第一信息和第二信息,确定第一网络状态和第二网络状态;基于第一网络状态和第二网络状态,确定网络拥塞情况。
请参见图7,第一设备基于第一网络状态和第二网络状态,确定网络拥塞情况的过程可以是:第一设备获取第一网络状态和第二网络状态,在确定第一网络状态和/或第二网络状态为过载状态时,则确定预设时长内的网络带宽处于过载状态;或者,在确定第一网络状态和第二网络状态均为正常状态时,则确定预设时长内的网络带宽处于正常状态;或者,在确定第一网络状态为低载状态,第二网络状态为正常状态时,则确定预设时长内的网络带宽处于低载状态。其中确定第一网络状态和第二网络状态的具体的实施方式,请参见前文关于实施方式1和实施方式2的描述,这里不再赘述。
示例性的,预设时长以5分钟为例,在5分钟内第一网络状态和/或第二网络状态为过载状态时,则确定5分钟内的网络带宽处于过载状态;或者,在5分钟内第一网络状态和第二网络状态均为正常状态时,则确定5分钟内的网络带宽处于正常状态;或者,在确定第一网络状态为正常状态,第二网络状态为低载状态时,则确定5分钟内的网络带宽处于低载状态。
需要说明的是,第一设备基于第二信息,确定在预设时长内的视频帧播放情况,有多种实施方式,包括但不限于以下实施方式:
实施方式1,视频接收信息包括视频帧接收间隔,视频播放缓存信息包括视频帧缓存时间;第一设备基于第二信息,确定在预设时长内的视频帧播放情况,包括:根据视频帧接收间隔和视频帧缓存时间,确定预设时长内的帧播放抖动时间;若帧播放抖动时间小于等于第九阈值,则确定在预设时长内视频播放未卡顿;或者,若帧播放抖动时间大于第九阈值,则确定在预设时长内视频播放卡顿。其中,帧播放抖动时间(jitter time)=视频帧缓存时间(buffer time)-视频帧接收间隔(interval)。
示例性的,第九阈值为2s,视频帧缓存时间(buffer time)为1s,视频帧接收间隔(interval)为0.6s。帧播放抖动时间(jitter time)=视频帧缓存时间(buffer time)-视频帧接收间隔(interval)=0.4s,则帧播放抖动时间小于第九阈值,则确定在预设时长内视频播放未卡顿。
实施方式2,视频接收信息包括视频帧接收间隔,视频播放缓存信息包括视频帧缓存时间;第一设备基于第二信息,确定在预设时长内的视频帧播放情况,包括:根据视频帧接收间隔和视频帧缓存时间,统计预设时长内的帧播放抖动次数;若帧播放抖动次数小于等于第十阈值,则确定在预设时长内视频播放未卡顿;或者,若帧播放抖动次数大于第十阈值,则确定在预设时长内视频播放卡顿。
示例性的,第十阈值为3次,5分钟内的帧播放抖动次数未4次,则帧播放抖动次数大于第十阈值,则确定在5分钟内视频播放卡顿。
实施方式3,请参见图8,第一设备获取第二信息(即视频帧缓存时间(buffertime)和视频帧接收间隔(interval))之后,确定帧播放抖动时间(jitter time),帧播放抖动时间(jitter time)小于预设阈值,则确定视频播放卡顿;进一步,统计预设时长内的帧播放抖动次数,在帧播放抖动次数大于第十阈值时,才认为在预设时长内视频播放卡顿。或者,统计预设时长内的帧播放抖动时长,在帧播放抖动时长大于第九阈值时,才认为在预设时长内视频播放卡顿,停止取流。如此,使得视频卡顿检测更灵活。
S304:第一设备基于视频帧播放情况和/或网络拥塞情况,确定码流调整策略。
请参见图9,在一种可能的实施方式中,第一设备基于视频帧播放情况和/或网络拥塞情况,确定码流调整策略的过程可以是:获取视频帧播放情况和网络拥塞情况,在预设时长内视频播放卡顿和/或网络带宽处于过载状态时,码流调整策略用于指示第二设备下调码流;或者,在预设时长内视频播放未卡顿和/或网络带宽处于正常状态时,码流调整策略用于指示第二设备上调码流;或者,在预设时长内视频播放未卡顿和/或网络带宽处于低载状态时,码流调整策略指示码流不变。
S305:第一设备向第二设备发送码流调整策略。相应的,第二设备接收码流调整策略。
S306:第二设备码流调整策略用于对码流进行调整。
示例性的,码流调整策略指示第二设备下调码流,则第二设备下调码流,例如将码流从2M降低为1M。若码流调整策略指示第二设备上调码流,则第二设备上调码流,例如将码流从1M降低为2M。
基于同一发明构思,本申请还提供了一种视频码流调整装置,请参见图10,图10为本申请实施例提供的一种视频码流调整装置的结构示意图,该装置可以用于实现上述第一设备执行的方法,该装置包括:
收发模块1001,用于接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;
处理模块1002,用于获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;
收发模块1001,还用于向所述第二设备发送所述码流调整策略,所述码流调整策略用于对码流进行调整。
在一种可能的实施方式中,处理模块1002具体用于:基于所述第一信息和所述第二信息,确定第一网络状态和/或第二网络状态;其中,所述第一网络状态与视频帧丢帧率关联,所述第二网络状态与视频帧时延关联;基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况。
在一种可能的实施方式中,所述视频发送信息包括视频帧发送数目,所述视频接收信息包括视频帧接收数目;处理模块1002在用于基于所述第一信息和所述第二信息,确定第一网络状态时,具体用于:基于所述视频帧发送数目和所述视频帧接收数目,确定所述预设时长内的视频帧丢帧率;若所述视频帧丢帧率大于第一阈值,则确定所述第一网络状态为过载状态;或者,若所述视频帧丢帧率为第二阈值,则确定所述第一网络状态为正常状态;或者,若所述视频帧丢帧率大于等于第二阈值且小于第一阈值,则确定所述第一网络状态为低载状态。
在一种可能的实施方式中,所述视频发送信息包括视频帧帧发送间隔,所述视频接收信息包括视频帧帧接收间隔;处理模块1002在用于基于所述第一信息和所述第二信息,确定第二网络状态时,具体用于:基于视频帧帧发送间隔和视频帧帧接收间隔,确定所述预设时长内的视频帧时延的变化趋势;若所述视频帧时延的变化趋势的量化值大于第三阈值,且在所述预设时长内网络带宽的过载次数超出第四阈值和/或所述网络带宽的过载时长超出第五阈值,则确定所述第二网络状态为过载状态;或者,若所述视频帧时延的变化趋势的量化值小于第六阈值,则确定第二网络状态为低载状态;或者,若所述视频帧时延的变化趋势的量化值小于等于第三阈值且大于等于第六阈值,且在所述预设时长内网络带宽的正常次数超出第七阈值和/或所述网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。
在一种可能的实施方式中,所述第三阈值和所述第六阈值是根据所述视频帧时延的变化趋势的量化值与所述第三阈值或所述第六阈值的差值的绝对值动态调整的。
在一种可能的实施方式中,处理模块1002在用于基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况,具体用于:所述第一网络状态和/或所述第二网络状态为过载状态,则确定所述预设时长内的网络带宽处于过载状态;所述第一网络状态和所述第二网络状态均为正常状态,则确定所述预设时长内的网络带宽处于正常状态;所述第一网络状态为正常状态,所述第二网络状态为低载状态,则确定所述预设时长内的网络带宽处于低载状态。
在一种可能的实施方式中,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;处理模块1002在用于基于所述第二信息,确定在所述预设时长内的视频帧播放情况,具体用于:根据所述视频帧接收间隔和所述视频帧缓存时间,确定所述预设时长内的帧播放抖动时间;若帧播放抖动时间小于等于第九阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动时间大于第九阈值,则确定在所述预设时长内视频播放卡顿。
在一种可能的实施方式中,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;处理模块1002在用于基于所述第二信息,确定在所述预设时长内的视频帧播放情况,具体用于:根据所述视频帧接收间隔和所述视频帧缓存时间,统计所述预设时长内的帧播放抖动次数;若帧播放抖动次数小于等于第十阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动次数大于第十阈值,则确定在所述预设时长内视频播放卡顿。
在一种可能的实施方式中,处理模块1002在用于基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略,具体用于:在所述预设时长内视频播放卡顿和/或网络带宽处于过载状态时,所述码流调整策略用于指示所述第二设备下调码流;或者,在所述预设时长内视频播放未卡顿和/或网络带宽处于正常状态时,所述码流调整策略用于指示所述第二设备上调码流。
基于同一发明构思,本申请还提供了一种视频码流调整装置,请参见图11,图11为本申请实施例提供的另一种视频码流调整装置的结构示意图,该装置可以用于实现上述第二设备执行的方法,该装置包括:
收发模块1101,用于发送第一信息,所述第一信息包括所述第二设备在预设时长内的视频帧发送信息;接收所述预设时长内的码流调整策略;
处理模块1102,用于基于所述码流调整策略,进行码流调整。
本申请实施例还提供了一种视频码流调整系统,该系统包括第一设备、第二设备和服务器,其中:第一设备可以通过服务器接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;以及,获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;通过所述服务器向所述第二设备发送所述码流调整策略;所述第二设备,可以通过所述服务器接收所述码流调整策略,并对码流进行调整。
请参见图12所示,图12为本申请实施例提供的电子设备的结构示意图。该电子设备(例如图3中的第一设备或第二设备)包括至少一个处理器1202,以及与至少一个处理器连接的存储器1201,本申请实施例中不限定处理器1202与存储器1201之间的具体连接介质,图12是以处理器1202和存储器1201之间通过总线1200连接为例,总线1200在图12中以粗线表示,其它部件之间的连接方式,仅是进行示意性说明,并不以此为限。总线1200可以分为地址总线、数据总线、控制总线等,为便于表示,图12中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
在本申请实施例中,存储器1201存储有可被至少一个处理器1202执行的指令,至少一个处理器1202通过调用存储器1201存储的指令,可以执行前述的一种视频码流调整方法中所包括的步骤。
其中,处理器1202是电子设备的控制中心,可以利用各种接口和线路连接整个电子设备的各个部分,通过执行存储在存储器1201内的指令,从而实现电子设备的各种功能。可选的,处理器1202可包括一个或多个处理单元,处理器1202可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器1202中。在一些实施例中,处理器1202和存储器1201可以在同一芯片上实现,在一些实施例中,它们也可以在独立的芯片上分别实现。
存储器1201作为一种非易失性计算机可读存储介质,可用于存储非易失性软件程序、非易失性计算机可执行程序以及模块。存储器1201可以包括至少一种类型的存储介质,例如可以包括闪存、硬盘、多媒体卡、卡型存储器、随机访问存储器(Random AccessMemory,RAM)、静态随机访问存储器(Static Random Access Memory,SRAM)、可编程只读存储器(Programmable Read Only Memory,PROM)、只读存储器(Read Only Memory,ROM)、带电可擦除可编程只读存储器(Electrically Erasable Programmable Read-Only Memory,EEPROM)、磁性存储器、磁盘、光盘等等。存储器1201是能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。本申请实施例中的存储器1201还可以是电路或者其它任意能够实现存储功能的装置,用于存储程序指令和/或数据。
处理器1202可以是通用处理器,例如中央处理器(CPU)、数字信号处理器、专用集成电路、现场可编程门阵列或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件,可以实现或者执行本申请实施例中公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者任何常规的处理器等。结合本申请实施例所公开的一种预警方法的步骤可以直接体现为硬件处理器执行完成,或者用处理器中的硬件及软件模块组合执行完成。
通过对处理器1202进行设计编程,可以将前述实施例中介绍的一种释放资源的方法所对应的代码固化到芯片内,从而使芯片在运行时能够执行前述的一种视频码流调整方法的步骤,如何对处理器1202进行设计编程为本领域技术人员所公知的技术,这里不再赘述。
基于上述实施例,本申请实施例中,提供了一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述任意方法实施例中的一种视频码流调整方法。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
显然,本领域的技术人员可以对本申请进行各种改动和变型而不脱离本申请的精神和范围。这样,倘若本申请的这些修改和变型属于本申请权利要求及其等同技术的范围之内,则本申请也意图包含这些改动和变型在内。

Claims (13)

1.一种视频码流调整方法,其特征在于,应用于第一设备,包括:
接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;
基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;
向所述第二设备发送所述码流调整策略,所述码流调整策略用于对码流进行调整。
2.如权利要求1所述的方法,其特征在于,基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况,包括:
基于所述第一信息和所述第二信息,确定第一网络状态和/或第二网络状态;其中,所述第一网络状态与视频帧丢帧率关联,所述第二网络状态与视频帧时延关联;
基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况。
3.如权利要求2所述的方法,其特征在于,所述视频发送信息包括视频帧发送数目,所述视频接收信息包括视频帧接收数目;基于所述第一信息和所述第二信息,确定第一网络状态,包括:
基于所述视频帧发送数目和所述视频帧接收数目,确定所述预设时长内的视频帧丢帧率;
若所述视频帧丢帧率大于第一阈值,则确定所述第一网络状态为过载状态;或者,若所述视频帧丢帧率为第二阈值,则确定所述第一网络状态为正常状态;或者,若所述视频帧丢帧率大于等于第二阈值且小于第一阈值,则确定所述第一网络状态为低载状态。
4.如权利要求2所述的方法,其特征在于,所述视频发送信息包括视频帧帧发送间隔,所述视频接收信息包括视频帧帧接收间隔;基于所述第一信息和所述第二信息,确定第二网络状态,包括:
基于视频帧帧发送间隔和视频帧帧接收间隔,确定所述预设时长内的视频帧时延的变化趋势;
若所述视频帧时延的变化趋势的量化值大于第三阈值,且在所述预设时长内网络带宽的过载次数超出第四阈值和/或所述网络带宽的过载时长超出第五阈值,则确定所述第二网络状态为过载状态;
或者,若所述视频帧时延的变化趋势的量化值小于第六阈值,则确定第二网络状态为低载状态;
或者,若所述视频帧时延的变化趋势的量化值小于等于第三阈值且大于等于第六阈值,且在所述预设时长内网络带宽的正常次数超出第七阈值和/或所述网络带宽的正常时长超出第八阈值,则确定第二网络状态为正常状态。
5.如权利要求4所述的方法,其特征在于,所述第三阈值和所述第六阈值是根据所述视频帧时延的变化趋势的量化值与所述第三阈值或所述第六阈值的差值的绝对值动态调整的。
6.如权利要求2所述的方法,其特征在于,基于所述第一网络状态和/或所述第二网络状态,确定所述网络拥塞情况,包括:
所述第一网络状态和/或所述第二网络状态为过载状态,则确定所述预设时长内的网络带宽处于过载状态;
所述第一网络状态和所述第二网络状态均为正常状态,则确定所述预设时长内的网络带宽处于正常状态;
所述第一网络状态为正常状态,所述第二网络状态为低载状态,则确定所述预设时长内的网络带宽处于低载状态。
7.如权利要求1-6任一项所述的方法,其特征在于,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;基于所述第二信息,确定在所述预设时长内的视频帧播放情况,包括:
根据所述视频帧接收间隔和所述视频帧缓存时间,确定所述预设时长内的帧播放抖动时间;
若帧播放抖动时间小于等于第九阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动时间大于第九阈值,则确定在所述预设时长内视频播放卡顿。
8.如权利要求1-6任一项所述的方法,其特征在于,所述视频接收信息包括视频帧接收间隔,所述视频播放缓存信息包括视频帧缓存时间;基于所述第二信息,确定在所述预设时长内的视频帧播放情况,包括:
根据所述视频帧接收间隔和所述视频帧缓存时间,统计所述预设时长内的帧播放抖动次数;
若帧播放抖动次数小于等于第十阈值,则确定在所述预设时长内视频播放未卡顿;或者,若帧播放抖动次数大于第十阈值,则确定在所述预设时长内视频播放卡顿。
9.如权利要求1-6任一项所述的方法,其特征在于,基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略,包括:
在所述预设时长内视频播放卡顿和/或网络带宽处于过载状态时,所述码流调整策略用于指示所述第二设备下调码流;或者,
在所述预设时长内视频播放未卡顿和/或网络带宽处于正常状态时,所述码流调整策略用于指示所述第二设备上调码流。
10.一种视频码流调整方法,其特征在于,应用于第二设备,包括:
发送第一信息,所述第一信息包括所述第二设备在预设时长内的视频帧发送信息;
接收所述预设时长内的码流调整策略;基于所述码流调整策略,进行码流调整。
11.一种视频码流调整系统,其特征在于,该系统包括第一设备、第二设备和服务器,其中:
所述第一设备,用于通过服务器接收第一信息,所述第一信息包括第二设备在预设时长内的视频帧发送信息;以及,获取第二信息,所述第二信息包括所述第一设备在所述预设时长内的视频帧接收信息和/或视频帧播放缓存信息;基于所述第一信息和所述第二信息,确定在所述预设时长内的网络拥塞情况;和/或,基于所述第二信息,确定在所述预设时长内的视频帧播放情况;基于所述视频帧播放情况和/或所述网络拥塞情况,确定码流调整策略;通过所述服务器向所述第二设备发送所述码流调整策略;
所述第二设备,用于通过所述服务器接收所述码流调整策略,并对码流进行调整。
12.一种视频码流调整装置,其特征在于,包括:处理器和存储器;
所述存储器用于存储计算机执行指令,当所述处理器执行所述指令时,使所述视频帧率的确定装置执行如权利要求1-9任一项所述的方法,或者执行如权利要求10所述的方法。
13.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质包括指令,当所述指令在计算机上运行时,使得所述计算机执行如权利要求1-9任一项所述的方法,或者执行如权利要求10所述的方法。
CN202111551164.XA 2021-12-17 2021-12-17 一种视频码流调整方法、装置及系统 Pending CN114222194A (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202111551164.XA CN114222194A (zh) 2021-12-17 2021-12-17 一种视频码流调整方法、装置及系统
CN202210893047.XA CN115086779B (zh) 2021-12-17 2022-07-27 视频传输系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111551164.XA CN114222194A (zh) 2021-12-17 2021-12-17 一种视频码流调整方法、装置及系统

Publications (1)

Publication Number Publication Date
CN114222194A true CN114222194A (zh) 2022-03-22

Family

ID=80703537

Family Applications (2)

Application Number Title Priority Date Filing Date
CN202111551164.XA Pending CN114222194A (zh) 2021-12-17 2021-12-17 一种视频码流调整方法、装置及系统
CN202210893047.XA Active CN115086779B (zh) 2021-12-17 2022-07-27 视频传输系统

Family Applications After (1)

Application Number Title Priority Date Filing Date
CN202210893047.XA Active CN115086779B (zh) 2021-12-17 2022-07-27 视频传输系统

Country Status (1)

Country Link
CN (2) CN114222194A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115361585A (zh) * 2022-08-19 2022-11-18 广州市百果园信息技术有限公司 视频播放卡顿预测方法、装置、设备及存储介质

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115334307B (zh) * 2022-10-11 2023-02-10 浙江大华技术股份有限公司 一种数据传输方法、前端设备、视频采集系统和介质
CN115734009A (zh) * 2022-11-15 2023-03-03 深圳艾灵网络有限公司 视频流的碰撞消除方法、装置、设备及存储介质
CN116996649B (zh) * 2023-04-04 2024-04-30 深圳Tcl新技术有限公司 投屏方法、装置、存储介质及电子设备
CN116233472B (zh) * 2023-05-08 2023-07-18 湖南马栏山视频先进技术研究院有限公司 一种音频视频同步的方法和云端处理系统
CN116320536B (zh) * 2023-05-16 2023-08-18 瀚博半导体(上海)有限公司 视频处理方法、装置、计算机设备及计算机可读存储介质
CN116828229B (zh) * 2023-08-30 2023-11-24 湖南马栏山视频先进技术研究院有限公司 一种用于音视频流的传输方法及系统
CN117560464B (zh) * 2024-01-10 2024-05-03 深圳市云屋科技有限公司 一种多平台视频会议方法及系统

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100421413C (zh) * 2004-12-28 2008-09-24 华为技术有限公司 一种无线链路控制子层发送缓存大小的调整方法
CN101583025B (zh) * 2009-06-11 2011-05-11 中兴通讯股份有限公司 一种流媒体播放方法及装置
CN101702711B (zh) * 2009-10-30 2014-01-29 中兴通讯股份有限公司 播放数据的方法和终端
CN101753977B (zh) * 2009-12-31 2012-10-03 中兴通讯股份有限公司 一种调节网络数字视频播放速度的方法及装置
CN101867804B (zh) * 2010-06-01 2014-04-09 中兴通讯股份有限公司 互联网协议电视直播系统和方法
CN101938483A (zh) * 2010-09-03 2011-01-05 中兴通讯股份有限公司 一种直播内容分发方法和系统
CN102547389B (zh) * 2012-01-16 2014-12-10 何建亿 一种网络自适应的流媒体QoS控制方法
CN103916716B (zh) * 2013-01-08 2017-06-20 北京信威通信技术股份有限公司 一种无线网络下视频实时传输的码率平滑方法
CN104581340B (zh) * 2015-01-16 2018-02-16 京东方科技集团股份有限公司 客户端、流媒体数据接收方法和流媒体数据传输系统
CN105119755B (zh) * 2015-09-10 2018-06-19 广州市百果园网络科技有限公司 一种抖动缓冲区调整方法及装置
CN105430532B (zh) * 2015-11-18 2019-04-16 南京创维信息技术研究院有限公司 一种视频数据传输自适应调整的控制方法及其系统
CN107529097A (zh) * 2016-06-20 2017-12-29 北京信威通信技术股份有限公司 一种自适应调整视频缓冲大小的方法及装置
CN108259948B (zh) * 2018-03-30 2020-12-15 武汉斗鱼网络科技有限公司 一种直播音视频的播放方法、装置、计算机及存储介质
CN109462773A (zh) * 2018-08-31 2019-03-12 北京潘达互娱科技有限公司 一种推流方法、装置、电子设备及存储介质
CN110933516B (zh) * 2018-09-19 2022-06-10 华为技术有限公司 多媒体直播方法、装置及设备
CN109905326A (zh) * 2019-03-26 2019-06-18 武汉大学 一种基于拥塞程度因子的速率下降参数优化方法
CN111447459B (zh) * 2020-05-14 2022-02-18 杭州当虹科技股份有限公司 一种rtmp自适应码率实现方法
CN111615006B (zh) * 2020-05-29 2022-02-01 北京讯众通信技术股份有限公司 基于网络状态自评估的视频编码转换传输控制系统
CN112019873A (zh) * 2020-09-08 2020-12-01 北京金山云网络技术有限公司 视频码率调整方法、装置和电子设备
CN112399141B (zh) * 2020-10-16 2022-03-25 浙江大华技术股份有限公司 基于多个前端视频设备的数据传输方法及相关装置
CN112104879B (zh) * 2020-11-13 2021-03-23 腾讯科技(深圳)有限公司 一种视频编码方法、装置、电子设备及存储介质
CN112953922B (zh) * 2021-02-03 2022-09-16 西安电子科技大学 一种自适应流媒体控制方法、系统、计算机设备及应用

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115361585A (zh) * 2022-08-19 2022-11-18 广州市百果园信息技术有限公司 视频播放卡顿预测方法、装置、设备及存储介质
CN115361585B (zh) * 2022-08-19 2023-11-07 广州市百果园信息技术有限公司 视频播放卡顿预测方法、装置、设备及存储介质

Also Published As

Publication number Publication date
CN115086779B (zh) 2024-04-16
CN115086779A (zh) 2022-09-20

Similar Documents

Publication Publication Date Title
CN114222194A (zh) 一种视频码流调整方法、装置及系统
US9398488B2 (en) Video service buffer management in a mobile rate control enabled network
CN110636346B (zh) 一种码率自适应切换方法、装置、电子设备及存储介质
CN109729437B (zh) 流媒体自适应传输方法、终端和系统
CN109660879B (zh) 直播丢帧方法、系统、计算机设备和存储介质
CN110267100B (zh) Flv视频的码率切换方法、装置、电子设备及存储介质
US20120106669A1 (en) Dynamic encode setting adjustment
US20100168885A1 (en) Method and device for sending and playing streaming data
CN107205160A (zh) 一种针对服务器下发的视频的播放方法及装置
CN107295395A (zh) 码率自适应调节方法、装置及电子设备
CN104394484A (zh) 一种无线实时流媒体传输方法
CN111225209B (zh) 视频数据推流方法、装置、终端及存储介质
CN107534618B (zh) 传输装置、传输方法和程序
CN102547449A (zh) 一种控制终端缓冲媒体流数据的方法、机顶盒及媒体服务器
GB2519835A (en) Calibration system
CN108737818B (zh) 一种拥塞网络下的丢帧方法、装置及终端设备
CN113037697A (zh) 一种视频帧处理方法、装置和电子设备及可读存储介质
JPH10336626A (ja) 映像データの転送方法および転送装置
CN104471936B (zh) 帧率控制方法以及帧率控制装置
CN110012315A (zh) 一种视频播放方法、装置及电子设备
CN110912922B (zh) 一种图像传输方法、装置、电子设备及存储介质
US20220286721A1 (en) A media client with adaptive buffer size and the related method
US8791981B2 (en) Bit rate control apparatus and method thereof
KR102510865B1 (ko) 신호 처리 장치 및 신호 처리 방법, 및 프로그램
CN114125452A (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
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20220322

WD01 Invention patent application deemed withdrawn after publication