当前位置: 首页 > news >正文

【计算机视觉】语义分割:Mask2Former:统一分割框架的技术突破与实战指南

在这里插入图片描述

深度解析Mask2Former:统一分割框架的技术突破与实战指南

  • 技术架构与创新设计
      • 核心设计理念
      • 关键技术组件
  • 环境配置与安装指南
      • 硬件要求
      • 安装步骤
      • 预训练模型下载
  • 实战全流程解析
      • 1. 数据准备
      • 2. 配置文件定制
      • 3. 训练流程
      • 4. 推理与可视化
  • 核心技术深度解析
      • 1. 掩膜注意力机制
      • 2. 多任务适配策略
      • 3. 动态查询机制
  • 常见问题与解决方案
      • 1. GPU显存不足
      • 2. 训练收敛困难
      • 3. 预测掩膜不连续
  • 性能优化策略
      • 1. 混合精度训练
      • 2. 模型量化部署
      • 3. 多GPU推理加速
  • 学术背景与核心论文
      • 基础论文
      • 技术突破
  • 应用场景与展望
      • 典型应用领域
      • 未来发展方向

Mask2Former是Meta AI推出的新一代通用分割框架,在CVPR 2022中提出,首次实现了全景分割、实例分割和语义分割任务的统一建模。该模型在COCO、ADE20K等基准数据集上均达到SOTA性能,其创新性的掩膜注意力机制重新定义了分割任务的技术范式。本文将从技术原理到工程实践,深入解析这一突破性框架的设计哲学与使用方法。

技术架构与创新设计

核心设计理念

  1. 任务统一建模:通过动态掩膜预测机制实现多任务统一
  2. 分层特征交互:多尺度特征的高效融合
  3. 内存优化策略:突破Transformer的显存限制

在这里插入图片描述

图:Mask2Former的三阶段处理流程(来源:原论文)

关键技术组件

  • 像素解码器:基于Deformable DETR的跨尺度特征提取
  • Transformer解码器:N层交叉注意力模块堆叠
  • 动态掩膜预测头:生成任务自适应的分割掩膜

环境配置与安装指南

硬件要求

组件推荐配置最低要求
GPUNVIDIA A100 (40GB)RTX 3090 (24GB)
CPUXeon 16核Core i7
内存64GB32GB

安装步骤

# 创建虚拟环境
conda create -n mask2former python=3.9 -y
conda activate mask2former# 安装PyTorch
pip install torch==1.13.1+cu116 torchvision==0.14.1+cu116 --extra-index-url https://download.pytorch.org/whl/cu116# 安装Detectron2
python -m pip install 'git+https://github.com/facebookresearch/detectron2.git'# 安装Mask2Former
git clone https://github.com/facebookresearch/Mask2Former.git
cd Mask2Former
pip install -r requirements.txt
python setup.py build develop

预训练模型下载

# 全景分割模型(COCO)
wget https://dl.fbaipublicfiles.com/maskformer/mask2former/coco/panoptic/maskformer2_swin_large_IN21k_384_bs16_100ep/model_final_f07440.pkl# 语义分割模型(ADE20K)
wget https://dl.fbaipublicfiles.com/maskformer/mask2former/ade20k/semantic/maskformer2_swin_large_IN21k_384_bs16_160k/model_final_6e87a1.pkl

实战全流程解析

1. 数据准备

支持COCO、Cityscapes等标准格式:

datasets/coco/
├── annotations/
│   ├── panoptic_train2017.json
│   └── panoptic_val2017.json
└── panoptic_train2017/  # 全景标注图像

2. 配置文件定制

# configs/coco/panoptic-segmentation/swin/maskformer2_swin_large_bs16_100ep.yaml
_MODEL:MASK_FORMER:NUM_OBJECT_QUERIES: 100TRANSFORMER_DECODER_NAME: "MultiScaleMaskedTransformerDecoder"
_DATASETS:TRAIN: ("coco_2017_train_panoptic",)TEST: ("coco_2017_val_panoptic",)
SOLVER:BASE_LR: 0.0001MAX_ITER: 90000
INPUT:MIN_SIZE_TRAIN: (512, 640, 768)

3. 训练流程

