Abstract— Image nonlocal self-similarity (NSS) property has been widely exploited via various sparsity models such as joint sparsity (JS) and group sparse coding (GSC). However, the existing NSS-based sparsity models are either too restrictive, e.g., JS enforces the sparse codes to share the same support, or too general, e.g., GSC imposes only plain sparsity on the group coefficients, which limit their effectiveness for modeling real images. In this paper, we propose a novel NSS-based sparsity model, namely, low-rank regularized group sparse coding (LR-GSC), to bridge the gap between the popular GSC and JS. The proposed LR-GSC model simultaneously exploits the sparsity and low-rankness of the dictionary-domain coefficients for each group of similar patches. An alternating minimization with an adaptive adjusted parameter strategy is developed to solve the proposed optimization problem for different image restoration tasks, including image denoising, image deblocking, image inpainting, and image compressive sensing. Extensive experimental results demonstrate that the proposed LR-GSC algorithm outperforms many popular or state-of-the-art methods in terms of objective and perceptual metrics.翻译

时间: 2024-04-28 21:25:41 浏览: 12
摘要—图像的非局部自相似性(NSS)属性已经被广泛应用于各种稀疏模型中,例如联合稀疏(JS)和群组稀疏编码(GSC)。然而,现有的基于NSS的稀疏模型要么太过严格,例如JS强制使稀疏编码共享相同的支持,要么太过通用,例如GSC仅对群组系数施加简单的稀疏性,这限制了它们对实际图像建模的有效性。本文提出了一种新的NSS-based稀疏模型,即低秩正则化群组稀疏编码(LR-GSC),以弥合流行的GSC和JS之间的差距。所提出的LR-GSC模型同时利用了每组相似补丁的字典域系数的稀疏性和低秩性。开发了一种带有自适应调整参数策略的交替最小化方法,用于解决不同的图像恢复任务,包括图像去噪、图像去块、图像修复和图像压缩感知。广泛的实验结果表明,所提出的LR-GSC算法在客观和感知度量方面优于许多流行或最先进的方法。
相关问题

nonlocal

`nonlocal` 是 Python 中的一个关键字,用于在嵌套函数中访问和修改外层函数中定义的变量。 在 Python 中,如果在一个函数内部定义了一个局部变量,那么默认情况下该变量只能在该函数内部使用,无法在函数外部访问。但是,如果在一个函数内部定义了另一个函数,那么内部函数可以访问外部函数中的变量。如果内部函数想要修改外部函数中的变量,就需要使用 `nonlocal` 关键字。 例如,下面的代码演示了如何使用 `nonlocal` 关键字: ```python def outer(): x = 0 def inner(): nonlocal x x += 1 print(x) return inner f = outer() f() # 输出 1 f() # 输出 2 f() # 输出 3 ``` 在这个例子中,`outer` 函数定义了一个局部变量 `x` 和一个内部函数 `inner`。在 `inner` 函数中,我们使用 `nonlocal x` 来声明 `x` 是外部函数 `outer` 中的变量,并且可以在 `inner` 中修改它。当我们调用 `outer` 函数时,它返回了 `inner` 函数的引用,并将其赋值给变量 `f`。我们可以通过调用 `f()` 来多次执行 `inner` 函数,每次执行都会将 `x` 的值加 1 并打印出来。

python nonlocal

Python 的 nonlocal 关键字用于在一个函数内部访问并修改其父函数中定义的变量。当一个函数 A 嵌套在另一个函数 B 中,且 A 中使用了 nonlocal 关键字声明变量 x,那么 A 内对 x 的修改也会反映在函数 B 中对 x 的访问中。需要注意的是,nonlocal 只能用于访问非全局作用域的变量,即嵌套函数中的局部变量或者任何上一级函数的变量,不能访问全局作用域中的变量。

相关推荐

最新推荐

recommend-type

Python中 Global和Nonlocal的用法详解

global关键字用来在函数或其他局部作用域中使用全局变量, nonlocal声明的变量不是局部变量,也不是全局变量,而是外部嵌套函数内的变量。这篇文章主要介绍了Python中 Global和Nonlocal的用法,需要的朋友可以参考下
recommend-type

埃森哲制药企业数字化转型项目顶层规划方案glq.pptx

埃森哲制药企业数字化转型项目顶层规划方案glq.pptx
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

已知n个人(以编号0,1,2,3...n-1分别表示)围坐在一张圆桌周围。从编号为0的人开始报数1,数到m的那个人出列;他的下一个人又从1开始报数,数到m+1的那个人又出列(每次报数值加1);依此规律重复下去,直到圆桌周围的人全部出列。用递归方法解决

这个问题可以使用递归方法解决。下面是一个思路: 1. 定义一个函数,接收三个参数:n、m、i,表示还剩下n个人,每次数到m时出列,当前报数的人是i; 2. 如果n=1,返回i,即最后留下的那个人的编号; 3. 否则,计算出下一个出列的人的编号j,通过递归调用函数解决n-1个人的问题,其结果为k; 4. 如果k < j,即当前i之后出列的人的编号为k,需要将k转换为在i之前出列的编号,返回值为 k+(n-1); 5. 如果k>=j,即当前i之后出列的人的编号为k,返回值为 k-(j-1); 下面是对应的Python代码: ```python def josephus(n, m, i):