旋转框目标检测mmrotate v1.0.0rc1 之RTMDet训练DOTA的官方问题解析整理(四)
关于rotated_rtmdet_l-coco_pretrain-3x-dota_ms.py配置文件的batchsize和学习率设置
问题:

回答:

如何在mmrotate中绘制特征图
问题:

回答:
你好@AllieLan,您可以尝试使用https://github.com/open-mmlab/mmyolo/blob/main/demo/featmap_vis_demo.py
[Feature] oriented reppoints 支持 filter_empty_gt=False 的训练
问题:

回答:

[1.x] RTMDet-R (tiny) 内存不足的 CUDA,具有 24GB VRAM 和 batch_size=1
问题:

回答:

如何在自己的数据集上测试大场景图片?
问题:

回答:
你好@TheGreatTreatsby, 你可以试试https://github.com/CAPTAIN-WHU/DOTA_devkit
请问这个项目中通道的ms+rr和论文中常说的多维度测试和多维度训练有什么区别
问题:

回答:

使用 DOTA V1.0 数据集时 CFA 重新分配过程中的张量不匹配错误
问题:

回答:


如何改变旋转框的定义范围(如何更改旋转框的定义范围)
问题:

回答:


如何获得精度和F1分数
问题:

回答:
在我的例子中,我修改了 eval_map.py 和我的 custumdataset.py
通过在 def eval_rbbox_map 中创建额外的变量来计算
cls_all_tp = np.sum(tp) cls_all_fp = np.sum(fp)
参考我项目的代码
我的项目

关于 R3Det 中的随机种子 #464
问题:





Question about random seed. #291


为什么相同的物体分类分数相差很大? #455
问题:



回答:

_base_ = ['./roi_trans_r50_fpn_1x_dota_le90.py']data_root = 'datasets/split_ms_dotav1/'
angle_version = 'le90'
img_norm_cfg = dict(mean=[123.675, 116.28, 103.53], std=[58.395, 57.12, 57.375], to_rgb=True)
train_pipeline = [dict(type='LoadImageFromFile'),dict(type='LoadAnnotations', with_bbox=True),dict(type='RResize', img_scale=(1024, 1024)),dict(type='RRandomFlip',flip_ratio=[0.25, 0.25, 0.25],direction=['horizontal', 'vertical', 'diagonal'],version=angle_version),dict(type='PolyRandomRotate',rotate_ratio=0.5,angles_range=180,auto_bound=False,rect_classes=[9, 11],version=angle_version),dict(type='Normalize', **img_norm_cfg),dict(type='Pad', size_divisor=32),dict(type='DefaultFormatBundle'),dict(type='Collect', keys=['img', 'gt_bboxes', 'gt_labels'])
]
data = dict(train=dict(pipeline=train_pipeline,ann_file=data_root + 'trainval/annfiles/',img_prefix=data_root + 'trainval/images/'),val=dict(ann_file=data_root + 'trainval/annfiles/',img_prefix=data_root + 'trainval/images/'),test=dict(ann_file=data_root + 'test/images/',img_prefix=data_root + 'test/images/'))model = dict(train_cfg=dict(rpn=dict(assigner=dict(gpu_assign_thr=200))))检测细长物体的困难 #384
问题:


回答:

def gen_single_level_base_anchors(self,base_size,scales,ratios,center=None):"""Generate base anchors of a single level.Args:base_size (int | float): Basic size of an anchor.scales (torch.Tensor): Scales of the anchor.ratios (torch.Tensor): The ratio between between the heightand width of anchors in a single level.center (tuple[float], optional): The center of the base anchorrelated to a single feature grid. Defaults to None.Returns:torch.Tensor: Anchors in a single-level feature maps."""w = base_sizeh = base_sizeif center is None:x_center = self.center_offset * wy_center = self.center_offset * helse:x_center, y_center = centerh_ratios = torch.sqrt(ratios)w_ratios = 1 / h_ratiosif self.scale_major:ws = (w * w_ratios[:, None] * scales[None, :]).view(-1)hs = (h * h_ratios[:, None] * scales[None, :]).view(-1)else:ws = (w * scales[:, None] * w_ratios[None, :]).view(-1)hs = (h * scales[:, None] * h_ratios[None, :]).view(-1)# use float anchor and the anchor's center is aligned with the# pixel centerbase_anchors = [x_center - 0.5 * ws, y_center - 0.5 * hs, x_center + 0.5 * ws,y_center + 0.5 * hs]base_anchors = torch.stack(base_anchors, dim=-1)return base_anchorsHRSC2016 数据集性能重新实现 #202
问题:

回答:
_base_ = ['../_base_/datasets/hrsc.py', '../_base_/schedules/schedule_3x.py','../_base_/default_runtime.py'
]angle_version = 'le90'
model = dict(type='ReDet',backbone=dict(type='ReResNet',depth=50,num_stages=4,out_indices=(0, 1, 2, 3),frozen_stages=1,style='pytorch',pretrained='./work_dirs/re_resnet50_c8_batch256-25b16846.pth'),neck=dict(type='ReFPN',in_channels=[256, 512, 1024, 2048],out_channels=256,num_outs=5),rpn_head=dict(type='RotatedRPNHead',in_channels=256,feat_channels=256,version=angle_version,anchor_generator=dict(type='AnchorGenerator',scales=[8],ratios=[0.5, 1.0, 2.0],strides=[4, 8, 16, 32, 64]),bbox_coder=dict(type='DeltaXYWHBBoxCoder',target_means=[.0, .0, .0, .0],target_stds=[1.0, 1.0, 1.0, 1.0]),loss_cls=dict(type='CrossEntropyLoss', use_sigmoid=True, loss_weight=1.0),loss_bbox=dict(type='SmoothL1Loss', beta=1.0 / 9.0, loss_weight=1.0)),roi_head=dict(type='RoITransRoIHead',version=angle_version,num_stages=2,stage_loss_weights=[1, 1],bbox_roi_extractor=[dict(type='SingleRoIExtractor',roi_layer=dict(type='RoIAlign', output_size=7, sampling_ratio=0),out_channels=256,featmap_strides=[4, 8, 16, 32]),dict(type='RotatedSingleRoIExtractor',roi_layer=dict(type='RiRoIAlignRotated',out_size=7,num_samples=2,num_orientations=8,clockwise=True),out_channels=256,featmap_strides=[4, 8, 16, 32]),],bbox_head=[dict(type='RotatedShared2FCBBoxHead',in_channels=256,fc_out_channels=1024,roi_feat_size=7,num_classes=1,bbox_coder=dict(type='DeltaXYWHAHBBoxCoder',angle_range=angle_version,norm_factor=2,edge_swap=True,target_means=[0., 0., 0., 0., 0.],target_stds=[0.1, 0.1, 0.2, 0.2, 0.1]),reg_class_agnostic=True,loss_cls=dict(type='CrossEntropyLoss',use_sigmoid=False,loss_weight=1.0),loss_bbox=dict(type='SmoothL1Loss', beta=1.0,loss_weight=1.0)),dict(type='RotatedShared2FCBBoxHead',in_channels=256,fc_out_channels=1024,roi_feat_size=7,num_classes=1,bbox_coder=dict(type='DeltaXYWHAOBBoxCoder',angle_range=angle_version,norm_factor=None,edge_swap=True,proj_xy=True,target_means=[0., 0., 0., 0., 0.],target_stds=[0.05, 0.05, 0.1, 0.1, 0.05]),reg_class_agnostic=False,loss_cls=dict(type='CrossEntropyLoss',use_sigmoid=False,loss_weight=1.0),loss_bbox=dict(type='SmoothL1Loss', beta=1.0, loss_weight=1.0))]),train_cfg=dict(rpn=dict(assigner=dict(type='MaxIoUAssigner',pos_iou_thr=0.7,neg_iou_thr=0.3,min_pos_iou=0.3,match_low_quality=True,ignore_iof_thr=-1),sampler=dict(type='RandomSampler',num=256,pos_fraction=0.5,neg_pos_ub=-1,add_gt_as_proposals=False),allowed_border=0,pos_weight=-1,debug=False),rpn_proposal=dict(nms_pre=2000,max_per_img=2000,nms=dict(type='nms', iou_threshold=0.7),min_bbox_size=0),rcnn=[dict(assigner=dict(type='MaxIoUAssigner',pos_iou_thr=0.5,neg_iou_thr=0.5,min_pos_iou=0.5,match_low_quality=False,ignore_iof_thr=-1,iou_calculator=dict(type='BboxOverlaps2D')),sampler=dict(type='RandomSampler',num=512,pos_fraction=0.25,neg_pos_ub=-1,add_gt_as_proposals=True),pos_weight=-1,debug=False),dict(assigner=dict(type='MaxIoUAssigner',pos_iou_thr=0.5,neg_iou_thr=0.5,min_pos_iou=0.5,match_low_quality=False,ignore_iof_thr=-1,iou_calculator=dict(type='RBboxOverlaps2D')),sampler=dict(type='RRandomSampler',num=512,pos_fraction=0.25,neg_pos_ub=-1,add_gt_as_proposals=True),pos_weight=-1,debug=False)]),test_cfg=dict(rpn=dict(nms_pre=2000,max_per_img=2000,nms=dict(type='nms', iou_threshold=0.7),min_bbox_size=0),rcnn=dict(nms_pre=2000,min_bbox_size=0,score_thr=0.05,nms=dict(iou_thr=0.1),max_per_img=2000)))img_norm_cfg = dict(mean=[123.675, 116.28, 103.53], std=[58.395, 57.12, 57.375], to_rgb=True)
train_pipeline = [dict(type='LoadImageFromFile'),dict(type='LoadAnnotations', with_bbox=True),dict(type='RResize', img_scale=(800, 512)),dict(type='RRandomFlip', flip_ratio=0.5),dict(type='Normalize', **img_norm_cfg),dict(type='Pad', size_divisor=32),dict(type='DefaultFormatBundle'),dict(type='Collect', keys=['img', 'gt_bboxes', 'gt_labels'])
]
test_pipeline = [dict(type='LoadImageFromFile'),dict(type='MultiScaleFlipAug',img_scale=(800, 512),flip=False,transforms=[dict(type='RResize'),dict(type='Normalize', **img_norm_cfg),dict(type='Pad', size_divisor=32),dict(type='DefaultFormatBundle'),dict(type='Collect', keys=['img'])])
]dataset_type = 'HRSCDataset'
data_root = '/data/dataset_share/HRSC2016/HRSC2016/'
data = dict(samples_per_gpu=2,workers_per_gpu=2,train=dict(type=dataset_type,classwise=False,ann_file=data_root + 'ImageSets/trainval.txt',ann_subdir=data_root + 'FullDataSet/Annotations/',img_subdir=data_root + 'FullDataSet/AllImages/',pipeline=train_pipeline),val=dict(type=dataset_type,classwise=False,ann_file=data_root + 'ImageSets/test.txt',ann_subdir=data_root + 'FullDataSet/Annotations/',img_subdir=data_root + 'FullDataSet/AllImages/',pipeline=test_pipeline),test=dict(type=dataset_type,classwise=False,ann_file=data_root + 'ImageSets/test.txt',ann_subdir=data_root + 'FullDataSet/Annotations/',img_subdir=data_root + 'FullDataSet/AllImages/',pipeline=test_pipeline))evaluation = dict(interval=12, metric='mAP')
optimizer = dict(lr=0.01)