# 单GPU训练
python train_net.py \--config-file configs/coco/panoptic-segmentation/swin/maskformer2_swin_large_bs16_100ep.yaml \--num-gpus 1 \OUTPUT_DIR outputs/coco_panoptic# 分布式训练(8 GPU)
python train_net.py \--config-file configs/coco/panoptic-segmentation/swin/maskformer2_swin_large_bs16_100ep.yaml \--num-gpus 8 \--dist-url tcp://127.0.0.1:12345 \OUTPUT_DIR outputs/coco_panoptic_dist

4. 推理与可视化

from detectron2.utils.visualizer import Visualizer
from predictor import VisualizationDemo# 初始化推理器
demo = VisualizationDemo(cfg=cfg,model=model,instance_mode=ColorMode.IMAGE
)# 执行推理
img = cv2.imread("input.jpg")
predictions = demo.run_on_image(img)# 可视化结果
vis = demo.draw_instance_predictions(predictions["instances"].to("cpu"))
cv2.imwrite("output.jpg", vis.get_image()[:, :, ::-1])

核心技术深度解析

1. 掩膜注意力机制

class MaskedAttention(nn.Module):def __init__(self, embed_dim, num_heads):super().__init__()self.attn = nn.MultiheadAttention(embed_dim, num_heads)self.mask_conv = nn.Conv2d(embed_dim, 1, kernel_size=1)def forward(self, query, key, value, mask):attn_mask = self.mask_conv(mask).flatten(2).sigmoid()return self.attn(query, key, value, key_padding_mask=attn_mask)

2. 多任务适配策略

def forward(self, batched_inputs):images = [x["image"] for x in batched_inputs]features = self.backbone(images.tensor)# 生成统一特征表示mask_features = self.pixel_decoder(features)# 任务分支选择if self.task == "panoptic":outputs = self.panoptic_head(mask_features)elif self.task == "instance":outputs = self.instance_head(mask_features)else:outputs = self.semantic_head(mask_features)return outputs

3. 动态查询机制

class QueryGenerator(nn.Module):def __init__(self, in_channels, num_queries):super().__init__()self.query_embed = nn.Embedding(num_queries, in_channels)self.coord_conv = nn.Conv2d(in_channels, 2, kernel_size=1)def forward(self, features):B, C, H, W = features.shapecoord_map = self.coord_conv(features)  # 生成坐标注意力图queries = self.query_embed.weight.unsqueeze(0).repeat(B,1,1)return queries, coord_map

常见问题与解决方案

1. GPU显存不足

现象CUDA out of memory during training
优化策略

# 启用梯度检查点
config.MODEL.MASK_FORMER.CHECKPOINT_TRANSFORMER = True# 降低输入分辨率
config.INPUT.MIN_SIZE_TRAIN = (384, 512)# 减小批次大小
config.SOLVER.IMS_PER_BATCH = 4

2. 训练收敛困难

诊断与解决

  1. 检查学习率配置:
    SOLVER:BASE_LR: 0.0001LR_SCHEDULER_NAME: "WarmupMultiStepLR"STEPS: (60000, 80000)
    
  2. 验证数据增强策略:
    INPUT:CROP:ENABLED: TrueTYPE: "absolute"SIZE: (512, 512)
    

3. 预测掩膜不连续

优化参数调整

# 调整掩膜阈值
config.MODEL.SEM_SEG_HEAD.MASK_THRESHOLD = 0.4# 增强后处理
config.MODEL.MASK_FORMER.TEST.MASK_ENSEMBLE = True

性能优化策略

1. 混合精度训练

python train_net.py \--config-file configs/coco/panoptic-segmentation/swin/maskformer2_swin_large_bs16_100ep.yaml \--amp \--fp16

2. 模型量化部署

# 导出TorchScript
python export_model.py \--config-file configs/coco/panoptic-segmentation/swin/maskformer2_swin_large_bs16_100ep.yaml \--output ./exported_model \--format torchscript# TensorRT优化
trtexec --onnx=mask2former.onnx \--saveEngine=mask2former.engine \--fp16 \--builderOptimizationLevel=5

3. 多GPU推理加速

