专栏电商日志财经减肥爱情
投稿投诉
爱情常识
搭配分娩
减肥两性
孕期塑形
财经教案
论文美文
日志体育
养生学堂
电商科学
头戴业界
专栏星座
用品音乐

视频清晰度优化指南

  一、背景介绍
  随着移动互联网的深入发展,视频消费场景逐渐变成主流,早期由于手机硬件的限制问题,导致生产出来的视频画质、清晰度存在较大的问题,用户体验不太好,当时的网络也处于4G的发展阶段,网络的限制也无法持续支持高清视频的消费,但是现在5G发展地如火如荼,网络的高速发展,手机硬件性能的提升,用户越来越不满足于低画质和低清晰度的视频。提升视频的画质和清晰度势在必行,需要一套行之有效提升视频清晰度的优化方案。
  二、评价标准
  做一件事情之前,首先需要确定一下评价这件事情的标准。所以在提出视频清晰度优化方案之前,必须先确定一下衡量视频清晰度的评价准则。评价视频清晰度有两种准则:
  2。1客观标准
  客观标准就是利用算法计算视频画面质量分,同等条件下,如果A视频的质量分得到高于B视频,说明A视频的保真质量做得比B视频更好。评估视频质量的算法有两大类:
  完全参考:两个视频逐帧对比分析,计算对比的质量,这种使用的比较多,常见的VMAF、PSNR、SSIM都是完全参考。
  部分参考:截图视频中的部分帧来对比分析。有些场景例如直播没法完全对比,截取部分帧来对比是比较科学的。
  目前Netflix推出的VMAF算法是评价视频质量的主流算法,下面我们简单介绍一下:
  VMAF全称VideoMultimethodAssessmentFusion,它借助人类视觉模型以及机器学习来评估一个视频的质量。
  VMAF的评价指标主要包含:其中VIF和DLM是空间域的,表示一帧画面之内的特征;TI是时间域的,表示多帧画面之间的相关性特征。
  视频信息保真度(VIF:VisualQualityFidelity)细节损失指标(DLM:DetailLossMeasure)时域运动指标平均相关位置像素差(TI:TemporalInformation)
  VMAF基于SVM的nuSvr算法,在运行的过程中,根据事先训练好的model,赋予每种视频特征以不同的权重,对每一种画面都生成一个评分,最终以均值算法进行归总,算出该视频的最终评分。
  VMAF计算出的分数范围是0100,其中0表示最低质量,100表示最高质量,后续对比的时候只给出分数。
  2。2主观标准
  客观标准固然重要,但是视频是给人看的,最终视频的质量好不好,还需要用户主观感受。换言之,两个视频的VMAF可能相近,但是用户观感可能会不一样,有些用户喜欢柔色,有些用户喜欢暖色。
  主观标准操作起来比较简单,找几个视频,让用户观看之后主观给出评价,视频A和视频B的质量对比如何,这种输出的结果比较准确,但是工作量比较大,不好大范围推广。所以根据项目要求,在特定的时候采用客观评价标准,在某些场景采用主观评价标准。
  例如下面两张图片,它们的VMAF值是相近的,但是第二张看上去明显比第一张画质好多了,而且更加明亮,这并没有改变图片的编码结构,只是对画面本身进行一些调色处理(这个我们下面会单独拎出来讲),就能明显提升主观感受。所以评价视频质量需要综合主观标准和客观标准综合来判断。而且我们建议在有条件的情况下,主观标准更加重要,因为客观标准只是模拟人眼的视觉系统,和真实的场景还是有所差距。
  三、基础优化
  通过上面的描述我们基本了解了视频质量的评价标准,但如果要提升视频质量,这些还不够,我们还需要介绍一下视频的基本属性,以及这些属性可以在多大程度上影响视频的质量。
  我们首先使用MediaInfo来查看一下视频的属性,由于重点关注画质,所以就自动忽略封装格式和音频流信息,只关注视频轨道信息:VideoID:1Format:AVCFormatInfo:AdvancedVideoCodecFormatprofile:HighL3。1Formatsettings:CABAC4RefFramesFormatsettings,CABAC:YesFormatsettings,Referenceframes:4framesCodecID:avc1CodecIDInfo:AdvancedVideoCodingDuration:2min41sBitrate:634kbsBitratemode:CBRWidth:960pixelsHeight:540pixelsDisplayaspectratio:16:9Frameratemode:ConstantFramerate:25。000FPSColorspace:YUVChromasubsampling:4:2:0Bitdepth:8bitsScantype:ProgressiveBits(PixelFrame):0。049Streamsize:12。2MiB(94)Writinglibrary:x264core148Encodingsettings:cabac1ref3deblock1:0:0analyse0x3:0x113mehexsubme7psy1psyrd1。00:0。00mixedref1merange16chromame1trellis18x8dct1cqm0deadzone21,11fastpskip1chromaqpoffset2threads17lookaheadthreads2slicedthreads0nr0decimate1interlaced0bluraycompat0constrainedintra0bframes3bpyramid2badapt1bbias0direct1weightb1opengop0weightp2keyint75keyintmin7scenecut40intrarefresh0rclookahead40rccrfmbtree1crf26。0qcomp0。60qpmin0qpmax69qpstep4vbvmaxrate800vbvbufsize1600crfmax0。0nalhrdnonefiller0ipratio1。40aq1:1。00Codecconfigurationbox:av
  其中有几个非常重要的属性需要特别关注一下:下面我们列出的各个属性都是基于其他条件不变的情况下,只改变当前属性。例如谈Profile,就要保证其他的属性是相同的,只有Profile不同,这样比较视频的画质才有意义。
  3。1Profile
  Profile对应上面的是EncoderProfileLevel,正常情况下,ProfileLevel有三种类型:
  BaselineProfileMainProfileHighProfile
  其中BaselineProfile对应清晰度最低,Android3。0之后的版本都支持的,MainProfile清晰度比BaselineProfile清晰度要好,但是从Android7。0之后才支持,HighProfile清晰度最高,也是从Android7。0之后才支持。我们在设置EncoderProfileLevel之前,需要判断一下当前是否支持。
  3。2Bitrate码率
  视频码率是视频数据传输时单位时间内传送的数据位数。单位是kbps,望文生义,码率越大,单位时间填充的数据就越多,视频质量就越高。
  码率并不是越大越好,码率设置超过一定的大小,对视频画质的提升已不太明显,肉眼已经看不出区别,但是视频大小会增加很多。所以设置合适的码率就行。通常建议的码率计算方式是:BitratewidthheightframeRatefactorfactor0。15
  按照上面的公式设置的码率是比较合适的,当然如果想要更加高清的,可以适当增加factor大小。
  3。3BitrateMode
  码率虽然设置了,但是码率是描述一段时间的平均传输的数据位数,无法保证每一个时间段内传送的数据大小是固定的或者在一个固定的范围内。还有一个BitrateMode参数来表示码率模式。它也有三种类型:
  VBR:可变码率(VariableBitrate),此编码方式会根据帧间数据的变化量大小来动态调整码率,如果帧间的运动变化比较大,调高码率,如果帧间的运动变化比较小,调小码率。从编码方式就可以看出来,这样的编码方式有两个缺点:(1)运动预测计算算法有一定的耗时,编码时间较长;(2)码率多变,最终生成的文件大小不可预测。可能很大也可能很小。
  CBR:固定码率或者常数码率(ConstantBitrate),这是默认的编码方式,使用此编码方式,文件从始至终的编码码率会固定不变或者基本不变。这种方式的好处是文件大小是确定的,不会出现文件大小不可预测的情况。但是缺点也很明显,有时候帧间变化比较大,有时候帧间变化比较小,如果都使用同样的码率,帧间变化比较大的时间画质会比较一般,帧间变化比较小的时间显得浪费。无法做到较好的平衡。
  ABR:平均码率(AverageBitrate),平均码率较好地兼顾了VBR和CBR的,在帧间变化比较大的时间使用较大的码率,在帧间变化比较小的时间采用较小的码率,最终保证整体采用的码率固定就可以了。较好的处理了画质和文件大小之间的矛盾。
  但是很可惜的是MediaCodec并不支持ABR,我们如果想采用ABR模式的话还需要使用软编码。MediaCodec也提供了三种模式:
  BITRATEMODECQ:这种模式是全面考虑视频质量,尽可能保证视频质量,所以编码出来的视频都很大,并不可取。BITRATEMODEVBR:同上面的VBRBITRATEMODECBR:同上面的CBR
  众所周知,硬编码速度要远远快于软编码,所以编码都是优先采用硬编码,硬编码失败再采用软编码兼容。所以硬编码MediaCodec建议采用BITRATEMODECBR模式,切换到软编码采用VBR模式。
  3。4B帧设置
  视频由I帧、P帧、B帧三种类型的视频帧组成的。
  I帧是帧内图像帧,就是关键帧,意思是此帧不需要依赖其他的帧就可以进行编码或者解码。
  P帧是前向预测图像帧,此帧需要参考在它之前的I帧或者P帧,采用运动预测的方式进行帧间编码或者解码。P帧大小相当于I帧大小的110120。
  B帧是双向预测图像帧,此帧需要参考在它之前的I帧或者P帧,也需要参考在它之后的I帧或者P帧,采用运动预测的方式进行帧间预测编码或者解码。
  GOP表示两个I帧之间的图像帧序列,GOP2s,表示两个I帧之间的间隔是2s。
  Android平台只有高通部分芯片支持B帧编码,并且Android系统也没有开发设置B帧的接口,所以对使用AndroidMediaCodec编码的开发者而言,无法开启B帧编码(iOS是可以的,暗自垂泪)。当然软编码是可以设置B帧的。
  设置B帧有什么好处?
  B帧大小约是I帧大小的150,如果设置了B帧了,并不会降低清晰度,但是可以大大降低视频的大小,这样我们就可以相应地调大码率,最终实现了提升清晰度的目标。
  当然设置了B帧之后,增加了编码和解码的复杂度,这点开发者在设置的时候必须要有充分的认识。
  四、HEVC编码
  目前H。264编码还是使用最广泛的编码方式,主要还是H。264编码的兼容性比较好,而且免费开源。HEVC自从2013年第一版发布开源出来,还没有完全替代H。264(主要原因是收费,而且部分机型可能不支持),不过HEVC凭借其独特的优势也得到了较多地应用。
  HEVC相对H。264的优势:
  HEVC标准视频的帧内预测模式支持33种方向,并且提供了更好的运动补偿处理和矢量预测方法。而H。264只支持8种。
  HEVC采用了块的四叉树划分结构,采用了8x864x64像素的自适应块划分,而H。264每个宏块的大小都是固定的16x16像素,HEVC的这样设计可以保证在不同的帧间和帧内复杂程度中可以动态调整宏块的大小,经过测试发现,在相同的图像质量下,HEVC编码的视频比H。264编码的视频约减少40,换言之,如果HEVC和H。264码率相同,那么HEVC编码的视频比H。264编码的视频要清晰地多。
  上图可以看出同样的视频帧,HEVC使用的宏块比H。264要少很多,体现了HEVC的优势。
  分辨率
  H。264AVC
  H。265HEVC
  480p
  1。5Mbps
  0。75Mbps
  720p
  3Mbps
  1。5Mbps
  1080p
  6Mbps
  3Mbps
  4k
  32Mbps
  15Mbps
  我们在使用MediaCodecHEVC硬编码时,需要判断一下当前是否支持HEVC编码,Android5。0已经支持了HEVC,不过一些低端芯片可能还是没有支持HEVC,我们在编码之前需要判断一下是否支持。
  使用HEVC编码,可以保证在不增加文件大小的情况下,大大提升视频的清晰度。
  上图是H。264编码,下图是HEVC编码。
  五、色彩调优
  上面的几种优化方式都是在编码层面调整参数或者直接改变编码方式来提升视频的画质,但有一种方式通过调整视频画面的色值综合调整亮度、对比度、色温、饱和度、锐度等颜色参数,进而优化整体的视频画面,让视频画面看上去更清晰。
  我们经常用到的颜色空间有RGB颜色空间、HSV颜色空间、YUV颜色空间还有CIELab颜色空间,其中RGB颜色空间使用的比较广泛。如上图,图像分为三个通道量:R分量、G分量、B分量,每个分量的值是0255,三个分量共同组成一个颜色的RGB值。RGB分量的值分布构成了颜色色值的直方图,我们通过调节RGB值来调节图像的颜色。
  有几种对颜色色值的调节方式,对我们理解颜色调节有很大的帮助:
  亮度:亮度表示人眼对发光体或被照射物体表面的发光或反射光强度实际感受的物理量,简而言之,RGB分量越大,图像就越亮;反之,图像越暗。对比度:图像对比度是指图像中从黑色到白色渐变的层次反差或比值。反差越大,比值越大,从视觉上感知,图像就越清晰醒目,对比度越大;反差越小,比值越小,从视觉上感知,图像越不清晰醒目,蒙尘感越强,对比度越小。色温:色温和温度还真有一定的关系,表示绝对黑体从绝对零度开始加热之后呈现的颜色。从我们生活中来看,暖色调看上去比较温馨,冷色调感受上有点清凉。饱和度:饱和度是指色彩的鲜艳程度或者纯度。饱和度越高,图像色彩越鲜艳,色彩纯度越高;反之则越低,直至灰度图。锐度:锐度主要用来表示图像边缘的对比度,由于人类感官,高锐度的图像看起来更加清晰,图像上的细节对比非常明显。
  我们可以将上面五种调节方式综合起来调节图片色彩。
  亮度增加10个点(100100)色温增加5个点(100100)饱和度增加20个点(0100)锐度增加15个点(0100)
  第一张是原图,第二张是经过颜色调节之后输出的图片。
  六、超分算法
  上面提到的优化方式无论从编码层面,还是从颜色调节层面,都算是基本的优化方式,近年来,随着机器学习的火热,超分算法越来越广泛地应用到图像和视频处理上来。超分辨率就是指通过机器学习地方式重建图像,达成提升图像分辨率的效果。
  目前比较成熟的超分技术是RealESRGAN,基于BasicSR,采用ESRGAN算法,利用机器学习的优势对图片和视频进行去模糊、Resize、降噪、锐化等处理,重建图片,实现对图片的超分辨率处理。
  ESRGAN算法的三个步骤:
  特征提取:计算噪点非线性映射:放大,模糊化噪点图像重建:差分,平滑过度,去噪
  相对之前的SRCNN等超分算法,改进了如下几点:
  改进感知损失,提高输出图像的边缘清晰度和纹理真实性。利用对抗网络的优势不断反馈改进GAN判别器,预测高分辨率图像和原始图像之前的相对真实性而不是绝对真实性。可以恢复原始图像的真实的纹理细节。优化了模型的稳定性,每次生成的图片都和原图片残差对比,进行矫正训练,最终得到的结果非常稳定。
  下面是超分前后的对比结果:大家可以点击大图对比一下细节,可以看出超分之后的图片精细化很多,去掉模糊的地方、降低图片的噪点。
  七、总结
  本文结合当下视频的痛点(清晰度问题),提出衡量视频清晰度的标准主观标准和客观标准,指明了视频清晰度的优化目标和方向,根据视频的基本特征(码率、GOP、编码模式等)提出基础优化的方法,在基础优化的基础上提出高级编码方式(相对H。264编码方式),再结合目前主流的视频色彩滤镜提出视频色彩调优方案,让视频看上去更清晰。最终的大杀器超分算法采用ESRGAN方式进行放大、降噪、重建帧来提升视频清晰度。希望上面这些方法可以给大家带来一些帮助,对提升视频清晰度有更进一步的思考。
  参考文章:VMAF开源项目https:github。comNetflixvmaf揭秘VMAF视频质量评测标准https:xie。infoq。cnarticle26aaf2ab83f56192a65ba22eaNetflixVMAF视频质量评估工具概述https:zhuanlan。zhihu。comp94223056B帧对视频清晰度码率的影响https:blog。csdn。netmatrixlaboratoryarticledetails82726897H264vsH265https:www。cnblogs。comwujianming110117p12640533。html超分开源项目https:github。comxinntaoRealESRGAN
  作者:JeffMony
  来源:微信公众号:得物技术
  出处:https:mp。weixin。qq。comsYHfAjrMGN7nGLtrLEFEw

