验证torch.nn.Conv2d

部署运行你感兴趣的模型镜像
import os
import cv2
import torch
import numpy as np
import random
import cv2 as cv
from matplotlib import pyplot as plt

def f_VerifyConv2D():
    """
        验证torch.nn.Conv2d, 并将输入数据及权重保存到txt文件中
    """
    x = torch.randn(1, 1, 10, 10)
    x = x.round().float()

    print('==========================================================================')
    print('================================== 输入数据 ')
    print(x)
    kernel_size = 1
    conv_zeros = torch.nn.Conv2d(in_channels=1, out_channels=3, kernel_size=kernel_size, stride=1, padding=0, bias=True)
    conv_zeros.weight = torch.nn.Parameter(torch.ones(1, 1, kernel_size, kernel_size))
    conv_zeros.bias = torch.nn.Parameter(torch.ones(1))
    y = conv_zeros(x)
    print('==========================================================================')
    print('================================== 卷积权重数据 ')
    print(conv_zeros.state_dict())
    print('==========================================================================')
    print('================================== 卷积输出数据 ')
    print(y)

    print('==========================================================================')
    print('================================== 保存参数txt ')
    # 保存输入数据到1.txt
    ndarray = x.numpy()
    ndarray = ndarray.reshape(-1).astype(np.int16)
    ndarray[np.where(ndarray < 0)] = np.add(ndarray[np.where(ndarray < 0)], 256)  # 将负数以补码的形式进行存储
    np.savetxt("1.txt", ndarray, fmt='%x', delimiter='\n')

    # 保存输出结果到2.txt
    ndarray_o = y.detach().numpy()
    ndarray_o = ndarray_o.reshape(-1).astype(np.int16)
    ndarray_o[np.where(ndarray_o < 0)] = np.add(ndarray_o[np.where(ndarray_o < 0)], 256)  # 将负数以补码的形式进行存储
    np.savetxt("2.txt", ndarray_o, fmt='%x', delimiter='\n')

f_VerifyConv2D()

您可能感兴趣的与本文相关的镜像

PyTorch 2.5

PyTorch 2.5

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

### 查找 `torch.nn.Conv2d` 的源代码 在 PyTorch 中,`Conv2d` 类位于模块 `torch.nn.modules.conv` 下面。具体来说,类定义如下: ```python import torch.nn as nn class Conv2d(_ConvNd): def __init__( self, in_channels: int, out_channels: int, kernel_size: _size_2_t, stride: _size_2_t = 1, padding: Union[_size_2_t, str] = 0, dilation: _size_2_t = 1, groups: int = 1, bias: bool = True, padding_mode: str = 'zeros' ): ... ``` 该类继承自 `_ConvNd` 并实现了二维卷积层的功能[^4]。 当创建一个 `Conv2d` 对象并调用它时(即执行前向传播),实际发生的操作是由底层 C++ 扩展通过 Python 绑定来完成的。对于具体的卷积计算部分,则是在 `torch._C` 库内部处理,这部分通常是编译后的高效实现而不是纯 Python 代码[^5]。 为了查看更详细的源码逻辑,在 GitHub 上可以找到完整的文件路径以及更多细节说明。通常情况下,用户并不需要直接修改或深入理解这些底层实现,除非是为了贡献代码给项目本身或是出于学习目的深入了解框架的工作机制[^3]。 #### 关于 `torch.nn.functional.conv2d` 值得注意的是,除了 `torch.nn.Conv2d` 外还有一个函数版本叫做 `torch.nn.functional.conv2d()` 。这两个接口提供了相似的功能但是应用场景有所不同:前者用于构建可训练模型的一部分;后者则更适合一次性使用的场景或者是作为其他组件的基础构件。 ```python # 使用 torch.nn.Conv2d 构建网络层 conv_layer = nn.Conv2d(in_channels=1, out_channels=4, kernel_size=(2, 3)) # 或者使用 functional API 进行单次运算 output = F.conv2d(input_tensor, weights, ... ) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

#>木易

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值