CN110858925B - 一种实现视频流切换的方法、设备、系统和存储介质 - Google Patents

一种实现视频流切换的方法、设备、系统和存储介质 Download PDF

Info

Publication number
CN110858925B
CN110858925B CN201810962907.4A CN201810962907A CN110858925B CN 110858925 B CN110858925 B CN 110858925B CN 201810962907 A CN201810962907 A CN 201810962907A CN 110858925 B CN110858925 B CN 110858925B
Authority
CN
China
Prior art keywords
frame
video stream
switching
message
packet
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
CN201810962907.4A
Other languages
English (en)
Other versions
CN110858925A (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.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies 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
Priority to CN202111216180.3A priority Critical patent/CN114143606A/zh
Application filed by Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Priority to CN201810962907.4A priority patent/CN110858925B/zh
Priority to PCT/CN2019/101241 priority patent/WO2020038309A1/zh
Priority to JP2021509807A priority patent/JP7224439B2/ja
Priority to KR1020237010789A priority patent/KR102671249B1/ko
Priority to EP19851740.1A priority patent/EP3836552A4/en
Priority to KR1020217006921A priority patent/KR20210041052A/ko
Publication of CN110858925A publication Critical patent/CN110858925A/zh
Priority to US17/180,568 priority patent/US11483495B2/en
Application granted granted Critical
Publication of CN110858925B publication Critical patent/CN110858925B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/44016Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving splicing one content stream with another content stream, e.g. for substituting a video clip
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/45Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
    • H04N21/462Content or additional data management, e.g. creating a master electronic program guide from data received from the Internet and a Head-end, controlling the complexity of a video stream by scaling the resolution or bit-rate based on the client capabilities
    • H04N21/4622Retrieving content or additional data from different sources, e.g. from a broadcast channel and the Internet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/23424Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving splicing one content stream with another content stream, e.g. for inserting or substituting an advertisement
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • H04N21/218Source of audio or video content, e.g. local disk arrays
    • H04N21/21805Source of audio or video content, e.g. local disk arrays enabling multiple viewpoints, e.g. using a plurality of cameras
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • H04N21/218Source of audio or video content, e.g. local disk arrays
    • H04N21/2187Live feed
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • H04N21/2365Multiplexing of several video streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/4302Content synchronisation processes, e.g. decoder synchronisation
    • H04N21/4307Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen
    • H04N21/43072Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen of multiple content streams on the same device
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/4402Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
    • H04N21/440218Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display by transcoding between formats or standards, e.g. from MPEG-2 to MPEG-4
    • 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/633Control signals issued by server directed to the network components or client
    • H04N21/6338Control signals issued by server directed to the network components or client directed to network
    • 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/643Communication protocols
    • H04N21/64322IP
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/85Assembly of content; Generation of multimedia applications
    • H04N21/854Content authoring
    • H04N21/8547Content authoring involving timestamps for synchronizing content
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/222Studio circuitry; Studio devices; Studio equipment
    • H04N5/262Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
    • H04N5/268Signal distribution or switching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/38Transmitter circuitry for the transmission of television signals according to analogue transmission standards

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Databases & Information Systems (AREA)
  • Business, Economics & Management (AREA)
  • Marketing (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

本发明实施例公开了一种实现视频流切换的方法、装置和系统。所述方法包括:传输设备接收第一视频流和第二视频流,通过目标出端口发送第一视频流,在接收到切换指令时确定第一视频流的第一基准帧尾报文的切换参考信息和第二视频流的第二基准帧尾报文的切换参考信息,分别根据第一基准帧尾报文和第二基准帧尾报文的切换参考信息确定第一视频流的第一切换报文的切换参考信息和第二视频流的第二切换报文的切换参考信息,进而根据第一切换报文和第二切换报文的切换参考信息将通过目标出端口发送的第一视频流切换为第二视频流。由于在视频流切换时考虑了切换前后发送的数据报文所处的位置,因此,可以有效减轻切换操作对传输的视频画面的损伤。

Description

一种实现视频流切换的方法、设备、系统和存储介质
技术领域
本发明实施例涉及多媒体通信技术领域,尤其涉及一种实现视频流切换的方法、装置和系统。
背景技术
在多媒体通信技术领域,如电视(Television,TV)制播领域,存在对不同视频源设备发送的视频流进行切换的场景。如,在对足球比赛进行直播时,可以在传输设备(如路由器) 上对接收的通过对拍摄球场的不同位置所得到的视频流进行切换,以实现在视频终端上对球场不同角度的视频画面进行切换显示。
在传统的TV制播领域,通常是以串行数字接口(serial digital interface,SDI)格式传输视频流。由于用于传输SDI信号的同轴电缆最大长度通常受到限制,且比较昂贵,因此在TV制播领域,已经开始通过因特网协议(Internet Protocol,IP)网络传输视频流,如将SDI信号承载在IP报文中传输。
在实现对通过IP网络传输的视频流进行切换的现有技术中,传输设备在确定需要切换视频流时即停止发送要切出的视频流的数据报文并开始发送要切入的视频流的数据报文。
根据该现有技术实现视频流的切换,往往导致视频画面出现损伤。
发明内容
本发明实施例提供一种实现视频流切换的方法、装置和系统,用于解决现有技术中存在的视频流切换导致的视频画面出现损伤的问题。
第一方面,提供了一种实现视频流切换的方法,该方法包括:传输设备接收第一视频流和第二视频流,通过目标出端口发送该第一视频流,在接收到用于指示将通过该目标出端口发送的该第一视频流切换为该第二视频流的切换指令后,根据该切换指令确定该第一视频流的第一基准帧尾报文的切换参考信息(如序列号)和该第二视频流的第二基准帧尾报文的切换参考信息,根据该第一基准帧尾报文的切换参考信息确定该第一视频流的第一切换报文的切换参考信息,并根据该第二基准帧尾报文的切换参考信息确定该第二视频流的第二切换报文的切换参考信息,进而根据该第一切换报文的切换参考信息和该第二切换报文的切换参考信息将通过该目标出端口发送的该第一视频流切换为该第二视频流。该第一基准帧尾报文、第二基准帧尾报文、第一切换报文和第二切换报文的切换参考信息可以均为序列号或均为时间戳,也可以均包括序列号和时间戳。
根据第一方面的实现方式,根据切出流(即第一视频流)和切入流(即第二视频流)的帧尾报文的切换参考信息确定切出流和切入流的切换报文的切换参考信息(如序列号),并根据切换报文的切换参考信息进行视频流的切换。由于在视频流切换时考虑了切换前后发送的数据报文所处的位置,因此,可以有效减轻切换操作对传输的视频画面的损伤。
在第一方面的第一种实现方式中,该第一基准帧尾报文和该第二基准帧尾报文具体可以分别为确定该第一基准帧尾报文的切换参考信息和该第二基准帧尾报文的切换参考信息之前接收的该第一视频流的倒数第x个帧尾报文和该第二视频流的倒数第x个帧尾报文,其中x 为自然数,可以为1。
根据该实现方式确定的第一基准帧尾报文和第二基准帧尾报文的时间戳比较接近,因此可以更加准确地确定出时间戳比较一致的第一切换报文和第二切换报文,从而进一步减轻切换操作对传输的视频画面的损伤。
基于第一方面的第一种实现方式,在第一方面的第二种实现方式中,x取值为1,所述第一切换报文中的视频数据所属视频帧为所述第一基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧;所述第二切换报文中的视频数据所属视频帧为所述第二基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧。具体可以根据所述第一基准帧尾报文的序列号和封装所述第一视频流的单个视频帧的报文个数计算所述第一切换报文的序列号、并根据所述第二基准帧尾报文的序列号和封装所述第二视频流的单个视频帧的报文个数计算所述第二切换报文的序列号,确定的所述第一切换报文的序列号与所述第一基准帧尾报文的序列号的差值可以大于或等于封装所述第一视频流的单个视频帧的报文个数,确定的所述第二切换报文的序列号与所述第二基准帧尾报文的序列号的差值可以大于或等于封装所述第二视频流的单个视频帧的报文个数。具体还可以根据所述第一基准帧尾报文的时间戳和所述第一视频流的单个视频帧的时长计算所述第一切换报文的时间戳、并根据所述第二基准帧尾报文的时间戳和所述第二视频流的单个视频帧的时长计算所述第二切换报文的时间戳,确定的所述第一切换报文的时间戳与所述第一基准帧尾报文的时间戳的差值可以大于或等于所述第一视频流的单个视频帧的时长,确定的所述第二切换报文的时间戳与所述第二基准帧尾报文的时间戳的差值可以大于或等于所述第二视频流的单个视频帧的时长。
根据该实现方式实现在基准帧尾报文后至少一帧的位置处进行视频流切换,可以有效避免对当前正在传输的视频画面的损伤。
基于第一方面或第一方面的第一种或第二种实现方式,在第一方面的第三种实现方式中,可以根据该第一基准帧尾报文的切换参考信息、以及该第一视频流和该第二视频流之间的同步关系确定该第一切换报文的切换参考信息,并根据该第二基准帧尾报文的切换参考信息、以及该同步关系确定该第二切换报文的切换参考信息。
根据该实现方式,由于在计算第一切换报文和第二切换报文的切换参考信息时考虑了视频流之间的同步关系,可以更加精准地实现视频流的切换,从而进一步减轻切换操作对传输的视频画面的损伤。
基于第一方面的第三种实现方式,在第一方面的第四种实现方式中,可以根据该第一基准帧尾报文的切换参考信息、以及该同步关系确定该第一视频流的第一对齐帧尾报文的切换参考信息,并根据该第一对齐帧尾报文的切换参考信息确定该第一切换报文的切换参考信息,还可以根据该第二基准帧尾报文的切换参考信息、以及该同步关系确定该第二视频流的第二对齐帧尾报文的切换参考信息,并根据该第二对齐帧尾报文的切换参考信息确定该第二切换报文的切换参考信息,该第一对齐帧尾报文和该第二对齐帧尾报文为在时间上对应的帧尾报文。
根据该实现方式,在考虑同步关系的情况下确定的第一对齐帧尾报文和第二对齐帧尾报文为在时间上对应的帧尾报文,因此,根据第一对齐帧尾报文和第二对齐帧尾报文分别确定出的第一切换报文和第二切换报文在时间上也是对应的,因此可以进一步减轻切换操作对传输的视频画面的损伤。
基于第一方面的第四种实现方式,在第一方面的第五种实现方式中,可以直接将第一对齐帧尾报文的切换参考信息作为第一切换报文的切换参考信息并将第二对齐帧尾报文的切换参考信息作为第二切换报文的切换参考信息,即直接将第一对齐帧尾报文作为第一切换报文并将第二对齐帧尾报文作为第二切换报文。
根据该实现方式,可以实现在视频帧的边界进行视频流的切换,可以有效避免切换操作对传输的视频画面的损伤。
基于第一方面的第四种实现方式,在第一方面的第六种实现方式中,可以将用于封装该第一对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为该第一切换报文的切换参考信息,并将用于封装该第二对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为该第二切换报文的切换参考信息。
根据该实现方式,可以实现在封装视频帧的消隐区的数据报文处进行视频流的切换,由于消隐区数据并非有效的视频数据,对人眼是不可见的,因此,可以避免对有效的视频数据产生损伤。
以切换参考信息包括序列号为例,在具体实现时,在确定该同步关系为该第一视频流早于该第二视频流时,可以将该第一基准帧尾报文的序列号与m*M1的和确定为该第一对齐帧尾报文的序列号,并将该第二基准帧尾报文的序列号与(m+1)*M2的和确定为该第二对齐帧尾报文的序列号。在确定该同步关系为该第一视频流晚于该第二视频流时,将该第一基准帧尾报文的序列号与(n+1)*M1的和确定为该第一对齐帧尾报文的序列号,将该第二基准帧尾报文的序列号与n*M2的和确定为该第二对齐帧尾报文的序列号。或,在确定该同步关系为该第一视频流和该第二视频流同步时,可以将该第一基准帧尾报文的序列号与k*M1的和确定为该第一对齐帧尾报文的序列号,将该第二基准帧尾报文的序列号与k*M2的和确定为该第二对齐帧尾报文的序列号。其中,M1为封装该第一视频流的一个视频帧所需的数据报文的数量,M2为封装该第二视频流的一个视频帧所需的数据报文的数量,m、n和k均为自然数。
基于第一方面的第三种至第六种中的任意一种实现方式,在第一方面的第七种实现方式中,该传输设备具体可以根据该第一基准帧尾报文的时间戳和该第二基准帧尾报文的时间戳确定该第一视频流和该第二视频流的同步关系。
根据该实现方式,由于是根据该第一基准帧尾报文和第二基准帧尾报文确定该同步关系,因此该同步关系可以反映出该传输设备接收到该第一基准帧尾报文和第二基准帧尾报文时的同步状况,所以,根据第一基准帧尾报文的切换参考信息、第二基准帧尾报文的切换参考信息、以及该同步关系的组合确定的第一切换报文的切换参考信息和第二切换报文的切换参考信息更加符合视频流的真实同步状况,从而可以进一步减轻切换操作对传输的视频画面的损伤。
考虑到设备同步本身就有精度偏差,同一个时刻从不同视频源设备发出的数据报文,其时间戳可能会有偏差。另外,IP网络以报文为单位,报文转发的抖动也会引入一些同步偏差。因此,可以认为,如果两个视频流的基准帧尾报文的时间戳偏差小于预设的时差阈值即可认为这两个视频流同步。
相应地,传输设备具体可以在确定t1-t2>Δt1时,确定该第一视频流早于该第二视频流;在确定t2-t1>Δt1时,确定该第一视频流晚于该第二视频流;在确定|t1-t2|<Δt2时,确定该第一视频流与该第二视频流同步。t1为该第一基准帧尾报文的时间戳;t2为该第二基准帧尾报文的时间戳;Δt1为预设的第一时差阈值,Δt2为预设的第二时差阈值,Δt1和Δ t2均为大于0且小于T的值,Δt2可以和Δt1相同也可以小于Δt1。可以按照如下条件预设Δt1和Δt2:T/2<Δt1<T,如Δt1可以为3*T/4,0<Δt2<T/2,如Δt2可以为T/4,T 为单个视频帧的时长。
根据该实现方式,确定出的同步关系排除了设备同步本身的精度偏差、报文转发的抖动等的影响,更能反映出视频流之间的真实同步状况,确定的第一切换报文的切换参考信息和第二切换报文的切换参考信息也更加符合视频流的真实同步状况,从而可以进一步减轻切换操作对传输的视频画面的损伤。
第二方面,提供了一种传输设备,该传输设备包括处理单元和通信单元。
该通信单元,用于接收第一视频流和第二视频流,通过该传输设备的目标出端口发送该第一视频流,并接收切换指令,该切换指令用于指示将通过该目标出端口发送的该第一视频流切换为该第二视频流。该处理单元,用于根据该切换指令确定该第一视频流的第一基准帧尾报文的切换参考信息(如序列号)和该第二视频流的第二基准帧尾报文的切换参考信息,根据该第一基准帧尾报文的切换参考信息确定该第一视频流的第一切换报文的切换参考信息,并根据该第二基准帧尾报文的切换参考信息确定该第二视频流的第二切换报文的切换参考信息。该通信单元,还用于根据该第一切换报文的切换参考信息和该第二切换报文的切换参考信息将通过该目标出端口发送的该第一视频流切换为该第二视频流。该第一基准帧尾报文、第二基准帧尾报文、第一切换报文和第二切换报文的切换参考信息可以均为序列号或均为时间戳,也可以均包括序列号和时间戳。
根据第二方面的实现方式,根据切出流(即第一视频流)和切入流(即第二视频流)的帧尾报文的切换参考信息确定切出流和切入流的切换报文的切换参考信息(如序列号),并根据切换报文的切换参考信息进行视频流的切换。由于在视频流切换时考虑了切换前后发送的数据报文所处的位置,因此,可以有效减轻切换操作对传输的视频画面的损伤。
在第二方面的第一种实现方式中,该第一基准帧尾报文和该第二基准帧尾报文具体可以分别为确定该第一基准帧尾报文的切换参考信息和该第二基准帧尾报文的切换参考信息之前接收的该第一视频流的倒数第x个帧尾报文和该第二视频流的倒数第x个帧尾报文,其中x 为自然数,可以为1。
根据该实现方式确定的第一基准帧尾报文和第二基准帧尾报文的时间戳比较接近,因此可以更加准确地确定出时间戳比较一致的第一切换报文和第二切换报文,从而进一步减轻切换操作对传输的视频画面的损伤。
基于第二方面的第一种实现方式,在第二方面的第二种实现方式中,x取值为1,所述第一切换报文中的视频数据所属视频帧为所述第一基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧;所述第二切换报文中的视频数据所属视频帧为所述第二基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧。
根据该实现方式实现在基准帧尾报文后至少一帧的位置处进行视频流切换,可以有效避免对当前正在传输的视频画面的损伤。
基于第二方面或第二方面的第一种或第二种实现方式,在第二方面的第三种实现方式中,该处理单元具体可以根据该第一基准帧尾报文的切换参考信息、以及该第一视频流和该第二视频流之间的同步关系确定该第一切换报文的切换参考信息,并根据该第二基准帧尾报文的切换参考信息、以及该同步关系确定该第二切换报文的切换参考信息。
根据该实现方式,由于在计算第一切换报文和第二切换报文的切换参考信息时考虑了视频流之间的同步关系,可以更加精准地实现视频流的切换,从而进一步减轻切换操作对传输的视频画面的损伤。
基于第二方面的第三种实现方式,在第二方面的第四种实现方式中,该处理单元可以根据该第一基准帧尾报文的切换参考信息、以及该同步关系确定该第一视频流的第一对齐帧尾报文的切换参考信息,并根据该第一对齐帧尾报文的切换参考信息确定该第一切换报文的切换参考信息,还可以根据该第二基准帧尾报文的切换参考信息、以及该同步关系确定该第二视频流的第二对齐帧尾报文的切换参考信息,并根据该第二对齐帧尾报文的切换参考信息确定该第二切换报文的切换参考信息,该第一对齐帧尾报文和该第二对齐帧尾报文为在时间上对应的帧尾报文。
根据该实现方式,在考虑同步关系的情况下确定的第一对齐帧尾报文和第二对齐帧尾报文为在时间上对应的帧尾报文,因此,根据第一对齐帧尾报文和第二对齐帧尾报文分别确定出的第一切换报文和第二切换报文在时间上也是对应的,因此可以进一步减轻切换操作对传输的视频画面的损伤。
基于第二方面的第四种实现方式,在第二方面的第五种实现方式中,该处理单元可以直接将第一对齐帧尾报文的切换参考信息作为第一切换报文的切换参考信息并将第二对齐帧尾报文的切换参考信息作为第二切换报文的切换参考信息,即直接将第一对齐帧尾报文作为第一切换报文并将第二对齐帧尾报文作为第二切换报文。
根据该实现方式,可以实现在视频帧的边界进行视频流的切换,可以有效避免切换操作对传输的视频画面的损伤。
基于第二方面的第四种实现方式,在第二方面的第六种实现方式中,该处理单元可以将用于封装该第一对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为该第一切换报文的切换参考信息,并将用于封装该第二对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为该第二切换报文的切换参考信息。
根据该实现方式,可以实现在封装视频帧的消隐区的数据报文处进行视频流的切换,由于消隐区数据并非有效的视频数据,对人眼是不可见的,因此,可以避免对有效的视频数据产生损伤。
基于第二方面的第三种至第六种中的任意一种实现方式,在第二方面的第七种实现方式中,该传输设备具体可以根据该第一基准帧尾报文的时间戳和该第二基准帧尾报文的时间戳确定该第一视频流和该第二视频流的同步关系。
根据该实现方式,由于是根据该第一基准帧尾报文和第二基准帧尾报文确定该同步关系,因此该同步关系可以反映出该传输设备接收到该第一基准帧尾报文和第二基准帧尾报文时的同步状况,所以,根据第一基准帧尾报文的切换参考信息、第二基准帧尾报文的切换参考信息、以及该同步关系的组合确定的第一切换报文的切换参考信息和第二切换报文的切换参考信息更加符合视频流的真实同步状况,从而可以进一步减轻切换操作对传输的视频画面的损伤。
考虑到设备同步本身就有精度偏差,同一个时刻从不同视频源设备发出的数据报文,其时间戳可能会有偏差。另外,IP网络以报文为单位,报文转发的抖动也会引入一些同步偏差。因此,可以认为,如果两个视频流的基准帧尾报文的时间戳偏差小于预设的时差阈值即可认为这两个视频流同步。
相应地,该处理单元具体可以在确定t1-t2>Δt1时,确定该第一视频流早于该第二视频流;在确定t2-t1>Δt1时,确定该第一视频流晚于该第二视频流;在确定|t1-t2|<Δt2时,确定该第一视频流与该第二视频流同步。t1为该第一基准帧尾报文的时间戳;t2为该第二基准帧尾报文的时间戳;Δt1为预设的第一时差阈值,Δt2为预设的第二时差阈值,Δt1和Δt2均为大于0且小于T的值,Δt2可以和Δt1相同也可以小于Δt1。可以按照如下条件预设Δt1和Δt2:T/2<Δt1<T,如Δt1可以为3*T/4,0<Δt2<T/2,如Δt2可以为T/4, T为单个视频帧的时长。
根据该实现方式,确定出的同步关系排除了设备同步本身的精度偏差、报文转发的抖动等的影响,更能反映出视频流之间的真实同步状况,确定的第一切换报文的切换参考信息和第二切换报文的切换参考信息也更加符合视频流的真实同步状况,从而可以进一步减轻切换操作对传输的视频画面的损伤。
第三方面,提供了一种实现视频流切换的系统,该系统包括:控制器和第二方面或第二方面的任意一种实现方式所述的传输设备,其中,该控制器,用于向该传输设备发送切换指令。
第四方面,提供了提供了一种计算机可读存储介质,该计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行第一方面或第一方面的任意一种实现方式所述的方法。
第五方面,提供了提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行第一方面或第一方面的任意一种实现方式所述的方法。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍。
图1为本发明实施例提供的多媒体通信系统100的组网结构示意图;
图2为本发明实施例提供的方法100的流程示意图;
图3A-3C和图4A-4C为本发明实施例提供的切换示意图;
图5是本发明实施例2提供的传输设备200的结构示意图;
图6是本发明实施例3提供的传输设备1000的结构示意图;
具体实施方式
下面结合附图,对本发明的实施例进行描述。
图1为本发明实施例提供的一种多媒体通信系统100的组网结构示意图,多媒体通信系统100包括视频源设备110和传输设备120。其中,视频源设备110通过传输设备120向视频终端发送视频流。传输设备120可以接收来自多个视频源设备110的视频流,并向视频终端仅转发其中一路视频流,还可以对转发的视频流进行切换。传输设备120具体可以为交换机、路由器等,视频源设备可以为IP摄像机、对视频数据进行IP封装传输的设备等。多媒体通信系统100具体可以是TV制播系统,如电视台制播网络的总控系统、演播室系统、播出系统等对承载在IP网络上的视频流有净切换需求的系统。
如图1所示,多媒体通信系统100还可以包括控制器(Controller)130,控制器130用于向传输设备120发送用于指示传输设备120进行视频流切换的切换指令,相应地,传输设备120收到该切换指令后进行视频流切换。
在本发明实施例中,视频的每个视频帧封装在多个数据报文中传输,后续将封装每个视频帧的多个数据报文中的最后一个数据报文称为帧尾报文。本发明实施例中的数据报文携带序列号和/时间戳、以及用于判断该数据报文是否为帧尾报文的信息,具体可以是实时传输协议(Real-time Transport Protocol,RTP)报文、基于私有协议的报文等。根据动画和电视工程师协会(The Society of Motion Picture and Television Engineers,SMPTE)2022和 SMPTE 2110标准,采用RTP承载制播网的音视频数据。如,标准SMPTE 2022-6(Transport of High Bit Rate Media Signals over IP Networks(HBRMT))通过RTP封装SDI格式的视频数据并通过基于IP的网络传输。
本发明实施例中的视频帧指的是未压缩视频帧,可以是YUV视频帧或RGB视频帧,同一视频流的单个视频帧的报文个数(即封装该视频流的一个视频帧所需的数据报文的数量)一般是相同的,通常可以多达数千个,可以是预先设置的,也可以是根据接收的该视频流的两个相邻的帧尾报文的序列号的差值计算得出的。同一个视频流的单个视频帧的时长通常是相同的,可以是预先设置的,也可以是根据接收的该视频流的两个相邻的帧尾报文的时间戳的差值计算得出的。
本发明实施例中的切换报文指的是处于切换位置的数据报文,所述切换报文的切换参考信息为所述切换报文中的用于视频流切换的信息,可以包括所述切换报文的序列号(后续可以简称为切换序列号)和所述切换报文的时间戳(后续可以简称为切换时间戳)中的至少一个。进行视频流切换时,根据要切出的视频流(后续简称为切出流)的切换报文的切换参考信息和要切入的视频流(后续简称为切入流)的切换参考信息进行切换,如,对于切出流,不再转发序列号大于切出流的切换序列号的数据报文,对于切入流,开始转发序列号大于切入流的切换序列号的数据报文。
下面结合图2、图3A-3C和图4A-4C介绍本发明实施例一提供的方法100。图2是本发明实施例1提供的方法流程示意图,本发明实施例1的方法可以应用于图1所示的多媒体通信系统100,由传输设备执行。
如图2所示,方法100包括如下步骤:
S110:传输设备(如图1所示的传输设备120)接收第一视频流和第二视频流并通过该传输设备的目标出端口发送所述第一视频流。
具体地,该传输设备通过该目标出端口转发接收的第一视频流的数据报文并不通过所述目标出端口转发接收的第二视频流的数据报文。
该传输设备可能接收多个与该目标出端口对应的视频流,通过该目标出端口发送该多个视频流中的一个视频流,并在该多个视频流中对通过该目标出端口发送的视频流进行切换。第一视频流为执行步骤S110时正在通过该目标出端口发送的一个视频流,第二视频流为该多个视频流中的其它视频流中的一个视频流。
S120:所述传输设备接收用于指示将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流的切换指令。
具体可以是从控制器(如图1所示的控制器130)接收该切换指令。
该切换指令可以包括该目标出端口的端口号、该第一视频流的标识(如第一视频流的组播地址)和该第二视频流的标识(如第二视频流的组播地址),以指示该传输设备将通过该目标出端口发送的该第一视频流切换为第二视频流,既指示该传输设备停止通过该目标出端口转发该第一视频流并开始通过该目标出端口转发该第二视频流。
S130:所述传输设备根据所述切换指令确定所述第一视频流的基准帧尾报文(后续称为第一基准帧尾报文)的切换参考信息和所述第二视频流的基准帧尾报文(后续称为第二基准帧尾报文)的切换参考信息。
所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息可以均为序列号、均为时间戳、或均包括序列号和时间戳。
具体可以将执行步骤S130之前接收的所述第一视频流的倒数第x个帧尾报文和所述第二视频流的倒数第x个帧尾报文分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,其中x为自然数。x取值可以为1,x为1时,第一视频流和第二视频流中任一视频流的基准帧尾报文又可以称为执行步骤S130时该视频流的最新帧尾报文。
在具体实现时,可以根据所述传输设备接收到所述切换指令的时间确定所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息。如下为两种示例实施方式。
实施方式M:收到切换指令后立即执行步骤S130,即步骤S120和步骤S130的执行时间非常接近,则可以将接收到所述切换指令之前接收的所述第一视频流的倒数第x个帧尾报文的切换参考信息和接收的所述第二视频流的倒数第x个帧尾报文的切换参考信息分别确定为所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息,即所述第一基准帧尾报文和所述第二基准帧尾报文分别为接收到所述切换指令之前接收的所述第一视频流的倒数第x个帧尾报文和接收的所述第二视频流的倒数第x个帧尾报文。x为1时的第一基准帧尾报文和所述第二基准帧尾报文如图3A-3C所示。其中,如图3A所示,将帧尾报文 101和帧尾报文201分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为20和10。如图3B所示,将帧尾报文103和帧尾报文203分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为10和20。如图3C所示,将帧尾报文105和帧尾报文205分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为10和 10。
实施方式N:收到切换指令后再在分别接收到第一视频流的至少一个帧尾报文和第二视频流的至少一个帧尾报文后执行步骤S130。可以是在分别接收到第一视频流的至少一个帧尾报文和第二视频流的至少一个帧尾报文时执行步骤S130,将此时接收的第一视频流的最后一个帧尾报文的切换参考信息和第二视频流的最后一个帧尾报文的切换参考信息分别确定为所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息。如图4A所示,将帧尾报文107和帧尾报文207分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为30和20。如图4B所示,将帧尾报文109和帧尾报文209分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为20和30。如图4C所示,将帧尾报文111和帧尾报文211分别确定为所述第一基准帧尾报文和所述第二基准帧尾报文,序列号分别为20和20。如果在接收到切换指令后对于第一视频流和第二视频流均根据相邻帧尾报文的序列号计算单个视频帧的报文个数,则还可以是在分别接收到第一视频流的至少两个帧尾报文和第二视频流的至少两个帧尾报文时执行步骤S130,将此时接收的第一视频流的最后一个帧尾报文的切换参考信息和第二视频流的最后一个帧尾报文的切换参考信息分别确定为所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息。
S140:根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的切换报文(后续称为第一切换报文)的切换参考信息,并根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的切换报文(后续称为第二切换报文)的切换参考信息。
所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息可以均为序列号、均为时间戳、或均包括序列号和时间戳。
为便于表述,后续还可将第一切换报文的序列号称为第一切换序列号、将第二切换报文的序列号称为第二切换序列号、将第一切换报文的时间戳称为第一切换时间戳、将第二切换报文的序列号称为第二切换时间戳。
所述第一切换报文中的视频数据所属视频帧为所述第一基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧;所述第二切换报文中的视频数据所属视频帧为所述第二基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧。当x取值为1时,根据该实现方式实现在基准帧尾报文后至少一帧的位置处进行视频流切换,可以有效避免对当前正在传输的视频画面的损伤。
具体可以根据所述第一基准帧尾报文的序列号和封装所述第一视频流的单个视频帧的报文个数计算所述第一切换序列号、并根据所述第二基准帧尾报文的序列号和封装所述第二视频流的单个视频帧的报文个数计算所述第二切换序列号,确定的所述第一切换序列号与所述第一基准帧尾报文的序列号的差值可以大于或等于封装所述第一视频流的单个视频帧的报文个数,确定的所述第二切换序列号与所述第二基准帧尾报文的序列号的差值可以大于或等于封装所述第二视频流的单个视频帧的报文个数。
具体还可以根据所述第一基准帧尾报文的时间戳和所述第一视频流的单个视频帧的时长计算所述第一切换时间戳、并根据所述第二基准帧尾报文的时间戳和所述第二视频流的单个视频帧的时长计算所述第二切换时间戳,确定的所述第一切换时间戳与所述第一基准帧尾报文的时间戳的差值可以大于或等于所述第一视频流的单个视频帧的时长,确定的所述第二切换时间戳与所述第二基准帧尾报文的时间戳的差值可以大于或等于所述第二视频流的单个视频帧的时长。
在具体实现时,所述传输设备可以先根据该第一基准帧尾报文的切换参考信息确定该第一视频流的对齐帧尾报文(后续称为第一对齐帧尾报文)的切换参考信息,再根据该第一对齐帧尾报文的切换参考信息确定该第一切换报文的切换参考信息,如,将所述第一对齐帧尾报文的切换参考信息作为所述第一切换报文的切换参考信息,又如,将用于封装所述第一对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为所述第一切换报文的切换参考信息,该第一对齐帧尾报文为该第一基准帧尾报文的后续帧尾报文。并且可以先根据该第二视频流的第二基准帧尾报文的切换参考信息确定该第二视频流的对齐帧尾报文(后续称为第二对齐帧尾报文)的切换参考信息,再根据该第二对齐帧尾报文的切换参考信息确定该第二切换报文的切换参考信息,如,将所述第二对齐帧尾报文的切换参考信息作为所述第二切换报文的切换参考信息,又如,将用于封装所述第二对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的切换参考信息确定为所述第二切换报文的切换参考信息,该第二对齐帧尾报文为该第二基准帧尾报文的后续帧尾报文。该第一对齐帧尾报文和该第二对齐帧尾报文为在时间上对应的帧尾报文,即对于第一对齐帧尾报文,第二对齐帧尾报文是第二视频的所有帧尾报文中与第一对齐帧尾报文的时间戳最接近的帧尾报文。可以理解的是,对于第一对齐帧尾报文对应的视频帧,第二对齐帧尾报文对应的视频帧为第二视频的所有视频帧中与其时间上最接近的视频帧。所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、第一对齐帧尾报文的切换参考信息、第二对齐帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息可以均为序列号、均为时间戳、或均包括序列号和时间戳。
具体可以通过如下实施方式A和实施方式B中的一种或其组合确定第一视频流和第二视频流中的任一视频流的对齐帧尾报文的切换参考信息并确定所述视频流的切换报文的切换参考信息。其中,实施方式A用于确定所述切换报文的序列号,实施方式B用于确定所述切换报文的时间戳。
实施方式A:
在实施方式A中,该传输设备可以先根据该第一基准帧尾报文的序列号和该第一视频流的单个视频帧的报文个数计算该第一对齐帧尾报文的序列号,再根据该第一对齐帧尾报文的序列号确定该第一切换报文的序列号。并且可以先根据该第二视频流的第二基准帧尾报文的序列号和该第二视频流的单个视频帧的报文个数计算该第二对齐帧尾报文的序列号,再根据该第二对齐帧尾报文的序列号确定该第二切换报文序列号。
如图3A所示,收到切换指令之前记录了第一基准帧尾报文101的序列号20和第二基准帧尾报文201的序列号10,收到切换指令后立即确定对齐帧尾报文的序列号,其中确定的第一对齐帧尾报文的序列号为帧尾报文102的序列号30,即第一对齐帧尾报文为帧尾报文102,确定的第二对齐帧尾报文的序列号为帧尾报文202的序列号30,即第二对齐帧尾报文为帧尾报文202。帧尾报文102和帧尾报文202为在时间上对应的帧尾报文。假定第一视频流和第二视频流的帧率一样且起始帧号一样,帧尾报文102和帧尾报文202均为帧号为n+2的视频帧的帧尾报文。
具体可以通过实施方式A的如下两种实施方式(实施方式A1和实施方式A2)中的一种确定第一视频流和第二视频流中的任一视频流的对齐帧尾报文的序列号。
实施方式A1:考虑到不同视频流之间可能会不同步的问题,在实施方式A1中,传输设备先确定所述第一视频流和所述第二视频流的同步关系,进而对于第一视频流和第二视频流中的任一视频流,根据该视频流的基准帧尾报文的序列号、以及该同步关系,计算该视频流的对齐帧尾报文的序列号。所述第一视频流和所述第二视频流的同步关系,具体可以是所述第一视频流早于所述第二视频流、所述第一视频流晚于所述第二视频流或所述第一视频流与所述第二视频流同步。具有互相切换的需求的视频流之间的失步通常不会超过一帧。
确定第一视频流与第二视频流的同步关系之后,具体通过如下方式确定第一视频流的第一对齐帧尾报文的序列号和第二视频流的第二对齐帧尾报文的序列号。为便于表述,在本发明实施例中,将第一基准帧尾报文的序列号表示为S11,将第一对齐帧尾报文的序列号表示为S12,将第二基准帧尾报文的序列号表示为S21,将第二对齐帧尾报文的序列号表示为S22,将所述第一视频流的单个视频帧的报文个数表示为M1,将所述第二视频流的单个视频帧的报文个数表示为M2,M1与M2可以相同,也可以不同,通常是相同的。在如下方式的示例中,假定M1和M2均为10。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流早于所述第二视频流时,根据公式S12=S11+m*M1确定所述第一对齐帧尾报文的序列号S12,并根据公式 S22=S21+(m+1)*M2确定所述第二对齐帧尾报文的序列号S22,m为自然数,可以取1。
假定m为1且采用实施方式M。如图3A所示,所述第一基准帧尾报文为帧尾报文101,序列号为20,第一对齐帧尾报文102的序列号为20+10=30,所述第二基准帧尾报文为帧尾报文201,序列号为10,第二对齐帧尾报文202的序列号为10+2*10=30。
假定m为1且采用实施方式N。如图4A所示,所述第一基准帧尾报文为帧尾报文107,序列号为30,第一对齐帧尾报文108的序列号为30+10=40,所述第二基准帧尾报文为帧尾报文207,序列号为20,第二对齐帧尾报文208的序列号为20+2*10=40。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流晚于所述第二视频流时,根据公式S12=S11+(n+1)*M1确定所述第一对齐帧尾报文的序列号S12,并根据公式S22=S21+n*M2确定所述第二对齐帧尾报文的序列号S22,n为自然数,可以取1。
假定n为1且采用实施方式M。如图3B所示,所述第一基准帧尾报文为帧尾报文103,序列号为10,第一对齐帧尾报文104的序列号为10+2*10=30,所述第二基准帧尾报文为帧尾报文203,序列号为20,第二对齐帧尾报文204的序列号为20+10=30。
假定n为1且采用实施方式N。如图4B所示,所述第一基准帧尾报文为帧尾报文109,序列号为20,第一对齐帧尾报文110的序列号为20+2*10=40,所述第二基准帧尾报文为帧尾报文209,序列号为30,第二对齐帧尾报文210的序列号为30+10=40。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流和所述第二视频流同步时,根据公式S12=S11+k*M1确定所述第一对齐帧尾报文的序列号S12,并根据公式S22=S21+k*M2确定所述第二对齐帧尾报文的序列号S22,k为自然数,可以取1。
假定k为1且采用实施方式M。如图3C所示,所述第一基准帧尾报文为帧尾报文105,序列号为10,第一对齐帧尾报文106的序列号为10+10=20,所述第二基准帧尾报文为帧尾报文205,序列号为10,第二对齐帧尾报文206的序列号为10+10=20。
假定k为1且采用实施方式N。如图4C所示,所述第一基准帧尾报文为帧尾报文111,序列号为20,第一对齐帧尾报文112的序列号为20+10=30,所述第二基准帧尾报文为帧尾报文211,序列号为20,第二对齐帧尾报文212的序列号为20+10=30。
通过实施方式A1确定的第一对齐帧尾报文的序列号和第二对齐帧尾报文的序列号所对应的帧尾报文(即第一对齐帧尾报文和第二对齐帧尾报文)的时间戳基本是一致的,据此确定的切换报文的时间戳基本上也是一致的,因此,可以保证切换时切出流和切入流在时间维度上正好衔接,不会发生多帧或少帧的问题。
实施方式A2:在实施方式A2中不考虑不同视频流之间的同步关系,而是假定视频流之间是同步的,可以直接根据公式S12=S11+k*M1确定所述第一对齐帧尾报文的序列号S12,并根据公式S22=S21+k*M2确定所述第二对齐帧尾报文的序列号S22。
在确定第一对齐帧尾报文的序列号和第二对齐帧尾报文的序列号之后,可以通过如下两种实施方式(实施方式X1和实施方式X2)中的一种分别根据第一对齐帧尾报文的序列号和第二对齐帧尾报文的序列号确定第一切换序列号和第二切换序列号。
实施方式X1:实施方式X1用于实现在帧边界处切换视频流。在实施方式X1中,将所述第一视频流的第一对齐帧尾报文的序列号作为所述第一切换序列号,并将所述第二视频流的第二对齐帧尾报文的序列号作为所述第二切换序列号。
如图3A所示,将第一对齐帧尾报文102的序列号30作为第一切换序列号,即将第一对齐帧尾报文102作为第一视频流的切换报文,将第二对齐帧尾报文202的序列号30作为第二切换序列号,即将第二对齐帧尾报文202作为第二视频流的切换报文。
实施方式X2:实施方式X2用于实现在视频帧的消隐区切换视频流。
在视频领域,在将光信号转换为电信号的扫描过程中,扫描总是从图像的左上角开始,水平向右行进,同时扫描点也以较慢的速率向下移动。当扫描点到达图像右侧边缘时,扫描点快速返回左侧,重新开始在第1行的起点下面进行第2行扫描,行与行之间的返回过程称为水平消隐。一幅完整的图像扫描信号,由水平消隐间隔分开的行信号序列构成,称为一帧。扫描点扫描完一帧后,要从图像的右下角返回到图像的左上角,开始新一帧的扫描,这一时间间隔,叫做垂直消隐,也称场消隐。水平消隐、垂直消隐在SDI信号中不承载可视内容,统称消隐区。为了指导在SDI格式的视频流之间进行切换,SMPTE RP-168规定了切换行或切换区。在切换行或切换区切换两路SDI信号,不会对有效的视频数据产生损伤。因为SMPTE 2022-6是将SDI信号承载在IP报文中,所以对采用SMPTE 2022-6封装的视频流进行净切换时,应该在消隐区切换。
综上,如果所述第一视频流和所述第二视频流均为采用SMPTE 2022-6编码的视频流,可以在封装消隐区的数据报文处进行视频流切换。
对于第一视频流,具体可以将用于封装所述第一对齐帧尾报文的序列号所对应的视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第一切换序列号。如,将所述第一视频流的第一对齐帧尾报文的序列号和ΔM1的和确定为所述第一切换序列号,
Figure BDA0001774246540000126
Figure BDA0001774246540000121
Figure BDA0001774246540000122
其中,OL1为所述第一视频流的单个视频帧中每一行像素所占的字节数,SL1为所述第一视频流的切换行号。
对于第二视频流,将用于封装所述第二对齐帧尾报文的序列号所对应的视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第二切换序列号。如,将所述第二视频流的第二对齐帧尾报文的序列号和ΔM2的和确定为所述第二切换序列号,
Figure BDA0001774246540000123
Figure BDA0001774246540000124
Figure BDA0001774246540000125
其中,OL2为所述第二视频流的单个视频帧中每一行像素所占的字节数,SL2为所述第二视频流的切换行号。
切换行号可以取决于SDI视频标准,目前SMPTE RP-168规定了大部分视频格式的切换行号。第一视频流的切换行号SL1和第二视频流的切换行号SL2通常是相同的。
对于所述第一视频流和所述第二视频流中的任一视频流,如果采用4:2:2采样方式,所述视频流的单个视频帧中每一行像素所占的字节数OL=PL*BS*2/8,其中,PL为所述视频流的视频帧的每一行的总像素数(包括行消隐像素的数量和视频有效像素的数量),BS为像素位深。可以理解的是,如果第一视频流和第二视频流的像素位深和采样方式是相同的,通常OL1 和OL2是相同的。
实施方式B:
在实施方式B中,该传输设备可以先根据该第一基准帧尾报文的时间戳和该第一视频流的单个视频帧的时长计算该第一对齐帧尾报文的时间戳,再根据该第一对齐帧尾报文的时间戳确定该第一切换报文的时间戳。并且可以先根据该第二视频流的第二基准帧尾报文的时间戳和该第二视频流的单个视频帧的时长计算该第二对齐帧尾报文的时间戳,再根据该第二对齐帧尾报文的时间戳确定该第二切换报文时间戳。
具体可以通过实施方式B的如下两种实施方式(实施方式B1和实施方式B2)中的一种确定第一视频流和第二视频流中的任一视频流的对齐帧尾报文的时间戳。
实施方式B1:考虑到不同视频流之间可能会不同步的问题,在实施方式B1中,传输设备先确定所述第一视频流和所述第二视频流的同步关系,进而对于第一视频流和第二视频流中的任一视频流,根据该视频流的基准帧尾报文的时间戳、以及该同步关系,计算该视频流的对齐帧尾报文的时间戳。所述第一视频流和所述第二视频流的同步关系,具体可以是所述第一视频流早于所述第二视频流、所述第一视频流晚于所述第二视频流或所述第一视频流与所述第二视频流同步。具有互相切换的需求的视频流之间的失步通常不会超过一帧。
确定第一视频流与第二视频流的同步关系之后,具体通过如下方式确定第一视频流的第一对齐帧尾报文的时间戳和第二视频流的第二对齐帧尾报文的时间戳。为便于表述,在本发明实施例中,将第一基准帧尾报文的时间戳表示为t11,将第一对齐帧尾报文的时间戳表示为t12,将第二基准帧尾报文的时间戳表示为t21,将第二对齐帧尾报文的时间戳表示为t22,将所述第一视频流的单个视频帧的时长表示为T1,将所述第二视频流的单个视频帧的时长表示为T2,T1与T2可以相同,也可以不同,通常是相同的。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流早于所述第二视频流时,根据公式t12=t11+m*T1确定所述第一对齐帧尾报文的时间戳t12,并根据公式 t22=t21+(m+1)*T2确定所述第二对齐帧尾报文的时间戳t22,m为自然数,可以取1。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流晚于所述第二视频流时,根据公式t12=t11+(n+1)*T1确定所述第一对齐帧尾报文的时间戳t12,并根据公式t22=t21+n*T2确定所述第二对齐帧尾报文的时间戳t22,n为自然数,可以取1。
在确定的所述第一视频流和所述第二视频流的同步关系为所述第一视频流和所述第二视频流同步时,根据公式t12=t11+k*T1确定所述第一对齐帧尾报文的时间戳t12,并根据公式t22=t21+k*T2确定所述第二对齐帧尾报文的时间戳t22,k为自然数,可以取1。
通过实施方式B1确定的第一对齐帧尾报文的时间戳和第二对齐帧尾报文的时间戳基本是一致的,据此确定的切换报文的时间戳基本上也是一致的,因此,可以保证切换时切出流和切入流在时间维度上正好衔接,不会发生多帧或少帧的问题。
实施方式B2:在实施方式B2中不考虑不同视频流之间的同步关系,而是假定视频流之间是同步的,可以直接根据公式t12=t11+k*T1确定所述第一对齐帧尾报文的时间戳t12,并根据公式t22=t21+k*T2确定所述第二对齐帧尾报文的时间戳t22。
在确定第一对齐帧尾报文的切换参考信息和第二对齐帧尾报文的时间戳之后,可以通过如下两种实施方式(实施方式Y1和实施方式Y2)中的一种分别根据第一对齐帧尾报文的时间戳和第二对齐帧尾报文的时间戳确定第一切换时间戳和第二切换时间戳。
实施方式Y1:实施方式Y1用于实现在帧边界处切换视频流。在实施方式Y1中,将所述第一视频流的第一对齐帧尾报文的时间戳作为所述第一切换时间戳,并将所述第二视频流的第二对齐帧尾报文的时间戳作为所述第二切换时间戳。
实施方式Y2:实施方式Y2用于实现在视频帧的消隐区切换视频流。
对于第一视频流,具体可以将用于封装所述第一对齐帧尾报文的时间戳所对应的视频帧的下一视频帧的消隐区数据的数据报文的时间戳确定为所述第一切换时间戳。如,将所述第一视频流的第一对齐帧尾报文的时间戳和Δt1的和确定为所述第一切换时间戳,Δt1为属于区间[tx,ty]的值,如Δt1为tx或(tx+ty)/2,其中,tx=T1*SL1/L1,ty=T1*(SL1+1) /L1,其中,SL1为所述第一视频流的切换行号,L1为所述第一视频流的一个视频帧的像素的总行数。
对于第二视频流,将用于封装所述第二对齐帧尾报文的时间戳所对应的视频帧的下一视频帧的消隐区数据的数据报文的时间戳确定为所述第二切换时间戳。如,将所述第二视频流的第二对齐帧尾报文的时间戳和Δt2的和确定为所述第二切换时间戳,Δt2为属于区间[tm, tn]的值,如Δt2为tm或(tm+tn)/2,其中,tm=T2*SL2/L2,ty=T2*(SL2+1)/L2,其中, SL2为所述第二视频流的切换行号,L2为所述第二视频流的一个视频帧的像素的总行数。需要说明的是,根据相同的方法计算Δt1和Δt2,如,利用公式Δt1=T1*SL1/L1计算Δt1(即Δ t1为tx)并利用公式Δt2=T2*SL2/L2计算Δt2(即Δt2为tm)。
切换行号可以取决于SDI视频标准,目前SMPTE RP-168规定了大部分视频格式的切换行号。第一视频流的切换行号SL1和第二视频流的切换行号SL2通常是相同的。第一视频流的 L2和第二视频流的L2通常也是相同的。
在本发明实施例1中,该传输设备具体可以根据所述第一视频流的基准帧尾报文的时间戳、以及所述第二视频流的基准帧尾报文的时间戳确定所述第一视频流和所述第二视频流的同步关系。
考虑到设备同步本身就有精度偏差,同一个时刻从不同视频源设备发出的数据报文,其时间戳可能会有偏差。另外,IP网络以报文为单位,报文转发的抖动也会引入一些同步偏差。因此,可以认为,如果两个基准帧尾报文的时间戳偏差小于预设的时差阈值即可认为这两个视频流同步。用于判断同步与否的时差阈值可以根据网络中视频源设备的时钟同步精度决定。
传输设备具体可以在确定t1-t2>Δt1时,确定所述第一视频流早于所述第二视频流;在确定t2-t1>Δt1时,确定所述第一视频流晚于所述第二视频流;在确定|t1-t2|<Δt2时,确定所述第一视频流与所述第二视频流同步。t1为所述第一基准帧尾报文的时间戳;t2为所述第二基准帧尾报文的时间戳;Δt1为预设的第一时差阈值,Δt2为预设的第二时差阈值,Δt1和Δt2均为大于0且小于T的值,Δt2可以和Δt1相同也可以小于Δt1。可以按照如下条件预设Δt1和Δt2:T/2<Δt1<T,如Δt1可以为3*T/4,0<Δt2<T/2,如Δt2可以为T/4,T为单个视频帧的时长。在本发明实施例中,T可以是预先设置的或根据预先设置的视频信息(如帧率)计算得到的。另外,由于具有互相切换的需求的视频流的单个视频帧的时长通常是一样的,因此,T也可以是根据接收的第一视频流和第二视频流中的任一视频流的数据报文计算得到的,如,根据该视频流的两个相邻的帧尾报文的时间戳的差值计算得出。
S150:所述传输设备根据所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流。
在一种实现方式中,所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均为序列号,该传输设备具体可以不通过所述目标出端口发送接收的所述第一视频流的序列号大于所述第一切换序列号的数据报文,并通过所述目标出端口发送接收的所述第二视频流的序列号大于所述第二切换序列号的数据报文。
由于第一切换序列号和第二切换序列号为计算得出的尚未接收到的数据报文的序列号,在计算出第一切换序列号和第二切换序列号时,通常还会接收到第一视频流的序列号小于或等于第一切换序列号的数据报文和第二视频流的序列号小于或等于第二切换序列号的数据报文。该传输设备在步骤S150中可以根据接收的第一视频流的数据报文的序列号确定是否要通过该目标出端口发送该数据报文,如果小于或等于该第一切换序列号,则照常通过该目标出端口发送该数据报文,否则不通过该目标出端口发送该数据报文。相应地,该传输设备可以根据接收的第二视频流的数据报文的序列号确定是否要通过该目标出端口发送该数据报文,如果小于或等于该第二切换序列号,则照常不通过该目标出端口发送该数据报文,否则通过该目标出端口发送该数据报文。
在另一种实现方式中,所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均为时间戳,该传输设备具体可以不通过所述目标出端口发送接收的所述第一视频流的时间戳大于所述第一切换时间戳的数据报文,并通过所述目标出端口发送接收的所述第二视频流的时间戳大于所述第二切换时间戳的数据报文。另外,该传输设备还可以通过所述目标出端口发送接收的所述第一视频流的时间戳小于或等于所述第一切换时间戳的数据报文,并不通过所述目标出端口发送接收的所述第二视频流的时间戳小于或等于所述第二切换时间戳的数据报文
在再一种实现方式中,所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均包括序列号和时间戳。对于接收的所述第一视频流的数据报文,如果所述数据报文的时间戳与所述第一切换报文的时间戳的差值的绝对值Dif1大于阈值1且所述数据报文的时间戳大于所述第一切换报文的时间戳,或者Dif1小于或等于阈值1且所述数据报文的序列号大于所述第一切换报文的序列号,不通过所述目标出端口转发所述数据报文。对于接收的所述第二视频流的数据报文,如果所述数据报文的时间戳与所述第二切换报文的时间戳的差值的绝对值Dif2大于阈值2且所述数据报文的时间戳大于所述第二切换报文的时间戳,或者Dif2 小于或等于阈值2且所述数据报文的序列号大于所述第二切换报文的序列号,通过所述目标出端口转发所述数据报文。另外,对于接收的所述第一视频流的数据报文,如果Dif1大于阈值1 且所述数据报文的时间戳小于所述第一切换报文的时间戳,或者Dif1小于或等于阈值1且所述数据报文的序列号小于或等于所述第一切换报文的序列号,通过所述目标出端口转发所述数据报文。对于接收的所述第二视频流的数据报文,如果Dif2大于阈值2且所述数据报文的时间戳小于所述第二切换报文的时间戳,或者Dif2小于或等于阈值2且所述数据报文的序列号小于所述第二切换报文的序列号,不通过所述目标出端口转发所述数据报文。
其中,阈值1和阈值2可以相同也可以不同,均可以设置为大于或等于1/4T的值,具体可以设置为大于或等于1/4T且小于或等于7/4T的值,如3/4T,其中,T为所述第一视频流或所述第二视频流的单个视频帧的时长。
对于第一视频流和第二视频流中的任一视频流,可以在确定该视频流进入稳定状态后,如确定在开始执行步骤S150之后已处理该数据流的预定个数(如M、2M个)的数据报文、或在开始执行步骤S130之后经过了预设时长(如T、2T),此时再接收到该数据流的序列号或时间戳小于或等于该数据流的切换序列号或切换时间戳的数据报文的可能性很小,因此可以不再逐报文检查接收的该数据流的数据报文的序列号或时间戳来判断是否通过该目标出端口发送该数据报文,而是基于用于表明该数据报文所属的数据流(即该数据流)是否为需要发送的数据流的状态信息来确定是否通过该目标出端口发送该数据报文,从而提高转发效率。其中,M 为该视频流的单个视频帧的报文个数,T为该视频流的单个视频帧的时长。
需要说明的是,该传输设备可以包括多个出端口,如果方法100的步骤S110和S150由仅负责处理该目标出端口所对应的数据报文的单元来执行,则在步骤S110和S150中,该单元可以丢弃不需要通过所述目标出端口转发的数据报文。
为了减少对下游设备的影响,以实现下游设备对切换不感知,所述传输设备在转发所述第二视频流的数据报文时,还可以修改所述第二视频流的数据报文中的信息。
具体地,为了提升切换前后的视频流的一致性,该传输设备可以修改所述第二视频流的数据报文中的第一字段的值以使得切换后通过该目标出端口发出的第二视频流的数据报文中的第一字段的值和切换前通过该目标出端口发出的第一视频流的数据报文中的第一字段的值相同。所述第一字段可以为组播地址字段或载荷类型字段。如果采用RTP进行视频流传输,该第一字段还可以为同步源(Synchronization source,SSRC)字段。所述第一字段还可以为SMPTE 2022-6定义的HBRMT层参数,如FRCount,FRCount是SMPTE 2022-6定义的高码率媒体载荷头(High Bit Rate Media Payload Header)中的帧计数(FrameCount)字段,表示该视频流中累积的视频帧数。
对于一个出端口,可能需要在多条输入视频流间反复切换。所以,当前的切出流很可能是之前的切入流。
该传输设备可以在通过该目标出端口发送该多个视频流中的任一视频流时,均将该视频流的数据报文中的第一字段的值,修改为预设的值,如,将该视频流的数据报文中的组播地址修改为预设的组播地址(如239.0.2.1)。
如S110中所述,该传输设备可能接收多个与该目标出端口对应的视频流,通过该目标出端口发送该多个视频流中的一个视频流,并在该多个视频流中对通过该目标出端口发送的视频流进行切换。如,该多个视频流包括流1、流2和流3,该传输设备首先转发的是流2,后续依次切换到流1和流3。该传输设备还可以在第一次通过该目标出端口转发该多个视频流中的一个视频流(如流2)时,记录该视频流的第一字段的值,并在后续切换到其它视频流时,将其它视频流的数据报文中的第一字段的值修改为记录的该视频流的第一字段的值。如,在切换到流1时将流1的数据报文中的第一字段的值修改为流2的第一字段的值,并在切换到流3时将流3的数据报文中的第一字段的值也修改为流2的第一字段的值。
为了提升切换前后的视频流的连续性,所述传输设备在切换后发送所述第二视频流的数据报文时,还可以修改所述第二视频流的数据报文中的第二字段的值以使得切换后通过该目标出端口发出的第二视频流的数据报文中的第二字段的值和切换前通过该目标出端口发出的第一视频流的数据报文中的第二字段的值连续。所述第二字段的值可以为序列号、帧号和时间戳等中的一个或多个。
为了保证第二字段的值(如序列号)连续,具体可以将要发送的第二视频流的数据报文中的第二字段的值增加ΔV,其中,ΔV=V1-V2,V1为所述第一视频流的序列号等于所述第一切换序列号的数据报文在被通过该目标出端口发出时所携带的第二字段的值,V2为所述第二视频流的序列号等于所述第二切换序列号的数据报文在被接收时所携带的第二字段的值。
在执行步骤S130之前,传输设备还可以执行步骤S115以记录第一视频流和第二视频流的最新帧尾报文的目标信息,记录的目标信息包括最新帧尾报文的序列号和时间戳中的至少一个。相应地,在步骤S130中可以根据在步骤S115中记录的最新帧尾报文的目标信息确定基准帧尾报文,如,对于第一视频流和第二视频流中的任一视频流,将执行步骤S130之前最后一次通过步骤S115记录的该视频流的最新帧尾报文的目标信息(如序列号)作为该视频流的基准帧尾报文的切换参考信息(如序列号)。
该传输设备可以在步骤S120之前开始执行步骤S115。如S110中所述,该传输设备可能接收多个与该目标出端口对应的视频流,通过该目标出端口发送该多个视频流中的一个视频流,并在该多个视频流中对通过该目标出端口发送的视频流进行切换。则在该传输设备开始通过该目标出端口转发该多个视频流中的视频流时开始记录该多个视频流中的每个视频流的最新帧尾报文的目标信息。当后续要对其中两个视频流进行切换时,可以利用已经记录的这两个视频流的最新帧尾报文的目标信息执行步骤S130-S140以确定切换参考信息。当实现上述实施方式M时,可以在步骤S120之前开始执行步骤S115。
该传输设备也可以在步骤S120之后开始执行步骤S115。即,在接收到切换指令后开始记录要进行切换的两个视频流中的每个视频流的最新帧尾报文的目标信息,并进而根据记录的这两个视频流的最新帧尾报文的目标信息执行步骤S130-S140以确定切换报文的切换参考信息。当实现上述实施方式N时,可以在步骤S120之后开始执行步骤S115。
如果在步骤S120之前开始执行步骤S115,对于该多个视频流中的任一视频流,该传输设备可以在接收到该视频流中在顺序上的第一个帧尾报文时,将该帧尾报文的目标信息记录为该视频流的最新帧尾报文的目标信息,并根据后续接收的该视频流的数据报文更新该视频流的最新帧尾报文的目标信息。进而,在接收到切换指令后立即执行步骤S130-S140以根据接收到切换指令前记录的最新帧尾报文的目标信息(如序列号)计算切换报文的切换参考信息(如序列号)。如图3A所示,根据收到切换指令前记录的第一视频流的最新帧尾报文101 的序列号20计算第一切换序列号,根据第二视频流的最新帧尾报文201的序列号10计算第二切换序列号。
如果在步骤S120之后开始执行步骤S115,对于所述第一视频流和所述第二视频流中的任一视频流,该传输设备可以在接收到该视频流中在顺序上的第一个帧尾报文时,将该帧尾报文的目标信息记录为该视频流的最新帧尾报文的目标信息。如果在收到其中一路视频流的另一帧尾报文时还没有收到另一视频流的第一个帧尾报文,则可以对该视频流的最新帧尾报文的目标信息进行更新,直至收到另一视频流的第一个帧尾报文并相应记录另一个视频流的最新帧尾报文的目标信息。另外,如果对于第一视频流和第二视频流均根据相邻帧尾报文的序列号计算单个视频帧的报文个数,则在计算切换序列号之前对于每个视频流都至少接收两个帧尾报文,每次接收到帧尾报文时均将该帧尾报文的目标信息记录为所属视频流的最新帧尾报文的目标信息。此外,可以将接收的两个相邻帧尾报文的序列号的差值作为所属视频流的单个视频帧的报文个数,还可以将接收的两个相邻帧尾报文的时间戳的差值作为所属视频流的单个视频帧的时长。
如图4A所示,根据收到切换指令后记录的第一视频流的最新帧尾报文107的序列号30 计算第一切换序列号,根据第二视频流的最新帧尾报文207的序列号20计算第二切换序列号。
传输设备具体可以通过如下方式对任一视频流的最新帧尾报文的目标信息进行更新。
所述传输设备可以在每次接收到该视频流的帧尾报文时,将该视频流的最新帧尾报文的序列号更新为该帧尾报文的序列号,并将该视频流的最新帧尾报文的时间戳更新为该帧尾报文的时间戳。
所述传输设备也可以在更新时考虑可能发生的帧间报文乱序和帧尾报文丢失问题。如果存在帧间报文乱序,即后一帧的非帧尾报文先于前一帧的帧尾报文到达或先于前一帧的帧尾报文被传输设备处理,或存在帧尾报文丢失,该视频流的最新帧尾报文的序列号也可以是根据序列号大于未被收到的帧尾报文的非帧尾报文估算的该帧尾报文的序列号。相应地,该传输设备可以采用如下方式进行更新。
在确定接收的该视频流的数据报文不是帧尾报文且所述数据报文的序列号大于该视频流的最新帧尾报文的序列号与该视频流的单个视频帧的报文个数M的和时,将记录的该视频流的最新帧尾报文的序列号增加M。如果该目标信息还包括时间戳,相应地,将记录的该视频流的最新帧尾报文的时间戳增加单个视频帧的时长T。在确定接收的该视频流的数据报文为帧尾报文时,可以直接执行更新操作,即将该视频流的最新帧尾报文的序列号更新为该数据报文的序列号,并将该视频流的最新帧尾报文的时间戳更新为该数据报文的时间戳,也可以进一步判断该数据报文的时间戳是否大于记录的该视频流的最新帧尾报文的时间戳,并仅在大于时执行该更新操作。
下面以一种具体实施方式对步骤S115的具体实现进行详细描述。
传输设备建立视频流切换表。如果在步骤S120之前执行步骤S115,该切换表可以包括该多个视频流中的每个视频流的记录,如果在步骤S120之后执行步骤S115,该切换表可以仅包括要切换的两个视频流(即第一视频流和第二视频流)的记录,如表1所示。
该切换表可以包括字段FT_TS和FT_SN,每个视频流对应的FT_TS的值和FT_SN的值分别为该视频流的最新帧尾报文的时间戳和序列号。
该视频流切换表还可以包括字段Flow、Outport、State、FrameTime和FramePackets中的任意一个或任意组合。Flow的值用于标识对应的视频流。每个视频流对应的Outport的值用于记录该视频流对应的出端口的端口号,即表示该视频流从该传输设备的哪个端口转发出去,本发明实施例对对应同一个出端口的视频流进行切换。每个视频流对应的State的值用于记录该视频流的当前状态,其中,SW_Forwarding表明该视频流为传输设备在转发的视频流, SW_Discard表明该视频流为该传输设备不通过对应的出端口转发的视频流。每个视频流对应的FrameTime的值用于记录该视频流的单个视频帧的时长,如果采用RTP进行视频流传输, FrameTime的单位与RTP头中的TS字段的单位相同。每个视频流对应的FramePackets的值用于记录该视频流的单个视频帧的报文个数。
该视频流切换表还可以包括SW_SN,每个视频流对应的SW_SN的值用于记录该视频流的切换序列号。
Outport Flow State FrameTime FramePackets FT_TS FT_SN
6 1 SW_Forwarding T1 M1 TS1 SN1
6 2 SW_Discard T2 M2 TS2 SN2
表1
后续将所述视频流切换表中的任一视频流称为视频流A。
对于视频流A,在接收到视频流A的任一数据报文(后续称为报文a)时,首先判断报文a 是否为帧尾报文。
以RTP报文为例,根据RFC 3550制定的RTP报文头格式,RTP报文头中的M(Marker,边界) 字段的值用于表示该RTP报文是否为帧尾报文。如果M的值为1,表示该RTP报文为帧尾报文,如果为0,表示该RTP报文不是帧尾报文。
RTP报文头中的序列号(Sequence number,SN)字段的值表示该RTP报文在一条RTP流中的序列号,同一条RTP流的各RTP报文的序列号单调递增1。RTP报文头还包括时间戳(Timestamp,TS)。多媒体通信系统(如TV制播系统)中的各视频源设备会保持时钟同步,同一时刻发出的RTP报文,该字段的值非常接近,因此,可以利用该字段的值来判断不同视频流中的视频帧是否是同一时刻的视频帧,用于在切换时对齐不同的视频流,达到切换在时间维度上的衔接。
如果确定报文a为帧尾报文,且是视频流A在顺序上的的第一个帧尾报文,将报文a的TS字段的值和SN字段的值分别记录到第一切换表中视频流A对应的FT_TS字段和FT_SN字段中。
如果确定报文a为帧尾报文,且不是视频流A在顺序上的的第一个帧尾报文,将报文a的TS 字段的值和第一切换表中视频流A对应的FT_TS字段的值进行比较。如果报文a的TS字段的值大于第一切换表中视频流A对应的FT_TS字段的值,则报文a为最新帧尾报文,因此,将第一切换表中视频流A对应的FT_TS字段和FT_SN字段的值分别更新为报文a的TS字段和SN字段的值。如果小于,则不更新。
如果确定报文a不是帧尾报文,则判断是否发生了帧间乱序。报文在网络中传输时有可能发生乱序,报文所经过的传输设备的处理器对接收的报文进行多线程并发处理时也可能导致报文在处理上出现乱序。因此,一帧的非帧尾报文可能先于前一帧的帧尾报文到达传输设备或先于前一帧的帧尾报文被处理。如果一帧的报文先于前一帧的帧尾报文到达或先于前一帧的帧尾报文被处理,则表明发生了帧间报文乱序。
如果报文a不是帧尾报文,且报文a的序列号大于视频流A的最新帧尾报文的序列号与M的和,即报文a先于前一帧的帧尾报文到达了,则前一帧的帧尾报文可能发生了乱序或丢包,此时可以将FT_TS字段的值与T的和作为估计的该帧尾报文的时间戳,并将FT_SN字段的值和M的和作为估计的该帧尾报文的序列号,并利用估计的时间戳和序列号更新第一切换表视频流A 对应的FT_TS字段和FT_SN字段的值,即将FT_TS字段的值增加T,并将FT_SN字段的值增加M。
根据本发明实施例1,本发明实施例2提出了一种传输设备200,如图5所示,传输设备 200包括:处理单元210和通信单元220。
通信单元220,用于接收第一视频流和第二视频流,通过所述传输设备的目标出端口发送所述第一视频流,并接收切换指令,所述切换指令用于指示将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流。
处理单元210,用于根据所述切换指令确定所述第一视频流的第一基准帧尾报文的切换参考信息和所述第二视频流的第二基准帧尾报文的切换参考信息,根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的第一切换报文的切换参考信息,并根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的第二切换报文的切换参考信息。
通信单元220,还用于根据所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流。
本发明实施例2中描述的功能单元可以用来实施上述实施例1所述的方法中传输设备执行的操作。具体地,所述通信单元220用于与其它设备通信,如接收控制信令、接收数据报文、转发数据报文、在转发数据报文时修改数据报文中的信息等;所述处理单元210用于确定切入流和切出流的切换序列号等。
处理单元210可以包括多个处理子单元,分别对应一个需要切换视频流的出端口(如上述目标出端口)。通信单元220可以包括多个发送子单元,分别对应一个需要切换视频流的出端口。每个出端口的处理子单元确定该出端口的切入流和切出流的切换报文的切换参考信息(如序列号),每个出端口对应的发送子单元通过该出端口转发需要通过该出端口转发的视频流的数据报文、并直接丢弃不需要通过该出端口转发的视频流的数据报文。
根据本发明实施例2提供的传输设备200,由于在视频流切换时考虑了切换前后发送的数据报文所处的位置,因此,可以有效减轻切换操作对传输的视频画面的损伤。
根据本发明实施例1,本发明实施例3提供了一种传输设备1000。如图6所示,传输设备1000包括处理器1010和端口1020。
处理器1010,用于实施本发明实施例1提供的方法100中的传输设备执行的操作,其中,在与其它设备通信时通过端口1020与其它设备通信。处理器1010具体可以是中央处理器 (central processing unit,CPU),或者是特定集成电路(Application SpecificIntegrated Circuit,ASIC),或者是被配置成实施本发明实施例的一个或多个集成电路。
如图6所示,传输设备1000还可以包括存储器1030。处理器1010和存储器1030之间可以通过总线完成相互间的通信。存储器1030,用于存放计算机操作指令,具体可以是高速随机存取存储器(Random Access Memory,RAM),也可以是非易失性存储器(non-volatilememory)。处理器1010具体可以执行存储器1030中存放的计算机操作指令,通过执行所述计算机操作指令使得传输设备1000执行上述实施例1所述的方法中传输设备所执行的操作。在具体实现时,存储器1030可以包括处理模块1031和通信模块1032,分别存储用于实现图5所示的处理单元210和通信单元220的功能。相应地,处理器1010具体通过执行处理模块1031中的指令实现处理单元210的功能并通过执行通信模块1032中的指令实现通信单元220 的功能。
根据本发明实施例3提供的传输设备1000,由于在视频流切换时考虑了切换前后发送的数据报文所处的位置,因此,可以有效减轻切换操作对传输的视频画面的损伤。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本发明实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。

Claims (18)

1.一种实现视频流切换的方法,其特征在于,包括:
传输设备接收第一视频流和第二视频流;
所述传输设备通过目标出端口发送所述第一视频流;
所述传输设备接收切换指令,所述切换指令用于指示将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流;
所述传输设备根据所述切换指令确定所述第一视频流的第一基准帧尾报文的切换参考信息和所述第二视频流的第二基准帧尾报文的切换参考信息;
所述传输设备根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的第一切换报文的切换参考信息,并根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的第二切换报文的切换参考信息;
所述传输设备根据所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流;
所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均包括序列号;
所述根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的第一切换报文的切换参考信息包括:根据所述第一基准帧尾报文的序列号、以及所述第一视频流和所述第二视频流之间的同步关系确定所述第一视频流的第一对齐帧尾报文的序列号,并将所述第一对齐帧尾报文的序列号作为所述第一切换报文的序列号,或将用于封装所述第一对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第一切换报文的序列号;
所述根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的第二切换报文的切换参考信息包括:根据所述第二基准帧尾报文的序列号、以及所述同步关系确定所述第二视频流的第二对齐帧尾报文的序列号,并将所述第二对齐帧尾报文的序列号作为所述第二切换报文的序列号,或将用于封装所述第二对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第二切换报文的序列号,所述第一对齐帧尾报文和所述第二对齐帧尾报文为在时间上对应的帧尾报文。
2.根据权利要求1所述的方法,其特征在于,
所述第一基准帧尾报文和所述第二基准帧尾报文分别为确定所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息之前接收的所述第一视频流的倒数第x个帧尾报文和所述第二视频流的倒数第x个帧尾报文,其中x为自然数。
3.根据权利要求2所述的方法,其特征在于,x取值为1;
所述第一切换报文中的视频数据所属视频帧为所述第一基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧;所述第二切换报文中的视频数据所属视频帧为所述第二基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧。
4.根据权利要求1-3任意一项所述的方法,其特征在于,
所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均包括时间戳。
5.根据权利要求1所述的方法,其特征在于,
在确定所述同步关系为所述第一视频流早于所述第二视频流时,将所述第一基准帧尾报文的序列号与m*M1的和确定为所述第一对齐帧尾报文的序列号,并将所述第二基准帧尾报文的序列号与(m+1)*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,m为自然数;
在确定所述同步关系为所述第一视频流晚于所述第二视频流时,将所述第一基准帧尾报文的序列号与(n+1)*M1的和确定为所述第一对齐帧尾报文的序列号,将所述第二基准帧尾报文的序列号与n*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,n为自然数;或
在确定所述同步关系为所述第一视频流和所述第二视频流同步时,将所述第一基准帧尾报文的序列号与k*M1的和确定为所述第一对齐帧尾报文的序列号,将所述第二基准帧尾报文的序列号与k*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,k为自然数。
6.根据权利要求1所述的方法,其特征在于,所述传输设备具体根据所述第一基准帧尾报文的时间戳和所述第二基准帧尾报文的时间戳确定所述第一视频流和所述第二视频流的同步关系。
7.根据权利要求1-3任意一项所述的方法,其特征在于,所述传输设备通过所述目标出端口发出的第二视频流的数据报文中的第一字段的值与通过所述目标出端口发出的所述第一视频流的数据报文中的第一字段的值是相同的,所述第一字段为组播地址字段或载荷类型字段。
8.根据权利要求1-3任意一项所述的方法,其特征在于,所述传输设备通过所述目标出端口发出的所述第二视频流的数据报文的第二字段的值与通过所述目标出端口发出的所述第一视频流的数据报文中的第二字段的值是连续的,所述第二字段为序列号字段、帧号字段或时间戳字段。
9.一种传输设备,其特征在于,所述传输设备包括处理单元和通信单元;
所述通信单元,用于接收第一视频流和第二视频流,通过所述传输设备的目标出端口发送所述第一视频流,并接收切换指令,所述切换指令用于指示将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流;
所述处理单元,用于根据所述切换指令确定所述第一视频流的第一基准帧尾报文的切换参考信息和所述第二视频流的第二基准帧尾报文的切换参考信息,根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的第一切换报文的切换参考信息,并根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的第二切换报文的切换参考信息;
所述通信单元,还用于根据所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息将通过所述目标出端口发送的所述第一视频流切换为所述第二视频流;
所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均包括序列号;
所述处理单元用于根据所述第一基准帧尾报文的切换参考信息确定所述第一视频流的第一切换报文的切换参考信息包括:用于根据所述第一基准帧尾报文的序列号、以及所述第一视频流和所述第二视频流之间的同步关系确定所述第一视频流的第一对齐帧尾报文的序列号,并将所述第一对齐帧尾报文的序列号作为所述第一切换报文的序列号,或将用于封装所述第一对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第一切换报文的序列号;
所述处理单元用于根据所述第二基准帧尾报文的切换参考信息确定所述第二视频流的第二切换报文的切换参考信息包括:用于根据所述第二基准帧尾报文的序列号、以及所述同步关系确定所述第二视频流的第二对齐帧尾报文的序列号,并将所述第二对齐帧尾报文的序列号作为所述第二切换报文的序列号,或将用于封装所述第二对齐帧尾报文中的视频数据所属视频帧的下一视频帧的消隐区数据的数据报文的序列号确定为所述第二切换报文的序列号,所述第一对齐帧尾报文和所述第二对齐帧尾报文为在时间上对应的帧尾报文。
10.根据权利要求9所述的传输设备,其特征在于,
所述第一基准帧尾报文和所述第二基准帧尾报文分别为确定所述第一基准帧尾报文的切换参考信息和所述第二基准帧尾报文的切换参考信息之前接收的所述第一视频流的倒数第x个帧尾报文和所述第二视频流的倒数第x个帧尾报文,其中x为自然数。
11.根据权利要求10所述的传输设备,其特征在于,x取值为1;
所述第一切换报文中的视频数据所属视频帧为所述第一基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧;所述第二切换报文中的视频数据所属视频帧为所述第二基准帧尾报文中的视频数据所属视频帧在顺序上的下一视频帧或在顺序上的下一视频帧的后续视频帧。
12.根据权利要求9-11任意一项所述的传输设备,其特征在于,
所述第一基准帧尾报文的切换参考信息、所述第二基准帧尾报文的切换参考信息、所述第一切换报文的切换参考信息和所述第二切换报文的切换参考信息均包括时间戳。
13.根据权利要求9所述的传输设备,其特征在于,所述处理单元具体用于:
在确定所述同步关系为所述第一视频流早于所述第二视频流时,将所述第一基准帧尾报文的序列号与m*M1的和确定为所述第一对齐帧尾报文的序列号,并将所述第二基准帧尾报文的序列号与(m+1)*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,m为自然数;
在确定所述同步关系为所述第一视频流晚于所述第二视频流时,将所述第一基准帧尾报文的序列号与(n+1)*M1的和确定为所述第一对齐帧尾报文的序列号,将所述第二基准帧尾报文的序列号与n*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,n为自然数;或
在确定所述同步关系为所述第一视频流和所述第二视频流同步时,将所述第一基准帧尾报文的序列号与k*M1的和确定为所述第一对齐帧尾报文的序列号,将所述第二基准帧尾报文的序列号与k*M2的和确定为所述第二对齐帧尾报文的序列号,其中,M1为封装所述第一视频流的一个视频帧所需的数据报文的数量,M2为封装所述第二视频流的一个视频帧所需的数据报文的数量,k为自然数。
14.根据权利要求9所述的传输设备,其特征在于,所述处理单元具体根据所述第一基准帧尾报文的时间戳和所述第二基准帧尾报文的时间戳确定所述第一视频流和所述第二视频流的同步关系。
15.根据权利要求9-11任意一项所述的传输设备,其特征在于,所述通信单元通过所述目标出端口发出的第二视频流的数据报文中的第一字段的值与通过所述目标出端口发出的所述第一视频流的数据报文中的第一字段的值是相同的,所述第一字段为组播地址字段或载荷类型字段。
16.根据权利要求9-11任意一项所述的传输设备,其特征在于,所述通信单元通过所述目标出端口发出的所述第二视频流的数据报文的第二字段的值与通过所述目标出端口发出的所述第一视频流的数据报文中的第二字段的值是连续的,所述第二字段为序列号字段、帧号字段或时间戳字段。
17.一种实现视频流切换的系统,其特征在于,所述系统包括:控制器和如权利要求9-16任意一项所述的传输设备;
所述控制器,用于向所述传输设备发送切换指令。
18.一种计算机可读存储介质,包括指令,当其在计算机上运行时,使得计算机执行如权利要求1-8任意一项所述的方法。
CN201810962907.4A 2018-08-22 2018-08-22 一种实现视频流切换的方法、设备、系统和存储介质 Active CN110858925B (zh)

Priority Applications (8)

Application Number Priority Date Filing Date Title
CN201810962907.4A CN110858925B (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、设备、系统和存储介质
CN202111216180.3A CN114143606A (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、装置和系统
JP2021509807A JP7224439B2 (ja) 2018-08-22 2019-08-18 ビデオ・ストリーム切り換えを実装するための方法、装置およびシステム
KR1020237010789A KR102671249B1 (ko) 2018-08-22 2019-08-18 비디오 스트림을 스위칭하기 위한 방법, 장치, 및 시스템
PCT/CN2019/101241 WO2020038309A1 (zh) 2018-08-22 2019-08-18 一种实现视频流切换的方法、装置和系统
EP19851740.1A EP3836552A4 (en) 2018-08-22 2019-08-18 VIDEO STREAM SWITCHING PROCESS, APPARATUS AND SYSTEM
KR1020217006921A KR20210041052A (ko) 2018-08-22 2019-08-18 비디오 스트림을 스위칭하기 위한 방법, 장치, 및 시스템
US17/180,568 US11483495B2 (en) 2018-08-22 2021-02-19 Method, apparatus, and system for implementing video stream switching

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810962907.4A CN110858925B (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、设备、系统和存储介质

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CN202111216180.3A Division CN114143606A (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、装置和系统

Publications (2)

Publication Number Publication Date
CN110858925A CN110858925A (zh) 2020-03-03
CN110858925B true CN110858925B (zh) 2021-10-15

Family

ID=69592280

Family Applications (2)

Application Number Title Priority Date Filing Date
CN201810962907.4A Active CN110858925B (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、设备、系统和存储介质
CN202111216180.3A Pending CN114143606A (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、装置和系统

Family Applications After (1)

Application Number Title Priority Date Filing Date
CN202111216180.3A Pending CN114143606A (zh) 2018-08-22 2018-08-22 一种实现视频流切换的方法、装置和系统

Country Status (6)

Country Link
US (1) US11483495B2 (zh)
EP (1) EP3836552A4 (zh)
JP (1) JP7224439B2 (zh)
KR (1) KR20210041052A (zh)
CN (2) CN110858925B (zh)
WO (1) WO2020038309A1 (zh)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114338456B (zh) * 2020-09-25 2024-03-22 浙江宇视科技有限公司 图像采集设备状态确定方法、装置、电子设备及介质
CN113794942B (zh) * 2021-09-09 2022-12-02 北京字节跳动网络技术有限公司 自由视角视频的视角切换方法、装置、系统、设备和介质
CN115314643B (zh) * 2022-07-28 2023-12-15 中央广播电视总台 一种实现净切换的方法、系统、设备及存储介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101316357A (zh) * 2008-06-30 2008-12-03 华为技术有限公司 一种频道切换的方法、终端和媒体服务器
CN101753973A (zh) * 2008-12-12 2010-06-23 华为技术有限公司 一种频道切换方法、装置和系统
CN101854533A (zh) * 2010-06-10 2010-10-06 华为技术有限公司 频道切换方法、装置及系统
CN102045586A (zh) * 2009-10-14 2011-05-04 索尼公司 网络设备、信息处理装置、流切换方法和内容分送系统
CN103907358A (zh) * 2011-06-22 2014-07-02 无线电广播技术研究所有限公司 用于切换实时媒体流的设备和方法
CN106937155A (zh) * 2015-12-29 2017-07-07 北京华为数字技术有限公司 接入设备、因特网协议电视iptv系统和频道切换方法
CN107086963A (zh) * 2017-03-10 2017-08-22 中国传媒大学 一种基于sdn的目的端精准视频切换方法
CN107135169A (zh) * 2017-04-25 2017-09-05 中国传媒大学 一种基于sdn交换机的视频净切换方法

Family Cites Families (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4474310B2 (ja) * 2005-03-24 2010-06-02 パナソニック株式会社 デバイス切替システム、送信元および配信先デバイス
CN1331359C (zh) 2005-06-28 2007-08-08 清华大学 交互式多视点视频系统中视频流的传输方法
US20090097496A1 (en) * 2006-05-02 2009-04-16 Kazunori Nakamura Video Signal Switching System
US20080021971A1 (en) * 2006-07-21 2008-01-24 Halgas Joseph F System and Method for Electronic Messaging Notification Using End-User Display Devices
CN100559877C (zh) 2007-04-27 2009-11-11 北京大学 一种支持多视点视频合成的网络流媒体播放器及方法
JP2009100411A (ja) 2007-10-19 2009-05-07 Hitachi Ltd 映像配信システム、映像中継装置、及び映像中継方法
WO2010017656A1 (en) 2008-08-12 2010-02-18 Telefonaktiebolaget L M Ericsson (Publ) Fast content switching in a communication system
US20100225811A1 (en) * 2009-03-05 2010-09-09 Nokia Corporation Synchronization of Content from Multiple Content Sources
CN101917390B (zh) 2009-12-17 2013-03-06 新奥特(北京)视频技术有限公司 一种多功能网络播放器
EP2343845A3 (en) * 2009-12-31 2011-10-19 Thomson Licensing Precise compensation of video propagation duration
EP2448265A1 (en) 2010-10-26 2012-05-02 Google, Inc. Lip synchronization in a video conference
US9124419B2 (en) 2012-05-08 2015-09-01 Discretix Technologies Ltd. Method, device, and system of secure entry and handling of passwords
TW201349848A (zh) * 2012-05-22 2013-12-01 Chunghwa Telecom Co Ltd 多視角互動電視之影音串流方法
US9860458B2 (en) * 2013-06-19 2018-01-02 Electronics And Telecommunications Research Institute Method, apparatus, and system for switching transport stream
GB2516316A (en) * 2013-07-19 2015-01-21 Sony Corp Video network
WO2016084592A1 (ja) * 2014-11-28 2016-06-02 ソニー株式会社 送信装置、送信方法、受信装置および受信方法
CN107431845B (zh) 2015-03-31 2021-03-26 松下电器(美国)知识产权公司 发送方法、接收方法、发送装置以及接收装置
US10038651B2 (en) * 2015-09-05 2018-07-31 Nevion Europe As Asynchronous switching system and method
EP3185564A1 (en) 2015-12-22 2017-06-28 Harmonic Inc. Video stream splicing of groups of pictures (gop)
CN105554532A (zh) * 2016-02-15 2016-05-04 北京中传数广技术有限公司 一种直播电视精准广告、信息投放的方法及系统
CN106162235B (zh) 2016-08-17 2018-06-01 北京百度网讯科技有限公司 用于切换视频流的方法和装置
CN107770538B (zh) 2016-08-23 2020-09-11 华为技术有限公司 一种检测场景切换帧的方法、装置和系统
US10412441B2 (en) * 2016-12-06 2019-09-10 Rgb Spectrum Systems, methods, and devices for high-bandwidth digital content synchronization
CN107018379B (zh) 2017-04-25 2019-07-23 北京东土科技股份有限公司 一种视频流的传输方法和装置
CN107888909B (zh) * 2017-11-29 2019-01-18 中国传媒大学 一种ip视频净切换系统的测量方法
CN110891182B (zh) * 2018-09-11 2022-04-12 华为技术有限公司 一种实现视频流切换的方法、装置和系统
CN111629158B (zh) * 2019-02-28 2021-08-03 华为技术有限公司 一种音频流和视频流同步切换方法及装置

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101316357A (zh) * 2008-06-30 2008-12-03 华为技术有限公司 一种频道切换的方法、终端和媒体服务器
CN101753973A (zh) * 2008-12-12 2010-06-23 华为技术有限公司 一种频道切换方法、装置和系统
CN102045586A (zh) * 2009-10-14 2011-05-04 索尼公司 网络设备、信息处理装置、流切换方法和内容分送系统
CN101854533A (zh) * 2010-06-10 2010-10-06 华为技术有限公司 频道切换方法、装置及系统
CN103907358A (zh) * 2011-06-22 2014-07-02 无线电广播技术研究所有限公司 用于切换实时媒体流的设备和方法
CN106937155A (zh) * 2015-12-29 2017-07-07 北京华为数字技术有限公司 接入设备、因特网协议电视iptv系统和频道切换方法
CN107086963A (zh) * 2017-03-10 2017-08-22 中国传媒大学 一种基于sdn的目的端精准视频切换方法
CN107135169A (zh) * 2017-04-25 2017-09-05 中国传媒大学 一种基于sdn交换机的视频净切换方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"SDI over IP 实时制作系统视频净切换方案研究";王颖;《广播与电视技术》;20180531;第45卷(第5期);全文 *

Also Published As

Publication number Publication date
US20210176408A1 (en) 2021-06-10
CN114143606A (zh) 2022-03-04
EP3836552A4 (en) 2021-08-18
EP3836552A1 (en) 2021-06-16
JP7224439B2 (ja) 2023-02-17
KR20230047512A (ko) 2023-04-07
KR20210041052A (ko) 2021-04-14
US11483495B2 (en) 2022-10-25
WO2020038309A1 (zh) 2020-02-27
CN110858925A (zh) 2020-03-03
JP2021535658A (ja) 2021-12-16

Similar Documents

Publication Publication Date Title
CN110891182B (zh) 一种实现视频流切换的方法、装置和系统
US11483495B2 (en) Method, apparatus, and system for implementing video stream switching
US11184627B2 (en) Video transcoding system, method, apparatus, and storage medium
US11368634B2 (en) Audio stream and video stream synchronous switching method and apparatus
CN110602522B (zh) 一种多路实时直播WebRTC流合成方法
CN105191316A (zh) 用于切换经压缩的视频流的切换装置、具有切换装置的会议系统以及用于切换经压缩的视频流的过程
JP2017533605A (ja) ルーターファブリック
US9647951B2 (en) Media stream rate reconstruction system and method
CN112954433A (zh) 视频处理方法、装置、电子设备及存储介质
KR102671249B1 (ko) 비디오 스트림을 스위칭하기 위한 방법, 장치, 및 시스템
CN113645491A (zh) 一种多个直播播放端实现实时同步播放的方法
CN106937155B (zh) 接入设备、因特网协议电视iptv系统和频道切换方法
US20190191195A1 (en) A method for transmitting real time based digital video signals in networks
US11622101B2 (en) Transmission processing apparatus, transmission processing method, and storage medium
JP5367771B2 (ja) 映像伝送システム

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