from detectron2.engine import DefaultPredictor
from detectron2.data.parallel import ParallelLoader# 并行数据加载
dataloader = ParallelLoader(dataset, num_workers=8)
predictor = DefaultPredictor(cfg)# 批量推理
for batch in dataloader:outputs = predictor(batch)

学术背景与核心论文

基础论文

  • Mask2Former: Masked-attention Mask Transformer for Universal Image Segmentation
    Cheng B, et al. CVPR 2022
    提出掩膜注意力机制,实现全景/实例/语义分割统一建模

  • Transformer-Based Hierarchical Multi-Scale Attention
    Wang W, et al. NeurIPS 2021
    分层多尺度注意力机制的理论基础

  • Deformable DETR: Deformable Transformers for End-to-End Object Detection
    Zhu X, et al. ICLR 2021
    可变形注意力的关键实现

技术突破

  1. 动态查询机制:根据输入内容生成任务自适应的查询向量
  2. 掩膜引导注意力:通过预测掩膜优化注意力计算范围
  3. 多尺度特征融合:跨层级的特征交互策略

应用场景与展望

典型应用领域

  1. 自动驾驶:道路场景全景解析
  2. 医学影像:多器官联合分割
  3. 卫星遥感:地物分类与变化检测
  4. 工业质检:复杂场景缺陷识别

未来发展方向

  1. 视频分割:时序一致性建模
  2. 3D扩展:点云与体数据支持
  3. 开放词汇分割:结合CLIP等文本模型
  4. 边缘部署:移动端实时推理优化

Mask2Former通过统一的分割范式,极大简化了多任务视觉系统的开发流程。本文提供的技术解析与实战指南,将助力开发者快速掌握这一前沿工具。随着Transformer架构的持续进化,Mask2Former有望成为下一代视觉系统的核心基础,推动通用人工智能在分割领域的发展。

相关文章:

【计算机视觉】语义分割:Mask2Former:统一分割框架的技术突破与实战指南

深度解析Mask2Former:统一分割框架的技术突破与实战指南 技术架构与创新设计核心设计理念关键技术组件 环境配置与安装指南硬件要求安装步骤预训练模型下载 实战全流程解析1. 数据准备2. 配置文件定制3. 训练流程4. 推理与可视化 核心技术深度解析1. 掩膜注意力机制…...

Qt二维码demo

使用QZXing库生成的二维码demo 运行结果 实现代码 c文件 #include "mainwindow.h" #include "ui_mainwindow.h" #include "src/myqrcodeheader.h"MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow) {ui-&…...

Java 基础--数组(Array):存储数据的“排排坐”

作者:IvanCodes 发布时间:2025年5月1日🤓 专栏:Java教程 大家好!👋 咱们在编程时,经常需要处理一批相同类型的数据,比如班级里所有同学的成绩 💯、一周每天的最高气温 …...

OpenGL-ES 学习(10) ---- OpenGL-ES Shader语言语法

目录 Shader 举例Shader 语法版本规范声明变量和定法方法向量构造方法矩阵构造方法结构,数组,函数定义结构数组函数 内建函数条件语句和运算符统一变量统一变量块Shader 输入输出插值限定符预处理命令精度限定符不变性 Shader 举例 一个典型的简单的 Sh…...

Unity SpriteAtlas (精灵图集)

🏆 个人愚见,没事写写笔记 🏆《博客内容》:Unity3D开发内容 🏆🎉欢迎 👍点赞✍评论⭐收藏 🔎为什么要打图集? 💡打图集的目的就是减少DrawCall 提高性能 &a…...

(33)VTK C++开发示例 ---图片转3D

文章目录 1. 概述2. CMake链接VTK3. main.cpp文件4. 演示效果 更多精彩内容👉内容导航 👈👉VTK开发 👈 1. 概述 这是 VTK 测试 clipArt.tcl 的改编版本。 提供带有 2D 剪贴画的 jpg 文件,该示例将创建 3D 多边形数据模…...

RAG工程-基于LangChain 实现 Advanced RAG(预检索-查询优化)(上)

Enrich 完善问题 完善问题流程概述 问题转述 在典型RAG架构中,用户问题的质量直接影响检索系统的表现。研究表明,未经优化的自然语言查询会导致: 关键实体识别缺失 语义漂移导致召回偏离 长尾问题检索失败率升高 大多数用户并非提示词工程…...

