File: matmul_magic.txt

package info (click to toggle)
python-hypothesis 6.138.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 15,272 kB
  • sloc: python: 62,853; ruby: 1,107; sh: 253; makefile: 41; javascript: 6
file content (34 lines) | stat: -rw-r--r-- 1,232 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# This test code was written by the `hypothesis.extra.ghostwriter` module
# and is provided under the Creative Commons Zero public domain dedication.

import operator
from hypothesis import given, strategies as st

# TODO: replace st.nothing() with an appropriate strategy

matmul_operands = st.nothing()


@given(a=matmul_operands, b=matmul_operands, c=matmul_operands)
def test_associative_binary_operation_matmul(a, b, c):
    left = operator.matmul(a, operator.matmul(b, c))
    right = operator.matmul(operator.matmul(a, b), c)
    assert left == right, (left, right)


@given(a=matmul_operands)
def test_identity_binary_operation_matmul(a):
    identity = "identity element here"
    assert a == operator.matmul(a, identity)
    assert a == operator.matmul(identity, a)


@given(a=matmul_operands, b=matmul_operands, c=matmul_operands)
def test_add_distributes_over_binary_operation_matmul(a, b, c):
    left = operator.matmul(a, operator.add(b, c))
    ldist = operator.add(operator.matmul(a, b), operator.matmul(a, c))
    assert ldist == left, (ldist, left)

    right = operator.matmul(operator.add(a, b), c)
    rdist = operator.add(operator.matmul(a, c), operator.matmul(b, c))
    assert rdist == right, (rdist, right)