#原因是问题者的Target_stds和官方不一致,同时学习率也不一致导致的,官方也是使用单张GPU进行模型训练的。


问题:

回答:

不同batchsize下s2anet的mAP #59





单个类别训练报错
问题:


回答:

HRSC2016 的 classwise 设置为 True 时,在评估时出现“IndexError: tuple index out of range”。 #182


尝试结合 swin-Transform 和 s2anet #217
问题:

_base_ = ['./s2anet_r50_fpn_1x_dota_le135.py']pretrained = 'https://github.com/SwinTransformer/storage/releases/download/v1.0.0/swin_tiny_patch4_window7_224.pth' # noqamodel = dict(backbone=dict(_delete_=True,type='SwinTransformer',embed_dims=96,depths=[2, 2, 6, 2],num_heads=[3, 6, 12, 24],window_size=7,mlp_ratio=4,qkv_bias=True,qk_scale=None,drop_rate=0.,attn_drop_rate=0.,drop_path_rate=0.2,patch_norm=True,out_indices=(0, 1, 2, 3),with_cp=False,convert_weights=True,init_cfg=dict(type='Pretrained', checkpoint=pretrained)),neck=dict(_delete_=True,type='FPN',in_channels=[96, 192, 384, 768],out_channels=256,num_outs=5))optimizer = dict(_delete_=True,type='AdamW',lr=0.0001,betas=(0.9, 0.999),weight_decay=0.05,paramwise_cfg=dict(custom_keys={'absolute_pos_embed': dict(decay_mult=0.),'relative_position_bias_table': dict(decay_mult=0.),'norm': dict(decay_mult=0.)}))
数据标签过多次显示会爆炸、预测后不出指标结果;当数据标签过多时,显存会爆,预测后指标结果不显示; #333



