01: from libc.math cimport sin, pi
02: #cimport cython
03:
+04: cdef inline double c4_sin2(double x):
static CYTHON_INLINE double __pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_sin2(double __pyx_v_x) {
double __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("c4_sin2", 0);
/* … */
/* function exit code */
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
+05: return sin(x) ** 2
__pyx_r = pow(sin(__pyx_v_x), 2.0);
goto __pyx_L0;
06:
07: #@cython.cdivision(True)
+08: cdef double c4_int(double a, double b, double (*f)(double), int N=2000):
static double __pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_int(double __pyx_v_a, double __pyx_v_b, double (*__pyx_v_f)(double), struct __pyx_opt_args_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_int *__pyx_optional_args) {
int __pyx_v_N = ((int)0x7D0);
int __pyx_v_i;
double __pyx_v_dx;
double __pyx_v_s;
double __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("c4_int", 0);
if (__pyx_optional_args) {
if (__pyx_optional_args->__pyx_n > 0) {
__pyx_v_N = __pyx_optional_args->N;
}
}
/* … */
/* function exit code */
__pyx_L1_error:;
__Pyx_WriteUnraisable("_cython_magic_c931752a75e94374ce45da5b639fdc1e.c4_int", __pyx_clineno, __pyx_lineno, __pyx_filename, 0, 0);
__pyx_r = 0;
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
09: cdef:
10: int i
+11: double dx = (b-a)/N
__pyx_t_1 = (__pyx_v_b - __pyx_v_a);
if (unlikely(__pyx_v_N == 0)) {
PyErr_SetString(PyExc_ZeroDivisionError, "float division");
__PYX_ERR(0, 11, __pyx_L1_error)
}
__pyx_v_dx = (__pyx_t_1 / ((double)__pyx_v_N));
+12: double s = 0.0
__pyx_v_s = 0.0;
+13: for i in range(N):
__pyx_t_2 = __pyx_v_N;
for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) {
__pyx_v_i = __pyx_t_3;
+14: s += f(a+i*dx)
__pyx_v_s = (__pyx_v_s + __pyx_v_f((__pyx_v_a + (__pyx_v_i * __pyx_v_dx))));
}
+15: return s * dx
__pyx_r = (__pyx_v_s * __pyx_v_dx);
goto __pyx_L0;
16:
+17: cpdef double c4_main():
static PyObject *__pyx_pw_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_1c4_main(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static double __pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_main(CYTHON_UNUSED int __pyx_skip_dispatch) {
double __pyx_v_a;
double __pyx_v_b;
double __pyx_r;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("c4_main", 0);
/* … */
/* function exit code */
__pyx_r = 0;
goto __pyx_L0;
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_3);
__Pyx_XDECREF(__pyx_t_4);
__Pyx_WriteUnraisable("_cython_magic_c931752a75e94374ce45da5b639fdc1e.c4_main", __pyx_clineno, __pyx_lineno, __pyx_filename, 0, 0);
__pyx_r = 0;
__pyx_L0:;
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
/* Python wrapper */
static PyObject *__pyx_pw_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_1c4_main(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static PyObject *__pyx_pw_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_1c4_main(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
PyObject *__pyx_r = 0;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("c4_main (wrapper)", 0);
__pyx_r = __pyx_pf_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_main(__pyx_self);
/* function exit code */
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
static PyObject *__pyx_pf_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_main(CYTHON_UNUSED PyObject *__pyx_self) {
PyObject *__pyx_r = NULL;
__Pyx_RefNannyDeclarations
__Pyx_RefNannySetupContext("c4_main", 0);
__Pyx_XDECREF(__pyx_r);
__pyx_t_1 = PyFloat_FromDouble(__pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_main(0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 17, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_1);
__pyx_r = __pyx_t_1;
__pyx_t_1 = 0;
goto __pyx_L0;
/* function exit code */
__pyx_L1_error:;
__Pyx_XDECREF(__pyx_t_1);
__Pyx_AddTraceback("_cython_magic_c931752a75e94374ce45da5b639fdc1e.c4_main", __pyx_clineno, __pyx_lineno, __pyx_filename);
__pyx_r = NULL;
__pyx_L0:;
__Pyx_XGIVEREF(__pyx_r);
__Pyx_RefNannyFinishContext();
return __pyx_r;
}
+18: cdef double a=0.0, b=2.0*pi
__pyx_v_a = 0.0;
__pyx_v_b = (2.0 * M_PI);
+19: print(c4_int(a, b, c4_sin2, N=400000))
__pyx_t_2.__pyx_n = 1;
__pyx_t_2.N = 0x61A80;
__pyx_t_1 = __pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_int(__pyx_v_a, __pyx_v_b, __pyx_f_46_cython_magic_c931752a75e94374ce45da5b639fdc1e_c4_sin2, &__pyx_t_2);
__pyx_t_3 = PyFloat_FromDouble(__pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 19, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 19, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_4);
__Pyx_GIVEREF(__pyx_t_3);
PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
__pyx_t_3 = 0;
__pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_print, __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 19, __pyx_L1_error)
__Pyx_GOTREF(__pyx_t_3);
__Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
__Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;