|
- # Copyright 2019 Huawei Technologies Co., Ltd
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- # ============================================================================
- """test cases for exp"""
- import pytest
- import mindspore.nn as nn
- import mindspore.nn.probability.bijector as msb
- from mindspore import Tensor
- from mindspore import dtype
-
- def test_init():
- b = msb.Exp()
- assert isinstance(b, msb.Bijector)
-
- def test_type():
- with pytest.raises(TypeError):
- msb.Exp(name=0.1)
-
- class Net(nn.Cell):
- """
- Test class: forward and inverse pass of bijector.
- """
- def __init__(self):
- super(Net, self).__init__()
- self.b1 = msb.Exp()
- self.b2 = msb.Exp()
-
- def construct(self, x_):
- forward = self.b1.forward(x_)
- inverse = self.b1.inverse(forward)
- return x_ - inverse
-
- def test1():
- """
- Test forward and inverse pass of exp bijector.
- """
- net = Net()
- x = Tensor([2.0, 3.0, 4.0, 5.0], dtype=dtype.float32)
- ans = net(x)
- assert isinstance(ans, Tensor)
-
- class Jacobian(nn.Cell):
- """
- Test class: forward and inverse pass of bijector.
- """
- def __init__(self):
- super(Jacobian, self).__init__()
- self.b1 = msb.Exp()
- self.b2 = msb.Exp()
-
- def construct(self, x_):
- ans1 = self.b1.forward_log_jacobian(x_)
- ans2 = self.b1.inverse_log_jacobian(x_)
- return ans1 + ans2
-
- def test2():
- """
- Test jacobians of exp bijector.
- """
- net = Jacobian()
- x = Tensor([2.0, 3.0, 4.0, 5.0], dtype=dtype.float32)
- ans = net(x)
- assert isinstance(ans, Tensor)
|