一个对象在 oriented-reppoints 中有两个预测类 #426



[文档]关于lr和batchsize的问题 #645

loss降不下来 #330



如何进行多尺度测试? #201


当我使用 rmosaic 时如何可视化 #686
你好@QAQTATQAQTAT,您可以使用demo/image_demo.py可视化 rmosaic 的输出。rmosaic的使用方法可以参考https://github.com/open-mmlab/mmrotate/blob/dev-1.x/configs/rotated_rtmdet/rotated_rtmdet_tiny-300e-aug-hrsc.py 。
Mosaic( img_scale=(1024, 1024))-> Resize(scale=(2048, 2048))->RandomCrop(crop_size=(1024, 1024))
train_pipeline = [dict(type='mmdet.LoadImageFromFile',file_client_args={{_base_.file_client_args}}),dict(type='mmdet.LoadAnnotations', with_bbox=True, box_type='qbox'),dict(type='ConvertBoxType', box_type_mapping=dict(gt_bboxes='rbox')),dict(type='mmdet.CachedMosaic',img_scale=(800, 800),pad_val=114.0,max_cached_images=20,random_pop=False),dict(type='mmdet.RandomResize',resize_type='mmdet.Resize',scale=(1600, 1600),ratio_range=(0.5, 2.0),keep_ratio=True),dict(type='RandomRotate', prob=0.5, angle_range=180),dict(type='mmdet.RandomCrop', crop_size=(800, 800)),dict(type='mmdet.YOLOXHSVRandomAug'),dict(type='mmdet.RandomFlip',prob=0.75,direction=['horizontal', 'vertical', 'diagonal']),dict(type='mmdet.Pad', size=(800, 800), pad_val=dict(img=(114, 114, 114))),dict(type='mmdet.CachedMixUp',img_scale=(800, 800),ratio_range=(1.0, 1.0),max_cached_images=10,random_pop=False,pad_val=(114, 114, 114),prob=0.5),dict(type='mmdet.PackDetInputs')
][WIP] 在 TRR360D 中支持 RR360(旋转矩形 360)检测 #731
https://github.com/open-mmlab/mmrotate/pull/731
Oriented RCNN 不支持 iou loss? #649



如何训练宽高比大的物体 #285


