CN114915464A - 一种基于特殊矩阵运算的图像加密方法、解密方法 - Google Patents
一种基于特殊矩阵运算的图像加密方法、解密方法 Download PDFInfo
- Publication number
- CN114915464A CN114915464A CN202210486084.9A CN202210486084A CN114915464A CN 114915464 A CN114915464 A CN 114915464A CN 202210486084 A CN202210486084 A CN 202210486084A CN 114915464 A CN114915464 A CN 114915464A
- Authority
- CN
- China
- Prior art keywords
- row
- image
- encryption
- matrix
- column
- 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
- 239000011159 matrix material Substances 0.000 title claims abstract description 249
- 238000000034 method Methods 0.000 title claims abstract description 64
- 239000013598 vector Substances 0.000 claims abstract description 172
- 238000006243 chemical reaction Methods 0.000 claims description 93
- 230000009466 transformation Effects 0.000 claims description 7
- 238000004422 calculation algorithm Methods 0.000 abstract description 8
- 238000010586 diagram Methods 0.000 description 18
- 239000000203 mixture Substances 0.000 description 14
- 238000004590 computer program Methods 0.000 description 11
- 230000009286 beneficial effect Effects 0.000 description 4
- 238000004458 analytical method Methods 0.000 description 3
- 238000007781 pre-processing Methods 0.000 description 3
- 238000011084 recovery Methods 0.000 description 3
- 230000000694 effects Effects 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 238000010206 sensitivity analysis Methods 0.000 description 2
- 101100114365 Caenorhabditis elegans col-8 gene Proteins 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 238000013528 artificial neural network Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000006835 compression Effects 0.000 description 1
- 238000007906 compression Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000000605 extraction Methods 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 230000001902 propagating effect Effects 0.000 description 1
- 230000001681 protective effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
- 230000017105 transposition Effects 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/04—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
- H04L63/0428—Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/08—Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
- H04L9/0861—Generation of secret information including derivation or calculation of cryptographic keys or passwords
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Facsimile Transmission Control (AREA)
Abstract
本发明涉及一种基于特殊矩阵运算的图像加密方法、解密方法,所述加密方法包括:获取待加密图像;根据随机数,生成行加密向量和列加密向量;根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像。本发明利用首位,步长生成的行加密向量和列加密向量,并实现密钥与图像矩阵的合并,特殊矩阵运算及打乱,以此分别对图像矩阵行和列进行加密,利用了矩阵运算的高效性,既保持了很低算法的时间复杂度,又提高了对大图像的加密质量,同时也能保证图像信息的安全性。
Description
技术领域
本发明涉及图像加密技术领域,尤其涉及一种基于特殊矩阵运算的图像加密方法、解密方法。
背景技术
在信息化社会,信息安全尤为重要,图像中蕴含着大量的信息,在传输过程中,可能出现泄漏的隐患,而造成损失。因而,图像信息安全需要采取保护性的加密措施,并在接收端进行相应的解密措施,达到全方位保护信息安全的目的。
在传统图像加密领域中,经常使用AES和RES加密手段来对图像进行加密。而该技术往往需要S-box和64轮迭代运算,该技术对文本信息有较好的加密效果,但是由于彩色图像具有更大的数据量和更多的像素信息,使用传统方法不仅费时,而且很难达到预期的加密要求。因此,如何高效且快速地进行图像的加密、解密是亟待解决的问题。
发明内容
有鉴于此,有必要提供及一种基于特殊矩阵运算的图像加密方法、解密方法,用以克服现有技术中难以高效省时地加密解密图像的问题。
为了解决上述技术问题,本发明提供一种基于特殊矩阵运算的图像加密方法,包括:
获取待加密图像;
根据随机数,生成行加密向量和列加密向量;
根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像。
进一步地,所述根据随机数,生成行加密向量和列加密向量,包括:
根据随机数,确定第一首位数和第一随机步长;
根据所述第一首位数、所述第一随机步长和预设的加密长度,提取预设整数集合中的整数,生成所述列加密向量和所述行加密向量。
进一步地,所述根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像,包括:
将所述行加密向量和所述待加密图像转换的数据矩阵的每一行的行数据相加,得到第一转换矩阵;
根据所述第一转换矩阵的第1行的行数据至所述第一转换矩阵的第i行的所有行数据之和,确定第二转换矩阵的第i行的行数据,生成所述第二转换矩阵,其中,i为整数;
将所述行加密向量化为正序后,将所述第二转换矩阵打乱后并转置,生成所述第三转换矩阵。
进一步地,所述根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像,包括:
将所述列加密向量和所述第三转换矩阵的数据矩阵的每一列的列数据相加,得到所述第四转换矩阵;
根据所述第四转换矩阵的第1行的行数据至所述第四转换矩阵的第i行的所有行数据之和,确定第五转换矩阵的第i行的行数据,生成所述第五转换矩阵;
将所述列加密向量化为正序后,将所述第五转换矩阵打乱后并转置,生成所述第六转换矩阵;
根据所述第六转换矩阵,生成所述加密图像。
本发明还提供了一种基于特殊矩阵运算的图像解密方法,包括:
获取加密图像,其中,所述加密图像根据如上所述的基于特殊矩阵运算的图像加密方法生成;
根据随机数,生成行解密向量和列解密向量;
根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像。
进一步地,所述根据随机数,生成行解密向量和列解密向量,包括:
根据随机数,确定第二首位数和第二随机步长;
根据所述第二首位数、所述第二随机步长和预设的解密长度,提取预设整数集合中的整数,生成所述列解密向量和所述行解密向量。
进一步地,所述根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像,包括:
将所述列解密向量化为正序后,将所述加密图像转置后的数据矩阵打乱,生成第七转换矩阵;
根据所述第七转换矩阵的第i行的行数据与所述第七转换矩阵的第i-1行的所有行数据之差,确定第八转换矩阵的第i行的行数据,生成所述第八转换矩阵,其中,i为整数;
将所述第八转换矩阵的每一列的列数据都减去所述列解密向量,并进行转置,确定第九转换矩阵。
进一步地,所述根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像,包括:
将所述行解密向量化为正序后,将所述第九转换矩阵转置后的数据矩阵打乱,生成第十转换矩阵;
根据所述第十转换矩阵的第i行的行数据与所述第七转换矩阵的第i-1行的所有行数据之差,确定第十一转换矩阵的第i行的行数据,生成所述第十一转换矩阵,其中,i为整数;
将所述第十一转换矩阵的每一行的行数据都减去所述行解密向量,确定第十二转换矩阵;
根据所述第十二转换矩阵,生成所述解密图像。
与现有技术相比,本发明的有益效果包括:在加密方法中,首先,对待加密图像进行有效的获取;进而,分别利用行列首位,步长生成行加密向量和列加密向量;最后,把行列密钥与重构后矩阵的合并,合并后的矩阵进行特殊矩阵运算并利用Mod打乱,得到最终的密文图像。在解密方法中,首先,对加密图像进行有效获取;进而,分别利用行列首位,步长生成行解密向量和列解密向量;最后,恢复打乱加密图片由行解密向量和列解密向量决定,且恢复后的加密图片相邻像素值之间存在很强的相关性,即只要知道一个像素值和其前一个像素值,配合密钥就能恢复真实的像素值。综上,本发明利用首位,步长生成的行加密向量和列加密向量,并实现密钥与图像矩阵的合并,特殊矩阵运算及打乱,以此分别对图像矩阵行和列进行加密,利用了矩阵运算的高效性,既保持了很低算法的时间复杂度,又提高了对大图像的加密质量,同时也能保证图像信息的安全性。
附图说明
图1为本发明提供的基于特殊矩阵运算的图像加密方法一实施例的流程示意图;
图2为本发明提供的图1中步骤S102一实施例的流程示意图;
图3为本发明提供的图1中步骤S103一实施例的流程示意图;
图4为本发明提供的图1中步骤S103另一实施例的流程示意图;
图5为本发明提供的基于特殊矩阵运算的图像解密方法一实施例的流程示意图;
图6为本发明提供的图5中步骤S502一实施例的流程示意图;
图7为本发明提供的图5中步骤S503一实施例的流程示意图;
图8为本发明提供的图5中步骤S503另一实施例的流程示意图;
图9为本发明提供的加密图像、解密图像一实施的对比示意图;
图10为本发明提供的Lena图像灰度直方图一实施例的直方示意图;
图11为本发明提供的Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像灰度直方图一实施例的灰度示意图;
图12为本发明提供的Lena图像像素相关性图一实施例的相关性示意图;
图13为本发明提供的Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像像素相关性一实施例的相关性示意图;
图14为本发明提供的图像加密装置一实施例的结构示意图;
图15为本发明提供的图像解密装置一实施例的结构示意图;
图16为本发明提供的电子设备一实施例的结构示意图。
具体实施方式
下面结合附图来具体描述本发明的优选实施例,其中,附图构成本申请一部分,并与本发明的实施例一起用于阐释本发明的原理,并非用于限定本发明的范围。
在本发明的描述中,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括至少一个该特征。此外,“多个”的含义是至少两个,例如两个,三个等,除非另有明确具体的限定。
在本发明的描述中,提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本发明的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,所描述的实施例可以与其它实施例相结合。
本发明提供了一种基于特殊矩阵运算的图像加密方法、解密方法,利用行解密向量和列加密向量进行矩阵运算,并对应进行解密,为进一步提高加密、解密的效率性提供了新思路。
在实施例描述之前,对相关词语进行释义:
图像加密:利用数字图像的特性设计加密算法,以提高加密的安全性和运算效率的一种技术。为了实现数字图像保密,实际操作中一般先将二维图像转换成一维数据,再采用传统加密算法进行加密。与普通的文本信息不同,图像和视频具有时间性、空间性、视觉可感知性,还可进行有损压缩,这些特性使得为图像设计更加高效、安全的加密算法成为可能。自上世纪90年代起,研究者利用这些特性提出了多种图像加密算法。
图像解密:将加密后的图像与密钥图像进行相应的运算,从而从加密图像中解密出原图像信息的技术。
RGB:对一种颜色进行编码的方法统称为“颜色空间”或“色域”。用最简单的话说,世界上任何一种颜色的“颜色空间”都可定义成一个固定的数字或变量。RGB(红、绿、蓝)只是众多颜色空间的一种。采用这种编码方法,每种颜色都可用三个变量来表示-红色绿色以及蓝色的强度。记录及显示彩色图像时,RGB是最常见的一种方案。但是,它缺乏与早期黑白显示***的良好兼容性。因此,许多电子电器厂商普遍采用的做法是,将RGB转换成YUV颜色空间,以维持兼容,再根据需要换回RGB格式,以便在电脑显示器上显示对应的彩色图形。
基于上述技术名词的描述,现有技术中,往往着重于S-box和64轮迭代运算的应用,存在加密时间长,资源占用大,加密效果不理想的问题,因而,本发明旨在提出一种高效准确的图像加密、解密方法。
以下分别对具体实施例进行详细说明:
本发明实施例提供了一种基于特殊矩阵运算的图像加密方法,结合图1来看,图1为本发明提供的基于特殊矩阵运算的图像加密方法一实施例的流程示意图,包括步骤S101至步骤S103,其中:
在步骤S101中,获取待加密图像;
在步骤S102中,根据随机数,生成行加密向量和列加密向量;
在步骤S103中,根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像。
在本发明实施例中,首先,对待加密图像进行有效的获取;进而,分别利用行列首位,步长生成行加密向量和列加密向量;最后,把行列密钥与重构后矩阵的合并,合并后的矩阵进行特殊矩阵运算并利用Mod打乱,得到最终的密文图像。
需要说明的是,首先会针对被加密的彩色明文图像进行预处理,其具体包括RGB图像的像素的拆分,拆分后矩阵重构,以得到相关的待加密图像转换的数据矩阵。
作为优选的实施例,结合图2来看,图2为本发明提供的图1中步骤S102一实施例的流程示意图,步骤S102包括步骤S201至步骤S202,其中:
在步骤S201中,根据随机数,确定第一首位数和第一随机步长;
在步骤S202中,根据所述第一首位数、所述第一随机步长和预设的加密长度,提取预设整数集合中的整数,生成所述列加密向量和所述行加密向量。
在本发明实施例中,根据预设的第一首位数和第一随机步长,提取预设整数集合中的整数,以有效生成随机的列加密向量和行加密向量。
在本发明一个具体的实施例中,可以根据给定的首位和步长,对全体整数集合进行提取,得到行列密钥,例如首位为3,步长为2,所需密钥向量长度为5,那么对应的密钥向量就为[3,5,7,9,11],再由该密钥向量随机生成Mod,Mod为实数且满足步长%Mod不可等于0,且当密钥向量元素全为非负整数时,1-向量元素中最大值≤Mod≤向量元素中最大值,当密钥向量元素全为非正整数时,向量元素中最小值≤Mod≤-1-向量元素中最小值,当密钥向量元素既有正数也有负数且递增时,向量元素中最小值-向量元素中最大值-1≤Mod≤向量元素中最大值-向量元素中最小值+1,当密钥向量元素既有正数也有负数且递减时,向量元素中最小值-向量元素中最大值≤Mod≤向量元素中最大值-向量元素中最小值,最后使用该密钥和Mod来对明文图像进行加密。
作为优选的实施例,结合图3来看,图3为本发明提供的图1中步骤S103一实施例的流程示意图,步骤S103包括步骤S301至步骤S303,其中:
在步骤S301中,将所述行加密向量和所述待加密图像转换的数据矩阵的每一行的行数据相加,得到第一转换矩阵;
在步骤S302中,根据所述第一转换矩阵的第1行的行数据至所述第一转换矩阵的第i行的所有行数据之和,确定第二转换矩阵的第i行的行数据,生成所述第二转换矩阵,其中,i为整数;
在步骤S303中,将所述行加密向量化为正序后,将所述第二转换矩阵打乱后并转置,生成所述第三转换矩阵。
在本发明实施例中,根据行加密向量对待加密图像进行有效的加密转换。
作为优选的实施例,结合图4来看,图4为本发明提供的图1中步骤S103另一实施例的流程示意图,步骤S103包括步骤S401至步骤S404,其中:
在步骤S401中,将所述列加密向量和所述第三转换矩阵的数据矩阵的每一列的列数据相加,得到所述第四转换矩阵;
在步骤S402中,根据所述第四转换矩阵的第1行的行数据至所述第四转换矩阵的第i行的所有行数据之和,确定第五转换矩阵的第i行的行数据,生成所述第五转换矩阵;
在步骤S403中,将所述列加密向量化为正序后,将所述第五转换矩阵打乱后并转置,生成所述第六转换矩阵;
在步骤S404中,根据所述第六转换矩阵,生成所述加密图像。
在本发明实施例中,根据列加密向量对待加密图像转化的第三转换矩阵进行有效的加密转换。
在本发明一个具体的实施例中,可以根据所确定的行列密钥和Mod,与经过预处理的明文图像进行合并,特殊矩阵运算,打乱,行或者列加密过程都只包含三次矩阵运算,运算效率高,而且这样得到的密文图像,不仅其像素之间的相关性会变更强,即当前像素值的改变可以影响到多个像素,而且其所有像素拆分后的RGB值之间的相关性会变更强,即当前像素R值,G值,B值不仅影响该像素的R值,G值,B值,还可以影响到多个像素的R值,G值,B值,具有更高的安全性。
本发明实施例还提供了一种基于特殊矩阵运算的图像解密方法,结合图5来看,图5为本发明提供的基于特殊矩阵运算的图像解密方法一实施例的流程示意图,包括步骤S501至步骤S503,其中:
在步骤S501中,获取加密图像,其中,所述加密图像根据如上所述的基于特殊矩阵运算的图像加密方法生成;
在步骤S502中,根据随机数,生成行解密向量和列解密向量;
在步骤S503中,根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像。
在本发明实施例中,首先,对加密图像进行有效获取;进而,分别利用行列首位,步长生成行解密向量和列解密向量;最后,恢复打乱加密图片由行解密向量和列解密向量决定,且恢复后的加密图片相邻像素值之间存在很强的相关性,即只要知道一个像素值和其前一个像素值,配合密钥就能恢复真实的像素值。
需要说明的是,根据给定的正确的首位,步长,可以得到解密的行列密钥,密文图像利用密钥和给定的Mod对打乱的矩阵进行复原后,再进行特殊矩阵逆运算再减去行列密钥,可以得到正确的明文图像。
进一步地,结合图6来看,图6为本发明提供的图5中步骤S502一实施例的流程示意图,包括步骤S601至步骤S602,其中:
在步骤S601中,根据随机数,确定第二首位数和第二随机步长;
在步骤S602中,根据所述第二首位数、所述第二随机步长和预设的解密长度,提取预设整数集合中的整数,生成所述列解密向量和所述行解密向量。
在本发明实施例中,根据预设的第二首位数和第二随机步长,提取预设整数集合中的整数,以有效生成随机的列解密向量和行解密向量。
进一步地,结合图7来看,图7为本发明提供的图5中步骤S503一实施例的流程示意图,包括步骤S701至步骤S703,其中:
在步骤S701中,将所述列解密向量化为正序后,将所述加密图像转置后的数据矩阵打乱,生成第七转换矩阵;
在步骤S702中,根据所述第七转换矩阵的第i行的行数据与所述第七转换矩阵的第i-1行的所有行数据之差,确定第八转换矩阵的第i行的行数据,生成所述第八转换矩阵,其中,i为整数;
在步骤S703中,将所述第八转换矩阵的每一列的列数据都减去所述列解密向量,并进行转置,确定第九转换矩阵。
在本发明实施例中,根据列解密向量,对加密图像进行初次的转换,保证有效的解密。
进一步地,结合图8来看,图8为本发明提供的图5中步骤S503另一实施例的流程示意图,包括步骤S801至步骤S804,其中:
在步骤S801中,将所述行解密向量化为正序后,将所述第九转换矩阵转置后的数据矩阵打乱,生成第十转换矩阵;
在步骤S802中,根据所述第十转换矩阵的第i行的行数据与所述第七转换矩阵的第i-1行的所有行数据之差,确定第十一转换矩阵的第i行的行数据,生成所述第十一转换矩阵,其中,i为整数;
在步骤S803中,将所述第十一转换矩阵的每一行的行数据都减去所述行解密向量,确定第十二转换矩阵;
在步骤S804中,根据所述第十二转换矩阵,生成所述解密图像。
在本发明实施例中,根据行解密向量,对加密图像进行再次的转换,保证有效的解密。
下面结合一个具体的应用例更好地说明本发明技术方案如下:
结合图9来看,图9为本发明提供的加密图像、解密图像一实施的对比示意图,该实验数据来自Lena图像,整体的技术思路是构建一个基于特殊矩阵运算的大图像加密***,包括图像信息提取模块,图像预处理模板,行列密钥生成模块,明文图像加密模板,密文图像解密模板;行列密钥生成模块用于随机生成整数为首位,步长(不为0),并定义行列加密向量长度,利用首位和步长,对全体整数集合进行提取,得到行列密钥,进而生成Mod(不为0);明文图像加密模板用于将行加密向量和图像拆分后的RGB矩阵合并,进行特殊矩阵运算,打乱;对结果矩阵进行转置操作,将列加密向量和结果矩阵合并,进行特殊矩阵运算,打乱;对结果矩阵进行转置操作并模256后输出加密图像;密文图像解密模板用于对加密图像进行操作,将加密的图像转成拆分后的RGB矩阵并转置,定义列解密向量长度,利用首位和步长,对全体整数集合进行提取,得到列密钥,利用col_Mod对结果矩阵进行复原,进行特殊矩阵逆运算并减去列解密密钥并转置,定义行解密向量长度,利用首位和步长,对全体整数集合进行提取,得到行密钥,利用row_Mod对结果矩阵进行复原,进行特殊矩阵逆运算并减去行解密密钥并以此还原明文图像;
其中,加密阶段具体步骤如下:
第一步,首先对Lena图像进行预处理,将其转为尺寸512x512x3图像矩阵Ma_0,再将图像矩阵进行RGB拆分,得到512x1536的RGB矩阵Ma_1;
第二步,随机生成整数1为首位initial_1,随机生成整数1为步长step_1(不为0),并令行加密向量长度size_1=512,利用首位initial_1,步长step_1,行加密向量长度size_1提取全体整数集合中的整数,生成长度为512的行加密向量row_mix,定义row_Mod为3(不为0);同样地,随机生成整数1为首位initial_2,随机生成整数1为步长step_2(不为0),并令列加密向量长度size_2=1536,利用首位initial_2,步长step_2,列加密向量长度size_2提取全体整数集合中的整数,生成长度为1536的列加密向量col_mix,定义col_Mod为3(不为0);
第三步,将行加密向量row_mix和RGB矩阵Ma_1合并,即对矩阵Ma_1的每一列都加上行加密向量row_mix得到矩阵Ma_2;对矩阵Ma_2进行特殊矩阵运算,即结果矩阵Ma_3的第一行等于矩阵Ma_2的第一行,第二行为矩阵Ma_2的第一行和第二行之和,第三行为矩阵Ma_2的第一行,第二行和第三行之和,以此类推;公式表述:Ma3=θ(rowmix TI+Ma1),其中θ是尺寸为512x512的下三角阵,且下三角部分元素全为1,I是尺寸为1x1536的全1向量,利用行加密向量row_mix和row_Mod将矩阵Ma_3打乱为矩阵Ma_4,具体为,如果对行加密向量row_mix模rol_Mod后进行X操作可以使其化为正序,那么对矩阵Ma_3进行X操作使之打乱为矩阵Ma_4,公式表述:如果X(rowmix Mod rowMod)→正序,那么XMa3→Ma4;
进一步地,将矩阵Ma_4进行转置操作得到矩阵Ma_5,将列加密向量col_mix和矩阵Ma_5合并,即对矩阵Ma_5的每一列都加上列加密向量col_mix得到矩阵Ma_6,对矩阵Ma_6进行特殊矩阵运算,即结果矩阵Ma_7的第一行等于矩阵Ma_6的第一行,第二行为矩阵Ma_6的第一行和第二行之和,第三行为矩阵Ma_6的第一行,第二行和第三行之和,以此类推;公式表述为Ma7=θ(colmix TI+Ma5),其中θ是尺寸为1536x1536的下三角阵,且下三角部分元素全为1,I是尺寸为1x512的全1向量,利用列加密向量col_mix和col_Mod将矩阵Ma_7打乱为矩阵Ma_8,具体为,如果对列加密向量col_mix模col_Mod后进行Y操作可以使其化为正序,那么对矩阵Ma_7进行Y操作使之打乱为矩阵Ma_8,公式表述:如果Y(colmix Mod colMod)→正序,那么YMa7→Ma8,将矩阵Ma_8进行转置操作并模256得到矩阵Ma_9,将矩阵Ma_9重新组成Mx N的图像矩阵Ma_10,进而构成加密图片P_1。
其中,解密阶段具体步骤如下:
第1步,对加密图片P_1转为尺寸为512x512x3图像矩阵Ma_10,将图像矩阵Ma_10重新组成512x1536的矩阵Ma_9,将矩阵Ma_9进行转置操作得到矩阵Ma_8,令列解密向量长度size_2=1536,利用首位initial_2=1,步长step_2=1,列解密向量长度size_2提取全体整数集合中的整数,生成长度为1536的列解密向量col_key,利用列解密向量col_key和col_Mod对矩阵Ma_8进行复原,具体为,如果对列解密向量col_key模col_Mod后进行Y操作可以使其化为正序,那么对矩阵Ma_8进行YT操作使之复原,公式表述:如果Y(colkey ModcolMod)→正序,那么YTMa8→Ma7,并进行特殊矩阵逆运算即除了第一行,其他的每一行等于这一行减去前一行,得到结果矩阵Ma_6;
第2步,矩阵Ma_6的每一列都减去列解密向量col_key并转置得到矩阵Ma_5,公式表述:Ma5=(θMa7-colkey TI)T其中θ是尺寸为1536x1536的矩阵,且主对角线上元素全为1,主对角线下方最靠近主对角线的那条对角线上的元素全为-1,其他元素全为0,I是尺寸为1x512的全1向量;
令行解密向量长度size_1=512,利用首位initial_1=1,步长step_1=1,行解密向量长度size_1提取全体整数集合中的整数,生成长度为512的行解密向量row_key,利用行解密向量row_key和row_Mod对矩阵Ma_5进行复原,具体为,如果对行解密向量row_key模row_Mod后进行X操作可以使其化为正序,那么对矩阵Ma_5进行XT操作使之复原,公式表述:如果X(rowkey Mod rowMod)→正序,那么XTMa5→Ma4,并进行特殊矩阵逆运算,即除了第一行,其他的每一行等于这一行减去前一行,得到结果矩阵Ma_3,对矩阵Ma_3的每一列都减去行解密向量row_key得到矩阵Ma_2,将矩阵Ma_2模256得到Ma_1,公式表述:Ma1=(θMa4-rowkey TI)Mod 256,利用Ma_1重新组成512x512x3的图像矩阵Ma_0,进而得到明文图片Lena。
其中,附图加密解密参数:首位为1,步长为1,Mod为3,密钥敏感性分析Mod改为2;
其中,下表1是Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像和Lena图像在给定首位为1,步长为1,Mod为2的条件下基于该***加密后的图像的加密算法密钥敏感性分析:
表1
PSNR | UACI | |
R | 99.6098% | 33.4431% |
G | 99.5937% | 33.5308% |
B | 99.5865% | 33.3873% |
其中,下表2是Lena图像相关系数和Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像相关系数对比:
表2
通道 | Horizontal | Vertical | Diagonal |
R | 0.9782 | 0.9893 | 0.9664 |
G | 0.9699 | 0.9805 | 0.9548 |
B | 0.9359 | 0.9572 | 0.9239 |
通道 | Horizontal | Vertical | Diagonal |
R | 0.0219 | -0.0172 | -0.0059 |
G | 0.0081 | -0.0226 | -0.0293 |
B | 0.0199 | 0.0018 | -0.0053 |
其中,下表3是Lena图像和Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像的信息熵分析:
表3
信息熵计算 | 原Lena图像 | 加密图像 |
R | 6.879 | 7.999 |
G | 6.926 | 7.999 |
B | 6.968 | 7.999 |
其中,下表4是Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像随机性分析:
表4
GVD | 原图加密图像 |
R | 0.9864 |
G | 0.9755 |
B | 0.977 |
其中,下表5是Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像加密质量分析:
表5
EQ | 原图加密图像 |
R | 805 |
G | 587 |
B | 1023 |
其中,结合图10至图13来看,图10为本发明提供的Lena图像灰度直方图一实施例的直方示意图,图11为本发明提供的Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像灰度直方图一实施例的灰度示意图,图12为本发明提供的Lena图像像素相关性图一实施例的相关性示意图,图13为本发明提供的Lena图像在给定首位为1,步长为1,Mod为3的条件下基于该***加密后的图像像素相关性一实施例的相关性示意图。
本发明实施例还提供了一种图像加密装置,结合图14来看,图14为本发明提供的图像加密装置一实施例的结构示意图,图像加密装置1400包括:
第一获取单元1401,用于获取待加密图像;
第一处理单元1402,用于根据随机数,生成行加密向量和列加密向量;
加密单元1403,用于根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像。
图像加密装置的各个单元的更具体实现方式可以参见对于上述基于特殊矩阵运算的图像加密方法的描述,且具有与之相似的有益效果,在此不再赘述。
本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时,实现如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法。
本发明实施例还提供了一种图像解密装置,结合图15来看,图15为本发明提供的图像解密装置一实施例的结构示意图,图像解密装置1500包括:
第二获取单元1501,用于获取加密图像,其中,所述加密图像根据如上所述的基于特殊矩阵运算的图像加密方法生成;
第二处理单元1502,用于根据随机数,生成行解密向量和列解密向量;
解密单元1503,用于根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像。
图像解密装置的各个单元的更具体实现方式可以参见对于上述基于特殊矩阵运算的图像解密方法的描述,且具有与之相似的有益效果,在此不再赘述。
本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时,实现如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法。
一般来说,用于实现本发明方法的计算机指令的可以采用一个或多个计算机可读的存储介质的任意组合来承载。非临时性计算机可读存储介质可以包括任何计算机可读介质,除了临时性地传播中的信号本身。
计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言,特别是可以使用适于神经网络计算的Python语言和基于TensorFlow、PyTorch等平台框架。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
本发明实施例还提供了一种电子设备,结合图16来看,图16为本发明提供的电子设备一实施例的结构示意图,电子设备1600包括处理器1601、存储器1602及存储在存储器1602上并可在处理器1601上运行的计算机程序,处理器1601执行程序时,实现如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法。
作为优选的实施例,上述电子设备1600还包括显示器1603,用于显示处理器1601执行如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法。
示例性的,计算机程序可以被分割成一个或多个模块/单元,一个或者多个模块/单元被存储在存储器1602中,并由处理器1601执行,以完成本发明。一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述计算机程序在电子设备1600中的执行过程。例如,计算机程序可以被分割成上述实施例中的第一获取单元1401、第一处理单元1402、加密单元1403、第二获取单元1501、第二处理单元1502以及解密单元1503,各单元的具体功能如上所述,在此不一一赘述。
电子设备1600可以是带可调摄像头模组的桌上型计算机、笔记本、掌上电脑或智能手机等设备。
其中,处理器1601可能是一种集成电路芯片,具有信号的处理能力。上述的处理器1601可以是通用处理器,包括中央处理器(Central Processing Unit,CPU)、网络处理器(Network Processor,NP)等;还可以是数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
其中,存储器1602可以是,但不限于,随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-OnlyMemory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。其中,存储器1602用于存储程序,所述处理器1601在接收到执行指令后,执行所述程序,前述本发明实施例任一实施例揭示的流程定义的方法可以应用于处理器1601中,或者由处理器1601实现。
其中,显示器1603可以是LCD显示屏,也可以是LED显示屏。例如,手机上的显示屏。
可以理解的是,图16所示的结构仅为电子设备1600的一种结构示意图,电子设备1600还可以包括比图16所示更多或更少的组件。图16中所示的各组件可以采用硬件、软件或其组合实现。
根据本发明上述实施例提供的计算机可读存储介质和电子设备,可以参照根据本发明如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法具体描述的内容实现,并具有与如上所述的基于特殊矩阵运算的图像加密方法,和/或如上所述的基于特殊矩阵运算的图像解密方法类似的有益效果,在此不再赘述。
本发明公开了一种基于特殊矩阵运算的图像加密方法、解密方法,在加密方法中,首先,对待加密图像进行有效的获取;进而,分别利用行列首位,步长生成行加密向量和列加密向量;最后,把行列密钥与重构后矩阵的合并,合并后的矩阵进行特殊矩阵运算并利用Mod打乱,得到最终的密文图像。在解密方法中,首先,对加密图像进行有效获取;进而,分别利用行列首位,步长生成行解密向量和列解密向量;最后,恢复打乱加密图片由行解密向量和列解密向量决定,且恢复后的加密图片相邻像素值之间存在很强的相关性,即只要知道一个像素值和其前一个像素值,配合密钥就能恢复真实的像素值。
本发明技术方案,利用首位,步长生成的行加密向量和列加密向量,并实现密钥与图像矩阵的合并,特殊矩阵运算及打乱,以此分别对图像矩阵行和列进行加密,利用了矩阵运算的高效性,既保持了很低算法的时间复杂度,又提高了对大图像的加密质量,同时也能保证图像信息的安全性。
以上所述,仅为本发明较佳的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。
Claims (8)
1.一种基于特殊矩阵运算的图像加密方法,其特征在于,包括:
获取待加密图像;
根据随机数,生成行加密向量和列加密向量;
根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像。
2.根据权利要求1所述的基于特殊矩阵运算的图像加密方法,其特征在于,所述根据随机数,生成行加密向量和列加密向量,包括:
根据随机数,确定第一首位数和第一随机步长;
根据所述第一首位数、所述第一随机步长和预设的加密长度,提取预设整数集合中的整数,生成所述列加密向量和所述行加密向量。
3.根据权利要求1所述的基于特殊矩阵运算的图像加密方法,其特征在于,所述根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像,包括:
将所述行加密向量和所述待加密图像转换的数据矩阵的每一行的行数据相加,得到第一转换矩阵;
根据所述第一转换矩阵的第1行的行数据至所述第一转换矩阵的第i行的所有行数据之和,确定第二转换矩阵的第i行的行数据,生成所述第二转换矩阵,其中,i为整数;
将所述行加密向量化为正序后,将所述第二转换矩阵打乱后并转置,生成第三转换矩阵。
4.根据权利要求3所述的基于特殊矩阵运算的图像加密方法,其特征在于,所述根据所述行加密向量和所述列加密向量,对所述待加密图像的行数据和列数据进行打乱,生成加密图像,包括:
将所述列加密向量和所述第三转换矩阵的数据矩阵的每一列的列数据相加,得到第四转换矩阵;
根据所述第四转换矩阵的第1行的行数据至所述第四转换矩阵的第i行的所有行数据之和,确定第五转换矩阵的第i行的行数据,生成所述第五转换矩阵;
将所述列加密向量化为正序后,将所述第五转换矩阵打乱后并转置,生成第六转换矩阵;
根据所述第六转换矩阵,生成所述加密图像。
5.一种基于特殊矩阵运算的图像解密方法,其特征在于,包括:
获取加密图像,其中,所述加密图像根据权利要求1至5任一项所述的基于特殊矩阵运算的图像加密方法生成;
根据随机数,生成行解密向量和列解密向量;
根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像。
6.根据权利要求5所述的基于特殊矩阵运算的图像解密方法,其特征在于,所述根据随机数,生成行解密向量和列解密向量,包括:
根据随机数,确定第二首位数和第二随机步长;
根据所述第二首位数、所述第二随机步长和预设的解密长度,提取预设整数集合中的整数,生成所述列解密向量和所述行解密向量。
7.根据权利要求6所述的基于特殊矩阵运算的图像解密方法,其特征在于,所述根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像,包括:
将所述列解密向量化为正序后,将所述加密图像转置后的数据矩阵打乱,生成第七转换矩阵;
根据所述第七转换矩阵的第i行的行数据与所述第七转换矩阵的第i-1行的所有行数据之差,确定第八转换矩阵的第i行的行数据,生成所述第八转换矩阵,其中,i为整数;
将所述第八转换矩阵的每一列的列数据都减去所述列解密向量,并进行转置,确定第九转换矩阵。
8.根据权利要求7所述的基于特殊矩阵运算的图像解密方法,其特征在于,所述根据所述行加密向量和所述列加密向量,对所述加密图像的行数据和列数据进行解密,生成解密图像,包括:
将所述行解密向量化为正序后,将所述第九转换矩阵转置后的数据矩阵打乱,生成第十转换矩阵;
根据所述第十转换矩阵的第i行的行数据与所述第十转换矩阵的第i-1行的所有行数据之差,确定第十一转换矩阵的第i行的行数据,生成所述第十一转换矩阵,其中,i为整数;
将所述第十一转换矩阵的每一行的行数据都减去所述行解密向量,确定第十二转换矩阵;
根据所述第十二转换矩阵,生成所述解密图像。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210486084.9A CN114915464B (zh) | 2022-05-06 | 2022-05-06 | 一种基于特殊矩阵运算的图像加密方法、解密方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210486084.9A CN114915464B (zh) | 2022-05-06 | 2022-05-06 | 一种基于特殊矩阵运算的图像加密方法、解密方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114915464A true CN114915464A (zh) | 2022-08-16 |
CN114915464B CN114915464B (zh) | 2024-07-12 |
Family
ID=82766305
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210486084.9A Active CN114915464B (zh) | 2022-05-06 | 2022-05-06 | 一种基于特殊矩阵运算的图像加密方法、解密方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114915464B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115834790A (zh) * | 2023-01-09 | 2023-03-21 | 徐工汉云技术股份有限公司 | 基于像素移动的信息加密传输方法和信息解密传输方法 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108122188A (zh) * | 2018-01-12 | 2018-06-05 | 哈尔滨工业大学深圳研究生院 | 一种图像加密方法 |
CN111461952A (zh) * | 2020-03-30 | 2020-07-28 | 三维通信股份有限公司 | 图像加密方法、计算机设备和计算机可读存储介质 |
CN112383523A (zh) * | 2020-11-02 | 2021-02-19 | 国网电子商务有限公司 | 一种图像加密方法及相关装置 |
CN112422268A (zh) * | 2020-11-10 | 2021-02-26 | 郑州轻工业大学 | 一种基于分块置乱与状态转换的图像加密方法 |
WO2021227349A1 (zh) * | 2020-05-11 | 2021-11-18 | 华南理工大学 | 一种生物特征隐私保护的前端人像加密与识别方法 |
-
2022
- 2022-05-06 CN CN202210486084.9A patent/CN114915464B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108122188A (zh) * | 2018-01-12 | 2018-06-05 | 哈尔滨工业大学深圳研究生院 | 一种图像加密方法 |
CN111461952A (zh) * | 2020-03-30 | 2020-07-28 | 三维通信股份有限公司 | 图像加密方法、计算机设备和计算机可读存储介质 |
WO2021227349A1 (zh) * | 2020-05-11 | 2021-11-18 | 华南理工大学 | 一种生物特征隐私保护的前端人像加密与识别方法 |
CN112383523A (zh) * | 2020-11-02 | 2021-02-19 | 国网电子商务有限公司 | 一种图像加密方法及相关装置 |
CN112422268A (zh) * | 2020-11-10 | 2021-02-26 | 郑州轻工业大学 | 一种基于分块置乱与状态转换的图像加密方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115834790A (zh) * | 2023-01-09 | 2023-03-21 | 徐工汉云技术股份有限公司 | 基于像素移动的信息加密传输方法和信息解密传输方法 |
CN115834790B (zh) * | 2023-01-09 | 2023-04-28 | 徐工汉云技术股份有限公司 | 基于像素移动的信息加密传输方法和信息解密传输方法 |
Also Published As
Publication number | Publication date |
---|---|
CN114915464B (zh) | 2024-07-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Chen et al. | Compression-unimpaired batch-image encryption combining vector quantization and index compression | |
Liu et al. | Reversible data hiding in encrypted images using chunk encryption and redundancy matrix representation | |
Lee et al. | Digital image sharing by diverse image media | |
Zheng et al. | Lossless data hiding algorithm for encrypted images with high capacity | |
Zhang et al. | Harnessing the hybrid cloud for secure big image data service | |
Chen | Image sharing method for gray-level images | |
Chai et al. | A robust compressed sensing image encryption algorithm based on GAN and CNN | |
Liu et al. | A novel multiple-level secret image sharing scheme | |
CN110110535A (zh) | 一种基于像素矩阵的低失真隐写方法 | |
CN110634096B (zh) | 一种自适应多模态的信息隐藏方法及装置 | |
CN114915464B (zh) | 一种基于特殊矩阵运算的图像加密方法、解密方法 | |
Liu et al. | A fully reversible data hiding scheme in encrypted images based on homomorphic encryption and pixel prediction | |
Gao et al. | A secure lossless recovery for medical images based on image encoding and data self-embedding | |
CN112035847A (zh) | 一种图像加密、解密方法及装置、电子设备和存储介质 | |
Qiu et al. | A case study for practical issues of DCT based bitmap selective encryption methods | |
Cao et al. | Low-complexity reversible data hiding in encrypted image via MSB hierarchical coding and LSB compression | |
CN115131253B (zh) | 一种用于对抗jpeg重压缩的秘密图像分享方法和*** | |
Abed | A proposed encoding and hiding text in an image by using fractal image compression | |
CN115134471A (zh) | 图像加密、解密方法以及相关设备 | |
CN110009703B (zh) | 一种基于混沌***的图像加密、解密方法及设备 | |
Ajmera et al. | Video Steganography: Using Scrambling-AES Encryption and DCT, DST Steganography | |
Zhu et al. | TPE-C: Thumbnail-preserving encryption based on chaotic system | |
Rohith et al. | Reversible data embedding scheme in encrypted image using Arnold transform for satellite images | |
Zhao | An improved scheme for image scaling, cropping and colour correction in encrypted domain | |
Yan et al. | Encryption in high dynamic range images for RGBE format |
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 |