hi_niaoer 2023-03-14 23:13 采纳率: 50%
浏览 31
已结题

tensorflow的probability在pytorch中有没有对应的包

请问下大家tensorflow中的probability在pytorch中有没有对应的包,我非科班学了好久pytorch,结果发现probability中的convolution1dflipout在pytorch中找不到😭

  • 写回答

3条回答 默认 最新

  • PellyKoo 2023-03-15 09:53
    关注

    pytorch里面还没有与convolution1dflipout相对应的卷积层,你要不然就结合pyro这种概率编程库自己实现这个层,要不然就要用pytorch里的自定义层的功能自己实现。

    import torch
    import torch.nn as nn
    import torch.nn.functional as F
    from torch.nn.parameter import Parameter
    
    # 定义 Conv1dFlipout 层
    class Conv1dFlipout(nn.Module):
        def __init__(self, in_channels, out_channels, kernel_size, stride=1, padding=0, dilation=1, groups=1, bias=True):
            super(Conv1dFlipout, self).__init__()
    
            # 初始化各种参数
            self.in_channels = in_channels          # 输入通道数
            self.out_channels = out_channels        # 输出通道数
            self.kernel_size = kernel_size          # 卷积核大小
            self.stride = stride                    # 步幅
            self.padding = padding                  # 填充
            self.dilation = dilation                # 空洞
            self.groups = groups                    # 分组卷积
            self.bias = bias                        # 是否使用偏置项
    
            # 定义权重均值和对数标准差,这些参数是需要学习的
            self.weight_mean = Parameter(torch.Tensor(out_channels, in_channels // groups, kernel_size))
            self.weight_logstd = Parameter(torch.Tensor(out_channels, in_channels // groups, kernel_size))
    
            # 定义偏置项的均值和对数标准差,这些参数是需要学习的
            if bias:
                self.bias_mean = Parameter(torch.Tensor(out_channels))
                self.bias_logstd = Parameter(torch.Tensor(out_channels))
            else:
                self.register_parameter('bias_mean', None)
                self.register_parameter('bias_logstd', None)
    
            # 重置各个参数的初始值
            self.reset_parameters()
    
        # 重置各个参数的初始值
        def reset_parameters(self):
            nn.init.kaiming_uniform_(self.weight_mean, a=math.sqrt(5))
            nn.init.constant_(self.weight_logstd, -10)
    
            if self.bias is not None:
                fan_in, _ = nn.init._calculate_fan_in_and_fan_out(self.weight_mean)
                bound = 1 / math.sqrt(fan_in)
                nn.init.uniform_(self.bias_mean, -bound, bound)
                nn.init.constant_(self.bias_logstd, -10)
    
        # 定义前向传播函数
        def forward(self, x):
            weight_epsilon = torch.randn(self.weight_mean.shape).to(x.device)
            weight = self.weight_mean + weight_epsilon * torch.exp(self.weight_logstd)
    
            if self.bias is not None:
                bias_epsilon = torch.randn(self.bias_mean.shape).to(x.device)
                bias = self.bias_mean + bias_epsilon * torch.exp(self.bias_logstd)
            else:
                bias = None
    
            # 获取输入和权重的维度
            batch_size, input_channels, input_length = x.size()
            output_channels, _, kernel_size = weight.size()
    
            # 计算输出的维度
            output_length = (input_length + 2 * self.padding - dilation * (kernel_size - 1) - 1) // self.stride + 1
    
               # 将输入和权重张量重塑为卷积运算所需的形状
            x = x.view(batch_size, input_channels // self.groups, self.groups, input_length)
            weight = weight.view(output_channels, input_channels // self.groups, self.groups, kernel_size)
    
    
            # 使用groups进行卷积运算
             output = F.conv1d(x, weight, bias, stride=self.stride, padding=self.padding, dilation=self.dilation, groups=self.groups)
    
            # 将输出张量重塑为卷积运算输出的形状
            output = output.view(batch_size, output_channels, output_length)
    
        return output
    
           
    

    一个新的卷积结构就要重定义一个新的卷积层,这还是其中一个示例。所以说,既然这么麻烦,算了还不如直接调用tensorflow现成的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    1人已打赏
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月23日
  • 已采纳回答 3月15日
  • 创建了问题 3月14日

悬赏问题

  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探