交我算使用保姆教程:在计算中心利用singularity容器训练深度学习模型

文章目录 准备工作步骤如何封装和使用容器安装创建 Singularity 容器编写 def 文件构建容器查看构建容器的 python 版本本地测试挂载数据集和代码 如何上传数据windows 系统Linux 系统 如何设置作业任务脚本的结构常用的 Slurm 参数一份完整的 slurm 作业示例 如何在 debug 队列…...

CMake中强制启用option定义变量的方法

在CMake中,若要在另一个CMake文件中强制启用由option()定义的变量,可使用set(... FORCE)覆盖缓存变量。具体步骤如下: 使用set命令强制覆盖缓存: 在需要强制启用选项的CMake文件中,使用set命令并指定CACHE和FORCE参数。…...

图解 Git 工作流:理解 Rebase、Merge 与 Pull Request 的区别

图解 Git 工作流:理解 Rebase、Merge 与 Pull Request 的区别 在多人协作开发中,选择合适的 Git 分支管理策略至关重要。Merge、Rebase 和 Pull Request 是最常见的三种方式,它们本质不同,使用场景也不同。 本文将通过流程图&am…...

图与网络模型

目录 图的基本概念 例题:比赛的安排 MATLAB作图 最短路径模型 Dijkstra算法步骤 最短路径的Dijkstra算法示例 Dijkstra算法的Matlab函数 最短路径的Floyd算法模型 最短路径的Floyd算法步骤 Floyd算法的Matlab函数 图的基本概念 图G是一个二重组: …...

连接linux虚拟机并运行C++【从0开始】

连接linux虚拟机并运行C【从0开始】 NetSarang安装后两个,其实更加常用的 安装VMware安装Ubuntu 的 ISO 镜像VMWare--TipsUbuntu快捷键,可以在设置里面修改 连接Linux运行cwhy剪不断,理还乱操作 因为好多判题系统,后台都是Linux环…...

多线程系列二:Thread类

Thread类是jvm用来管理线程的一个类,换句话说,每个线程都有一个唯一的Thread对象与之关联 1.Thread常见构造方法 Thread():创建线程对象Thread(Runnable target):使用Runnable对象创建线程对象Thread(String name):创…...

2025五一杯数学建模C题:社交媒体平台用户分析问题,完整第一问模型与求解+代码

完整代码模型请见文末名片 • 问题1分析: – 来龙去脉和与其他问题的内在联系: • 来龙去脉:社交媒体平台为了评估博主的价值,合理分配资源和优化内容推荐,需要准确预测博主的新增关注数。新增关注数是衡量博主影响…...

开源飞控软件:推动无人机技术进步的引擎

在过去的二十年里,众多开源自动驾驶仪项目极大地推动了无人机技术的发展。像 MatrixPilot、Baseflight、TauLabs、OpenPilot、Cleanflight、MultiWii 和 dRonin 等一些开源自动驾驶仪项目已经停止开发,然而,Ardupilot/APM、Pixhawk/PX4、Papa…...

Pinia: vue3状态管理

一、Pinia 的相关介绍 1. 什么是 Pinia Pinia 是一个专门配合 vue.js 使用的状态管理, 从而实现跨组建通信或实现多个组件共享数据的一种技术 2. 使用 Pinia 的目的 我们的vuejs有俩个特性: 1> 数据驱动视图. 2> 组件化开发 基于这俩个特性, 我们引出pinia的使用目的 …...

初学Vue之记事本案例

初学Vue之记事本案例 案例功能需求相关Vue知识案例实现1.实现方法及代码2.演示 案例收获与总结 案例功能需求 基于Vue实现记事功能(不通过原生JS实现) 1.点击保存按钮将文本框的内容显示在特定位置,且清空文本框内容 2.点击清空按钮&#x…...

中国发布Web3计划:区块链列为核心基础技术,不排除发展加密资产应用!

在全球数字化浪潮汹涌、Web3概念方兴未艾之际,中国政府再次展现了其在区块链技术领域的雄心与布局。近日,北京市多个核心政府部门联合发布了一项名为《北京市区块链创新应用发展行动计划(2025–2027年)》的重要政策文件&#xff0…...

