首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PyTorch VAE向onnx转换失败

PyTorch VAE向onnx转换失败
EN

Stack Overflow用户
提问于 2019-02-15 05:19:23
回答 1查看 520关注 0票数 0

我正在尝试将PyTorch VAE转换为onnx,但我得到了:torch.onnx.symbolic.normal does not exist

问题似乎是由reparametrize()函数引起的:

代码语言:javascript
复制
    def reparametrize(self, mu, logvar):
        std = logvar.mul(0.5).exp_()
        if self.have_cuda:
             eps = torch.normal(torch.zeros(std.size()),torch.ones(std.size())).cuda()
        else:
           eps = torch.normal(torch.zeros(std.size()),torch.ones(std.size()))
        return eps.mul(std).add_(mu)

我也试过了:

代码语言:javascript
复制
eps = torch.cuda.FloatTensor(std.size()).normal_()

它产生了这个错误:

代码语言:javascript
复制
    Schema not found for node. File a bug report.
    Node: %173 : Float(1, 20) = aten::normal(%169, %170, %171, %172), scope: VAE 
    Input types:Float(1, 20), float, float, Generator

代码语言:javascript
复制
eps = torch.randn(std.size()).cuda()

它产生了这个错误:

代码语言:javascript
复制
    builtins.TypeError: i_(): incompatible function arguments. The following argument types are supported:
    1. (self: torch._C.Node, arg0: str, arg1: int) -> torch._C.Node
    Invoked with: %137 : Tensor = onnx::RandomNormal(), scope: VAE, 'shape', 133 defined in (%133 : int[] = prim::ListConstruct(%128, %132), scope: VAE) (occurred when translating randn)

我正在使用cuda

任何想法都很感谢。也许我需要用不同的方式来处理onnx的z/latent?

注意:单步执行,我可以看到它正在为torch.randn()查找RandomNormal(),这应该是正确的。但在这一点上,我并不能真正访问参数,那么我如何修复它呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-02-15 11:34:32

简而言之,下面的代码可能会起作用。(至少在我的环境中,它在没有错误的情况下工作)。

似乎.size()运算符可能返回变量,而不是常量,因此导致onnx编译错误。(当我更改为使用.size()时,我得到了相同的错误)

代码语言:javascript
复制
import torch
import torch.utils.data
from torch import nn
from torch.nn import functional as F



IN_DIMS = 28 * 28
BATCH_SIZE = 10
FEATURE_DIM = 20

class VAE(nn.Module):
    def __init__(self):
        super(VAE, self).__init__()

        self.fc1 = nn.Linear(784, 400)
        self.fc21 = nn.Linear(400, FEATURE_DIM)
        self.fc22 = nn.Linear(400, FEATURE_DIM)
        self.fc3 = nn.Linear(FEATURE_DIM, 400)
        self.fc4 = nn.Linear(400, 784)

    def encode(self, x):
        h1 = F.relu(self.fc1(x))
        return self.fc21(h1), self.fc22(h1)

    def reparameterize(self, mu, logvar):
        std = torch.exp(0.5*logvar)
        eps = torch.randn(BATCH_SIZE, FEATURE_DIM, device='cuda')
        return eps.mul(std).add_(mu)

    def decode(self, z):
        h3 = F.relu(self.fc3(z))
        return torch.sigmoid(self.fc4(h3))

    def forward(self, x):
        mu, logvar = self.encode(x)
        z = self.reparameterize(mu, logvar)
        recon_x = self.decode(z)

        return recon_x

model = VAE().cuda()

dummy_input = torch.randn(BATCH_SIZE, IN_DIMS, device='cuda')
torch.onnx.export(model, dummy_input, "vae.onnx", verbose=True)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54699201

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档