CN113596518A - 一种用于提升倍速播放性能的视频存取方法 - Google Patents
一种用于提升倍速播放性能的视频存取方法 Download PDFInfo
- Publication number
- CN113596518A CN113596518A CN202110929870.7A CN202110929870A CN113596518A CN 113596518 A CN113596518 A CN 113596518A CN 202110929870 A CN202110929870 A CN 202110929870A CN 113596518 A CN113596518 A CN 113596518A
- Authority
- CN
- China
- Prior art keywords
- frame
- speed
- video
- target
- sequence
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 47
- 230000008569 process Effects 0.000 claims description 16
- 238000004458 analytical method Methods 0.000 claims description 5
- 230000011664 signaling Effects 0.000 claims description 5
- 238000012545 processing Methods 0.000 abstract description 21
- 230000004044 response Effects 0.000 abstract description 3
- 230000000694 effects Effects 0.000 description 8
- 230000001133 acceleration Effects 0.000 description 3
- 238000013461 design Methods 0.000 description 3
- 230000006872 improvement Effects 0.000 description 3
- 238000003672 processing method Methods 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000013500 data storage Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/23418—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving operations for analysing video streams, e.g. detecting features or characteristics
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
- H04N21/234309—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements by transcoding between formats or standards, e.g. from MPEG-2 to MPEG-4 or from Quicktime to Realvideo
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
- H04N21/234381—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements by altering the temporal resolution, e.g. decreasing the frame rate by frame skipping
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/238—Interfacing the downstream path of the transmission network, e.g. adapting the transmission rate of a video stream to network bandwidth; Processing of multiplex streams
- H04N21/2387—Stream processing in response to a playback request from an end-user, e.g. for trick-play
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Television Signal Processing For Recording (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
Abstract
本发明提供一种用于提升倍速播放性能的视频存取方法,包括:存储服务器建立与每个摄像机ID对应的I帧索引表;在进行视频倍速读取时,存储服务器挑选出符合视频回放倍速X的目标I帧序列,并返回给流媒体服务器。优点为:1)减轻了存储服务器的IO带宽、CPU要求及内存要求,降低了存储服务器与流媒体服务器间的网络带宽占用。2)同时对于流媒体服务器,因为不需要对完整的视频流进行缓存、解码、定位、跳帧等处理,因此减轻了性能消耗,提升了倍速播放的响应速度,改善了用户体验。3)由于最终向播放器返回的为I帧,I帧是完整画面帧,而不像P帧仅为差别画面帧,因此,对于播放器,倍速播放I帧,能够保证播放画面质量。
Description
技术领域
本发明属于流媒体应用及视频存储技术领域,具体涉及一种用于提升倍速播放性能的视频存取方法。
背景技术
视频存储是安防监控领域常见的业务类型,视频最常见的应用是实时播放及回放。对于视频回放业务,倍速播放是十分常用的业务场景,多用于当某事件发生后,管理人员试图通过倍速播放快速地查找和定位其所关注的“画面”,从而锁定事件发生时间的视频段,以便进一步分析情况。
从技术角度,对于2倍速的视频播放,通常采取跳帧的方式实现,即:以同样的播放帧率,只播放原有图像帧序列的奇数图像帧或偶数图像帧;对于大于2倍速的回放,例如4倍速、8倍速及以上倍速,单纯跳帧的方法效果欠佳。例如,对于4倍速,以同样的播放帧率,只播放原有图像帧序列的第1图像帧,第5图像帧,第9图像帧,第13图像帧...如果原始图像帧的帧率为32帧/秒,则通常情况下,第1帧为I帧(关键帧,为完整画面帧),而2到32帧为P帧(即前向预测编码帧,简称“差别帧”,只保留本帧与前一帧相比的差别画面),由于第5图像帧和第1图像帧之间跳过3个P帧,同样的,第9图像帧和第5图像帧之间跳过3个P帧,即:相邻两个图像帧之间跳过3个P帧,跳过的P帧数量较多,导致相邻的后一图像帧与前一图像帧差别太大,因此,数据质量差,很容易引起画面模糊。
对于视频回放,当前方法主要为:由流媒体服务器将视频数据当作普通视频流交给存储服务器,存储服务器以数据块的方式存储视频数据;在回放时,流媒体服务器通过存储服务器取到所需时间段的视频数据,再将所需时间段的视频数据传输给终端播放器,由终端播放器进行跳帧处理,达到倍速播放的目的。
该技术主要存在以下问题:对流媒体服务器而言,当进行X倍速播放时,需要在单位时间内获取相当于原有数据量X倍的视频数据,流媒体服务器的处理能力,缓存数量、流媒体服务器与存储服务器之间的带宽,存储服务器的处理能力和缓存数量以及存储服务器上磁盘的IO能力都要相应地扩大到X倍才能实现这一业务。因此在实际工程中,当倍速播放的速率较大(例如大于4倍)时,能够看到倍速播放的效果不佳,一是实际播放的倍速可能达不到预期倍速,再或者是为了达到预期倍速而中间跳帧过多导致画面连续性较差。
由此可见,当倍速播放的速率较大时,从存储服务器、流媒体服务器到终端播放器,其处理性能、缓存能力网络性能等都可能成为瓶颈,进而影响倍速播放的效果。
发明内容
针对现有技术存在的缺陷,本发明提供一种用于提升倍速播放性能的视频存取方法,可有效解决上述问题。
本发明采用的技术方案如下:
本发明提供一种用于提升倍速播放性能的视频存取方法,包括以下步骤:
步骤一:视频写入过程:
步骤1.1:摄像机将视频流推送到流媒体服务器;其中,视频流中携带摄像机ID;
步骤1.2:流媒体服务器对接收到的视频流进行协议解析及解封装,从视频流中去掉信令数据,得到处理后的视频流;其中,处理后的视频流为图像帧序列;
步骤1.3:流媒体服务器对处理后的视频流进行解码,从图像帧序列中识别出I帧,并对识别到的每个I帧写入I帧标记,由此得到解码后的图像帧序列;
步骤1.4:流媒体服务器以图像帧为写入单位,将解码后的图像帧序列写入到存储服务器;
步骤1.5:存储服务器对接收到的图像帧序列进行分析,根据I帧标记识别到每个I帧,并预建立与每个摄像机ID对应的I帧索引表,将每个I帧的关键信息存入到所述I帧索引表;其中,每个I帧的关键信息包括时间戳、帧类型、帧序号、帧偏移地址和帧长度;
步骤1.6:存储服务器将接收到的图像帧序列写入到存储介质;
步骤二:视频倍速读取过程:
步骤2.1:播放器向流媒体服务器发起视频倍速回放请求;其中,所述视频倍速回放请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.2:流媒体服务器向存储服务器发送视频数据读取请求;其中,所述视频数据读取请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.3:存储服务器根据摄像机ID及待播放时间段,查找与摄像机ID对应的I帧索引表,根据每个I帧的时间戳,确定与待播放时间段对应的第一目标I帧序列;
然后,根据视频回放倍速X,从与待播放时间段对应的第一目标I帧序列中,挑选出符合视频回放倍速X的第二目标I帧序列;
然后,根据第二目标I帧序列中每个I帧的帧偏移地址和帧长度,从存储介质中读取到第二目标I帧序列;
步骤2.4:存储服务器向流媒体服务器返回获取到的第二目标I帧序列;
步骤2.5:流媒体服务器对接收到的第二目标I帧序列进行打包封装,得到封装后的目标I帧序列;
步骤2.6:流媒体服务器将封装后的目标I帧序列发送给播放器;
步骤2.7:播放器对接收到的封装后的目标I帧序列进行解码,并按照需要的视频回放倍速要求,倍速播放目标I帧序列。
优选的,步骤2.7具体为:
步骤2.7.1,对于帧率为m帧/秒的视频流,1秒对应的m帧中,存在1个I帧,其他m-1帧均为P帧;
步骤2.7.2,播放器获取到待播放时间段的第二目标I帧序列,将第二目标I帧序列表示为:第1I帧,第2I帧,...,第nI帧,其中,n为第二目标I帧序列的帧数;
步骤2.7.3,假设播放器需要X倍速播放第二目标I帧序列,并且,播放器的播放速度为Y帧/秒;
则:
播放器在第1秒,读取第1I帧-第XI帧,对第1I帧-第XI帧进行均匀补零帧,将第1I帧-第XI帧扩充为Y帧;然后,在第1秒,播放补零帧后的Y帧;
同样的,在第2秒,读取第(X+1)I帧-第(2X)I帧,对第(X+1)I帧-第(2X)I帧进行均匀补零帧,将第(X+1)I帧-第(2X)I帧扩充为Y帧;然后,在第2秒,播放补零帧后的Y帧;
依此类推,实现以X倍速播放第二目标I帧序列。
本发明提供的一种用于提升倍速播放性能的视频存取方法具有以下优点:
1)减轻了存储服务器的IO带宽、CPU要求及内存要求,降低了存储服务器与流媒体服务器间的网络带宽占用。
2)同时对于流媒体服务器,因为不需要对完整的视频流进行缓存、解码、定位、跳帧等处理,因此减轻了性能消耗,提升了倍速播放的响应速度,改善了用户体验。
3)由于最终向播放器返回的为I帧,I帧是完整画面帧,而不像P帧仅为差别画面帧,因此,对于播放器,倍速播放I帧,能够保证播放画面质量。
附图说明
图1为本发明提供的一种用于提升倍速播放性能的视频存取方法的流程示意图;
图2为本发明建立的I帧索引表的示意图;
图3为传统视频倍速播放过程与本发明倍速播放过程的对比图。
具体实施方式
为了使本发明所解决的技术问题、技术方案及有益效果更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
本发明属于流媒体应用及视频存储领域,专门针对视频存取的方法改进设计,以提升视频倍速播放时的性能。
本发明提出一种用于提升倍速播放性能的视频存取方法,视频流在向存储服务器写入时,存储服务器建立I帧索引表,在倍速回放时,存储服务器仅返回满足要求的I帧,而不是返回全部的码流,以此降低包括存储服务器、流媒体服务器以及播放器在内的整个***的计算、缓存及网络负荷,进而提升倍速回放业务的用户体验。
本发明的主要原理是:流媒体服务器在向存储服务器提交视频流时,进行简单的解码工作,区分每个图像帧的类型,识别出视频流中的所有I帧,存储服务器为视频流中的所有I帧建立I帧索引表。在播放器需要进行倍速播放时,播放器通过流媒体服务器向存储服务器发送倍速播放请求,存储服务器根据视频回放倍速要求,通过简单计算,仅从磁盘中查找到所需时间段并且满足视频回放倍速要求的I帧,并向流媒体服务器返回对应的I帧,流媒体服务器再将对应的I帧返回给播放器进行播放。可见,流媒体服务器和存储服务器之间,以及流媒体服务器和播放器之间,并不是传输完整的视频流,而仅仅是满足要求的I帧。因此具有以下优点:1)减轻了存储服务器的IO带宽、CPU要求及内存要求,降低了存储服务器与流媒体服务器间的网络带宽占用。2)同时对于流媒体服务器,因为不需要对完整的视频流进行缓存、解码、定位、跳帧等处理,因此减轻了性能消耗,提升了倍速播放的响应速度,改善了用户体验。3)由于最终向播放器返回的为I帧,I帧是完整画面帧,而不像P帧仅为差别画面帧,因此,对于播放器,倍速播放I帧,能够保证播放画面质量。
参考图1,本发明提供一种用于提升倍速播放性能的视频存取方法,包括以下步骤:
步骤一:视频写入过程:
步骤1.1:摄像机将视频流推送到流媒体服务器;其中,视频流中携带摄像机ID;
步骤1.2:流媒体服务器对接收到的视频流进行协议解析及解封装,从视频流中去掉信令数据,得到处理后的视频流;其中,处理后的视频流为图像帧序列;
具体的,流媒体服务器对接收到的视频流进行协议解析及解封装,目的是从原始的流媒体协议数据中去掉信令数据,只保留音视频数据,并进行音视频数据的分离。
步骤1.3:流媒体服务器对处理后的视频流进行解码,从图像帧序列中识别出I帧,并对识别到的每个I帧写入I帧标记,由此得到解码后的图像帧序列;
本步骤中,流媒体服务器对处理后的视频流,只需要进行简单解码,实际应用中,除识别出I帧,还可进一步进行视频头部信息的识别,识别出序列参数集(SPS)和图像参数集(PPS)。该过程并不进行实际的视频解码工作,因此其开销极小。
步骤1.4:流媒体服务器以图像帧为写入单位,将解码后的图像帧序列写入到存储服务器;
具体的,传统方案中,视频流写入是以数据块为单位(例如每2M字节为一块)进行写入。而本发明中,以图像帧为写入单位,进行视频流写入。
步骤1.5:存储服务器对接收到的图像帧序列进行分析,根据I帧标记识别到每个I帧,并预建立与每个摄像机ID对应的I帧索引表,将每个I帧的关键信息存入到所述I帧索引表;其中,每个I帧的关键信息包括时间戳、帧类型、帧序号、帧偏移地址和帧长度;
具体的,如果步骤1.3中识别出序列参数集(SPS)和图像参数集(PPS),则本步骤,存储服务器对接收到的图像帧序列进行分析时,可包括获取并记录序列参数集(SPS)和图像参数集(PPS)。SPS和PPS包括视频编码用到的一些关键参数,包括编码视频序列、码流的档次、参考帧的最大数目、图像的宽度和长度、图像的分辨率等,这些信息用于视频解码,通常是固定不变的,这些信息可以以全局结构统一记录。
而I帧索引表,采用(时间戳,帧类型,帧序号,帧偏移地址,帧长度)的五元组,其中(时间戳,帧类型,帧序号)作为联合关键字是唯一的。时间戳是以秒为单位,帧序号主要用于对I帧编号,以处理同一秒内出现多个I帧的情况。I帧索引表的详细结构说明参见图2。
步骤1.6:存储服务器将接收到的图像帧序列写入到磁盘等存储介质;
具体的,存储服务器进行数据落盘,落盘的策略可自定义,以便于对摄像机进行按时间检索为宜,例如为每个摄像机在每个小时建立一个视频文件。
步骤二:视频倍速读取过程:
步骤2.1:播放器向流媒体服务器发起视频倍速回放请求;其中,所述视频倍速回放请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.2:流媒体服务器向存储服务器发送视频数据读取请求;其中,所述视频数据读取请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.3:存储服务器根据摄像机ID及待播放时间段,查找与摄像机ID对应的I帧索引表,根据每个I帧的时间戳,确定与待播放时间段对应的第一目标I帧序列;
然后,根据视频回放倍速X,从与待播放时间段对应的第一目标I帧序列中,挑选出符合视频回放倍速X的第二目标I帧序列;
然后,根据第二目标I帧序列中每个I帧的帧偏移地址和帧长度,从存储介质中读取到第二目标I帧序列;根据I帧索引表,确定I帧偏移的过程参见图3。
假如对于原视频流,帧率为32帧/秒,每秒只包括一个I帧;获取的与待播放时间段对应的第一目标I帧序列,共包括100个I帧,编号分别为:第1I帧,第2I帧,...,第100I帧;
如果视频回放倍速X为1倍速,则需要将100个I帧均获取,并传输给播放器。如果视频回放倍速X为2倍速,4倍速,直到32倍速,仍然需要将100个I帧均获取,并传输给播放器。而如果为非常高倍速,超过32倍速,例如为64倍速,而需要对I帧进行跳帧处理,仅从100个I帧中,挑选出奇数I帧,再传输给播放器。
步骤2.4:存储服务器向流媒体服务器返回获取到的第二目标I帧序列;
步骤2.5:流媒体服务器对接收到的第二目标I帧序列进行打包封装,在媒体数据中添加信令信息以利于其在信道上传输,从而得到封装后的目标I帧序列;
步骤2.6:流媒体服务器将封装后的目标I帧序列发送给播放器;
不同于传统处理过程的是,本发明本步骤返回的是满足倍速播放条件的I帧,而非完整的视频流。
步骤2.7:播放器对接收到的封装后的目标I帧序列进行解码,并按照需要的视频回放倍速要求,倍速播放目标I帧序列。
步骤2.7具体为:
步骤2.7.1,对于帧率为m帧/秒的视频流,1秒对应的m帧中,存在1个I帧,其他m-1帧均为P帧;
步骤2.7.2,播放器获取到待播放时间段的第二目标I帧序列,将第二目标I帧序列表示为:第1I帧,第2I帧,...,第nI帧,其中,n为第二目标I帧序列的帧数;
步骤2.7.3,假设播放器需要X倍速播放第二目标I帧序列,并且,播放器的播放速度为Y帧/秒;
则:
播放器在第1秒,读取第1I帧-第XI帧,对第1I帧-第XI帧进行均匀补零帧,将第1I帧-第XI帧扩充为Y帧;然后,在第1秒,播放补零帧后的Y帧;
同样的,在第2秒,读取第(X+1)I帧-第(2X)I帧,对第(X+1)I帧-第(2X)I帧进行均匀补零帧,将第(X+1)I帧-第(2X)I帧扩充为Y帧;然后,在第2秒,播放补零帧后的Y帧;
依此类推,实现以X倍速播放第二目标I帧序列。
参考图2,若对于帧率为30帧/秒的视频流进行X倍速(X=4,8,16,…,128)播放场景,与传统处理方式相比,本发明具有以下优点:
1)存储服务器需要访问的磁盘数据大幅减少,数据访问量降低到全部数据量的1/30到1/X(X>30时,需要跳过I帧);
2)从存储服务器向流媒体服务器返回的数据量降低到1/30到1/X,即网络带宽占用降低至传统处理方式的1/30到1/X(X>30);
3)流媒体服务器需要进行视频打包封装处理的数据量降低至传统方式的1/30到1/X(X>30);
4)流媒体服务器返回给播放器的数据量降低到1/30到1/X,即网络带宽消耗降低到传统处理方式的1/30到1/X(X>30);
5)播放器需要处理的数据量降低至1/30到1/X(X>30),播放器能够有效地进行高倍速播放;
6)存储服务器、流媒体服务器以及播放器在整个处理过程中的内存需求(数据缓存的空间)降低至1/30到1/X(X>30);
简言之,本发明提供的用于倍速回放的视频存取方法,较之传统的视频回放方法,将整个***的CPU运算、内存占用、网络使用、IO访问的带宽降低至1/30到1/X(X>30),满足高倍速播放的需求,有效降低***开销,提升用户体验。
与此同时,本发明所付出的额外代价有:
1)在视频写入环节进行简单解码,以标记I帧;
2)在视频写入环节为I帧建立I帧索引;
3)存储服务器在视频读取环节进行跳帧处理;
以上工作引入少量的CPU运算开销,而比起上述节省的大量开销而言,此部分代价可以忽略,该方法整体而言对整个***的开销起到了削减作用,显著提升***性能及业务体验。
下面对本发明带来的优点,进行详细分析介绍:
对于帧率为30帧/秒的视频流,设定一秒一个I帧,摄像机采用ONVIF(OpenNetwork Video Interface Forum,开放型网络视频接口论坛)协议进行管理和控制,视频采用H.264编码,摄像机与流媒体服务器之间采用RFSP(Real Time Streaming Protocol,实时流协议)及RTP(Real-time Transport Protocol,实时传输协议)协议进行会话建立及媒体传输。
流媒体服务器与存储服务器采用通用的块存储接口/对象存储接口/文件存储接口或者自定义接口,播放器采用常见开源播放器如MPV播放器或VLC media player等,这样基本上构建了一套完整的流媒体处理***。
传统处理方法主要有以下两种:
(一)简单的加速播放方式
传统处理方法,例如,假设原始视频流为30帧/秒,视频播放倍速方式为:采用简单的加速播放方式,即:假如视频播放倍速为2倍速,则采用对原始视频流以60帧/秒的速度进行播放。由于采用原始视频流全帧播放,因此,当视频播放倍速达到4倍以上时,倍速播放的效果开始变差,主要表现为画面实际倍速远低于预期倍速,例如播放8倍速,根据画面上的时间戳能看到实际效果最多达到4倍速,当请求更高播放倍速时,实际的播放倍速也停留在4倍速或者稍高的速率,不会再升高。原因为:由于采用原始视频流全帧播放,播放器以及整个流媒体***无法简单地将性能提升至期望的播放速率倍数(如4倍速播放,整个***无法将处理性能直接提升到正常播放性能的4倍),通常最大的瓶颈在于播放器一侧(因为其主要运行在普通工作机上,性能一般),所以对于高倍速播放,传统处理方式播放器“无能为力”。
(二)跳帧加速播放方式
传统处理方法,例如,假设原始视频流为30帧/秒,视频播放倍速方式为2倍速,则播放器以30帧/秒的速度,只播放原始视频流中的奇数帧,由此达到2倍速播放效果。
此种播放速率虽然达到了预期倍速,但是,当播放倍速较高时,由于跳过的帧数量多,并且,跳过的P帧与之前的帧之间差异较大,导致画面效果差,存在画面模糊或花屏的情况。
使用本发明提供的视频存取方法,对存储服务器存储接口及流媒体服务器的相应部分进行改造,此时带来的改变是:
1)对于倍速播放,无论播放倍速的倍速值,整个***处理是流畅的,没有因为倍速的增高而导致画面变慢,实际播放倍速完全符合预期倍速,且播放倍速越高,对比效果越明显
2)倍速播放画面能够保持连续而清晰,不出现画面模糊或花屏等情况
此外本发明兼容正常的视频回放过程,因此对于正常速率的视频回放本例也能正常处理。
本发明提出的用于提升倍速播放性能的视频存取方法,其主要特征在于:
1)本方法拉通了视频数据处理的全流程,对视频数据存储策略进行优化,从存储的角度而非简单的流媒体处理的角度出发,从而从本质上解决倍速播放性能提升问题。
2)流媒体存储接口由块存储方式改为帧存储方式,存储服务器为I帧建立索引。
3)存储服务器内部进行跳帧处理,从信息源头上精准提取了倍速回放需要用到的I帧,进而减轻后续环节的处理负担
4)流媒体服务器仅需要在视频写入时进行帧识别和写入标记。
5)本发明对播放器等独立组件无特殊要求。
6)本方法对于任意倍速的视频回放处理的综合时间复杂度是一致的,因此,并不因为播放倍速的提高而引起性能降低,这一点是其他优化方法所不具备的。
本发明提出的用于提升倍速播放性能的视频存取方法,其核心设计思路,关键流程、算法及数据结构,以及由此内涵衍生出的方案及应用都在本发明专利的保护范围内。
以上所述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视本发明的保护范围。
Claims (2)
1.一种用于提升倍速播放性能的视频存取方法,其特征在于,包括以下步骤:
步骤一:视频写入过程:
步骤1.1:摄像机将视频流推送到流媒体服务器;其中,视频流中携带摄像机ID;
步骤1.2:流媒体服务器对接收到的视频流进行协议解析及解封装,从视频流中去掉信令数据,得到处理后的视频流;其中,处理后的视频流为图像帧序列;
步骤1.3:流媒体服务器对处理后的视频流进行解码,从图像帧序列中识别出I帧,并对识别到的每个I帧写入I帧标记,由此得到解码后的图像帧序列;
步骤1.4:流媒体服务器以图像帧为写入单位,将解码后的图像帧序列写入到存储服务器;
步骤1.5:存储服务器对接收到的图像帧序列进行分析,根据I帧标记识别到每个I帧,并预建立与每个摄像机ID对应的I帧索引表,将每个I帧的关键信息存入到所述I帧索引表;其中,每个I帧的关键信息包括时间戳、帧类型、帧序号、帧偏移地址和帧长度;
步骤1.6:存储服务器将接收到的图像帧序列写入到存储介质;
步骤二:视频倍速读取过程:
步骤2.1:播放器向流媒体服务器发起视频倍速回放请求;其中,所述视频倍速回放请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.2:流媒体服务器向存储服务器发送视频数据读取请求;其中,所述视频数据读取请求中携带摄像机ID、待播放时间段和视频回放倍速X的信息;
步骤2.3:存储服务器根据摄像机ID及待播放时间段,查找与摄像机ID对应的I帧索引表,根据每个I帧的时间戳,确定与待播放时间段对应的第一目标I帧序列;
然后,根据视频回放倍速X,从与待播放时间段对应的第一目标I帧序列中,挑选出符合视频回放倍速X的第二目标I帧序列;
然后,根据第二目标I帧序列中每个I帧的帧偏移地址和帧长度,从存储介质中读取到第二目标I帧序列;
步骤2.4:存储服务器向流媒体服务器返回获取到的第二目标I帧序列;
步骤2.5:流媒体服务器对接收到的第二目标I帧序列进行打包封装,得到封装后的目标I帧序列;
步骤2.6:流媒体服务器将封装后的目标I帧序列发送给播放器;
步骤2.7:播放器对接收到的封装后的目标I帧序列进行解码,并按照需要的视频回放倍速要求,倍速播放目标I帧序列。
2.根据权利要求1所述的一种用于提升倍速播放性能的视频存取方法,其特征在于,步骤2.7具体为:
步骤2.7.1,对于帧率为m帧/秒的视频流,1秒对应的m帧中,存在1个I帧,其他m-1帧均为P帧;
步骤2.7.2,播放器获取到待播放时间段的第二目标I帧序列,将第二目标I帧序列表示为:第1I帧,第2I帧,...,第nI帧,其中,n为第二目标I帧序列的帧数;
步骤2.7.3,假设播放器需要X倍速播放第二目标I帧序列,并且,播放器的播放速度为Y帧/秒;
则:
播放器在第1秒,读取第1I帧-第XI帧,对第1I帧-第XI帧进行均匀补零帧,将第1I帧-第XI帧扩充为Y帧;然后,在第1秒,播放补零帧后的Y帧;
同样的,在第2秒,读取第(X+1)I帧-第(2X)I帧,对第(X+1)I帧-第(2X)I帧进行均匀补零帧,将第(X+1)I帧-第(2X)I帧扩充为Y帧;然后,在第2秒,播放补零帧后的Y帧;
依此类推,实现以X倍速播放第二目标I帧序列。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110929870.7A CN113596518B (zh) | 2021-08-13 | 2021-08-13 | 一种用于提升倍速播放性能的视频存取方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110929870.7A CN113596518B (zh) | 2021-08-13 | 2021-08-13 | 一种用于提升倍速播放性能的视频存取方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113596518A true CN113596518A (zh) | 2021-11-02 |
CN113596518B CN113596518B (zh) | 2022-04-08 |
Family
ID=78258008
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110929870.7A Active CN113596518B (zh) | 2021-08-13 | 2021-08-13 | 一种用于提升倍速播放性能的视频存取方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113596518B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114302180A (zh) * | 2021-12-31 | 2022-04-08 | 深圳市创维软件有限公司 | 视频单帧播放方法、设备、服务器、***及存储介质 |
CN114666603A (zh) * | 2022-05-06 | 2022-06-24 | 厦门美图之家科技有限公司 | 一种视频解码方法、装置、电子设备及存储介质 |
CN114945018A (zh) * | 2022-04-29 | 2022-08-26 | 中国电信股份有限公司 | 一种流媒体数据分发方法、*** |
CN115103209A (zh) * | 2022-06-10 | 2022-09-23 | 慧之安信息技术股份有限公司 | 实现监控视频倍速回放的方法 |
Citations (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1873820A (zh) * | 2006-05-18 | 2006-12-06 | 北京中星微电子有限公司 | 视频文件处理方法、视频索引方法和视频索引装置 |
CN101800874A (zh) * | 2010-01-28 | 2010-08-11 | 南京信息工程大学 | 压缩视频存取方法及存取*** |
CN101841692A (zh) * | 2010-04-23 | 2010-09-22 | 深圳市茁壮网络股份有限公司 | 视频流快进快退的方法 |
CN102025956A (zh) * | 2009-09-23 | 2011-04-20 | 华为技术有限公司 | 网络流媒体快进快退播放的处理方法、装置和*** |
CN102467940A (zh) * | 2010-11-08 | 2012-05-23 | 安凯(广州)微电子技术有限公司 | 一种无索引视频文件快进快退方法、装置以及播放*** |
US20130294743A1 (en) * | 2012-05-01 | 2013-11-07 | Kevin Thornberry | Separate video file for i-frame and non-i-frame data to improve disk performance in trick play |
CN104394426A (zh) * | 2014-12-10 | 2015-03-04 | 福建星网锐捷网络有限公司 | 流媒体倍速播放方法和装置 |
CN104573037A (zh) * | 2015-01-16 | 2015-04-29 | 北京中电兴发科技有限公司 | 一种通过多颜色时间轴快速查询监控录像的方法及*** |
CN104581406A (zh) * | 2014-12-25 | 2015-04-29 | 桂林远望智能通信科技有限公司 | 一种网络视频录像与回放***和方法 |
CN105430506A (zh) * | 2015-11-06 | 2016-03-23 | 浙江宇视科技有限公司 | 一种视频回放中防止报文丢失的方法及装置 |
CN106162022A (zh) * | 2015-04-08 | 2016-11-23 | 深圳市尼得科技有限公司 | 一种快速播放视频的方法、***及移动终端 |
CN106231348A (zh) * | 2016-09-19 | 2016-12-14 | 浙江宇视科技有限公司 | 一种gop数据的回放方法、装置和*** |
CN107979621A (zh) * | 2016-10-24 | 2018-05-01 | 杭州海康威视数字技术股份有限公司 | 一种视频文件的存储、定位播放方法及装置 |
CN109005447A (zh) * | 2018-08-10 | 2018-12-14 | 高新兴科技集团股份有限公司 | 一种安防高清录像倒播方法及装置 |
-
2021
- 2021-08-13 CN CN202110929870.7A patent/CN113596518B/zh active Active
Patent Citations (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1873820A (zh) * | 2006-05-18 | 2006-12-06 | 北京中星微电子有限公司 | 视频文件处理方法、视频索引方法和视频索引装置 |
CN102025956A (zh) * | 2009-09-23 | 2011-04-20 | 华为技术有限公司 | 网络流媒体快进快退播放的处理方法、装置和*** |
CN101800874A (zh) * | 2010-01-28 | 2010-08-11 | 南京信息工程大学 | 压缩视频存取方法及存取*** |
CN101841692A (zh) * | 2010-04-23 | 2010-09-22 | 深圳市茁壮网络股份有限公司 | 视频流快进快退的方法 |
CN102467940A (zh) * | 2010-11-08 | 2012-05-23 | 安凯(广州)微电子技术有限公司 | 一种无索引视频文件快进快退方法、装置以及播放*** |
US20130294743A1 (en) * | 2012-05-01 | 2013-11-07 | Kevin Thornberry | Separate video file for i-frame and non-i-frame data to improve disk performance in trick play |
CN104394426A (zh) * | 2014-12-10 | 2015-03-04 | 福建星网锐捷网络有限公司 | 流媒体倍速播放方法和装置 |
CN104581406A (zh) * | 2014-12-25 | 2015-04-29 | 桂林远望智能通信科技有限公司 | 一种网络视频录像与回放***和方法 |
CN104573037A (zh) * | 2015-01-16 | 2015-04-29 | 北京中电兴发科技有限公司 | 一种通过多颜色时间轴快速查询监控录像的方法及*** |
CN106162022A (zh) * | 2015-04-08 | 2016-11-23 | 深圳市尼得科技有限公司 | 一种快速播放视频的方法、***及移动终端 |
CN105430506A (zh) * | 2015-11-06 | 2016-03-23 | 浙江宇视科技有限公司 | 一种视频回放中防止报文丢失的方法及装置 |
CN106231348A (zh) * | 2016-09-19 | 2016-12-14 | 浙江宇视科技有限公司 | 一种gop数据的回放方法、装置和*** |
CN107979621A (zh) * | 2016-10-24 | 2018-05-01 | 杭州海康威视数字技术股份有限公司 | 一种视频文件的存储、定位播放方法及装置 |
CN109005447A (zh) * | 2018-08-10 | 2018-12-14 | 高新兴科技集团股份有限公司 | 一种安防高清录像倒播方法及装置 |
Non-Patent Citations (2)
Title |
---|
M. MAZIERE: "Segmentation and tracking of video objects for a content-based video indexing context", 《2000 IEEE INTERNATIONAL CONFERENCE ON MULTIMEDIA AND EXPO. ICME2000. PROCEEDINGS. LATEST ADVANCES IN THE FAST CHANGING WORLD OF MULTIMEDIA (CAT. NO.00TH8532)》 * |
石迎生: "从MPEG压缩视频流中提取I帧的设计与实现", 《中国有线电视》 * |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114302180A (zh) * | 2021-12-31 | 2022-04-08 | 深圳市创维软件有限公司 | 视频单帧播放方法、设备、服务器、***及存储介质 |
CN114302180B (zh) * | 2021-12-31 | 2024-02-06 | 深圳市创维软件有限公司 | 视频单帧播放方法、设备、服务器、***及存储介质 |
CN114945018A (zh) * | 2022-04-29 | 2022-08-26 | 中国电信股份有限公司 | 一种流媒体数据分发方法、*** |
CN114666603A (zh) * | 2022-05-06 | 2022-06-24 | 厦门美图之家科技有限公司 | 一种视频解码方法、装置、电子设备及存储介质 |
CN114666603B (zh) * | 2022-05-06 | 2024-05-03 | 厦门美图之家科技有限公司 | 一种视频解码方法、装置、电子设备及存储介质 |
CN115103209A (zh) * | 2022-06-10 | 2022-09-23 | 慧之安信息技术股份有限公司 | 实现监控视频倍速回放的方法 |
Also Published As
Publication number | Publication date |
---|---|
CN113596518B (zh) | 2022-04-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN113596518B (zh) | 一种用于提升倍速播放性能的视频存取方法 | |
CN102598688B (zh) | 流式传输经编码视频数据 | |
CN106231348B (zh) | 一种gop数据的回放方法、装置和*** | |
KR101737325B1 (ko) | 멀티미디어 시스템에서 멀티미디어 서비스의 경험 품질 감소를 줄이는 방법 및 장치 | |
JP5953307B2 (ja) | クライアント、コンテンツクリエータエンティティ及びそれらがメディアストリーミングする方法 | |
US20100198887A1 (en) | Scalable video coding (svc) file format | |
JP4598627B2 (ja) | コンテンツ編集装置及びその再生装置 | |
US20030063675A1 (en) | Image data providing system and method thereof | |
CN107979621A (zh) | 一种视频文件的存储、定位播放方法及装置 | |
US20050193138A1 (en) | Storage medium storing multimedia data, and method and apparatus for reproducing the multimedia data | |
WO2007042916B1 (en) | System and method for efficient scalable stream adaptation | |
CN110830838A (zh) | 一种安防高清录像倒播方法及装置 | |
CN101283351A (zh) | 用于媒体数据传输的方法和设备 | |
CN109168083B (zh) | 一种流媒体实时播放方法及装置 | |
JP2003114845A (ja) | メディア変換方法およびメディア変換装置 | |
CN104363403A (zh) | 一种视频监控***中视频数据的存储方法及存储设备 | |
CN112653904B (zh) | 一种基于pts与dts修改的快速视频裁剪方法 | |
US6693959B1 (en) | Method and apparatus for indexing and locating key frames in streaming and variable-frame-length data | |
EP2974323A1 (en) | Method for decreasing the bit rate needed to transmit videos over a network by dropping video frames | |
CN114979023A (zh) | 一种数据传输方法、***、电子设备及存储介质 | |
CN102196249A (zh) | 监控数据回放方法及编码器、视频管理服务器 | |
US20050025250A1 (en) | Video decoding during I-frame decode at resolution change | |
CN102118633B (zh) | 视频文件播放的方法、装置及*** | |
CN108989905B (zh) | 媒体流控制方法、装置、计算设备及存储介质 | |
CN112532991B (zh) | 一种作用于rmff格式文件的硬件解码方法 |
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 |