GQ报道走,去安吉看不坐班的年轻人1997年,时任日立CEO的牧本次雄首次提出数字游民(DigitalNomads)的概念,用来形容依靠互联网工具而摆脱了地域限制的工作者。据统计,全球有约3500万数字游民,聚集在快览预计今年全球客运量将恢复至2019年的92(第104期)关注DFE,关注中国免税投稿广告业务合作dfeidutyfree。cnDFE资讯快览(据Dfnionline报道)据国际机场理事会(ACI)公布的最新数据显示,2022年全球客运量毕业游记二从神农架到三峡D57。27襄阳神农架昨天下午一路从洛阳赶到襄阳,一路经过新野隆中檀溪等地,都是在三国演义小说里耳熟能详的地名。襄阳和南阳离得不远,难怪南阳人诸葛亮住在襄阳隆中呢。从隆中出口下高速来咯!武夷山度假区漫步道上的赏花图鉴,get!经过一年的等待与期盼武夷山度假区的春天远道而来崇溪漫步道作为度假区内的天然氧吧绿色连廊最美网红漫步道延伸于山水之间,一吸一呼尽是负氧离子也将美丽的花儿们收集于此在这个春天,即将迎来临沂推出13条旅游专列精品线路助力文旅市场强劲复苏快旅慢游成新趋势记者从24日召开的临沂车务段2023年客运旅游产品合作交流会上了解到,在全国疫情防控形势持续向好旅游市场稳步复苏背景下,乘坐旅游专列快旅慢游成为旅游新趋势。今年,临沂车务段推出研学梅好时光,我想开了!预报春消息,花中第一枝。嘉定这些诗意赏梅地花开正艳,跟随小嘉一起遇见梅好在嘉定镇街道南城墙旁秋霞圃内环城河边梅花已竞相绽放,疏影横斜暗香浮动。拍摄地南城墙公园拍摄地秋霞圃拍摄地环城金三角与缅北罪恶之城的前世今生金三角有那么可怕吗?金三角位于东南亚三国交界之处,曾经是世界最大罂粟产区,军阀统治下老百姓被打伤打残,被迫种植罂粟。图片来源网络图片来源网络金三角民族地区斗争激烈,儿童被剥夺上学的广东省茂名市神秘和诡异的一些地方,你去过几个?茂名市位于广东省西南部,有着悠久的历史和丰富的文化遗产。以下是茂名市神秘和诡异的一些地方数据来源于chatgpt广东省茂名市电白区的小榄村广东省茂名市电白区的小榄村。据传说,这个村国家一级保护动物白颈鸦现身仙女湖2月23日,一只国家一级保护动物白颈鸦在仙女湖景区觅食。只见这只白颈鸦停留在码头广场上,并不怕路过的陌生人,路人靠近拍摄时,它也不惊慌。一只拥有大熊猫配色的乌鸦俗话说天下乌鸦一般黑万字详谈SpringBoot多数据源以及事务处理背景在高并发的项目中,单数据库已无法承载大数据量的访问,因此需要使用多个数据库进行对数据的读写分离,此外就是在微服化的今天,我们在项目中可能采用各种不同存储,因此也需要连接不同的数民生沸点建议监督八小时工作制执行?政协委员发言引热议1建议监督八小时工作制执行?政协委员发言引热议近日,全国政协委员蒋胜男建议对企事业单位8小时工作制执行情况加强监督,引发社会热议。蒋胜男,温州大学人文学院研究员著名编剧和网络作家芈
大家知道吗,奔驰也推出了好多款电动汽车奔驰都不陌生,但是电动奔驰大家知道有哪些吗?不得不说,由于各种原因新能源汽车越来越火,传统燃油车的优势也越来越少了。不能说燃油车不好,只是新能源汽车的降维打击实在是太厉害了。当然很带你快速了解人工智能头号有新人人工智能(ArtificialIntelligence,简称AI)是研究开发用于模拟延伸和扩展人的智能的计算机科学领域。人工智能研究包括计算机视觉自然语言处理机器学习专家毕业设计谁的大学没有一个万年历(基础款分享)本次分享的毕设是一个难度系数比较低的51单片机时钟万年历。如果你是零基础的话,是非常适合入手的。如果作为毕设的话,部分院校应该比较难通过,但是在此基础上可以添加更多的功能,让作品的早上洗头容易掉发?没这个说法头发油腻还总脱发,每次洗头就掉一大把,这跟洗头的时间有关系?网传早上起来洗头容易脱发,是因为身体还并没有完全的苏醒,洗头发的话就会刺激身体当中的循环加速,就会出现脱发或者是头痛的情陆军军官学校二十一期十一大队四十一中队一代黄埔人,情倾黄埔魂。华夏大地留下无数先辈们奋斗的足迹,流传着感人的故事,展示历史更多历史痕迹,追寻更多黄埔记忆。中央陆军军官学校二十一期成都北校场督练区步兵第六大队十一大队工兵女知青被领导诬陷,她枪杀三人后数万群众为她求情,结局如何?知青岁月对于上个世纪五六年代的人来说是一段难忘的岁月。他们将大好的青春都奉献在这片土地上,而对于女知青蒋爱珍来说更是难以忘记。随着四声枪响,她的人生轨迹也发生了变化,蒋爱珍杀了人,昆阳之战刘秀以少胜多真的是因为天降陨石吗?真正的胜负手是什么昆阳之战是光武帝刘秀的成名之战,也是玄汉政权推翻新莽政权的定鼎之战,所以这次战争在历史上的地位和意义都十分重要。再加上这次战争自带以弱胜强以少胜多的传奇剧本,还有天降陨石这样的玄幻惜才爱才不仅指善待人才,更是不要因为某些谣言而否定人才刘邦巧识陈平陈平的故乡户牖是一片黄土的农村,土质贫瘠,农产很不丰足,地势蜿蜒曲折。陈平的家在村子的最外围。陈平双亲早故,兄长陈伯耕种了三十亩旱地。长得斯文俊雅的陈平总想为哥哥分担一产品齐放痛点待解,机构如何输送新养料?不断升温的教育信息化和课后服务赛道,正酝酿着怎样的变革?撰文张子悦12月22日,由蓝鲸教育主办,中关村互联网教育创新中心特别支持的2022第六届蓝鲸教育大会,在中关村互联网教育创新成熟但不成型明代的盐法道的创立与发展(一)文南破青丝蛊编辑南破青丝蛊前言盐法道,又名盐路,是一种专门从事盐务工作的地方,始于明朝,清朝一直延续至今。前人对明朝盐法道的研究,大多只注重于明清两朝的道制问题,而忽略了盐法道的详香港乐坛教父逝世!网友辉黄组合天堂相聚香港著名音乐家顾嘉辉于1月3日逝世,享年92岁。他是粤语流行曲最重要的创作人之一,有香港乐坛教父之称。顾嘉辉顾嘉辉于1933年出生于广州,他擅长作曲编曲及指挥,被视为香港粤语流行曲
友情链接:快好找快生活快百科快传网中准网文好找聚热点快软网