Home - Summaries: (main) : (py3.11) : Everything - Nightly builds - Benchmarks - RPython - Builders - About

pypy/module/pypyjit/test_pypy_c/test_math.py::TestMath::()::test_sin_cos

self = <pypy.module.pypyjit.test_pypy_c.test_math.TestMath object at 0x000001f1bef75f68>

    def test_sin_cos(self):
        def main(n):
            import math
    
            i = 1
            s = 0.0
            while i < n:
                s += math.sin(i) - math.cos(i)
                i += 1
            return s
        log = self.run(main, [500])
        assert round(log.result, 6) == round(main(500), 6)
        loop, = log.loops_by_filename(self.filepath)
>       assert loop.match("""
                i2 = int_lt(i0, i1)
                guard_true(i2, descr=...)
                guard_not_invalidated(descr=...)
                f1 = cast_int_to_float(i0)
                i6 = --ISINF--(f1)
                guard_false(i6, descr=...)
                f2 = call_f(ConstClass(sin), f1, descr=<Callf . f EF=0>)
                f3 = call_f(ConstClass(cos), f1, descr=<Callf . f EF=0>)
                f4 = float_sub(f2, f3)
                f5 = float_add(f0, f4)
                i7 = int_add(i0, 1)
                --TICK--
                jump(..., descr=)
            """)

pypy\module\pypyjit\test_pypy_c\test_math.py:48: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
pypy\module\pypyjit\test_pypy_c\model.py:186: in match
    return matcher.match(expected_src, **kwds)
pypy\module\pypyjit\test_pypy_c\model.py:527: in match
    self.match_loop(expected_ops, ignore_ops)
pypy\module\pypyjit\test_pypy_c\model.py:503: in match_loop
    self.match_op(op, exp_op)
pypy\module\pypyjit\test_pypy_c\model.py:420: in match_op
    self._assert(self.match_var(arg, exp_arg), "variable mismatch: %r instead of %r" % (arg, exp_arg))
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _

self = <pypy.module.pypyjit.test_pypy_c.model.OpMatcher object at 0x000001f1be99af38>
cond = False
message = "variable mismatch: 'ConstClass(ccall_sin)' instead of 'ConstClass(sin)'"

    def _assert(self, cond, message):
        if not cond:
>           raise InvalidMatch(message, frame=sys._getframe(1))
E           InvalidMatch: variable mismatch: 'ConstClass(ccall_sin)' instead of 'ConstClass(sin)'

pypy\module\pypyjit\test_pypy_c\model.py:405: InvalidMatch
---------- Captured stdout call ----------
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Loops don't match
=================
loop id = None
("variable mismatch: 'ConstClass(ccall_sin)' instead of 'ConstClass(sin)'",)
<could not determine information>

Ignore ops: []
Got:
    i57 = int_lt(i52, i31)
    guard_true(i57, descr=<Guard0x20e090e6260>)
    guard_not_invalidated(descr=<Guard0x20e090e0dd0>)
    f58 = cast_int_to_float(i52)
    f60 = float_add(f58, 11235582092889474423308157442431404585112356118389416079589380072358292237843810195794279832650471001320007117491962084853674360550901038905802964414967132773610493339054092829768888725077880882465817684505312860552384417646403930092119569408801702322709406917786643639996702871154982269052209770601514008576.000000)
    i61 = float_eq(f60, f58)
    guard_false(i61, descr=<Guard0x20e090e0e30>)

	===== HERE =====
    f63 = call_f(ConstClass(ccall_sin), f58, descr=<Callf 8 f EF=2>)
    f65 = call_f(ConstClass(ccall_cos), f58, descr=<Callf 8 f EF=2>)
    f66 = float_sub(f63, f65)
    f67 = float_add(f50, f66)
    i69 = int_add(i52, 1)
    i71 = getfield_raw_i(140711600789008, descr=<FieldS pypysig_long_struct_inner.c_value 0>)
    i73 = int_lt(i71, 0)
    guard_false(i73, descr=<Guard0x20e090e62a8>)
    jump(p0, p1, p6, p7, p10, p12, i69, f67, i31, descr=TargetToken(2259304726624))

Expected:
    
    i2 = int_lt(i0, i1)
    guard_true(i2, descr=...)
    guard_not_invalidated(descr=...)
    f1 = cast_int_to_float(i0)
    f1\B999 = float_add(f1, ...)
    i6 = float_eq(f1\B999, f1)
    guard_false(i6, descr=...)
    f2 = call_f(ConstClass(sin), f1, descr=<Callf . f EF=0>)
    f3 = call_f(ConstClass(cos), f1, descr=<Callf . f EF=0>)
    f4 = float_sub(f2, f3)
    f5 = float_add(f0, f4)
    i7 = int_add(i0, 1)
    
    guard_not_invalidated?
    ticker0 = getfield_raw_i(#, descr=<FieldS pypysig_long_struct_inner.c_value .*>)
    ticker_cond0 = int_lt(ticker0, 0)
    guard_false(ticker_cond0, descr=...)
    
    jump(..., descr=)
builder: pypy-c-jit-win-x86-64 build #2372+
test: pypy/module/pypyjit/test_pypy_c/test_math.py::TestMath::()::test_sin_cos