【Block总结】ELGCA模块,池化-转置(PT)注意力和深度卷积有效聚合局部和全局上下文信息
ELGCA结构
论文题目:ELGC-Net: Efficient Local-Global Context Aggregation for Remote Sensing Change Detection
论文链接:https://arxiv.org/pdf/2403.17909
官方github:https://github.com/techmn/elgcnet
高效局部-全局上下文聚合器(ELGCA)是ELGC-Net框架中的核心模块,旨在有效捕获遥感图像中的局部和全局上下文信息。其结构主要包括以下几个方面:
-
Siamese编码器:ELGC-Net采用Siamese架构,通过两个相同的编码器分别处理输入的时间序列图像。这种设计使得模型能够有效地提取和比较两个图像之间的特征。
-
池化-转置(PT)注意力机制:ELGCA引入了一种新颖的PT注意力机制,通过池化操作来增强全局上下文的捕获,同时利用转置卷积来恢复特征图的空间分辨率。这种机制能够在保持计算效率的同时,捕获更丰富的上下文信息。
-
深度卷积:通过深度卷积,ELGCA能够在不同的空间尺度上提取特征,从而增强模型对细微变化的敏感性。这种方法有效地减少了模型的参数数量,同时提高了特征提取的效率。
-
融合模块:在特征提取后,ELGCA通过融合模块将来自不同图像的特征进行整合,生成最终的变化检测输出。这一过程确保了模型能够综合考虑局部和全局信息,从而提高检测精度。
优点
ELGCA的设计带来了多个显著的优点:
-
提高检测精度:通过有效聚合局部和全局上下文信息,ELGCA显著提高了遥感变化检测的准确性。实验结果表明,ELGC-Net在多个挑战性数据集上均超越了现有的最先进方法。
-
减少计算复杂性:ELGCA通过引入高效的注意力机制和深度卷积,减少了模型的计算复杂性和参数数量,使得ELGC-Net在资源受限的环境中也能高效运行。
-
适应性强:ELGCA能够自适应地处理不同尺度和不同类型的遥感图像,增强了模型在多种应用场景下的适用性,包括城市监测、环境变化分析等。
-
轻量化设计:ELGC-Net还提供了一个轻量级变体(ELGC-Net-LW),在保持性能的同时,进一步减少了计算资源的需求,适合在边缘设备上进行实时变化检测。
综上所述,高效局部-全局上下文聚合器(ELGCA)通过其创新的设计和实现,不仅提升了遥感变化检测的性能,还为实际应用提供了更高的灵活性和效率。
代码结构
import torch
import torch.nn as nnclass ELGCA(nn.Module):"""Efficient local global context aggregation moduledim: number of channels of inputheads: number of heads utilized in computing attention"""def __init__(self, dim, heads=4):super().__init__()self.heads = headsself.dwconv = nn.Conv2d(dim // 2, dim // 2, 3, padding=1, groups=dim // 2)self.qkvl = nn.Conv2d(dim // 2, (dim // 4) * self.heads, 1, padding=0)self.pool_q = nn.AvgPool2d(kernel_size=3, stride=2, padding=1)self.pool_k = nn.MaxPool2d(kernel_size=2, stride=2, padding=0)self.act = nn.GELU()def forward(self, x):B, C, H, W = x.shapex1, x2 = torch.split(x, [C // 2, C // 2], dim=1)# apply depth-wise convolution on half channelsx1 = self.act(self.dwconv(x1))# linear projection of other half before computing attentionx2 = self.act(self.qkvl(x2))x2 = x2.reshape(B, self.heads, C // 4, H, W)q = torch.sum(x2[:, :-3, :, :, :], dim=1)k = x2[:, -3, :, :, :]q = self.pool_q(q)k = self.pool_k(k)v = x2[:, -2, :, :, :].flatten(2)lfeat = x2[:, -1, :, :, :]qk = torch.matmul(q.flatten(2), k.flatten(2).transpose(1, 2))qk = torch.softmax(qk, dim=1).transpose(1, 2)x2 = torch.matmul(qk, v).reshape(B, C // 4, H, W)x = torch.cat([x1, lfeat, x2], dim=1)return xif __name__ == '__main__':# 创建一个随机输入张量,形状为 (batch_size,height×width,channels)input = torch.rand(1, 64,40, 40)# 实例化ELGCA模块block = ELGCA(64,4)# 前向传播output = block(input)# 打印输入和输出的形状print(input.size())print(output.size())
输出结果
torch.Size([1, 64, 40, 40])
torch.Size([1, 64, 40, 40])
主要组件
-
初始化方法 (
__init__
):dim
: 输入通道数。heads
: 注意力头的数量,默认为4。dwconv
: 深度卷积层,用于对输入的一半通道进行卷积操作,增强局部特征提取。qkvl
: 线性投影层,将另一半通道的特征映射到多个注意力头。pool_q
和pool_k
: 池化层,用于对查询(Q)和键(K)进行下采样,分别使用平均池化和最大池化。act
: 激活函数,使用GELU(高斯误差线性单元)。
-
前向传播方法 (
forward
):- 输入
x
的形状为(B, C, H, W)
,其中B
是批量大小,C
是通道数,H
和W
是特征图的高度和宽度。 - 使用
torch.split
将输入x
分为两部分x1
和x2
,每部分的通道数为C // 2
。 - 对
x1
应用深度卷积,提取局部特征。 - 对
x2
进行线性投影,准备计算注意力。 - 将
x2
重塑为(B, heads, C // 4, H, W)
,以便于后续的注意力计算。 - 计算查询(Q)、键(K)和值(V):
q
是x2
的前heads-3
个通道的和。k
是x2
的倒数第三个通道。v
是x2
的倒数第二个通道,展平为二维。lfeat
是x2
的最后一个通道,保留用于后续拼接。
- 对
q
和k
进行池化,减少计算量。 - 计算注意力权重
qk
,并通过softmax归一化。 - 使用注意力权重对值(V)进行加权求和,得到新的特征图
x2
。 - 最后,将
x1
、lfeat
和x2
在通道维度上拼接,形成最终输出。
- 输入
总结
ELGCA模块通过深度卷积和注意力机制的结合,有效地聚合了局部和全局上下文信息。这种设计不仅提高了特征提取的效率,还降低了计算复杂性,使得ELGC-Net在遥感变化检测任务中表现出色。
相关文章:

【Block总结】ELGCA模块,池化-转置(PT)注意力和深度卷积有效聚合局部和全局上下文信息
ELGCA结构 论文题目:ELGC-Net: Efficient Local-Global Context Aggregation for Remote Sensing Change Detection 论文链接:https://arxiv.org/pdf/2403.17909 官方github:https://github.com/techmn/elgcnet 高效局部-全局上下文聚合器&…...
MERN全栈脚手架(MongoDB、Express、React、Node)与Yeoman详解
MERN 全栈脚手架是一种用于快速构建基于 MongoDB、Express、React 和 Node.js 的全栈应用的框架或模板。它帮助开发者快速启动项目,减少了从零开始配置的时间。以下是关于 MERN 全栈脚手架的详细解析。 一、MERN 技术栈简介 MongoDB: 文档型数据库,用于…...

基于springboot+vue+微信小程序的宠物领养系统
基于springbootvue微信小程序的宠物领养系统 一、介绍 本项目利用SpringBoot、Vue和微信小程序技术,构建了一个宠物领养系统。 本系统的设计分为两个层面,分别为管理层面与用户层面,也就是管理者与用户,管理权限与用户权限是不…...
如何使用策略模式并让spring管理
1、策略模式公共接口类 BankFileStrategy public interface BankFileStrategy {String getBankFile(String bankType) throws Exception; } 2、策略模式业务实现类 Slf4j Component public class ConcreteStrategy implements BankFileStrategy {Overridepublic String ge…...
react中hooks之useRef 用法总结
1. 基本概念 useRef 是 React 的一个 Hook,返回一个可变的 ref 对象,其 .current 属性被初始化为传入的参数。这个对象在组件的整个生命周期内保持不变。 2. 主要用途和特性 2.1 获取 DOM 元素实例 function TextInputWithFocusButton() {const inpu…...

使用 Docker 部署 Java 项目(通俗易懂)
目录 1、下载与配置 Docker 1.1 docker下载(这里使用的是Ubuntu,Centos命令可能有不同) 1.2 配置 Docker 代理对象 2、打包当前 Java 项目 3、进行编写 DockerFile,并将对应文件传输到 Linux 中 3.1 编写 dockerfile 文件 …...
如何在Ubuntu上安装和配置Git
版本控制系统(VCS)是软件开发过程中不可或缺的工具之一,它帮助开发者跟踪代码变更、协作开发以及管理不同版本的项目。Git作为当前最流行的分布式版本控制系统,因其高效性和灵活性而广受青睐。本文将指导你如何在Ubuntu操作系统上…...

FPGA 21 ,深入理解 Verilog 中的基数,以及二进制数与十进制数之间的关系( Verilog中的基数 )
目录 前言 一. 基数基础 1.1 基数介绍 2.1 基数符号 3.1 二进制数 二. 二进制与十进制数 三. 二进制数 3.1 定义寄存器类型变量 3.2 定义线网类型变量 3.3 赋值操作 3.4 解析二进制数为十进制数 四. 代码示例 五. 注意事项 六. 更多操作 前言 在Verilog中&#…...
【redis】redis-cli命令行工具的使用
redis-cli命令行工具是一个功能强大的Redis客户端,它允许用户与Redis数据库进行交互和管理。 以下是一些常用参数的使用说明: 基本连接参数 -h, --host <hostname>:指定要连接的Redis服务器的主机名或IP地址。如果未指定,…...

使用Matplotlib显示中文的方法
1 问题提出 使用图1所示的代码进行matplotlib绘图时,因为其默认不支持中文,此时无法显示正确内容,如图2所示。 图1 matplotlib绘图绘图代码 图2 matplotlib无法显示中文 2 问题解决 2.1 设置全局字体 在图1所示的代码中,第13…...

SQL Server2022详细安装教程
1. 打开SQL Server官网:SQL Server 下载 | Microsoft 2. 选择Developer版 3. 下载好安装包,打开,选择自定义 4. 选择下载位置,最好不要在C盘即主磁盘即可。等待下载 5. 下载成功之后会弹出这个框 6. 点击“安装”&#…...

家里温度随心控,假期出行更舒适~
春节假期马上到来啦!这是放松身心、陪伴家人的最佳时机~ 但旅途结束的温差变化、空气质量问题是否让你有些担忧呢? 别担心!有了约克VRF中央空调,让你的假期更加舒心无忧~ 清新空气,自在出游…...
压力测试详解
压力测试 压力测试是一种软件测试,用于验证软件应用程序的稳定性和可靠性。压力测试的目标是在极其沉重的负载条件下测量软件的健壮性和错误处理能力,并确保软件在危急情况下不会崩溃。它甚至可以测试超出正常工作点的测试,并评估软件在极端…...

从epoll事件的视角探讨TCP:三次握手、四次挥手、应用层与传输层之间的联系
目录 一、应用层与TCP之间的联系 二、 当通信双方中的一方如客户端主动断开连接时,仅是在客户端的视角下连接已经断开,在服务端的眼中,连接依然存在,为什么?——触发EPOLLRDHUP事件:对端关闭连接或停止写…...

Redis复制(replica)
Redis主从复制 [Redis主从复制](replica)是一个多Redis实例进行数据同步的过程,其中一个实例是主实例(Master),其他实例是从实例(Slave)。主实例负责处理命令请求,而从实…...

[云讷科技] 用于软件验证的仿真环境
我们使用Pursuit自动驾驶仪为各种场景设计仿真环境,以便用户可以在模拟环境中直接验证他们的软件,无需现场测试。该环境基于Gazebo引擎。 1. 工作区目录 模拟环境的工作区位于提供的U盘中的~/pursuit_space/sitl_space_pursuit中。用户可以按照用户手册…...
使用 Vite 和 Vue 框架创建组件库
在前端开发中,组件化开发已成为一种高效、可维护的方式。通过创建组件库,不仅可以提高代码复用率,还能方便地在不同项目之间共享组件。本文将详细介绍如何使用 Vite 和 Vue 框架创建一个组件库,并将其导出供其他项目使用。为保持一…...
【数据结构学习笔记】19:跳表(Skip List)
介绍 跳表是一个能在 O ( n l o g n ) O(nlogn) O(nlogn)时间完成查找、插入、删除的数据结构,相比于树形结构优点就是很好写(所以也用于实现Redis ZSet)。其核心思想就是维护一个元素有序的,能随机提升索引层数的链表。最下面一…...
【8】深入理解 Go 语言中的协程-从基础到高级应用
文章目录 一、引言 🌟二、协程基础概念 🧐(一)什么是协程(二)协程与线程、进程的区别三、协程的创建与启动 🚀(一)使用 go 关键字创建协程(二)简单…...

深入理解 ECMAScript 2024 新特性:字符串 isWellFormed 方法
ECMAScript 2024 引入了一个新的字符串实例方法:String.prototype.isWellFormed。这一新增功能是为了帮助开发者更容易地验证字符串是否为有效的 Unicode 文本。本文将详细介绍这一方法的使用场景、实现原理及其在实际应用中的价值。 String.prototype.isWellFormed…...
算法分析与设计之贪心算法
文章目录 前言一、Greedy Algorithms1.1 贪心选择性质1.2 最优子结构性质1.3 正确性证明 二、典型例题2.1 Interval Scheduling间隔调度2.2 Interval Partitioning最少间教室排课2.3 Selecting Breakpoints选择加油站停靠点2.4 硬币找零2.5 Scheduling to Minimizing Lateness2…...

Centos 宝塔安装
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh 安装成功界面 宝塔说明文档 https://www.bt.cn/admin/servers#wcu 或者可以注册宝塔账号 1 快速部署 安装docker 之后 2 需要在usr/bin下下载do…...

蓝桥与力扣刷题(709 转换成小写字母)
题目:给你一个字符串 s ,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。 示例 1: 输入:s "Hello" 输出:"hello"示例 2: 输入:s "here…...

Redis的过期策略、内存淘汰机制
Redis只能存5G数据,可是你写了10G,那会删5G的数据。怎么删的?还有,你的数据已经设置了过期时间,但是时间到了,为什么内存占用率还是比较高? 一、Redis的过期策略 Redis采用的是定期删除惰性删除策略。 1…...

视觉多模态大模型---MiniMax-vl-01---以闪电般的注意力缩放基础模型
简介 MiniMax-VL-01 是与今年1月15日由上海稀宇科技有限公司(MiniMax)发布并开源的一款视觉多模态大模型,它与基础语言大模型 MiniMax-Text-01 一同构成了 MiniMax-01 系列。这款模型的设计初衷是为了应对日益增长的长上下文处理需求&#x…...

【微服务】面试 3、 服务监控 SkyWalking
微服务监控的原因 问题定位:在微服务架构中,客户端(如 PC 端、APP 端、小程序等)请求后台服务需经过网关再路由到各个微服务,服务间可能存在多链路调用。当某一微服务挂掉时,在复杂的调用链路中难以迅速确定…...

【案例81】NMC调用导致数据库的效率问题
问题现象 客户在使用NC系统时,发现系统特别卡顿。需要紧急排查。 问题分析 排查NMC发现,所有的线程都处于执行SQL层面,说明数据库当前出现了异常。查看数据库资源状态发现,Oracle相关进程CPU利用率达到了100%。 查看现在数据库…...

Linux_信号
信号的概念 && 知识补充 信号是进程之间事件异步通知的一种方式,是一种软中断。 标准信号:编号为1-31之间都是标准信号,这些都是预定义信号,用于通知进程发生的各种事件。实时信号:编号从32开始起均是实时信号…...

LeetCode100之搜索二维矩阵(46)--Java
1.问题描述 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回…...

学员答疑:安卓分屏窗口的TouchableRegion设置流程追踪
背景: vip学员在群里问到了一个分屏触摸区域设置的问题,开始以为就是和普通Activity设置区域没啥差别,都是在InputMonitor中进行的设置,但是仔细研究下来其实并不是哈。本文就带大家来手把手分析一下分屏情况下的触摸区域是怎么设置的。 d…...