CN116438794B - 图像压缩方法、装置、电子设备、芯片及储存介质 - Google Patents
图像压缩方法、装置、电子设备、芯片及储存介质 Download PDFInfo
- Publication number
- CN116438794B CN116438794B CN202280004643.6A CN202280004643A CN116438794B CN 116438794 B CN116438794 B CN 116438794B CN 202280004643 A CN202280004643 A CN 202280004643A CN 116438794 B CN116438794 B CN 116438794B
- Authority
- CN
- China
- Prior art keywords
- code rate
- scanning line
- current
- line
- upper limit
- 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
Links
- 238000007906 compression Methods 0.000 title claims abstract description 262
- 230000006835 compression Effects 0.000 title claims abstract description 244
- 238000000034 method Methods 0.000 title claims abstract description 77
- 230000003247 decreasing effect Effects 0.000 claims description 19
- 230000004044 response Effects 0.000 claims description 9
- 230000009467 reduction Effects 0.000 claims description 6
- 238000004590 computer program Methods 0.000 claims description 2
- 230000008569 process Effects 0.000 abstract description 12
- 230000010355 oscillation Effects 0.000 abstract description 8
- 238000004364 calculation method Methods 0.000 abstract description 3
- 238000012545 processing Methods 0.000 description 13
- 238000004891 communication Methods 0.000 description 10
- 230000008859 change Effects 0.000 description 7
- 238000005516 engineering process Methods 0.000 description 6
- 238000013139 quantization Methods 0.000 description 6
- 238000010586 diagram Methods 0.000 description 5
- 230000000694 effects Effects 0.000 description 5
- 230000003287 optical effect Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 230000001133 acceleration Effects 0.000 description 3
- 238000013473 artificial intelligence Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000006978 adaptation Effects 0.000 description 2
- 230000003044 adaptive effect Effects 0.000 description 2
- 238000013459 approach Methods 0.000 description 2
- 230000000712 assembly Effects 0.000 description 2
- 238000000429 assembly Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000002474 experimental method Methods 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 238000005070 sampling Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/146—Data rate or code amount at the encoder output
Abstract
本公开提供一种图像压缩方法、装置、电子设备、芯片及储存介质,所述方法包括:根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。通过本公开所述方案,避免了依赖经验信息对压缩参数进行控制,并将码率限制在码率范围内,减少码率震荡,使压缩损失更均匀,提升全图的无损概率。此外,由于不涉及复杂计算过程,可以减小设备的运算压力。
Description
技术领域
本公开涉及图像压缩技术领域,尤其涉及一种图像压缩方法、装置、电子设备、芯片及储存介质。
背景技术
当前,基于JPEG-LS标准(用于连续色调图像无损压缩的静态图像压缩标准)的图像压缩方法,需要通过当前扫描行的压缩状态对邻近扫描行的待压缩像素进行残差预测,并对残差进行量化处理以对量化后的残差进行编码压缩。
由于常规模式下,需要以经验值确定的压缩参数对图像的扫描行进行压缩编码,而由于图像中不同扫描行生成的预测残差与真实值的偏离程度不同,通过同一压缩参数进行压缩会使每一扫描行压缩后的码流长度出现无规律的波动,引起码率震荡,使图像压缩损失不均匀,难以控制图像压缩后的画质损失。
发明内容
有鉴于此,本公开提供一种图像压缩方法、装置、电子设备、芯片及储存介质,以至少解决相关技术中存在的技术问题。
根据本公开实施例的第一方面,提供了一种图像压缩方法,所述方法包括:
获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度;
根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率;
根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数;
根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
结合本公开的任一实施方式,所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
在所述当前扫描行的预测码率大于码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
响应于当前扫描行数大于第一行数阈值 ,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,在所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,还包括:
响应于当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值 ,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整;
所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整,包括:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
结合本公开的任一实施方式,所述方法还包括:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
结合本公开的任一实施方式,在所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,还包括:
响应于当前扫描行数大于第二行数阈值 ,根据当前扫描行对应的衰减因子,对当前的码率范围的上限进行调整,所述衰减因子用于控制所述码率上限收敛至设定目标码率;
所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述方法还包括:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
结合本公开的任一实施方式,所述方法还包括:
根据当前扫描行数和所述第二行数阈值,确定所述衰减因子。
结合本公开的任一实施方式,所述根据当前扫描行数和所述第二设定阈值,确定所述衰减因子,包括:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
结合本公开的任一实施方式,所述方法还包括:
响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
根据本公开实施例的第二方面,提供了一种图像压缩装置,所述装置包括:
参数获取模块:用于获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度;
码率预测模块:用于根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率;
参数确定模块:用于根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数;
压缩模块:用于根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
在所述当前扫描行的预测码率大于码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
响应于当前扫描行数大于第一行数阈值,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,所述装置还包括范围调整模块,用于:
响应于当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整;
所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整过程中,具体用于:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
结合本公开的任一实施方式,所述装置还包括范围限制模块,用于:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
响应于当前扫描行数大于第二行数阈值,根据当前扫描行对应的衰减因子,对当前的码率范围的上限进行调整,所述衰减因子用于控制所述码率上限收敛至设定目标码率;
所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述装置还包括第二行数阈值确定模块,用于:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
结合本公开的任一实施方式,所述装置还包括衰减因子确定模块,用于:
根据当前扫描行数和所述第二行数阈值,确定所述衰减因子。
结合本公开的任一实施方式,所述衰减因子确定模块在根据当前扫描行数和所述第二行数阈值,确定所述衰减因子过程中,具体用于:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
结合本公开的任一实施方式,所述装置还包括范围确定模块,用于:
响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
根据本公开实施例的第三方面,提供了一种电子设备,包括:
存储器,用于存储所述处理器可执行指令;
处理器,被配置为执行所述存储器中的可执行指令以实现上述第一方面任一实施方式所述方法的步骤。
根据本公开实施例的第四方面,提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述第一方面任一实施方式所述方法的步骤。
根据本公开实施例的第五方面,提供一种芯片,包括:
一个或多个接口电路和一个或多个处理器;所述接口电路用于从电子设备的存储器接收信号,并向所述处理器发送所述信号,所述信号包括存储器中存储的计算机指令;当所述处理器执行所述计算机指令时,使得所述电子设备执行上述第一方面任一实施方式所述的图像压缩方法。
本公开实施例提供的技术方案可以包括以下有益效果:
基于当前扫描行的压缩状态,得到以当前压缩参数压缩剩余扫描行后全图的预测码率,并通过设置码率范围,结合预测码率以调整下一扫描行的压缩参数,使每一扫描行都能够对下一扫描行的压缩参数进行及时调整,使得基于压缩参数压缩后的码率控制在码率范围内。避免依赖经验信息对压缩参数进行控制,减少码率震荡,使压缩损失均匀可控,提升了全图的无损概率。此外,由于不涉及复杂计算过程,可以减小设备的运算压力。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是本公开根据一示例性实施例示出的一种图像压缩方法流程图;
图2是本公开根据一示例性实施例示出的一种压缩参数调整流程图;
图3是本公开根据一示例性实施例示出的一种第二行数阈值确定流程图;
图4是本公开根据一示例性实施例示出的一种图像压缩效果对照图;
图5是本公开根据一示例性实施例示出的一种图像压缩装置示意图;
图6是本公开根据一示例性实施例示出的一种电子设备框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
在本公开使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本公开。在本公开和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
应当理解,尽管在本公开可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本公开范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
图1示出了本公开根据一示例性实施例示出的一种图像压缩方法流程图。
在步骤S101中,获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度。
所述压缩参数用于反应图像的压缩程度,与压缩后扫描行的码流长度和码率负相关。在当前扫描行中,通过当前的压缩参数对图像当前扫描行的像素进行压缩,以获取当前扫描行压缩后的码流长度。同样的,在图像首行至当前扫描行的扫描压缩过程中,通过每行对应的压缩参数对图像进行压缩,得到首行至所述当前扫描行的码流总长度。在JPEG-LS标准中,通过Golomb编码器对量化后的预测残差进行编码,可以通过量化步长表征所述压缩参数。量化步长大,表示当前扫描行的压缩程度高,量化步长小,表示当前扫描行的压缩程度低。对于同一扫描行,通过更大的量化步长压缩后的码流长度更小。
在步骤S102中,根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率。
所述当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,用于表示在当前扫描行及全部历史扫描行的压缩状态。所述预测码率是基于截止当前扫描行的压缩状态,推算得到的以当前压缩参数压缩剩余扫描行后全图的最终码率。在一个示例中,所述预测码率可以通过公式(1)确定:
(1)
其中,p表示所述预测码率,H表示图像的总行数,h表示当前扫描行的行数,可以通过当前所在行索引获取,H-h表示图像的剩余未扫描行数,表示当前扫描行的码流长度,/>表示首行至所述当前扫描行的码流总长度。公式(1)的分子部分表示基于当前的压缩参数压缩剩余扫描行后全图的最终码流长度。
H和W分别表示图像基于高度和宽度的像素量,P表示图像的比特位宽,用于表示图像中每个像素的信息量。公式(1)中的分母部分表示图像的总信息量。
通过计算预测码流长度在图像中总信息量的占比,可以获取所述预测码率。
在步骤S103中,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
所述码率范围用于限制所述预测码率的波动程度,可以通过图像的设定目标码率或多次实验确定。所述码率范围可以包括所述预测码率的上限和/或下限。在一个示例中,可以在所述预测码率超出所述码率范围的情况下,通过调整下一扫描行的压缩参数提升或降低预测码率,以使所述预测码率回归至所述码率范围。
在步骤S104中,根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
可以控制压缩编码通过调整后的下一扫描行的压缩参数,对下一个扫描行的像素进行编码压缩。在JPEG-LS标准中,可以通过Golomb编码器基于调整后的量化步长对量化后的预测残差进行编码。
本公开所述方案,通过基于当前扫描行的压缩状态,得到以当前压缩参数压缩剩余扫描行后全图的预测码率,并通过设置码率范围,结合预测码率以调整下一扫描行的压缩参数,实现每一扫描行都能够对下一扫描行的压缩参数进行及时调整,使得基于压缩参数压缩后的码率控制在码率范围内。避免了依赖经验信息或图像本身内容特性对压缩参数进行控制,减少码率震荡,使压缩损失均匀可控,提升了全图的无损概率。此外,由于不涉及复杂计算过程,可以减小设备的运算压力。
在一个可选的实施例中,所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
在所述当前扫描行的预测码率大于码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
可选的,当前扫描行的预测码率超出所述码率上限,表示当前扫描行的压缩程度过小,可以通过提升下一个扫描行的压缩参数,即提升下一个扫描行的压缩程度,以降低下一个扫描行的码率,使在对下一扫描行进行压缩的过程中的码率不超出所述码率上限。
同样的,当前扫描行的预测码率低于所述码率下限,表示当前扫描行的压缩程度过大,可以通过降低下一个扫描行的压缩参数,即降低下一个扫描行的压缩程度,以提升下一个扫描行的码率,以使在对下一扫描行进行压缩的过程中的码率不低于所述码率下限。
图2示出了本申请公开根据一示例性实施例示出的一种压缩参数调整流程图。
在步骤S201中,判断所述预测码率是否大于码率上限。
在步骤S202中,在所述预测码率大于所述码率上限的情况下,可以判断当前的压缩参数是否大于压缩参数阈值,以确定当前的压缩过程是否处于常规压缩模式,在一个示例中,所述压缩参数阈值可以设置为15。
在步骤S203中,在当前压缩过程处于常规压缩模式的情况下,提升所述压缩参数。
在步骤S204中,判断所述预测码率是否小于码率下限。
在步骤S205中,在所述预测码率小于所述码率下限的情况下,可以判断当前的压缩参数是否小于0,以确定当前是否处于压缩过程,也即确定当前的压缩过程是否处于常规压缩模式。
在步骤S206中,在当前压缩过程处于常规压缩模式的情况下,降低所述压缩参数。
在步骤S207中,在所述预测码率在码率范围内的情况下,可以保持当前压缩参数。此外,在当前不处于常规压缩模式的情况下,也可以通过保持当前压缩参数的方法等待进一步处理。
在一个示例中,可以通过对压缩参数加1的方式提升所述压缩参数,通过对压缩参数减1的方式降低所述压缩参数,以确保相邻扫描行的压缩参数变化量控制在1或0,避免由于压缩参数的骤增或骤降使压缩后的图像有明显的压缩损失,从而保证图像中压缩强度的均匀过度。
本公开所述方案,通过比较当前扫描行的预测码率与码率范围,及时调整压缩参数,以使下一扫描行的码率控制在码率范围内,同时,通过限制所述压缩参数每次的调整量,避免压缩后的图像有明显的压缩损失,从而保证图像中压缩强度的均匀过度。
在一个可选的实施例中,所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
响应于当前扫描行数大于第一行数阈值 ,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
可选的,由于在图像刚刚启动扫描压缩过程时,无法确定所述扫描范围的选取是否合理,且前几行没有足够的历史信息,若由于图像复杂程度过大导致图像不同扫描行的码率由于客观原因存在较大波动,选取过小的码率范围可能会导致所述压缩过程无法正常运行,因此可以在确定所述码率范围前,先对第一行数阈值前的扫描行进行无码率范围限制的压缩,再根据所述图像的压缩状态确定所述码率范围,在一个示例中,所述第一行数阈值为10。
在一个示例中,响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
所述设定目标码率表示用户希望对当前图像压缩后的最终码率。所述设定范围系数可以根据第一行数阈值前的扫描行的压缩状态确定。例如,将110%的设定目标码率确定为所述码率上限,将95%的设定码率范围确定为所述码率下限,以确保图像压缩过程中的码率始终围绕所述设定目标码率波动。
本公开所述方案,通过先对第一行数阈值及其之前的扫描行进行无码率范围限制的压缩,再根据所述图像的压缩状态确定所述码率范围,保证所述压缩范围的合理选取。此外,根据目标设定码率和范围系数确定所述码率范围,以确保图像压缩过程中的码率始终围绕所述设定目标码率波动。
在一个可选的实施例中,在所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,还包括:
响应于当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值 ,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围上限进行调整;
所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
可选的,在所述当前扫描行数大于第一行数阈值的情况下,在所述当前扫描行前存在若干历史扫描行,可以根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,获取最近部分扫描行的预测码率变化趋势,并根据所述变化趋势自适应调整所述码率范围。
在一个示例中,具体的码率范围调整方法包括:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
可选的,在基于JPEG-LS标准对图像进行压缩的过程中,由于存在码率小幅震荡,整体预测码率变化随行数增加通常呈现W型或M型,即在第N个扫描行的预测码率小于相邻扫描行的预测码率的情况下,第N+1个扫描行的预测码率大于相邻扫描行的预测码率,可以通过相隔扫描行的预测码率变化趋势确定最近扫描部分的码率变化趋势。在根据当前扫描行及其前2个扫描行确定所述待检测预测码率的情况下,可以将所述当前扫描行与距其前2行对应的2个预测码率确定为所述待检测预测码率;在根据当前扫描行及其前5个扫描行确定所述待检测预测码率的情况下,可以将所述当前扫描行与距其前2行和前4行对应的3个预测码率确定为所述待检测预测码率,或将距当前扫描行前1行、前3行和前5行对应的3个预测码率确定为所述待检测预测码率,并根据所属待检测预测码率的增减趋势确定所述码率上限的调整方式。在一个示例中,可以固定将当前扫描行相邻的前5个扫描行对应的预测码率确定为所述待检测预测码率,在结束对当前扫描行的扫描压缩后,自动向下一行移动所述历史扫描行的选取范围,将下一扫描行的前5个扫描行对应的预测码率确定为所述待检测预测码率。
在所述预测码率依次递增的情况下,表示最近扫描部分的码率呈增加趋势,间接表示当前扫描部分为图像的复杂纹理区域,可以通过提升所述码率上限,允许在当前区域以较小的压缩参数进行压缩,以在纹理复杂区域分配更多的码流长度。
在所述预测码率依次递减的情况下,表示最近扫描部分的码率呈下降趋势,间接表示当前扫描部分为图像的简单纹理区域,可以通过降低所述码率上限,允许在当前区域以较大的压缩参数进行压缩,以在简单纹理区域分配更少的码流长度。
本公开所述方案,通过根据最近部分扫描行的码率变化趋势自适应调整码率范围,以使压缩过程中,在复杂纹理区域分配更多的码流长度,在简单纹理区域分配更少的码流长度,减少编码过程中的码率震荡,从而实现编码过程中码流的合理分配,达到重建图像画质的均匀过度的效果。
在一个可选的实施例中,所述方法还包括:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
可选的,虽然在前述方法中,可以根据最近部分扫描行的码率变化趋势自适应调整码率范围,但码率范围的适应性调整程度仍应具有一定的程度限制,以避免码率上限无限制的升高或降低。可以通过设置提升次数阈值和降低次数阈值限制所述码率上限的升高或降低次数,也可以同构设置提升或降低范围值的方法,控制所述码率上限的具体数值保持在适当区间。
在一个示例中,可以通过对所述码率上限提升或降低5%实现对码率上限的调整,并且通过标志位f对所述码率上限的提升或降低结果进行标志,在上限提高后,f标记为true,上限降低后,f标记为false,以使所述码率上限无法连续升高或降低,只能够在±5%的范围内进行调整。
在一个示例中,所述码率上限的提升和降低条件可以分别通过公式(2)和公式(3)表示。
(2)
(3)
其中,P0-P4表示距当前扫描行相邻的5个历史扫描行对应的预测码率,p表示当前扫描行的预测码率,rt表示所述设定目标码率,l表示上限距离100%的偏移量,且每次满足调整条件时,调整量直接加到l上,!f表示所述码率上限可以提升,f表示所述码率上限可以降低。
进一步的,根据实验数据,可以通过当前扫描行的预测码率与设定目标码率的比例范围或待检测预测码率间的差值,进一步精确码率上限提升或降低的触发条件。
本公开所述方案,通过设置提升次数阈值和降低次数阈值,限制所述码率上限的升高或降低次数,或通过范围值,使所述码率上限的具体数值保持在适当区间,避免在对所述码率上限的自适应调整过程中,码率上限的无限制上升或下降。
在一个可选的实施例中,在所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,还包括:
响应于当前扫描行数大于第二行数阈值,根据当前扫描行对应的衰减因子,对当前的码率范围上限进行调整,所述衰减因子用于控制所述码率上限收敛至设定目标码率;
所述根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
可选的,在扫描压缩的最后阶段,通过逐渐将所述码率上限收敛至设定目标码率,以约束整个图像压缩过程中的最终压缩码率。所述衰减因子用于控制所述码率上限收敛至设定目标码率。所述第二行数阈值表示图像扫描压缩过程中的衰减起点,若所述码率上限在所述衰减起点前经过了自适应调整阶段,则在所述衰减起点将所述码率上限重置为初始上限,例如第一行数阈值的下一扫描行对应的码率上限。
在一个示例中,所述方法还包括:
根据当前扫描行数和所述第二行数阈值,确定所述衰减因子。
可选的,可以通过公式(4)确定所述衰减因子:
(4)
其中,decay表示所述衰减因子,h表示当前扫描行的行数,表示第二行数阈值,即衰减起始行的行数。因此,所述衰减因子可以通过以a为底,以经过衰减起点后的累计行数为幂的指数函数表示。其中,a<1,以使衰减因子随着行数的增加逐渐趋近于0,使得码率上限随着行数的增加逐渐逼近于所述设定目标码率。在一个示例中,a=0.989。
本公开所述方案,通过将衰减因子作为码率上限偏移量系数,逐渐将所述码率上限收敛至设定目标码率,以约束整个图像压缩过程中的最终压缩码率。
在一个可选的实施例中,所述根据当前扫描行数和所述第二设定阈值,确定所述衰减因子,包括:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
可选的,为了便于硬件实现,可以通过查表获取每一扫描行对应的衰减因子。如果表过大难以获取,可以通过设定步长进行跳点采样,而在步长范围内的点,则可以通过查表值临近的两个查表结果通过先行差值计算得到。
本公开所述方案,通过获取扫描行数和所述衰减因子的对应关系,直接通过查表获取每一扫描行对应的衰减因子,以进一步减小设备的运算压力。
在一个可选的实施例中,所述方法还包括:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
图3公开了本公开根据一示例性实施例示出的一种第二行数阈值确定流程图,其中,H表示所述图像的总行数,表示所述第二行数阈值。
如图3所示,通常,在所述图像总行数H大于1500的情况下,将所述总行数的3/4确定为所述第二行数阈值;
在所述图像总行数在1500行至375行之间的情况下,将所述图像的倒数第375行确定为所述第二行数阈值;
在所述图像总行数小于375行的情况下,将所述图像总行数的第十行确定为所述第二行数阈值。进一步的,为了避免在扫描结束时所述码率上限仍无法收敛至设定目标码率,可以在图像的倒数第十行判断基于当前的衰减因子能否完成所述码率上限的收敛,若不能,则将所述衰减因子设置为0,直接将所述设定目标码率确定为所述码率上限,以及时完成对图像的压缩码率的收敛。
本公开所述方案,通过根据所述图像的总行数确定所述第二行数阈值,控制所述扫描压缩过程在适当的收敛起点进行码率上限的收敛,以约束整个图像压缩过程中的最终压缩码率。
图4示出了本公开根据一示例性实施例示出的一种图像压缩效果对照图。
图4以是否通过本公开所述方法对bayer图像进行压缩为例,能够体现是否采取本公开所述方案进行图像压缩的前后对比效果。其中,x轴为扫描行数索引,y轴为每一扫描行对应的实际码率。
可见,基于本公开所述方案,能过明显降低图像压缩过程中的码率震荡,并使实际码率更快地收敛到目标码率。
此外,由于本公开所述方案不依赖于图像内容本身,只依赖于码率历史信息的变化规律,所以不同类型不同尺寸的图像均可以达到码率控制的效果。
进一步的,通过根据最近部分扫描行的码率变化趋势自适应调整码率范围,以使压缩过程中,在复杂纹理区域分配更多的码流长度,在简单纹理区域分配更多的码流长度,减少编码过程中的码率震荡,从而实现重建图像画质的均匀过度,使得图像画质得到有效控制。
对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本公开并不受所描述的动作顺序的限制,因为依据本公开,某些步骤可以采用其他顺序或者同时进行。
其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作和模块并不一定是本公开所必须的。
与前述应用功能实现方法实施例相对应,本公开还提供了应用功能实现装置及相应的终端的实施例。
本公开一示例性实施例示出的一种图像压缩的装置框图如图5所示,所述装置包括:
401,参数获取模块:用于获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度;
402,码率预测模块:用于根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率;
403,参数确定模块:用于根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数;
404,压缩模块:用于根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
在所述当前扫描行的预测码率大于码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
响应于当前扫描行数大于第一行数阈值,根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,所述装置还包括范围调整模块,用于:
响应于当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围上限进行调整;
所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述参数确定模块在根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围上限进行调整过程中,具体用于:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
结合本公开的任一实施方式,所述装置还包括范围限制模块,用于:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
结合本公开的任一实施方式,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
响应于当前扫描行数大于第二行数阈值,根据当前扫描行对应的衰减因子,对当前的码率范围上限进行调整,所述衰减因子用于控制所述码率上限收敛至设定目标码率;
所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
结合本公开的任一实施方式,所述装置还包括第二行数阈值确定模块,用于:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
结合本公开的任一实施方式,所述装置还包括衰减因子确定模块,用于:
根据当前扫描行数和所述第二行数阈值,确定所述衰减因子。
结合本公开的任一实施方式,所述衰减因子确定模块在根据当前扫描行数和所述第二行数阈值,确定所述衰减因子过程中,具体用于:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
结合本公开的任一实施方式,所述装置还包括范围确定模块,用于:
响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
对于装置实施例而言,由于其基本对应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的装置实施例仅仅是示意性的,其中上述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本公开方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
图6示出了本公开根据一示例性实施例示出的一种电子设备框图。
请参照附图6,其示例性的示出了一种电子设备的框图。例如,装置600可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图6,装置600可以包括以下一个或多个组件:处理组件602,存储器604,电源组件606,多媒体组件608,音频组件610,输入/输出(I/O)的接口612,传感器组件614,以及通信部件616。
处理组件602通常控制装置600的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件602可以包括一个或多个处理器620来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件602可以包括一个或多个模块,便于处理组件602和其他组件之间的交互。例如,处理组件602可以包括多媒体模块,以方便多媒体组件608和处理组件602之间的交互。
存储器604被配置为存储各种类型的数据以支持在装置600的操作。这些数据的示例包括用于在装置600上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器604可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件606为装置600的各种组件提供电力。电力组件606可以包括电源管理系统,一个或多个电源,及其他与为装置600生成、管理和分配电力相关联的组件。
多媒体组件608包括在所述装置600和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件608包括一个前置摄像头和/或后置摄像头。当装置600处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件610被配置为输出和/或输入音频信号。例如,音频组件610包括一个麦克风(MIC),当装置600处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器604或经由通信部件616发送。在一些实施例中,音频组件610包括一个扬声器,用于输出音频信号。
I/O接口612为处理组件602和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件614包括一个或多个传感器,用于为装置600提供各个方面的状态评估。例如,传感器组件614可以检测到装置600的打开/关闭状态,组件的相对定位,例如所述组件为装置600的显示器和小键盘,传感器组件614可以检测装置600或装置600一个组件的位置改变,用户与装置600接触的存在或不存在,装置600方位或加速/减速和装置600的温度变化。传感器组件614可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件614可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件614可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信部件616被配置为便于装置600和其他设备之间有线或无线方式的通信。装置600可以接入基于通信标准的无线网络,如WiFi,2G或3G,4G或5G或它们的组合。在一个示例性实施例中,通信部件616经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件616包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置600可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述电子设备的供电方法。
本公开在示例性实施例中,提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器604,上述指令可由装置600的处理器620执行以完成上述电子设备的供电方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
本公开还提供一种芯片,具体包括一个或多个接口电路和一个或多个处理器,所述接口电路用于从电子设备的存储器接收信号,并向所述处理器发送所述信号,所述信号包括存储器中存储的计算机指令。当所述处理器执行所述计算机指令时,使得所述电子设备执行本公开任一项所述的图像压缩方法。其中,所述芯片可以为常规的CPU(centralprocessing unit,中央处理器)芯片、GPU(graphics processing unit,图形处理器)芯片等,也可以为人工智能技术专用的加速芯片,例如AI(Artificial Intelligence,人工智能)加速器等。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
Claims (21)
1.一种图像压缩方法,其特征在于,所述方法包括:
获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度;
根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率;
响应于当前扫描行数大于第二行数阈值,根据所述当前扫描行数和所述第二行数阈值,确定衰减因子;
根据所述当前扫描行对应的所述衰减因子,对当前的码率范围的上限进行调整,所述衰减因子用于控制码率上限收敛至设定目标码率;
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数;
根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
2.根据权利要求1所述的方法,其特征在于,所述根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
在所述当前扫描行的预测码率大于所述码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
3.根据权利要求1所述的方法,其特征在于,所述根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数,包括:
响应于所述当前扫描行数大于第一行数阈值,根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
4.根据权利要求3所述的方法,其特征在于,在所述根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,还包括:
响应于所述当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整。
5.根据权利要求4所述的方法,其特征在于,所述根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整,包括:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
6.根据权利要求5所述的方法,其特征在于,所述方法还包括:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
7.根据权利要求1所述的方法,其特征在于,所述根据所述当前扫描行数和所述第二行数阈值,确定所述衰减因子,包括:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
8.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
9.根据权利要求3-6中任一项所述的方法,其特征在于,所述方法还包括:
响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
10.一种图像压缩装置,其特征在于,所述装置包括:
参数获取模块:用于获取当前扫描行的压缩参数和码流长度,以及首行至所述当前扫描行的码流总长度;
码率预测模块:用于根据当前扫描行的码流长度和首行至所述当前扫描行的码流总长度,确定当前扫描行的预测码率,所述预测码率表征基于当前扫描行对应的压缩参数对下一个扫描行至图像最后扫描行压缩后,所述图像的最终码率;
参数确定模块:用于响应于当前扫描行数大于第二行数阈值,根据所述当前扫描行数和所述第二行数阈值,确定衰减因子;
根据所述当前扫描行对应的所述衰减因子,对当前的码率范围的上限进行调整,所述衰减因子用于控制码率上限收敛至设定目标码率;
根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数;
压缩模块:用于根据所述下一个扫描行的压缩参数,对下一个扫描行的像素数据进行压缩处理。
11.根据权利要求10所述的装置,其特征在于,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
在所述当前扫描行的预测码率大于所述码率上限的情况下,提升所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数;和/或,
在所述当前扫描行的预测码率小于码率下限的情况下,降低所述当前扫描行的压缩参数,得到下一个扫描行的压缩参数。
12.根据权利要求10所述的装置,其特征在于,所述参数确定模块在根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数过程中,具体用于:
响应于所述当前扫描行数大于第一行数阈值,根据所述预测码率、调整后的码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数。
13.根据权利要求12所述的装置,其特征在于,所述参数确定模块在根据所述预测码率、码率范围和当前扫描行的压缩参数,确定下一个扫描行的压缩参数之前,所述装置还包括范围调整模块,用于:
响应于所述当前扫描行数大于所述第一行数阈值且小于等于第二行数阈值,根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整。
14.根据权利要求13所述的装置,其特征在于,所述参数确定模块在根据所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率,对当前的码率范围的上限进行调整过程中,具体用于:
根据预设规则,在所述当前扫描行之前的至少两个扫描行的预测码率和所述当前扫描行的预测码率中,选取待检测预测码率;
在所述待检测预测码率依次递增的情况下,提升所述码率上限;
在所述待检测预测码率依次递减的情况下,降低所述码率上限。
15.根据权利要求14所述的装置,其特征在于,所述装置还包括范围限制模块,用于:
在所述码率上限的提升次数超过提升次数阈值的情况下,停止提升所述码率上限,在所述码率上限的降低次数超过降低次数阈值的情况下,停止降低所述码率上限,或;
在提升后的码率上限超出提升范围阈值的情况下,停止提升当次码率上限;
在降低后的码率上限超出降低范围阈值的情况下,停止降低当次码率上限。
16.根据权利要求10所述的装置,其特征在于,所述衰减因子确定模块在根据当前扫描行数和所述第二行数阈值,确定所述衰减因子过程中,具体用于:
获取所述当前扫描行数和所述衰减因子的对应关系;
根据所述当前扫描行数和所述对应关系,获取所述衰减因子。
17.根据权利要求10所述的装置,其特征在于,所述装置还包括第二行数阈值确定模块,用于:
在当前图像的总行数大于第三行数阈值的情况下,根据所述总行数和第一比例系数,得到所述第二行数阈值;
在图像的总行数小于第三行数阈值且大于第四行数阈值的情况下,将所述总行数减去第一预设行数值,得到所述第二行数阈值;
在图像的总行数小于第四行数阈值的情况下,将第二预设行数值确定为所述第二行数阈值。
18.根据权利要求12~15中任一项所述的装置,其特征在于,所述装置还包括范围确定模块,用于:
响应于当前扫描行为所述第一行数阈值对应行的下一行,根据设定目标码率和设定范围系数,确定所述码率范围。
19.一种电子设备,其特征在于,所述电子设备包括:
存储器,用于存储处理器可执行指令;
处理器,被配置为执行所述存储器中的可执行指令以实现权利要求1~9任一项所述方法的步骤。
20.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现权利要求1~9任一项所述的方法的步骤。
21.一种芯片,其特征在于,包括:
一个或多个接口电路和一个或多个处理器;所述接口电路用于从电子设备的存储器接收信号,并向所述处理器发送所述信号,所述信号包括存储器中存储的计算机指令;当所述处理器执行所述计算机指令时,使得所述电子设备执行权利要求1~9任一项所述的图像压缩方法。
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/CN2022/096492 WO2023230933A1 (zh) | 2022-05-31 | 2022-05-31 | 图像压缩方法、装置、电子设备、芯片及储存介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN116438794A CN116438794A (zh) | 2023-07-14 |
CN116438794B true CN116438794B (zh) | 2023-12-12 |
Family
ID=87083713
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202280004643.6A Active CN116438794B (zh) | 2022-05-31 | 2022-05-31 | 图像压缩方法、装置、电子设备、芯片及储存介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN116438794B (zh) |
WO (1) | WO2023230933A1 (zh) |
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1998053613A1 (en) * | 1997-05-20 | 1998-11-26 | Motorola Inc. | Apparatus, method and computer readable medium for scalable coding of video information |
CN1211876A (zh) * | 1997-06-25 | 1999-03-24 | 索尼公司 | 数字信号编码方法和装置、信号记录介质和信号传送方法 |
WO2004091221A2 (en) * | 2003-04-04 | 2004-10-21 | Avid Technology, Inc. | Fixed bit rate, intraframe compression and decompression of video |
JP2007166192A (ja) * | 2005-12-13 | 2007-06-28 | Toshiba Corp | 情報処理装置、制御方法およびプログラム |
CN103297775A (zh) * | 2013-05-17 | 2013-09-11 | 西安电子科技大学 | 基于联合码率分配和控制的多光谱图像压缩系统与方法 |
CN103916675A (zh) * | 2014-03-25 | 2014-07-09 | 北京工商大学 | 一种基于条带划分的低延迟帧内编码方法 |
CN105205521A (zh) * | 2015-09-30 | 2015-12-30 | 立德高科(昆山)数码科技有限责任公司 | 将二维码扫描区域中扫描线更改为选定素材的方法及装置 |
CN109379598A (zh) * | 2018-09-12 | 2019-02-22 | 合肥埃科光电科技有限公司 | 一种基于fpga实现的图像无损压缩方法 |
CN113670608A (zh) * | 2021-07-21 | 2021-11-19 | 广州大学 | 基于后缀树和向量机的故障检测方法、系统、装置及介质 |
CN114051144A (zh) * | 2021-11-09 | 2022-02-15 | 京东科技信息技术有限公司 | 视频的压缩方法、装置、计算机设备及存储介质 |
CN114357665A (zh) * | 2022-03-15 | 2022-04-15 | 成都中科翼能科技有限公司 | 一种压气机叶片振动限制值的确定方法 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4063205B2 (ja) * | 2003-11-20 | 2008-03-19 | セイコーエプソン株式会社 | 画像データ圧縮装置及びエンコーダ |
US7729551B2 (en) * | 2006-09-08 | 2010-06-01 | Eastman Kodak Company | Method for controlling the amount of compressed data |
CN101159871B (zh) * | 2007-11-12 | 2010-08-04 | 中兴通讯股份有限公司 | 宏块组级视频码率控制方法 |
US7844097B2 (en) * | 2007-12-03 | 2010-11-30 | Samplify Systems, Inc. | Compression and decompression of computed tomography data |
CN102938838A (zh) * | 2012-10-19 | 2013-02-20 | 西安电子科技大学 | 基于jpeg-ls标准的动态码率控制方法 |
CN106658006B (zh) * | 2017-01-12 | 2019-08-13 | 武汉轻工大学 | 一种率失真性能近似最优的jpeg-ls图像近无损压缩的码率控制方法 |
-
2022
- 2022-05-31 WO PCT/CN2022/096492 patent/WO2023230933A1/zh unknown
- 2022-05-31 CN CN202280004643.6A patent/CN116438794B/zh active Active
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1998053613A1 (en) * | 1997-05-20 | 1998-11-26 | Motorola Inc. | Apparatus, method and computer readable medium for scalable coding of video information |
CN1211876A (zh) * | 1997-06-25 | 1999-03-24 | 索尼公司 | 数字信号编码方法和装置、信号记录介质和信号传送方法 |
WO2004091221A2 (en) * | 2003-04-04 | 2004-10-21 | Avid Technology, Inc. | Fixed bit rate, intraframe compression and decompression of video |
JP2007166192A (ja) * | 2005-12-13 | 2007-06-28 | Toshiba Corp | 情報処理装置、制御方法およびプログラム |
CN103297775A (zh) * | 2013-05-17 | 2013-09-11 | 西安电子科技大学 | 基于联合码率分配和控制的多光谱图像压缩系统与方法 |
CN103916675A (zh) * | 2014-03-25 | 2014-07-09 | 北京工商大学 | 一种基于条带划分的低延迟帧内编码方法 |
CN105205521A (zh) * | 2015-09-30 | 2015-12-30 | 立德高科(昆山)数码科技有限责任公司 | 将二维码扫描区域中扫描线更改为选定素材的方法及装置 |
CN109379598A (zh) * | 2018-09-12 | 2019-02-22 | 合肥埃科光电科技有限公司 | 一种基于fpga实现的图像无损压缩方法 |
CN113670608A (zh) * | 2021-07-21 | 2021-11-19 | 广州大学 | 基于后缀树和向量机的故障检测方法、系统、装置及介质 |
CN114051144A (zh) * | 2021-11-09 | 2022-02-15 | 京东科技信息技术有限公司 | 视频的压缩方法、装置、计算机设备及存储介质 |
CN114357665A (zh) * | 2022-03-15 | 2022-04-15 | 成都中科翼能科技有限公司 | 一种压气机叶片振动限制值的确定方法 |
Non-Patent Citations (3)
Title |
---|
EE2: Summary Report on Enhanced Compression beyond VVC capability;Vadim Seregin等;《JVET》;全文 * |
基于JPEG2000的码率控制算法的研究;秦成;陈志云;俞琨;周雁;;计算机应用与软件(第02期);全文 * |
基于SAE的全息图恢复算法;吴芯洋;曾月;廉昊;胥炆欣;刘美玲;;电子设计工程(第05期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN116438794A (zh) | 2023-07-14 |
WO2023230933A1 (zh) | 2023-12-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7911509B2 (en) | Adaptive video encode scaling | |
EP3173923A1 (en) | Method and device for image display | |
CN110536168B (zh) | 视频上传方法、装置、电子设备及存储介质 | |
US7756349B2 (en) | Image processing apparatus and computer-readable storage medium | |
CN107480785B (zh) | 卷积神经网络的训练方法及装置 | |
CN115052150A (zh) | 视频编码方法、装置、电子设备和存储介质 | |
CN109547782B (zh) | Mpm候选列表构建方法、装置、电子设备及存储介质 | |
CN108600503B (zh) | 语音通话的控制方法及装置 | |
CN116438794B (zh) | 图像压缩方法、装置、电子设备、芯片及储存介质 | |
CN105472228B (zh) | 图像处理方法、装置及终端 | |
CN112821508B (zh) | 充电方法、装置以及存储介质 | |
CN115048221A (zh) | 负载处理方法、装置、电子设备及计算机可读存储介质 | |
CN114898760A (zh) | 语音编码方法、装置、电子设备及存储介质 | |
CN110069310B (zh) | 切换桌面壁纸的方法、装置及存储介质 | |
CN111124099A (zh) | 状态控制方法、装置及存储介质 | |
CN116634532A (zh) | 终端功耗控制方法、装置和存储介质 | |
CN111538447A (zh) | 信息展示方法、装置、设备及存储介质 | |
CN111858970A (zh) | 多媒体内容推荐方法、装置、电子设备及可读存储介质 | |
CN115348448B (zh) | 滤波器训练方法、装置、电子设备及存储介质 | |
CN116264614A (zh) | 画质调试信息的控制方法、装置、终端及存储介质 | |
CN117354771A (zh) | 蓝牙控制方法、装置、电子设备及可读储存介质 | |
CN117336609A (zh) | 功耗控制方法及装置、电子设备及存储介质 | |
CN116708883A (zh) | 视频数据上传方法、装置、电子设备及存储介质 | |
CN116567411A (zh) | 一种功耗控制方法、装置、设备及介质 | |
CN117956145A (zh) | 视频编码方法、装置、电子设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |