pytorch

Форк
0
/
math_ops_test.py 
50 строк · 1.6 Кб
1

2

3

4

5

6
from caffe2.python import core
7
from hypothesis import given, settings
8
from hypothesis import strategies as st
9
import caffe2.python.hypothesis_test_util as hu
10
import caffe2.python.serialized_test.serialized_test_util as serial
11

12
import numpy as np
13
import unittest
14

15

16
class TestMathOps(serial.SerializedTestCase):
17

18
    @given(X=hu.tensor(),
19
           exponent=st.floats(min_value=2.0, max_value=3.0),
20
           **hu.gcs)
21
    def test_elementwise_power(self, X, exponent, gc, dc):
22
        # negative integer raised with non-integer exponent is domain error
23
        X = np.abs(X)
24
        def powf(X):
25
            return (X ** exponent,)
26

27
        def powf_grad(g_out, outputs, fwd_inputs):
28
            return (exponent * (fwd_inputs[0] ** (exponent - 1)) * g_out,)
29

30
        op = core.CreateOperator(
31
            "Pow", ["X"], ["Y"], exponent=exponent)
32

33
        self.assertReferenceChecks(gc, op, [X], powf,
34
                                   output_to_grad="Y",
35
                                   grad_reference=powf_grad,
36
                                   ensure_outputs_are_inferred=True)
37

38
    @given(X=hu.tensor(),
39
           exponent=st.floats(min_value=-3.0, max_value=3.0),
40
           **hu.gcs)
41
    @settings(deadline=10000)
42
    def test_sign(self, X, exponent, gc, dc):
43
        def signf(X):
44
            return [np.sign(X)]
45

46
        op = core.CreateOperator(
47
            "Sign", ["X"], ["Y"])
48

49
        self.assertReferenceChecks(
50
            gc, op, [X], signf, ensure_outputs_are_inferred=True)
51
        self.assertDeviceChecks(dc, op, [X], [0])
52

53

54
if __name__ == "__main__":
55
    unittest.main()
56

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.