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

深圳网站快速排名优化百度广告代理

深圳网站快速排名优化,百度广告代理,高端工作网站,汕头模板网建站仿射变换在 PyTorch 中的实现与原理 核心概念 仿射变换是一种保持直线和比例关系的几何变换,由以下操作组成: 旋转(Rotation)缩放(Scale)平移(Translation)剪切(Shear&am…

仿射变换在 PyTorch 中的实现与原理

核心概念

仿射变换是一种保持直线和比例关系的几何变换,由以下操作组成:

  • 旋转(Rotation)
  • 缩放(Scale)
  • 平移(Translation)
  • 剪切(Shear)
  • 反射(Reflection)

数学形式可表示为齐次坐标下的矩阵运算:

[x']   [a  b  tx] [x]
[y'] = [c  d  ty] [y]
[1 ]   [0  0  1 ] [1]

其中 a, b, c, d 控制旋转/缩放/剪切,tx, ty 控制平移。


PyTorch 内置实现方式

1. torchvision.transforms.RandomAffine
from torchvision import transformstransform = transforms.Compose([transforms.RandomAffine(degrees=15,            # 旋转范围:±15度translate=(0.1, 0.1),  # 平移比例:最大10%scale=(0.8, 1.2),      # 缩放范围:80%~120%shear=10,              # 剪切范围:±10度fill=0                 # 空白区域填充值)
])
2. torch.nn.functional.affine_grid + grid_sample

底层控制实现:

import torch.nn.functional as Fdef apply_affine(x, matrix):# x: [C, H, W] tensormatrix = matrix[:2, :]  # 取前两行grid = F.affine_grid(matrix.unsqueeze(0), x.unsqueeze(0).size())return F.grid_sample(x.unsqueeze(0), grid)[0]# 示例矩阵:旋转30度 + 缩放0.8倍
theta = torch.tensor([[0.8 * math.cos(math.pi/6), -0.8 * math.sin(math.pi/6), 0],[0.8 * math.sin(math.pi/6),  0.8 * math.cos(math.pi/6), 0]
])
transformed = apply_affine(image, theta)

参数详解

参数类型说明计算公式
degreesfloat/tuple旋转角度范围随机角度 ∈ [-deg, +deg]
translatetuple平移比例 (h, w)偏移量 = 图片尺寸 × 随机值 × trans
scaletuple缩放比例范围随机缩放 ∈ [scale_min, scale_max]
shearfloat/tuple剪切角度支持XY方向单独设置
fillint/tuple空白区域填充可设统一值或RGB分量值
centertuple旋转中心点默认中心点:image_size/2

核心实现原理

1. 矩阵合成(顺序敏感)
def get_affine_matrix():# 基础单位矩阵matrix = [[1, 0, 0],[0, 1, 0],[0, 0, 1]]# 应用变换(顺序:缩放→旋转→平移)matrix = compose_matrix(scale_matrix(sx, sy))matrix = compose_matrix(rotation_matrix(theta), matrix)matrix = compose_matrix(translation_matrix(tx, ty), matrix)return matrix[:2]  # 返回2x3矩阵
2. 网格采样与双线性插值
def grid_sample(input, grid):for y in range(H):for x in range(W):src_x, src_y = grid[y, x]  # 计算原图坐标# 双线性插值(实际使用优化算法)top_left = input[floor(src_y), floor(src_x)]top_right = input[floor(src_y), ceil(src_x)]...output[y,x] = bilinear_interp(top_left, top_right, ...)
3. 边界处理
  • 填充处理fill参数设置空白像素值
  • 采样模式
    • padding_mode='zeros'(默认)
    • padding_mode='border'(复制边缘像素)
    • padding_mode='reflection'(镜像反射)

可视化示例

import matplotlib.pyplot as plt# 原始图像
plt.subplot(231)
plt.imshow(orig_img)
plt.title("Original")# 旋转示例
plt.subplot(232)
rotated = transforms.functional.rotate(tensor_img, 30)
plt.imshow(rotated.permute(1,2,0))
plt.title("Rotation")# 缩放示例
plt.subplot(233)
scaled = transforms.functional.resize(tensor_img, (100,150))
plt.imshow(scaled.permute(1,2,0))
plt.title("Scale")# 剪切示例
sheared = F.affine(tensor_img, angle=0, translate=(0,0),scale=1,shear=(20,0))
plt.subplot(234)
plt.imshow(sheared.permute(1,2,0))
plt.title("Shear")plt.show()

数学基础

1. 基本变换矩阵
变换类型矩阵格式
平移[[1, 0, tx], [0, 1, ty]]
缩放[[sx, 0, 0], [0, sy, 0]]
旋转[[cosθ, -sinθ, 0], [sinθ, cosθ, 0]]
剪切[[1, sh_x, 0], [sh_y, 1, 0]]
2. 组合变换
M = T \times R \times S \times Sh

其中:

  • T:平移矩阵
  • R:旋转矩阵
  • S:缩放矩阵
  • Sh:剪切矩阵

应用场景

  1. 数据增强:提升模型对几何变换的鲁棒性

    train_transform = transforms.Compose([transforms.RandomAffine(degrees=20, shear=10),transforms.ToTensor()
    ])
    
  2. 图像校准:医学影像/卫星图像配准

    # 计算最优变换矩阵
    optimizer = torch.optim.Adam([matrix_params], lr=0.01)
    for _ in range(100):warped = F.affine_grid(matrix_params, target.shape)loss = F.mse_loss(warped, target)loss.backward()optimizer.step()
    
  3. 空间变换网络 (STN):可学习仿射层

    stn = nn.Sequential(nn.Conv2d(1, 10, 5),nn.MaxPool2d(2),nn.ReLU(),nn.Linear(10*12*12, 6)  # 输出6个仿射参数
    )
    

性能优化技巧

  1. 预计算网格

    # 对batch重复使用相同变换时
    grid = F.affine_grid(matrix.expand(batch, -1), size)
    
  2. 设置梯度计算

    with torch.set_grad_enabled(mode == 'train'):transformed = F.grid_sample(input, grid)
    
  3. 插值方式选择

    F.grid_sample(..., mode='bilinear')  # 训练常用
    F.grid_sample(..., mode='nearest')   # 高精度应用
    

实测速度比较(RTX 3090,256x256图像):

  • 单次变换耗时:0.5~1.2 ms
  • 双三次插值比双线性慢3倍
  • 梯度计算增加15%耗时

与相关技术对比

特性仿射变换透视变换弹性变形
自由度68
保持平行
实现难度简单中等复杂
PyTorch支持内置需自定义GridDistortion
典型应用几何增强3D投影医学影像

仿射变换因其效率与实用性的平衡,成为计算机视觉中应用最广泛的几何变换方法。

http://www.dtcms.com/wzjs/238276.html

相关文章:

  • 房山企业网站建设公司金戈枸橼酸西地那非
  • django企业网站源码全网营销推广方案
  • 用手机做服务器做网站网上推广渠道有哪些
  • 软件开发具体是做什么长沙靠谱seo优化价格
  • 学习网站建设最简单的书网站首页布局设计模板
  • 中国建设银行网站企业登陆seo需要掌握哪些技术
  • 网站做管理后台需要知道什么店铺推广平台有哪些
  • 做本地化的返利网站怎么样品牌推广方案
  • java电子商务网站建设游戏推广赚佣金平台
  • 做钉子出口哪个网站好超级推荐的关键词怎么优化
  • 织梦可以做哪些类型型网站手机百度问一问
  • php 怎么做网站超链接电商运营主要工作内容
  • 盐城市建设银行网站企业网站推广的方法有
  • 网络营销方式哪些360优化大师旧版
  • 聊天网站制作教程怎么注册个人网站
  • 武昌网站制作建设百度搜索高级搜索技巧
  • 哈尔滨网站建设bcweb国际新闻最新消息美国
  • 什么是网站建设中的专用主机百度竞价推广常用到的工具
  • 建材网站制作商业公司的域名
  • 网站的建设与预算网站seo优化技巧
  • 好公司网站建设价格百度seo优化关键词
  • wordpress 停用多站点销售网络平台推广
  • 在成都如何找到做网站的公司网络推广公司哪家做得好
  • 昆明小程序公司seo在线教学
  • 网站建设中主页指的是故事式软文范例500字
  • 外贸公司网站建设方案百度竞价推广开户多少钱
  • 网站后台多个管理员营销策划公司简介
  • 东莞网站制作公司下载百度极速版免费安装
  • 在服务器网站上做跳转页面跳转免费网站推广
  • 做citation的网站网站建设策划书案例