并发设计模式实战系列(11):两阶段终止(Two-Phase Termination)

🌟 大家好,我是摘星! 🌟 今天为大家带来的是并发设计模式实战系列,第十一章两阶段终止(Two-Phase Termination),废话不多说直接开始~ 目录 一、核心原理深度拆解 1. 两阶段终止流…...

科学养生,解锁健康生活密码

健康是生命的基石,养生并非高深的学问,而是通过科学的生活方式,为身体构筑持久的健康防线。在现代快节奏生活中,掌握正确的养生方法,能有效提升生活质量,预防疾病侵袭。 均衡饮食是养生的核心。日常饮食应遵…...

计算机视觉——基于树莓派的YOLO11模型优化与实时目标检测、跟踪及计数的实践

概述 设想一下,你在多地拥有多个仓库,要同时监控每个仓库的实时状况,这对于时间和精力而言,都构成了一项艰巨挑战。从成本和可靠性的层面考量,大规模部署计算设备也并非可行之策。一方面,大量计算设备的购…...

初识 Java

文章目录 一、背景知识二、技术体系 一、背景知识 Java 是美国 sun(Stanford University Network)公司(2009 年被 Oracle 公司收购)在 1995 年推出的一门计算机高级编程语言 二、技术体系 Java SE(Java Standard Edition):标准版,Java 技术的核心和基…...

彩带飘落效果

文章目录 彩带效果适应场景HTML版本Vue3版本 彩带效果 彩带特效组件 适应场景 完成小结、版本升级等场景。提供HTM、Vue3版本。 HTML版本 <!doctype html> <html lang"zh-CN"><head><meta charset"UTF-8" /><meta name"…...

统计模式识别理论与方法

我们在前文《模式识别的基本概念与理论体系》中就已经提及“模式分类”。 具体内容看我的CSDN文章&#xff1a;模式识别的基本概念与理论体系-CSDN博客 模式的识别方法主要有统计模式识别方法和结构模式识别方法两大类。统计模式识别方法提出得较早&#xff0c;理论也较成熟…...

Ubuntu 安装 Cursor

Cursor 目前只有 Windows 和 Mac 版本&#xff0c;那么如何在 Ubuntu 上运行呢&#xff1f; 本质上是一个如何在 Ubuntu 运行 .appimage 的问题。 1. 下载 Cursor Linux 首先找到 Cursor 官网&#xff0c;下载 x64 安装包&#xff0c;如果你是 arm 架构&#xff0c;就下载 ar…...

前端八股 7

垃圾回收机制 系统周期性地找出暂时不再使用的变量的机制&#xff0c;释放其内存的机制 方法&#xff1a;古老引用计数法 创建一张引用表记录各种资源被引用的次数&#xff0c;当引用次数为0就回收 问题&#xff1a;当有两个对象互相引用时会造成内存泄漏 比如&#xff1a…...

二、HTML

2.1 介绍 HTML&#xff08;HyperText Markup Language&#xff0c;超文本标记语言&#xff09; HTML是网页的骨架&#xff0c;用于定义网页的结构和内容。通过各种标签&#xff08;如<div>、<p>、<a>、<img>等&#xff09;来组织文本、图片、表格、表…...

EBO的使用

EBO 其实就是个索引&#xff0c;绑定在相应的VAO中&#xff0c;用来描述绘制顺序。比如在OpenGL绘制三角形的时候&#xff0c;假设有四个顶点&#xff0c;我称他们分别为1&#xff0c;2&#xff0c;3&#xff0c;4号顶点&#xff0c;常规绘制三角形函数是按三个点为一组&#x…...

AI大模型基础设施:NVIDIA的用于AI大语言模型训练和推理的几款主流显卡

英伟达&#xff08;NVIDIA&#xff09;在AI大语言模型&#xff08;LLM&#xff09;的训练和推理领域占据主导地位&#xff0c;其GPU因强大的并行计算能力和专为深度学习优化的架构而广受青睐。以下介绍几款主流的NVIDIA GPU&#xff0c;适用于AI大语言模型的训练和推理&#xf…...

面试手撕——迭代法中序遍历二叉树