相关文章:
旋转框目标检测mmrotate v1.0.0rc1 之RTMDet训练DOTA的官方问题解析整理(四)
关于rotated_rtmdet_l-coco_pretrain-3x-dota_ms.py配置文件的batchsize和学习率设置问题:回答:如何在mmrotate中绘制特征图问题:回答:你好AllieLan,您可以尝试使用https://github.com/open-mmlab/mmyolo/blob/main/de…...
4个顶级的华为/小米/OPPO/Vivo手机屏幕解锁工具软件
有好几次用户发现自己被锁定在他们的华为/小米/OPPO/Vivo设备之外,我们知道这可能是一种非常可怕的体验。在这种情况下,找到安卓手机解锁软件,重新获得手机中重要数据和文件的访问权限。看看这篇文章,因为我们将与您分享什么是解锁…...
华为OD机试题 - 和最大子矩阵(JavaScript)| 机考必刷
更多题库,搜索引擎搜 梦想橡皮擦华为OD 👑👑👑 更多华为OD题库,搜 梦想橡皮擦 华为OD 👑👑👑 更多华为机考题库,搜 梦想橡皮擦华为OD 👑👑👑 华为OD机试题 最近更新的博客使用说明本篇题解:和最大子矩阵题目输入输出示例一输入输出说明Code思路版权说明华…...
企业电子招标采购系统源码之项目说明和开发类型
项目说明 随着公司的快速发展,企业人员和经营规模不断壮大,公司对内部招采管理的提升提出了更高的要求。在企业里建立一个公平、公开、公正的采购环境,最大限度控制采购成本至关重要。符合国家电子招投标法律法规及相关规范,以及…...
Python高频面试题——装饰器(带大家理解装饰器的本质)
装饰器概念装饰器本质上是一个python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限验证等场景…...
全方位解读智能中控屏发展趋势!亚马逊Alexa语音+Matter能力成必备
随着智能家居行业逐步从碎片化的智能单品阶段,迈向体验更完整的全屋互联阶段,智能中控屏作为智能家居最佳的入口之一,在年轻人青睐全屋智能装修的风潮下,市场潜力彻底被引爆。 一、为什么是智能中控屏? 在智能音箱增…...
JAVA练习74-括号生成
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 前言 提示:这里可以添加本文要记录的大概内容: 3月10日练习内容 提示:以下是本篇文章正文内容,下面案例可供参考 一、题目-…...
Java ORM开发 更全面的应用场景
1. 一个web系统, 想支持多种数据库, 如同时要用mysql, oracle 需要动态切换数据源? 2. 读写分离, 但读库与写库是不同的类型, 如分别是: mysql, oracle 3. 智能化自动过滤null和空字符串,不再需要写判断非空的代码。 4.动态/任意组合查询条件,不需要提前准备da…...
SpringBoot【基础篇】---- 基础配置
SpringBoot【基础篇】---- 基础配置1. 属性配置2. 配置文件分类3. yaml 文件4. yaml 数据读取1. 读取单一数据2. 读取全部数据3. 读取对象数据yaml 文件中的数据引用1. 属性配置 SpringBoot 通过配置文件 application.properties 就可以修改默认的配置,那咱们就先找…...
手机磁吸背夹散热器制冷快速方案
手机散热器是什么?手机散热器分为几种类型?手机散热的方式都有哪些? 因为经常玩游戏,手机发热得厉害,都可以煎鸡蛋了,心想着要买个东西给手机散散热,没想到还真的有手机散热器。 不知道手机散…...
青岛OJ(QingdaoU/OnlineJudge)部署如何直连数据库批量修改
1.postgres数据库QingdaoU/OnlineJudge用的数据库是postgreSQL,一个关系型数据库。默认端口是5432,我们下载一个navcat 15以上的版本,用来连数据库。2.修改docker-compose.yml文件修改docker-compose.yml,手动添加一个端口&#x…...
渗透测试——信息收集(详细)
信息收集:前言:信息收集是渗透测试除了授权之外的第一步,也是关键的一步,尽量多的收集目标的信息会给后续的渗透事半功倍。收集信息的思路有很多,例如:页面信息收集、域名信息收集、敏感信息收集、子域名收…...
什么是谐波
什么是谐波 目录 1. 问题的提出 2. “谐”字在中英文中的原意 2.1 “谐”字在汉语中的原义 2.2 “谐”字对应的英语词的原义 3.“harmonics(谐波)”概念是谁引入物理学中的? 4.“harmonics(谐波)”的数学解释 1. 问题的提出 “谐波”这个术语用于各种学科&am…...
技术报告:程序员如何开发一个商城型购物网站
前言随着互联网的快速发展,电商行业正成为越来越多人的选择。而作为电商行业的主要参与者之一,商城型购物网站的开发则成为程序员不可避免的任务之一。本文将对商城型购物网站的开发进行详细阐述,包括需求分析、架构设计、技术选型、前后端开…...
DPDK系列之八虚拟化virtio
一、virtio的介绍 在一篇文章中对virtio进行了简单的说明。在早期的虚拟化的过程中,无论是KVM还是Vmware亦或是Xen,每个平台想当然的是自己搞自己的IO接口。这就和现在国内的互联各个平台都是大而全一样,怎么可能我用你的支付接口呢…...
直播间与2位优秀创作者分享经历
我是卢松松,点点上面的头像,欢迎关注我哦! 昨天,卢松松的直播间好像又被推荐给了2.9万人观看,讲了一个小时后直播间的人数一直攀升,最终冲破了2万人大关。晚些时候,白杨SEO也来到了我的直播间&…...
linux上快速安装 Flarum 指南
一、安装Composer Composer是PHP的依赖管理器(类似于Node.js的npm或Python的 pip ),它可用于当前流行的PHP平台,例如Drupal、Magento等。那么如何安装PHP Composer呢?本文将为大家介绍下在Debian 10上安装PHP Composer的教程。 在安装 Composer 之前,请确保您的 Debian …...
数学不好,英语不行,非本专业,可以学IT吗?
看到很多想入行IT编程的小伙伴,都会问一些比较类似的问题。 比如: 不是计算机专业的,可以学编程吗? 数学一直就不好,可以转行学IT吗? 学编程开发,对英语的要求会不会很高? 01、…...
软件测试13
Linux命令 1.pwd:查看当前所在的路径位置 2.ls:查看当前路径下有哪些文件 3.cd:切换路径 4.touch:创建普通文件,可以创建单文件,也可以创建多文件(touch a,touch b c) 5…...
React(八):引出Hook、useState、useEffect的使用详解
React(八)一、类组件的优劣势1.类组件的优势2.类组件的劣势(1)复杂组件会难以理解(2)复杂的class(3)组件复用状态很难二、Hook初体验useState1.使用Hook的计数器案例2.详解useState&…...
芯洲SCT SCT2630ASTER ESOP-8 DC-DC电源芯片
特性宽输入范围:4.5V - 60V高达3.5A的连续输出电流0.8V 1%反馈参考电压集成80mΩ高端MOSFET低静态电流:175uA轻载时采用脉冲跳跃模式(PSM)最小导通时间130ns4ms内部软启动时间可调频率100kHz至1.2MHz外部时钟同步精确使能阈值&…...
浏览器端HTML转DOCX解决方案:告别服务器依赖的文档生成革命
浏览器端HTML转DOCX解决方案:告别服务器依赖的文档生成革命 【免费下载链接】html-docx-js Converts HTML documents to DOCX in the browser 项目地址: https://gitcode.com/gh_mirrors/ht/html-docx-js 在当今数字化办公环境中,前端开发者经常面…...
终极指南:async-labs/saas代码架构解析与MobX状态管理最佳实践
终极指南:async-labs/saas代码架构解析与MobX状态管理最佳实践 【免费下载链接】saas Build your own SaaS business with SaaS boilerplate. Productive stack: React, Material-UI, Next, MobX, WebSockets, Express, Node, Mongoose, MongoDB. Written with Type…...
OpenClaw语音控制之 从语音到执行命令
15.1 流水线总览 15.1.1 整体架构设计 OpenClaw 的语音命令处理流水线是一个典型的事件驱动架构,整个系统由多个解耦的处理阶段组成,每个阶段通过消息队列或回调机制进行异步通信。这种设计确保了系统在高并发场景下的稳定性,同时便于各阶段的独立扩展和故障隔离。 从宏观…...
PromptPilot避坑指南:这样调参让豆包模型性能翻倍(含多模态测试数据集)
PromptPilot深度调参实战:解锁豆包模型多模态潜能的7个关键策略 当算法工程师第一次接触豆包模型的多模态能力时,往往会陷入两种极端——要么被默认参数的平庸表现劝退,要么在无方向的调参中耗尽耐心。本文将揭示如何通过PromptPilot系统性地…...
清华教授:心情差的时候,做这8件小事,比硬扛管用多了
你有没有这样的时刻:心情突然就不好了,说不清为什么,就是闷闷的、烦躁、提不起劲。硬扛?扛不住。发泄?发完更累。清华大学的彭凯平教授总结了8个简单易行的方法,专门用来调节负面情绪。从传统文化里来&…...
终极TorchServe性能优化指南:10个技巧让模型推理速度提升300%
终极TorchServe性能优化指南:10个技巧让模型推理速度提升300% 【免费下载链接】serve Serve, optimize and scale PyTorch models in production 项目地址: https://gitcode.com/gh_mirrors/serv/serve TorchServe是一个强大的PyTorch模型服务工具࿰…...
2026年最值钱的不是会用AI的人,而是会给AI搭系统的人
2026年最值钱的不是会用AI的人,而是会给AI搭系统的人我这几天一直在想一个问题。我身边有两种人在学AI。一种人学的是工具——ai怎么出图、豆包怎么写文案。另一种人学的是系统——怎么让AI自己去抓热点、自己去写初稿、自己去排版、甚至自己去定时发布。前者每天都…...
模型剪枝实战避坑指南:从L1、Taylor到激活统计,三大策略到底怎么选?
模型剪枝实战避坑指南:L1、Taylor与激活统计三大策略深度解析 在深度学习模型部署的实际场景中,工程师们常常面临一个关键抉择:当模型大小和推理速度成为瓶颈时,如何在保证精度的前提下有效压缩模型?模型剪枝作为模型…...
从三电阻采样到VOFA+观测:一份给STM32新手的BLDC FOC电流环调试避坑指南
从三电阻采样到VOFA观测:STM32 BLDC FOC电流环调试实战手册 当电机控制新手第一次面对FOC算法时,电流环往往是最令人困惑的环节。那些抽象的相电流波形、复杂的坐标变换公式,以及难以捉摸的PI参数调节,常常让初学者望而却步。本文…...