思路 访问顺序和处理顺序不一致导致迭代法难写&#xff0c;体现在总要先遍历根节点&#xff0c;才能访问左右孩子&#xff0c;用null标记&#xff0c;null标记的节点表示已经访问过了&#xff0c;下一次可以处理&#xff0c;所以在当前栈顶节点不是null的时候&#xff0c;都要…...

SQL注入与简单实战

Example1 谁从小还没有一个当黑帽子的梦想呢&#xff0c;所以就来讲讲SQL&#x1f489;&#x1fa78;吧… 环境要求 sqlmap命令行工具使用Go语言安装包&#xff1a;waybackruls (需要在自己的电脑上部署) 寻找目标 url 对目标网站使用&#xff1a; echo https://xxx | wayb…...

ffmpeg 元数据

ffmpeg 元数据 1. 解释什么是ffmpeg元数据 ffmpeg元数据是指与音视频文件相关的附加信息&#xff0c;这些信息不直接影响音视频内容的播放&#xff0c;但提供了关于文件内容、创作者、版权、播放参数等的有用信息。元数据在音视频文件的处理、管理和共享中起着重要作用。 2.…...

Qwen3 正式发布

2025 年 4 月 29 日&#xff0c;阿里巴巴正式发布新一代通义千问模型 Qwen31。此次发布的 Qwen3 包含多种模型版本&#xff0c;具体如下&#xff1a; MoE 模型&#xff1a;有 Qwen3-235B-A22B&#xff08;总参数 2350 亿&#xff0c;激活参数 220 亿&#xff09;和 Qwen3-30B-A…...

[操作系统] 线程互斥

文章目录 背景概念线程互斥的引出互斥量锁的操作初始化 (Initialization)静态初始化动态初始化 加锁 (Locking)阻塞式加锁非阻塞式加锁 (尝试加锁/一般不考虑) 解锁 (Unlocking)销毁 (Destruction)设置属性 (Setting Attributes - 通过 pthread_mutex_init) 锁本身的保护互斥锁…...

KDD 2025 | (8月轮)时间序列(Time Series)论文总结

KDD 2025将在2025年8月3号到7号在加拿大多伦多举行&#xff0c;本文总结了KDD 2025(August Cycle)有关时间序列&#xff08;Time Series&#xff09;相关文章&#xff0c;共计11篇&#xff0c;其中1-10为Research Track&#xff0c;11为ADS Track。如有疏漏&#xff0c;欢迎补充…...

Spring MVC @PathVariable 注解怎么用?

我们来详细分析 Spring MVC 中的 PathVariable 注解。 PathVariable 注解的作用 PathVariable 注解用于从 URI 模板&#xff08;URI Template&#xff09;中提取值&#xff0c;并将这些值绑定到 Controller 方法的参数上。URI 模板是一种包含占位符的 URL 路径&#xff0c;这…...

PostgreSQL运算符

运算符 算数运算符 运算符描述示例加法SELECT 2 3; 结果为 5-减法SELECT 5 - 2; 结果为 3*乘法SELECT 2 * 3; 结果为 6/除法&#xff08;对于整数相除&#xff0c;会截断小数部分&#xff09;SELECT 5 / 2; 结果为 2 &#xff0c;若要得到精确结果&#xff0c;可使用浮点数 …...

Ocelot与.NETcore7.0部署(基于腾讯云)

资料链接&#xff1a;https://download.csdn.net/download/ly1h1/90731290 1.效果 基于Ocelot&#xff0c;实现对3个微服务的轮询调用&#xff0c;实现不停机更新&#xff0c;无缝更新&#xff1b; 2.环境要求 1.部署环境&#xff1a;腾讯云的轻量化应用服务器 2.系统环境&…...

Umi-OCR项目(1)

最近接触到了一个项目&#xff0c;我在想能不能做出点东西出来。 目标&#xff1a;识别一张带表格的图片&#xff0c;要求非表格内容和表格内容都要识别得很好&#xff0c;并且可视化输出为word文档。 下面是第一步的测试代码&#xff0c;测试是否能够调用ocr能力。 import re…...

前端面试常问问题[From CV]

作为前端面试官&#xff0c;我会针对简历中的技术栈、项目经历和技能细节提出以下20个问题&#xff0c;并附上参考答案&#xff1a; 技术基础类问题 Q&#xff1a;请解释JavaScript事件循环机制&#xff0c;结合宏任务/微任务说明代码执行顺序 A&#xff1a;事件循环分为调用栈…...

C语言学习之动态内存的管理

学完前面的C语言内容后&#xff0c;我们之前给内存开辟空间的方式是这样的。 int val20; char arr[10]{0}; 我们发现这个方式有两个弊端&#xff1a;空间是固定的&#xff1b;同时在声明的时候必须指定数组的长度&#xff0c;一旦确定了大小就不能调整的。 而实际应用的过程中…...

CMake中的“包管理“模块FetchContent

背景介绍 C的包管理工具&#xff0c;好像除了微软家的vcpkg外&#xff0c;并没有一个特别有名的包管理器。 CMake其实也提供了基础的包管理功能。使用 FetchContent 模块系列命令可以下载项目依赖的源代码或者其他文件。 基本用法 FetchContent_Declare命令定义我们下载的内…...

python3基础

Python3 基础教程 1. Python简介 Python是一种高级、解释型、通用的编程语言,由Guido van Rossum于1989年底发明。Python的设计哲学强调代码的可读性和简洁性,其核心理念体现在"Python之禅"中: 优美胜于丑陋(Beautiful is better than ugly) 显式胜于隐式(E…...

课题推荐——通信信号处理中的非线性系统状态估计(如信号跟踪、相位恢复等场景),使用无迹卡尔曼滤波(UKF)的非线性滤波算法,MATLAB实现

给出一个基于无迹卡尔曼滤波&#xff08;UKF&#xff09;的非线性滤波算法及其MATLAB实现&#xff0c;适用于通信信号处理中的非线性系统状态估计&#xff08;如信号跟踪、相位恢复等场景&#xff09;。该算法结合了非线性动态模型和观测模型&#xff0c;并通过UT变换避免雅可比…...

Postgresql源码(145)优化器nestloop参数化路径评估不准问题分析

相关 《Postgresql源码&#xff08;133&#xff09;优化器动态规划生成连接路径的实例分析》 1 问题 最近遇到一个问题&#xff0c;评估行数和真实行数存在较大差距&#xff0c;导致计划不准的问题。 nestloop内表评估是根据外表的参数来的。因为外表驱动表每取一条&#xff…...

【深度学习新浪潮】小米MiMo-7B报告内容浅析

一段话总结 该报告介绍了专为推理任务设计的大语言模型MiMo-7B,其在预训练阶段通过优化数据预处理、采用三阶段数据混合策略(处理约25万亿token)和引入MultiToken Prediction(MTP)目标提升推理潜力;后训练阶段构建13万可验证数学和编程问题数据集,结合测试难度驱动奖励…...

使用Python和Pandas实现的Snowflake权限检查与SQL生成用于IT审计

import snowflake.connector import pandas as pddef get_snowflake_permissions():# 连接Snowflake&#xff08;需要替换实际凭证&#xff09;conn snowflake.connector.connect(user<USER>,password<PASSWORD>,account<ACCOUNT>,warehouse<WAREHOUSE&g…...

spring 从application.properties中获取参数的四种方式

在Spring Boot中&#xff0c;自定义一个Starter时&#xff0c;从application.properties中获取参数主要有以下几种方法&#xff1a; 使用Value注解 这是最常用的方法之一&#xff0c;通过Value注解可以直接将application.properties中的属性值注入到Spring管理的Bean中。 imp…...

react学习笔记2——基于React脚手架与ajax

使用create-react-app创建react应用 react脚手架 xxx脚手架: 用来帮助程序员快速创建一个基于xxx库的模板项目 包含了所有需要的配置&#xff08;语法检查、jsx编译、devServer…&#xff09;下载好了所有相关的依赖可以直接运行一个简单效果 react提供了一个用于创建react项…...

nim模块教程

导入一个模块 如果我们想要导入一个模块&#xff0c;并且和它的所有函数&#xff0c;我们要做的是写import <moduleName>在我们的文件里&#xff0c;这通常是在文件顶部进行的&#xff0c;这样我们就可以很容易地看到我们的代码使用了什么。 创建一个模块 first.nim …...