Generated by Cython 0.29.21

Yellow lines hint at Python interaction.
Click on a line that starts with a "+" to see the C code that Cython generated for it.

Raw output: shader.c

+0001: # cython: binding=False, boundscheck=False, wraparound=False, nonecheck=False, cdivision=True,
  __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_2) < 0) __PYX_ERR(1, 1, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 0002: # cython: optimize.use_switch=True
 0003: # encoding: utf-8
 0004: 
 0005: """
 0006:                  GNU GENERAL PUBLIC LICENSE
 0007:                        Version 3, 29 June 2007
 0008: 
 0009:  Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
 0010:  Everyone is permitted to copy and distribute verbatim copies
 0011:  of this license document, but changing it is not allowed.
 0012: 
 0013: Copyright Yoann Berenguer
 0014: """
 0015: 
 0016: 
 0017: """
 0018: Version 1.0.1 (yank)
 0019: + new cartoon effect added to library for offline surface processing. This shader cannot  
 0020:   be used in real time due to the amount of transformation. 
 0021: 
 0022: Version 1.0.2 same than 1.0.1
 0023: + new cartoon effect added to library for offline surface processing. This shader cannot  
 0024:   be used in real time due to the amount of transformation. 
 0025: 
 0026: 
 0027: Version 1.0.3 
 0028: ++ New transition effect (blend effect) 
 0029: 
 0030: ++ BUG CORRECTED IN rgb_split
 0031: #         unsigned char [:] red   = numpy.empty(z, uint8, order='C')
 0032: #         unsigned char [:] green = numpy.empty(z, uint8, order='C')
 0033: #         unsigned char [:] blue  = numpy.empty(z, uint8, order='C')
 0034: # TO
 0035: #         unsigned char [:] red   = numpy.zeros(z, uint8, order='C')
 0036: #         unsigned char [:] green = numpy.zeros(z, uint8, order='C')
 0037: #         unsigned char [:] blue  = numpy.zeros(z, uint8, order='C')
 0038: 
 0039: # ++ Predator mode has now a blending mode
 0040: # int blend = pygame.BLEND_RGB_ADD
 0041: # Also change declaration in pxd file and pyx bint inv_colormap and bint fast
 0042: cpdef predator_vision(object surface_, unsigned int sobel_threshold=*,
 0043:                            unsigned int bpf_threshold=*, unsigned int bloom_threshold=*,
 0044:                            bint inv_colormap=*, bint fast=*, int blend=*)
 0045:                            
 0046: ++ Renamed all the methods with a quicker and easier name to remember
 0047: 
 0048: ++ corrected algos swirl and swirl2 (divided r by r_max)
 0049: 
 0050: ++ new algorithm dirt_lens effect
 0051: 
 0052: ++ Change brightness and brightness_exclude, no change if shift_ == 0 
 0053: 
 0054: ++ Changed /corrected bug with color_reduction algorithm.
 0055: 
 0056: ++ Added Dithering algorithm 
 0057: ++ Added Color_palette
 0058: ++ added bilateral filter 
 0059: ++ added emboss filter
 0060: ++ pixelation 
 0061: ++ convert to 27 colors
 0062: ++ spectrum surface
 0063: ++ horizontal gradient (unit misc.pyx)
 0064: 
 0065: ++ create misc.pxd file
 0066: 
 0067: """
 0068: 
 0069: 
 0070: 
 0071: 
+0072: __VERSION__ = "1.0.3"
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_VERSION, __pyx_kp_s_1_0_3) < 0) __PYX_ERR(1, 72, __pyx_L1_error)
 0073: 
+0074: import warnings
  __pyx_t_1 = __Pyx_Import(__pyx_n_s_warnings, 0, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 74, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_warnings, __pyx_t_1) < 0) __PYX_ERR(1, 74, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
 0075: 
+0076: warnings.filterwarnings("ignore", category=FutureWarning)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_warnings); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 76, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_filterwarnings); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 76, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 76, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_category, __pyx_builtin_FutureWarning) < 0) __PYX_ERR(1, 76, __pyx_L1_error)
  __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_tuple__55, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 76, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
/* … */
  __pyx_tuple__55 = PyTuple_Pack(1, __pyx_n_s_ignore); if (unlikely(!__pyx_tuple__55)) __PYX_ERR(1, 76, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__55);
  __Pyx_GIVEREF(__pyx_tuple__55);
+0077: warnings.filterwarnings("ignore", category=RuntimeWarning)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_warnings); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 77, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_filterwarnings); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 77, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 77, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_category, __pyx_builtin_RuntimeWarning) < 0) __PYX_ERR(1, 77, __pyx_L1_error)
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_tuple__55, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 77, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+0078: warnings.filterwarnings("ignore", category=ImportWarning)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_warnings); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 78, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_filterwarnings); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 78, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 78, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_category, __pyx_builtin_ImportWarning) < 0) __PYX_ERR(1, 78, __pyx_L1_error)
  __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_tuple__55, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 78, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
 0079: 
+0080: try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L7_try_end;
    __pyx_L2_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6);
    goto __pyx_L1_error;
    __pyx_L7_try_end:;
  }
+0081:     import numpy
      __pyx_t_1 = __Pyx_Import(__pyx_n_s_numpy, 0, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 81, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_numpy, __pyx_t_1) < 0) __PYX_ERR(1, 81, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0082:     from numpy import empty, uint8, int16, float32, asarray, linspace, \
      __pyx_t_1 = PyList_New(12); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_n_s_empty);
      __Pyx_GIVEREF(__pyx_n_s_empty);
      PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_empty);
      __Pyx_INCREF(__pyx_n_s_uint8);
      __Pyx_GIVEREF(__pyx_n_s_uint8);
      PyList_SET_ITEM(__pyx_t_1, 1, __pyx_n_s_uint8);
      __Pyx_INCREF(__pyx_n_s_int16);
      __Pyx_GIVEREF(__pyx_n_s_int16);
      PyList_SET_ITEM(__pyx_t_1, 2, __pyx_n_s_int16);
      __Pyx_INCREF(__pyx_n_s_float32);
      __Pyx_GIVEREF(__pyx_n_s_float32);
      PyList_SET_ITEM(__pyx_t_1, 3, __pyx_n_s_float32);
      __Pyx_INCREF(__pyx_n_s_asarray);
      __Pyx_GIVEREF(__pyx_n_s_asarray);
      PyList_SET_ITEM(__pyx_t_1, 4, __pyx_n_s_asarray);
      __Pyx_INCREF(__pyx_n_s_linspace);
      __Pyx_GIVEREF(__pyx_n_s_linspace);
      PyList_SET_ITEM(__pyx_t_1, 5, __pyx_n_s_linspace);
      __Pyx_INCREF(__pyx_n_s_ascontiguousarray);
      __Pyx_GIVEREF(__pyx_n_s_ascontiguousarray);
      PyList_SET_ITEM(__pyx_t_1, 6, __pyx_n_s_ascontiguousarray);
      __Pyx_INCREF(__pyx_n_s_zeros);
      __Pyx_GIVEREF(__pyx_n_s_zeros);
      PyList_SET_ITEM(__pyx_t_1, 7, __pyx_n_s_zeros);
      __Pyx_INCREF(__pyx_n_s_uint16);
      __Pyx_GIVEREF(__pyx_n_s_uint16);
      PyList_SET_ITEM(__pyx_t_1, 8, __pyx_n_s_uint16);
      __Pyx_INCREF(__pyx_n_s_uint32);
      __Pyx_GIVEREF(__pyx_n_s_uint32);
      PyList_SET_ITEM(__pyx_t_1, 9, __pyx_n_s_uint32);
      __Pyx_INCREF(__pyx_n_s_int32);
      __Pyx_GIVEREF(__pyx_n_s_int32);
      PyList_SET_ITEM(__pyx_t_1, 10, __pyx_n_s_int32);
      __Pyx_INCREF(__pyx_n_s_int8);
      __Pyx_GIVEREF(__pyx_n_s_int8);
      PyList_SET_ITEM(__pyx_t_1, 11, __pyx_n_s_int8);
      __pyx_t_2 = __Pyx_Import(__pyx_n_s_numpy, __pyx_t_1, -1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_empty, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_uint8, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_int16); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_int16, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_float32); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_float32, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_asarray); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_asarray, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_linspace); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_linspace, __pyx_t_1) < 0) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_ascontiguousarray, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_zeros, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_uint16); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_uint16, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_uint32); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_uint32, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_int32); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_int32, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_int8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 82, __pyx_L2_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_int8, __pyx_t_1) < 0) __PYX_ERR(1, 83, __pyx_L2_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 0083:         ascontiguousarray, zeros, uint16, uint32, int32, int8
+0084: except ImportError:
    __pyx_t_7 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_ImportError);
    if (__pyx_t_7) {
      __Pyx_AddTraceback("PygameShader.shader", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_2, &__pyx_t_1, &__pyx_t_3) < 0) __PYX_ERR(1, 84, __pyx_L4_except_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_GOTREF(__pyx_t_3);
+0085:     raise ImportError("\n<numpy> library is missing on your system."
      __pyx_t_8 = __Pyx_PyObject_Call(__pyx_builtin_ImportError, __pyx_tuple__56, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 85, __pyx_L4_except_error)
      __Pyx_GOTREF(__pyx_t_8);
      __Pyx_Raise(__pyx_t_8, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __PYX_ERR(1, 85, __pyx_L4_except_error)
    }
    goto __pyx_L4_except_error;
    __pyx_L4_except_error:;
/* … */
  __pyx_tuple__56 = PyTuple_Pack(1, __pyx_kp_s_numpy_library_is_missing_on_you); if (unlikely(!__pyx_tuple__56)) __PYX_ERR(1, 85, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__56);
  __Pyx_GIVEREF(__pyx_tuple__56);
 0086:           "\nTry: \n   C:\\pip install numpy on a window command prompt.")
 0087: 
 0088: cimport numpy as np
 0089: 
+0090: try:
  {
    /*try:*/ {
/* … */
    }
  }
 0091:     cimport cython
 0092:     from cython.parallel cimport prange
 0093: 
 0094: except ImportError:
 0095:     raise ImportError("\n<cython> library is missing on your system."
 0096:           "\nTry: \n   C:\\pip install cython on a window command prompt.")
 0097: 
 0098: # PYGAME IS REQUIRED
+0099: try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L21_try_end;
    __pyx_L16_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6);
    goto __pyx_L1_error;
    __pyx_L21_try_end:;
  }
+0100:     import pygame
      __pyx_t_3 = __Pyx_Import(__pyx_n_s_pygame, 0, -1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 100, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pygame, __pyx_t_3) < 0) __PYX_ERR(1, 100, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+0101:     from pygame import Color, Surface, SRCALPHA, RLEACCEL, BufferProxy, HWACCEL, HWSURFACE, \
      __pyx_t_3 = PyList_New(13); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_INCREF(__pyx_n_s_Color);
      __Pyx_GIVEREF(__pyx_n_s_Color);
      PyList_SET_ITEM(__pyx_t_3, 0, __pyx_n_s_Color);
      __Pyx_INCREF(__pyx_n_s_Surface);
      __Pyx_GIVEREF(__pyx_n_s_Surface);
      PyList_SET_ITEM(__pyx_t_3, 1, __pyx_n_s_Surface);
      __Pyx_INCREF(__pyx_n_s_SRCALPHA);
      __Pyx_GIVEREF(__pyx_n_s_SRCALPHA);
      PyList_SET_ITEM(__pyx_t_3, 2, __pyx_n_s_SRCALPHA);
      __Pyx_INCREF(__pyx_n_s_RLEACCEL);
      __Pyx_GIVEREF(__pyx_n_s_RLEACCEL);
      PyList_SET_ITEM(__pyx_t_3, 3, __pyx_n_s_RLEACCEL);
      __Pyx_INCREF(__pyx_n_s_BufferProxy);
      __Pyx_GIVEREF(__pyx_n_s_BufferProxy);
      PyList_SET_ITEM(__pyx_t_3, 4, __pyx_n_s_BufferProxy);
      __Pyx_INCREF(__pyx_n_s_HWACCEL);
      __Pyx_GIVEREF(__pyx_n_s_HWACCEL);
      PyList_SET_ITEM(__pyx_t_3, 5, __pyx_n_s_HWACCEL);
      __Pyx_INCREF(__pyx_n_s_HWSURFACE);
      __Pyx_GIVEREF(__pyx_n_s_HWSURFACE);
      PyList_SET_ITEM(__pyx_t_3, 6, __pyx_n_s_HWSURFACE);
      __Pyx_INCREF(__pyx_n_s_QUIT);
      __Pyx_GIVEREF(__pyx_n_s_QUIT);
      PyList_SET_ITEM(__pyx_t_3, 7, __pyx_n_s_QUIT);
      __Pyx_INCREF(__pyx_n_s_K_SPACE);
      __Pyx_GIVEREF(__pyx_n_s_K_SPACE);
      PyList_SET_ITEM(__pyx_t_3, 8, __pyx_n_s_K_SPACE);
      __Pyx_INCREF(__pyx_n_s_BLEND_RGB_ADD);
      __Pyx_GIVEREF(__pyx_n_s_BLEND_RGB_ADD);
      PyList_SET_ITEM(__pyx_t_3, 9, __pyx_n_s_BLEND_RGB_ADD);
      __Pyx_INCREF(__pyx_n_s_Rect);
      __Pyx_GIVEREF(__pyx_n_s_Rect);
      PyList_SET_ITEM(__pyx_t_3, 10, __pyx_n_s_Rect);
      __Pyx_INCREF(__pyx_n_s_BLEND_RGB_MAX);
      __Pyx_GIVEREF(__pyx_n_s_BLEND_RGB_MAX);
      PyList_SET_ITEM(__pyx_t_3, 11, __pyx_n_s_BLEND_RGB_MAX);
      __Pyx_INCREF(__pyx_n_s_BLEND_RGB_MIN);
      __Pyx_GIVEREF(__pyx_n_s_BLEND_RGB_MIN);
      PyList_SET_ITEM(__pyx_t_3, 12, __pyx_n_s_BLEND_RGB_MIN);
      __pyx_t_1 = __Pyx_Import(__pyx_n_s_pygame, __pyx_t_3, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Color); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_Color, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_Surface, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_SRCALPHA); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_SRCALPHA, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_RLEACCEL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_RLEACCEL, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BufferProxy); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_BufferProxy, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_HWACCEL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_HWACCEL, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_HWSURFACE); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_HWSURFACE, __pyx_t_3) < 0) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_QUIT); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_QUIT, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_K_SPACE); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_K_SPACE, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_BLEND_RGB_ADD, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_Rect); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_Rect, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BLEND_RGB_MAX); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_BLEND_RGB_MAX, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_BLEND_RGB_MIN); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 101, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_BLEND_RGB_MIN, __pyx_t_3) < 0) __PYX_ERR(1, 102, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
 0102:     QUIT, K_SPACE, BLEND_RGB_ADD, Rect, BLEND_RGB_MAX, BLEND_RGB_MIN
+0103:     from pygame.surfarray import pixels3d, array_alpha, pixels_alpha, array3d, \
      __pyx_t_1 = PyList_New(9); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_n_s_pixels3d);
      __Pyx_GIVEREF(__pyx_n_s_pixels3d);
      PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_pixels3d);
      __Pyx_INCREF(__pyx_n_s_array_alpha);
      __Pyx_GIVEREF(__pyx_n_s_array_alpha);
      PyList_SET_ITEM(__pyx_t_1, 1, __pyx_n_s_array_alpha);
      __Pyx_INCREF(__pyx_n_s_pixels_alpha);
      __Pyx_GIVEREF(__pyx_n_s_pixels_alpha);
      PyList_SET_ITEM(__pyx_t_1, 2, __pyx_n_s_pixels_alpha);
      __Pyx_INCREF(__pyx_n_s_array3d);
      __Pyx_GIVEREF(__pyx_n_s_array3d);
      PyList_SET_ITEM(__pyx_t_1, 3, __pyx_n_s_array3d);
      __Pyx_INCREF(__pyx_n_s_make_surface);
      __Pyx_GIVEREF(__pyx_n_s_make_surface);
      PyList_SET_ITEM(__pyx_t_1, 4, __pyx_n_s_make_surface);
      __Pyx_INCREF(__pyx_n_s_blit_array);
      __Pyx_GIVEREF(__pyx_n_s_blit_array);
      PyList_SET_ITEM(__pyx_t_1, 5, __pyx_n_s_blit_array);
      __Pyx_INCREF(__pyx_n_s_pixels_red);
      __Pyx_GIVEREF(__pyx_n_s_pixels_red);
      PyList_SET_ITEM(__pyx_t_1, 6, __pyx_n_s_pixels_red);
      __Pyx_INCREF(__pyx_n_s_pixels_green);
      __Pyx_GIVEREF(__pyx_n_s_pixels_green);
      PyList_SET_ITEM(__pyx_t_1, 7, __pyx_n_s_pixels_green);
      __Pyx_INCREF(__pyx_n_s_pixels_blue);
      __Pyx_GIVEREF(__pyx_n_s_pixels_blue);
      PyList_SET_ITEM(__pyx_t_1, 8, __pyx_n_s_pixels_blue);
      __pyx_t_3 = __Pyx_Import(__pyx_n_s_pygame_surfarray, __pyx_t_1, -1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pixels3d, __pyx_t_1) < 0) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_array_alpha); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_array_alpha, __pyx_t_1) < 0) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_pixels_alpha); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pixels_alpha, __pyx_t_1) < 0) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_array3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_array3d, __pyx_t_1) < 0) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_make_surface, __pyx_t_1) < 0) __PYX_ERR(1, 104, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_blit_array); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_blit_array, __pyx_t_1) < 0) __PYX_ERR(1, 104, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_pixels_red); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pixels_red, __pyx_t_1) < 0) __PYX_ERR(1, 104, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_pixels_green); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pixels_green, __pyx_t_1) < 0) __PYX_ERR(1, 105, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_pixels_blue); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 103, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_pixels_blue, __pyx_t_1) < 0) __PYX_ERR(1, 105, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 0104:         make_surface, blit_array, pixels_red, \
 0105:     pixels_green, pixels_blue
+0106:     from pygame.image import frombuffer, fromstring, tostring
      __pyx_t_3 = PyList_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_INCREF(__pyx_n_s_frombuffer);
      __Pyx_GIVEREF(__pyx_n_s_frombuffer);
      PyList_SET_ITEM(__pyx_t_3, 0, __pyx_n_s_frombuffer);
      __Pyx_INCREF(__pyx_n_s_fromstring);
      __Pyx_GIVEREF(__pyx_n_s_fromstring);
      PyList_SET_ITEM(__pyx_t_3, 1, __pyx_n_s_fromstring);
      __Pyx_INCREF(__pyx_n_s_tostring);
      __Pyx_GIVEREF(__pyx_n_s_tostring);
      PyList_SET_ITEM(__pyx_t_3, 2, __pyx_n_s_tostring);
      __pyx_t_1 = __Pyx_Import(__pyx_n_s_pygame_image, __pyx_t_3, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_frombuffer, __pyx_t_3) < 0) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_fromstring, __pyx_t_3) < 0) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_tostring); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_tostring, __pyx_t_3) < 0) __PYX_ERR(1, 106, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0107:     from pygame.math import Vector2
      __pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 107, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_n_s_Vector2);
      __Pyx_GIVEREF(__pyx_n_s_Vector2);
      PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_Vector2);
      __pyx_t_3 = __Pyx_Import(__pyx_n_s_pygame_math, __pyx_t_1, -1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 107, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_Vector2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 107, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_Vector2, __pyx_t_1) < 0) __PYX_ERR(1, 107, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+0108:     from pygame import _freetype
      __pyx_t_3 = PyList_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 108, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_INCREF(__pyx_n_s_freetype);
      __Pyx_GIVEREF(__pyx_n_s_freetype);
      PyList_SET_ITEM(__pyx_t_3, 0, __pyx_n_s_freetype);
      __pyx_t_1 = __Pyx_Import(__pyx_n_s_pygame, __pyx_t_3, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 108, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_freetype); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 108, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_freetype, __pyx_t_3) < 0) __PYX_ERR(1, 108, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0109:     from pygame._freetype import STYLE_STRONG, STYLE_NORMAL
      __pyx_t_1 = PyList_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_n_s_STYLE_STRONG);
      __Pyx_GIVEREF(__pyx_n_s_STYLE_STRONG);
      PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_STYLE_STRONG);
      __Pyx_INCREF(__pyx_n_s_STYLE_NORMAL);
      __Pyx_GIVEREF(__pyx_n_s_STYLE_NORMAL);
      PyList_SET_ITEM(__pyx_t_1, 1, __pyx_n_s_STYLE_NORMAL);
      __pyx_t_3 = __Pyx_Import(__pyx_n_s_pygame__freetype, __pyx_t_1, -1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_STYLE_STRONG); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_STYLE_STRONG, __pyx_t_1) < 0) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_STYLE_NORMAL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_STYLE_NORMAL, __pyx_t_1) < 0) __PYX_ERR(1, 109, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+0110:     from pygame.transform import scale, smoothscale, rotate, scale2x
      __pyx_t_3 = PyList_New(4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_INCREF(__pyx_n_s_scale);
      __Pyx_GIVEREF(__pyx_n_s_scale);
      PyList_SET_ITEM(__pyx_t_3, 0, __pyx_n_s_scale);
      __Pyx_INCREF(__pyx_n_s_smoothscale);
      __Pyx_GIVEREF(__pyx_n_s_smoothscale);
      PyList_SET_ITEM(__pyx_t_3, 1, __pyx_n_s_smoothscale);
      __Pyx_INCREF(__pyx_n_s_rotate);
      __Pyx_GIVEREF(__pyx_n_s_rotate);
      PyList_SET_ITEM(__pyx_t_3, 2, __pyx_n_s_rotate);
      __Pyx_INCREF(__pyx_n_s_scale2x);
      __Pyx_GIVEREF(__pyx_n_s_scale2x);
      PyList_SET_ITEM(__pyx_t_3, 3, __pyx_n_s_scale2x);
      __pyx_t_1 = __Pyx_Import(__pyx_n_s_pygame_transform, __pyx_t_3, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_scale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_scale, __pyx_t_3) < 0) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_smoothscale, __pyx_t_3) < 0) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_rotate); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_rotate, __pyx_t_3) < 0) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_scale2x); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_scale2x, __pyx_t_3) < 0) __PYX_ERR(1, 110, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+0111:     from pygame.pixelcopy import array_to_surface
      __pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 111, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_INCREF(__pyx_n_s_array_to_surface);
      __Pyx_GIVEREF(__pyx_n_s_array_to_surface);
      PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_array_to_surface);
      __pyx_t_3 = __Pyx_Import(__pyx_n_s_pygame_pixelcopy, __pyx_t_1, -1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 111, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_array_to_surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 111, __pyx_L16_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (PyDict_SetItem(__pyx_d, __pyx_n_s_array_to_surface, __pyx_t_1) < 0) __PYX_ERR(1, 111, __pyx_L16_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 0112: 
+0113: except ImportError:
    __pyx_t_7 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_ImportError);
    if (__pyx_t_7) {
      __Pyx_AddTraceback("PygameShader.shader", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_3, &__pyx_t_1, &__pyx_t_2) < 0) __PYX_ERR(1, 113, __pyx_L18_except_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_GOTREF(__pyx_t_2);
+0114:     raise ImportError("\n<Pygame> library is missing on your system."
      __pyx_t_8 = __Pyx_PyObject_Call(__pyx_builtin_ImportError, __pyx_tuple__57, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 114, __pyx_L18_except_error)
      __Pyx_GOTREF(__pyx_t_8);
      __Pyx_Raise(__pyx_t_8, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __PYX_ERR(1, 114, __pyx_L18_except_error)
    }
    goto __pyx_L18_except_error;
    __pyx_L18_except_error:;
/* … */
  __pyx_tuple__57 = PyTuple_Pack(1, __pyx_kp_s_Pygame_library_is_missing_on_yo); if (unlikely(!__pyx_tuple__57)) __PYX_ERR(1, 114, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__57);
  __Pyx_GIVEREF(__pyx_tuple__57);
 0115:           "\nTry: \n   C:\\pip install pygame on a window command prompt.")
 0116: 
+0117: try:
  {
    /*try:*/ {
/* … */
    }
  }
 0118:     cimport cython
 0119:     from cython.parallel cimport prange
 0120:     from cpython cimport PyObject_CallFunctionObjArgs, PyObject, \
 0121:         PyList_SetSlice, PyObject_HasAttr, PyObject_IsInstance, \
 0122:         PyObject_CallMethod, PyObject_CallObject
 0123:     from cpython.dict cimport PyDict_DelItem, PyDict_Clear, PyDict_GetItem, PyDict_SetItem, \
 0124:         PyDict_Values, PyDict_Keys, PyDict_Items
 0125:     from cpython.list cimport PyList_Append, PyList_GetItem, PyList_Size, PyList_SetItem
 0126:     from cpython.object cimport PyObject_SetAttr
 0127: 
 0128: except ImportError:
 0129:     raise ImportError("\n<cython> library is missing on your system."
 0130:           "\nTry: \n   C:\\pip install cython on a window command prompt.")
 0131: 
+0132: from PygameShader.gaussianBlur5x5 import canny_blur5x5_surface24_c
  __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_n_s_canny_blur5x5_surface24_c);
  __Pyx_GIVEREF(__pyx_n_s_canny_blur5x5_surface24_c);
  PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_canny_blur5x5_surface24_c);
  __pyx_t_1 = __Pyx_Import(__pyx_n_s_PygameShader_gaussianBlur5x5, __pyx_t_2, -1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_1, __pyx_n_s_canny_blur5x5_surface24_c); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_canny_blur5x5_surface24_c, __pyx_t_2) < 0) __PYX_ERR(1, 132, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
 0133: from PygameShader.misc cimport color_diff_hsv, color_diff_hsl, close_color
 0134: 
 0135: from libc.stdlib cimport rand, malloc
 0136: from libc.math cimport sqrt, atan2, sin, cos, nearbyint, exp, pow, floor
 0137: from libc.stdlib cimport malloc, free
 0138: from libc.math cimport round as round_c
 0139: 
 0140: from libc.stdio cimport printf
 0141: 
+0142: cdef float M_PI = 3.14159265358979323846
  __pyx_v_12PygameShader_6shader_M_PI = 3.14159265358979323846;
+0143: cdef float M_PI2 =3.14159265358979323846/2.0
  __pyx_v_12PygameShader_6shader_M_PI2 = (3.14159265358979323846 / 2.0);
+0144: cdef float M_2PI =2 * 3.14159265358979323846
  __pyx_v_12PygameShader_6shader_M_2PI = (2.0 * 3.14159265358979323846);
 0145: 
+0146: cdef float RAD_TO_DEG=<float>(180.0/M_PI)
  __pyx_v_12PygameShader_6shader_RAD_TO_DEG = ((float)(180.0 / __pyx_v_12PygameShader_6shader_M_PI));
+0147: cdef float DEG_TO_RAD=<float>(M_PI/180.0)
  __pyx_v_12PygameShader_6shader_DEG_TO_RAD = ((float)(__pyx_v_12PygameShader_6shader_M_PI / 180.0));
 0148: 
+0149: cdef float C1 = <float>7.0/<float>16.0
  __pyx_v_12PygameShader_6shader_C1 = (((float)7.0) / ((float)16.0));
+0150: cdef float C2 = <float>3.0/<float>16.0
  __pyx_v_12PygameShader_6shader_C2 = (((float)3.0) / ((float)16.0));
+0151: cdef float C3 = <float>5.0/<float>16.0
  __pyx_v_12PygameShader_6shader_C3 = (((float)5.0) / ((float)16.0));
+0152: cdef float C4 = <float>1.0/<float>16.0
  __pyx_v_12PygameShader_6shader_C4 = (((float)1.0) / ((float)16.0));
 0153: 
+0154: cdef int THREADS = 4
  __pyx_v_12PygameShader_6shader_THREADS = 4;
 0155: 
 0156: DEF HALF         = 1.0/2.0
 0157: DEF ONE_THIRD    = 1.0/3.0
 0158: DEF ONE_FOURTH   = 1.0/4.0
 0159: DEF ONE_FIFTH    = 1.0/5.0
 0160: DEF ONE_SIXTH    = 1.0/6.0
 0161: DEF ONE_SEVENTH  = 1.0/7.0
 0162: DEF ONE_HEIGHT   = 1.0/8.0
 0163: DEF ONE_NINTH    = 1.0/9.0
 0164: DEF ONE_TENTH    = 1.0/10.0
 0165: DEF ONE_ELEVENTH = 1.0/11.0
 0166: DEF ONE_TWELVE   = 1.0/12.0
 0167: DEF ONE_32       = 1.0/32.0
 0168: DEF ONE_64       = 1.0/64.0
 0169: DEF ONE_128      = 1.0/128.0
 0170: DEF ONE_255      = 1.0/255.0
 0171: DEF ONE_360      = 1.0/360.0
 0172: DEF TWO_THIRD    = 2.0/3.0
 0173: 
 0174: cdef float[360] COS_TABLE
 0175: cdef float[360] SIN_TABLE
 0176: cdef int ANGLE
+0177: for ANGLE in range(0, 360):
  for (__pyx_t_7 = 0; __pyx_t_7 < 0x168; __pyx_t_7+=1) {
    __pyx_v_12PygameShader_6shader_ANGLE = __pyx_t_7;
+0178:     COS_TABLE[ANGLE] = <float>cos(<float>(ANGLE * DEG_TO_RAD))
    (__pyx_v_12PygameShader_6shader_COS_TABLE[__pyx_v_12PygameShader_6shader_ANGLE]) = ((float)cos(((float)(__pyx_v_12PygameShader_6shader_ANGLE * __pyx_v_12PygameShader_6shader_DEG_TO_RAD))));
+0179:     SIN_TABLE[ANGLE] = <float>sin(<float>(ANGLE * DEG_TO_RAD))
    (__pyx_v_12PygameShader_6shader_SIN_TABLE[__pyx_v_12PygameShader_6shader_ANGLE]) = ((float)sin(((float)(__pyx_v_12PygameShader_6shader_ANGLE * __pyx_v_12PygameShader_6shader_DEG_TO_RAD))));
  }
 0180: 
+0181: COLORS_CPC64 = numpy.array(
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 181, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_array_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 181, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
/* … */
  __pyx_t_32 = PyTuple_New(1); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 181, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_GIVEREF(__pyx_t_33);
  PyTuple_SET_ITEM(__pyx_t_32, 0, __pyx_t_33);
  __pyx_t_33 = 0;
/* … */
  __pyx_t_30 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_32, __pyx_t_33); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 181, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_COLORS_CPC64, __pyx_t_30) < 0) __PYX_ERR(1, 181, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
+0182:     [[0, 0, 0],
  __pyx_t_1 = PyList_New(3); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 182, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_1, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_1, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_1, 2, __pyx_int_0);
/* … */
  __pyx_t_33 = PyList_New(27); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 182, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_GIVEREF(__pyx_t_1);
  PyList_SET_ITEM(__pyx_t_33, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_3);
  PyList_SET_ITEM(__pyx_t_33, 1, __pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_8);
  PyList_SET_ITEM(__pyx_t_33, 2, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_9);
  PyList_SET_ITEM(__pyx_t_33, 3, __pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_10);
  PyList_SET_ITEM(__pyx_t_33, 4, __pyx_t_10);
  __Pyx_GIVEREF(__pyx_t_11);
  PyList_SET_ITEM(__pyx_t_33, 5, __pyx_t_11);
  __Pyx_GIVEREF(__pyx_t_12);
  PyList_SET_ITEM(__pyx_t_33, 6, __pyx_t_12);
  __Pyx_GIVEREF(__pyx_t_13);
  PyList_SET_ITEM(__pyx_t_33, 7, __pyx_t_13);
  __Pyx_GIVEREF(__pyx_t_14);
  PyList_SET_ITEM(__pyx_t_33, 8, __pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_15);
  PyList_SET_ITEM(__pyx_t_33, 9, __pyx_t_15);
  __Pyx_GIVEREF(__pyx_t_16);
  PyList_SET_ITEM(__pyx_t_33, 10, __pyx_t_16);
  __Pyx_GIVEREF(__pyx_t_17);
  PyList_SET_ITEM(__pyx_t_33, 11, __pyx_t_17);
  __Pyx_GIVEREF(__pyx_t_18);
  PyList_SET_ITEM(__pyx_t_33, 12, __pyx_t_18);
  __Pyx_GIVEREF(__pyx_t_19);
  PyList_SET_ITEM(__pyx_t_33, 13, __pyx_t_19);
  __Pyx_GIVEREF(__pyx_t_20);
  PyList_SET_ITEM(__pyx_t_33, 14, __pyx_t_20);
  __Pyx_GIVEREF(__pyx_t_21);
  PyList_SET_ITEM(__pyx_t_33, 15, __pyx_t_21);
  __Pyx_GIVEREF(__pyx_t_22);
  PyList_SET_ITEM(__pyx_t_33, 16, __pyx_t_22);
  __Pyx_GIVEREF(__pyx_t_23);
  PyList_SET_ITEM(__pyx_t_33, 17, __pyx_t_23);
  __Pyx_GIVEREF(__pyx_t_24);
  PyList_SET_ITEM(__pyx_t_33, 18, __pyx_t_24);
  __Pyx_GIVEREF(__pyx_t_25);
  PyList_SET_ITEM(__pyx_t_33, 19, __pyx_t_25);
  __Pyx_GIVEREF(__pyx_t_26);
  PyList_SET_ITEM(__pyx_t_33, 20, __pyx_t_26);
  __Pyx_GIVEREF(__pyx_t_27);
  PyList_SET_ITEM(__pyx_t_33, 21, __pyx_t_27);
  __Pyx_GIVEREF(__pyx_t_28);
  PyList_SET_ITEM(__pyx_t_33, 22, __pyx_t_28);
  __Pyx_GIVEREF(__pyx_t_29);
  PyList_SET_ITEM(__pyx_t_33, 23, __pyx_t_29);
  __Pyx_GIVEREF(__pyx_t_30);
  PyList_SET_ITEM(__pyx_t_33, 24, __pyx_t_30);
  __Pyx_GIVEREF(__pyx_t_31);
  PyList_SET_ITEM(__pyx_t_33, 25, __pyx_t_31);
  __Pyx_GIVEREF(__pyx_t_32);
  PyList_SET_ITEM(__pyx_t_33, 26, __pyx_t_32);
  __pyx_t_1 = 0;
  __pyx_t_3 = 0;
  __pyx_t_8 = 0;
  __pyx_t_9 = 0;
  __pyx_t_10 = 0;
  __pyx_t_11 = 0;
  __pyx_t_12 = 0;
  __pyx_t_13 = 0;
  __pyx_t_14 = 0;
  __pyx_t_15 = 0;
  __pyx_t_16 = 0;
  __pyx_t_17 = 0;
  __pyx_t_18 = 0;
  __pyx_t_19 = 0;
  __pyx_t_20 = 0;
  __pyx_t_21 = 0;
  __pyx_t_22 = 0;
  __pyx_t_23 = 0;
  __pyx_t_24 = 0;
  __pyx_t_25 = 0;
  __pyx_t_26 = 0;
  __pyx_t_27 = 0;
  __pyx_t_28 = 0;
  __pyx_t_29 = 0;
  __pyx_t_30 = 0;
  __pyx_t_31 = 0;
  __pyx_t_32 = 0;
+0183:     [0, 0, 128],
  __pyx_t_3 = PyList_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 183, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_3, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_3, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_3, 2, __pyx_int_128);
+0184:     [0, 0, 255],
  __pyx_t_8 = PyList_New(3); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 184, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_8, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_8, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_8, 2, __pyx_int_255);
+0185:     [128, 0, 0],
  __pyx_t_9 = PyList_New(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_9, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_9, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_9, 2, __pyx_int_0);
+0186:     [128, 0, 128],
  __pyx_t_10 = PyList_New(3); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 186, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_10, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_10, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_10, 2, __pyx_int_128);
+0187:     [128, 0, 255],
  __pyx_t_11 = PyList_New(3); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 187, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_11, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_11, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_11, 2, __pyx_int_255);
+0188:     [255, 0, 0],
  __pyx_t_12 = PyList_New(3); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 188, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_12, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_12, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_12, 2, __pyx_int_0);
+0189:     [255, 0, 128],
  __pyx_t_13 = PyList_New(3); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_13);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_13, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_13, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_13, 2, __pyx_int_128);
+0190:     [255, 0, 255],
  __pyx_t_14 = PyList_New(3); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 190, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_14, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_14, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_14, 2, __pyx_int_255);
+0191:     [0, 128, 0],
  __pyx_t_15 = PyList_New(3); if (unlikely(!__pyx_t_15)) __PYX_ERR(1, 191, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_15);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_15, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_15, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_15, 2, __pyx_int_0);
+0192:     [0, 128, 128],
  __pyx_t_16 = PyList_New(3); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 192, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_16, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_16, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_16, 2, __pyx_int_128);
+0193:     [0, 128, 255],
  __pyx_t_17 = PyList_New(3); if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 193, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_17);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_17, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_17, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_17, 2, __pyx_int_255);
+0194:     [128, 128, 0],
  __pyx_t_18 = PyList_New(3); if (unlikely(!__pyx_t_18)) __PYX_ERR(1, 194, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_18);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_18, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_18, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_18, 2, __pyx_int_0);
+0195:     [128, 128, 128],
  __pyx_t_19 = PyList_New(3); if (unlikely(!__pyx_t_19)) __PYX_ERR(1, 195, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_19);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_19, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_19, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_19, 2, __pyx_int_128);
+0196:     [128, 128, 255],
  __pyx_t_20 = PyList_New(3); if (unlikely(!__pyx_t_20)) __PYX_ERR(1, 196, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_20);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_20, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_20, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_20, 2, __pyx_int_255);
+0197:     [255, 128, 0],
  __pyx_t_21 = PyList_New(3); if (unlikely(!__pyx_t_21)) __PYX_ERR(1, 197, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_21);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_21, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_21, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_21, 2, __pyx_int_0);
+0198:     [255, 128, 128],
  __pyx_t_22 = PyList_New(3); if (unlikely(!__pyx_t_22)) __PYX_ERR(1, 198, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_22);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_22, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_22, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_22, 2, __pyx_int_128);
+0199:     [255, 128, 255],
  __pyx_t_23 = PyList_New(3); if (unlikely(!__pyx_t_23)) __PYX_ERR(1, 199, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_23);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_23, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_23, 1, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_23, 2, __pyx_int_255);
+0200:     [0, 255, 0],
  __pyx_t_24 = PyList_New(3); if (unlikely(!__pyx_t_24)) __PYX_ERR(1, 200, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_24);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_24, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_24, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_24, 2, __pyx_int_0);
+0201:     [0, 255, 128],
  __pyx_t_25 = PyList_New(3); if (unlikely(!__pyx_t_25)) __PYX_ERR(1, 201, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_25);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_25, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_25, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_25, 2, __pyx_int_128);
+0202:     [0, 255, 255],
  __pyx_t_26 = PyList_New(3); if (unlikely(!__pyx_t_26)) __PYX_ERR(1, 202, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_26);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_26, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_26, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_26, 2, __pyx_int_255);
+0203:     [128, 255, 0],
  __pyx_t_27 = PyList_New(3); if (unlikely(!__pyx_t_27)) __PYX_ERR(1, 203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_27);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_27, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_27, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_27, 2, __pyx_int_0);
+0204:     [128, 255, 128],
  __pyx_t_28 = PyList_New(3); if (unlikely(!__pyx_t_28)) __PYX_ERR(1, 204, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_28);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_28, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_28, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_28, 2, __pyx_int_128);
+0205:     [128, 255, 255],
  __pyx_t_29 = PyList_New(3); if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 205, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_29, 0, __pyx_int_128);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_29, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_29, 2, __pyx_int_255);
+0206:     [255, 255, 0],
  __pyx_t_30 = PyList_New(3); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 206, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_30, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_30, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_30, 2, __pyx_int_0);
+0207:     [255, 255, 128],
  __pyx_t_31 = PyList_New(3); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 207, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_31, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_31, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_128);
  __Pyx_GIVEREF(__pyx_int_128);
  PyList_SET_ITEM(__pyx_t_31, 2, __pyx_int_128);
+0208:     [255, 255, 255]], dtype=numpy.uint8)
  __pyx_t_32 = PyList_New(3); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 208, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_32, 0, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_32, 1, __pyx_int_255);
  __Pyx_INCREF(__pyx_int_255);
  __Pyx_GIVEREF(__pyx_int_255);
  PyList_SET_ITEM(__pyx_t_32, 2, __pyx_int_255);
/* … */
  __pyx_t_33 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 208, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_GetModuleGlobalName(__pyx_t_31, __pyx_n_s_numpy); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 208, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __pyx_t_30 = __Pyx_PyObject_GetAttrStr(__pyx_t_31, __pyx_n_s_uint8); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 208, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  if (PyDict_SetItem(__pyx_t_33, __pyx_n_s_dtype, __pyx_t_30) < 0) __PYX_ERR(1, 208, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
 0209: 
 0210: cdef:
+0211:     float [:, :] COLORS_CPC64_C = numpy.divide(COLORS_CPC64, 255.0).astype(dtype=float32)
  __Pyx_GetModuleGlobalName(__pyx_t_30, __pyx_n_s_numpy); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_30, __pyx_n_s_divide); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_30, __pyx_n_s_COLORS_CPC64); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __pyx_t_32 = PyTuple_New(2); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_GIVEREF(__pyx_t_30);
  PyTuple_SET_ITEM(__pyx_t_32, 0, __pyx_t_30);
  __Pyx_INCREF(__pyx_float_255_0);
  __Pyx_GIVEREF(__pyx_float_255_0);
  PyTuple_SET_ITEM(__pyx_t_32, 1, __pyx_float_255_0);
  __pyx_t_30 = 0;
  __pyx_t_30 = __Pyx_PyObject_Call(__pyx_t_33, __pyx_t_32, NULL); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_30, __pyx_n_s_astype); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __pyx_t_30 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_float32); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  if (PyDict_SetItem(__pyx_t_30, __pyx_n_s_dtype, __pyx_t_33) < 0) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_t_33 = __Pyx_PyObject_Call(__pyx_t_32, __pyx_empty_tuple, __pyx_t_30); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __pyx_t_34 = __Pyx_PyObject_to_MemoryviewSlice_dsds_float(__pyx_t_33, PyBUF_WRITABLE); if (unlikely(!__pyx_t_34.memview)) __PYX_ERR(1, 211, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_COLORS_CPC64_C, 1);
  __pyx_v_12PygameShader_6shader_COLORS_CPC64_C = __pyx_t_34;
  __pyx_t_34.memview = NULL;
  __pyx_t_34.data = NULL;
 0212: 
 0213: 
 0214: 
 0215: # todo  BILATERAL FILTER (CHECK project spritesheetstudio tools) + PIXELATE and PIXEL
 0216: #  BLOCKS
 0217: # TODO FUNCTION TESTING IMAGE
 0218: # TODO ADD HSV
 0219: 
 0220: 
 0221: 
+0222: cpdef inline void rgb_to_bgr(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_1rgb_to_bgr(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_rgb_to_bgr(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_bgr", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.rgb_to_bgr", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_1rgb_to_bgr(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_rgb_to_bgr[] = "  \n    SHADER RGB to BGR\n  \n    Convert your game display from RGB to BGR format\n    This algorithm can also be used to transform pygame texture in the equivalent bgr format\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n    new surface.\n\n    e.g:\n    rgb_to_bgr(surface)\n\n    :param surface_    : Pygame surface or display surface compatible (image 24-32 bit with or \n                         without per-pixel transparency / alpha channel)\n    :return             : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_1rgb_to_bgr(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_bgr (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_rgb_to_bgr(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_rgb_to_bgr(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_bgr", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_rgb_to_bgr(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 222, __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("PygameShader.shader.rgb_to_bgr", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0223:     """  
 0224:     SHADER RGB to BGR
 0225:   
 0226:     Convert your game display from RGB to BGR format
 0227:     This algorithm can also be used to transform pygame texture in the equivalent bgr format
 0228:     
 0229:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0230:     new surface.
 0231: 
 0232:     e.g:
 0233:     rgb_to_bgr(surface)
 0234: 
 0235:     :param surface_    : Pygame surface or display surface compatible (image 24-32 bit with or 
 0236:                          without per-pixel transparency / alpha channel)
 0237:     :return             : void
 0238:     """
+0239:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 239, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 239, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 239, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0240:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 240, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 239, __pyx_L1_error)
    }
  }
  #endif
 0241: 
+0242:     shader_rgb_to_bgr_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 242, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 242, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 242, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_rgb_to_bgr_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0243: 
 0244: 
+0245: cpdef inline void rgb_to_brg(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_3rgb_to_brg(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_rgb_to_brg(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_brg", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.rgb_to_brg", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_3rgb_to_brg(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_2rgb_to_brg[] = "\n    SHADER RGB TO BRG\n\n    Convert your game display from RGB to BRG format.\n    This algorithm can also be used to transform pygame texture in the equivalent BRG format\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.\n    \n    e.g:\n    rgb_to_brg(surface)\n\n    :param surface_: Pygame surface or display surface compatible (image 24-32 bit with or without \n                     per-pixel transparency / alpha channel)\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_3rgb_to_brg(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_brg (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_2rgb_to_brg(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_2rgb_to_brg(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_brg", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_rgb_to_brg(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 245, __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("PygameShader.shader.rgb_to_brg", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0246:     """
 0247:     SHADER RGB TO BRG
 0248: 
 0249:     Convert your game display from RGB to BRG format.
 0250:     This algorithm can also be used to transform pygame texture in the equivalent BRG format
 0251:     
 0252:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0253:       new surface.
 0254:     
 0255:     e.g:
 0256:     rgb_to_brg(surface)
 0257: 
 0258:     :param surface_: Pygame surface or display surface compatible (image 24-32 bit with or without 
 0259:                      per-pixel transparency / alpha channel)
 0260:     :return: void 
 0261:     """
+0262:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 262, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 262, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 262, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0263:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 263, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 262, __pyx_L1_error)
    }
  }
  #endif
 0264: 
+0265:     shader_rgb_to_brg_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 265, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_rgb_to_brg_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0266: 
+0267: cpdef inline void greyscale(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_5greyscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_greyscale(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("greyscale", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.greyscale", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_5greyscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_4greyscale[] = "\n    SHADER GRAYSCALE (CONSERVE LUMINOSITY)\n\n    This shader transform the game display on a grayscale video game effect\n    \n    * This shader can also be applied to pygame textures/surface to transform them into\n      an equivalent grayscale model\n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.\n\n    e.g:\n    greyscale(surface)\n\n    :param surface_  : Pygame surface or display surface compatible (image 24-32 bit with \n                       or without per-pixel transparency / alpha channel)\n    :return          : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_5greyscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("greyscale (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_4greyscale(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_4greyscale(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("greyscale", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_greyscale(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 267, __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("PygameShader.shader.greyscale", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0268:     """
 0269:     SHADER GRAYSCALE (CONSERVE LUMINOSITY)
 0270: 
 0271:     This shader transform the game display on a grayscale video game effect
 0272:     
 0273:     * This shader can also be applied to pygame textures/surface to transform them into
 0274:       an equivalent grayscale model
 0275:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0276:       new surface.
 0277: 
 0278:     e.g:
 0279:     greyscale(surface)
 0280: 
 0281:     :param surface_  : Pygame surface or display surface compatible (image 24-32 bit with 
 0282:                        or without per-pixel transparency / alpha channel)
 0283:     :return          : void
 0284:     
 0285:     """
+0286:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 286, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 286, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 286, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0287:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 287, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 286, __pyx_L1_error)
    }
  }
  #endif
 0288: 
+0289:     shader_greyscale_luminosity24_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 289, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 289, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 289, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_greyscale_luminosity24_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0290: 
 0291: 
+0292: cpdef inline void sepia(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_7sepia(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_sepia(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sepia", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.sepia", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_7sepia(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_6sepia[] = "\n    SHADER SEPIA MODEL\n\n    Transform your video game into an equivalent sepia model\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.\n\n    e.g:\n    sepia(surface)\n\n\n    :param surface_  : Pygame surface or display surface compatible (image 24-32 bit with \n                       or without per-pixel transparency / alpha channel)\n    :return:         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_7sepia(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sepia (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_6sepia(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_6sepia(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sepia", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_sepia(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 292, __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("PygameShader.shader.sepia", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0293:     """
 0294:     SHADER SEPIA MODEL
 0295: 
 0296:     Transform your video game into an equivalent sepia model
 0297:     
 0298:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0299:       new surface.
 0300: 
 0301:     e.g:
 0302:     sepia(surface)
 0303: 
 0304: 
 0305:     :param surface_  : Pygame surface or display surface compatible (image 24-32 bit with 
 0306:                        or without per-pixel transparency / alpha channel)
 0307:     :return:         : void
 0308:     """
+0309:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 309, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 309, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 309, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0310:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 310, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 309, __pyx_L1_error)
    }
  }
  #endif
 0311: 
+0312:     shader_sepia24_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 312, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 312, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 312, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_sepia24_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0313: 
 0314: 
 0315: @cython.boundscheck(False)
 0316: @cython.wraparound(False)
 0317: @cython.nonecheck(False)
 0318: @cython.cdivision(True)
+0319: cdef inline void median_fast(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_median_fast(PyObject *__pyx_v_surface_, struct __pyx_opt_args_12PygameShader_6shader_median_fast *__pyx_optional_args) {
  unsigned short __pyx_v_kernel_size_ = ((unsigned short)2);
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)1);
  PyObject *__pyx_v_surface_cp = NULL;
  int __pyx_v_w;
  int __pyx_v_h;
  __Pyx_memviewslice __pyx_v_surface_cp_arr = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_i;
  int __pyx_v_j;
  __Pyx_memviewslice __pyx_v_org_surface = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_fast", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
      }
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_8);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.median_fast", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_surface_cp);
  __PYX_XDEC_MEMVIEW(&__pyx_v_surface_cp_arr, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_org_surface, 1);
  __Pyx_RefNannyFinishContext();
}
 0320:         object surface_,
 0321:         unsigned short int kernel_size_=2,
 0322:         unsigned short int reduce_factor_=1
 0323: ):
 0324:     """
 0325:     This function cannot be called directly from python script (cdef)
 0326: 
 0327:     :param surface_: pygame.surface; Surface compatible 24-32 bit 
 0328:     :param kernel_size_: integer; size of the kernel 
 0329:     :param reduce_factor_: integer; value of 1 divide the image by 2, value of 2 div the image by 4
 0330:     :return: void
 0331:     """
 0332: 
+0333:     surface_cp = surface_.copy()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_copy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 333, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 333, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_surface_cp = __pyx_t_1;
  __pyx_t_1 = 0;
 0334:     cdef:
 0335:         int w, h
+0336:     w, h = surface_cp.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_cp, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 336, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 336, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 336, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyInt_As_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 336, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 336, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 0337: 
+0338:     surface_cp = smoothscale(surface_cp, (w >> reduce_factor_, h >> reduce_factor_))
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 338, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = __Pyx_PyInt_From_int((__pyx_v_w >> __pyx_v_reduce_factor_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 338, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = __Pyx_PyInt_From_int((__pyx_v_h >> __pyx_v_reduce_factor_)); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 338, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 338, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_4);
  __pyx_t_2 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  __pyx_t_7 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_7 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface_cp, __pyx_t_8};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_7, 2+__pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 338, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface_cp, __pyx_t_8};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_7, 2+__pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 338, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  } else
  #endif
  {
    __pyx_t_2 = PyTuple_New(2+__pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface_cp);
    __Pyx_GIVEREF(__pyx_v_surface_cp);
    PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_7, __pyx_v_surface_cp);
    __Pyx_GIVEREF(__pyx_t_8);
    PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_7, __pyx_t_8);
    __pyx_t_8 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF_SET(__pyx_v_surface_cp, __pyx_t_1);
  __pyx_t_1 = 0;
 0339: 
 0340:     cdef:
+0341:         unsigned char [:, :, :] surface_cp_arr = pixels3d(surface_cp)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 341, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_v_surface_cp) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_surface_cp);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 341, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 341, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_surface_cp_arr = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 0342:         int i, j
+0343:         unsigned char[:, :, :] org_surface = pixels3d(surface_)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 343, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 343, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 343, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_org_surface = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 0344: 
+0345:     shader_median_filter24_inplace_c(surface_cp_arr, kernel_size_)
  __pyx_t_10.__pyx_n = 1;
  __pyx_t_10.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_f_12PygameShader_6shader_shader_median_filter24_inplace_c(__pyx_v_surface_cp_arr, &__pyx_t_10); 
+0346:     surface_cp_arr = scale_array24_c(surface_cp_arr, w, h)
  __pyx_t_11 = __pyx_f_12PygameShader_6shader_scale_array24_c(__pyx_v_surface_cp_arr, __pyx_v_w, __pyx_v_h); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 346, __pyx_L1_error)
  __PYX_XDEC_MEMVIEW(&__pyx_v_surface_cp_arr, 1);
  __pyx_v_surface_cp_arr = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 0347: 
+0348:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L7:;
      }
  }
+0349:         for i in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_7 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static)
/* … */
        __pyx_t_7 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_12; __pyx_t_6++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_j = ((int)0xbad0bad0);
+0350:             for j in range(h):
                            __pyx_t_13 = __pyx_v_h;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_14; __pyx_t_15+=1) {
                              __pyx_v_j = __pyx_t_15;
+0351:                 org_surface[i, j, 0] = surface_cp_arr[i, j, 0]
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 0;
                              __pyx_t_19 = __pyx_v_i;
                              __pyx_t_20 = __pyx_v_j;
                              __pyx_t_21 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_org_surface.data + __pyx_t_19 * __pyx_v_org_surface.strides[0]) ) + __pyx_t_20 * __pyx_v_org_surface.strides[1]) ) + __pyx_t_21 * __pyx_v_org_surface.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_surface_cp_arr.data + __pyx_t_16 * __pyx_v_surface_cp_arr.strides[0]) ) + __pyx_t_17 * __pyx_v_surface_cp_arr.strides[1]) ) + __pyx_t_18 * __pyx_v_surface_cp_arr.strides[2]) )));
+0352:                 org_surface[i, j, 1] = surface_cp_arr[i, j, 1]
                              __pyx_t_18 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_16 = 1;
                              __pyx_t_21 = __pyx_v_i;
                              __pyx_t_20 = __pyx_v_j;
                              __pyx_t_19 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_org_surface.data + __pyx_t_21 * __pyx_v_org_surface.strides[0]) ) + __pyx_t_20 * __pyx_v_org_surface.strides[1]) ) + __pyx_t_19 * __pyx_v_org_surface.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_surface_cp_arr.data + __pyx_t_18 * __pyx_v_surface_cp_arr.strides[0]) ) + __pyx_t_17 * __pyx_v_surface_cp_arr.strides[1]) ) + __pyx_t_16 * __pyx_v_surface_cp_arr.strides[2]) )));
+0353:                 org_surface[i, j, 2] = surface_cp_arr[i, j, 2]
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 2;
                              __pyx_t_19 = __pyx_v_i;
                              __pyx_t_20 = __pyx_v_j;
                              __pyx_t_21 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_org_surface.data + __pyx_t_19 * __pyx_v_org_surface.strides[0]) ) + __pyx_t_20 * __pyx_v_org_surface.strides[1]) ) + __pyx_t_21 * __pyx_v_org_surface.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_surface_cp_arr.data + __pyx_t_16 * __pyx_v_surface_cp_arr.strides[0]) ) + __pyx_t_17 * __pyx_v_surface_cp_arr.strides[1]) ) + __pyx_t_18 * __pyx_v_surface_cp_arr.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 0354: 
 0355: 
+0356: cpdef inline void median(
static PyObject *__pyx_pw_12PygameShader_6shader_9median(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_median(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_median *__pyx_optional_args) {
  unsigned short __pyx_v_kernel_size_ = ((unsigned short)2);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_6);
  __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
  __Pyx_AddTraceback("PygameShader.shader.median", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_9median(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_8median[] = "\n    SHADER MEDIAN FILTER COMPATIBLE 24-32 bit IMAGE\n\n    This shader cannot be used for real time display rendering as the performance \n    of the algorithm is not satisfactory < 50 fps. \n    The code would have to be changed and improved with C or assembler in order to\n    be adapted for a real time application. \n\n    In the state, this shader can be used for texture/surface transformation offline\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.  \n\n    :param surface_      : Pygame surface or display surface compatible (image 24-32 bit with \n                           or without per-pixel transparency / alpha channel)\n    :param kernel_size_  : integer; Kernel size or neighbourhood pixels to be included default is 2\n                           Increase the effect with kernel size > 2 (effect overall speed is \n                           degrading quickly with large kernel size e.g > 2)\n    :param fast_         : boolean; Flag for fast calculation (default True). Improve overall speed \n                           performance by using smaller texture sizes (see reduce_factor_ option)\n    :param reduce_factor_: integer; Int value to reduce the size of the original surface to \n                           process. A value of 1, divide the original surface by 2 and a value of 2\n                           reduce the surface by 4 (value of 1 and 2 are acceptable, over 2 the \n                           image quality is too pixelated and blur) default value is 1 (div by 2).\n                           This argument as no effect if flag fast_=False\n    :return:             : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_9median(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  unsigned short __pyx_v_kernel_size_;
  int __pyx_v_fast_;
  unsigned short __pyx_v_reduce_factor_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_kernel_size,&__pyx_n_s_fast,&__pyx_n_s_reduce_factor,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_kernel_size);
          if (value) { values[1] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fast);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_reduce_factor);
          if (value) { values[3] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "median") < 0)) __PYX_ERR(1, 356, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_kernel_size_ = __Pyx_PyInt_As_unsigned_short(values[1]); if (unlikely((__pyx_v_kernel_size_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 358, __pyx_L3_error)
    } else {
      __pyx_v_kernel_size_ = ((unsigned short)2);
    }
    if (values[2]) {
      __pyx_v_fast_ = __Pyx_PyObject_IsTrue(values[2]); if (unlikely((__pyx_v_fast_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 359, __pyx_L3_error)
    } else {
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_8median(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, unsigned short __pyx_v_kernel_size_, int __pyx_v_fast_, unsigned short __pyx_v_reduce_factor_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 3;
  __pyx_t_1.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_t_1.fast_ = __pyx_v_fast_;
  __pyx_t_1.reduce_factor_ = __pyx_v_reduce_factor_;
  __pyx_f_12PygameShader_6shader_median(__pyx_v_surface_, 0, &__pyx_t_1); if (unlikely(PyErr_Occurred())) __PYX_ERR(1, 356, __pyx_L1_error)
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.median", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0357:         object surface_,
 0358:         unsigned short int kernel_size_=2,
+0359:         bint fast_=True,
  int __pyx_v_fast_ = ((int)1);
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)1);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_fast_ = __pyx_optional_args->fast_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
        }
      }
    }
  }
/* … */
      __pyx_v_fast_ = ((int)1);
    }
    if (values[3]) {
      __pyx_v_reduce_factor_ = __Pyx_PyInt_As_unsigned_short(values[3]); if (unlikely((__pyx_v_reduce_factor_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 360, __pyx_L3_error)
    } else {
      __pyx_v_reduce_factor_ = ((unsigned short)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("median", 0, 1, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 356, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.median", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_8median(__pyx_self, __pyx_v_surface_, __pyx_v_kernel_size_, __pyx_v_fast_, __pyx_v_reduce_factor_);
 0360:         unsigned short int reduce_factor_=1
 0361: ) except *:
 0362:     """
 0363:     SHADER MEDIAN FILTER COMPATIBLE 24-32 bit IMAGE
 0364: 
 0365:     This shader cannot be used for real time display rendering as the performance 
 0366:     of the algorithm is not satisfactory < 50 fps. 
 0367:     The code would have to be changed and improved with C or assembler in order to
 0368:     be adapted for a real time application. 
 0369: 
 0370:     In the state, this shader can be used for texture/surface transformation offline
 0371:     
 0372:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0373:       new surface.  
 0374: 
 0375:     :param surface_      : Pygame surface or display surface compatible (image 24-32 bit with 
 0376:                            or without per-pixel transparency / alpha channel)
 0377:     :param kernel_size_  : integer; Kernel size or neighbourhood pixels to be included default is 2
 0378:                            Increase the effect with kernel size > 2 (effect overall speed is 
 0379:                            degrading quickly with large kernel size e.g > 2)
 0380:     :param fast_         : boolean; Flag for fast calculation (default True). Improve overall speed 
 0381:                            performance by using smaller texture sizes (see reduce_factor_ option)
 0382:     :param reduce_factor_: integer; Int value to reduce the size of the original surface to 
 0383:                            process. A value of 1, divide the original surface by 2 and a value of 2
 0384:                            reduce the surface by 4 (value of 1 and 2 are acceptable, over 2 the 
 0385:                            image quality is too pixelated and blur) default value is 1 (div by 2).
 0386:                            This argument as no effect if flag fast_=False
 0387:     :return:             : void
 0388:     """
+0389:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 389, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 389, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 389, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0390:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 390, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 389, __pyx_L1_error)
    }
  }
  #endif
 0391: 
+0392:     if kernel_size_ <= 0:
  __pyx_t_3 = ((__pyx_v_kernel_size_ <= 0) != 0);
  if (unlikely(__pyx_t_3)) {
/* … */
  }
+0393:         raise ValueError('\nArgument kernel_size_ cannot be <= 0')
    __pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple_, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 393, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_Raise(__pyx_t_2, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __PYX_ERR(1, 393, __pyx_L1_error)
/* … */
  __pyx_tuple_ = PyTuple_Pack(1, __pyx_kp_s_Argument_kernel_size__cannot_be); if (unlikely(!__pyx_tuple_)) __PYX_ERR(1, 393, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple_);
  __Pyx_GIVEREF(__pyx_tuple_);
+0394:     if not 0 < reduce_factor_ < 9:
  __pyx_t_3 = (0 < __pyx_v_reduce_factor_);
  if (__pyx_t_3) {
    __pyx_t_3 = (__pyx_v_reduce_factor_ < 9);
  }
  __pyx_t_4 = ((!(__pyx_t_3 != 0)) != 0);
  if (unlikely(__pyx_t_4)) {
/* … */
  }
+0395:         raise ValueError('\nArgument reduce_factor_ must be in range [1 ... 8] ')
    __pyx_t_2 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 395, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_Raise(__pyx_t_2, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __PYX_ERR(1, 395, __pyx_L1_error)
/* … */
  __pyx_tuple__2 = PyTuple_Pack(1, __pyx_kp_s_Argument_reduce_factor__must_be); if (unlikely(!__pyx_tuple__2)) __PYX_ERR(1, 395, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__2);
  __Pyx_GIVEREF(__pyx_tuple__2);
 0396: 
+0397:     if fast_:
  __pyx_t_4 = (__pyx_v_fast_ != 0);
  if (__pyx_t_4) {
/* … */
    goto __pyx_L5;
  }
+0398:         median_fast(surface_, kernel_size_, reduce_factor_)
    __pyx_t_5.__pyx_n = 2;
    __pyx_t_5.kernel_size_ = __pyx_v_kernel_size_;
    __pyx_t_5.reduce_factor_ = __pyx_v_reduce_factor_;
    __pyx_f_12PygameShader_6shader_median_fast(__pyx_v_surface_, &__pyx_t_5); 
 0399:     else:
+0400:         shader_median_filter24_inplace_c(pixels3d(surface_), kernel_size_)
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 400, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_6 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_1);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_1, function);
      }
    }
    __pyx_t_2 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_6, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 400, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 400, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_8.__pyx_n = 1;
    __pyx_t_8.kernel_size_ = __pyx_v_kernel_size_;
    __pyx_f_12PygameShader_6shader_shader_median_filter24_inplace_c(__pyx_t_7, &__pyx_t_8); 
    __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
    __pyx_t_7.memview = NULL;
    __pyx_t_7.data = NULL;
  }
  __pyx_L5:;
 0401: 
 0402: 
+0403: cpdef inline void median_grayscale(
static PyObject *__pyx_pw_12PygameShader_6shader_11median_grayscale(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_median_grayscale(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_median_grayscale *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_grayscale", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.median_grayscale", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_11median_grayscale(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_10median_grayscale[] = "\n    SHADER MEDIAN FILTER (GRAYSCALE)\n\n    This shader cannot be used for real time rendering as the performance of the algorithm are not\n    satisfactory. The code would have to be changed and improved with C or assembler in order to\n    be adapted for a real time application. \n\n    In the state, this shader can be used for texture/surface transformation offline\n\n    The surface is compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.  \n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit with or without alpha layer\n    :param kernel_size_: integer; Kernel size (must be > 0), default value = 2\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_11median_grayscale(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_kernel_size_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_grayscale (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_kernel_size,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_kernel_size);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "median_grayscale") < 0)) __PYX_ERR(1, 403, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_kernel_size_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_kernel_size_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 405, __pyx_L3_error)
    } else {
      __pyx_v_kernel_size_ = ((int)2);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("median_grayscale", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 403, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.median_grayscale", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_10median_grayscale(__pyx_self, __pyx_v_surface_, __pyx_v_kernel_size_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_10median_grayscale(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_kernel_size_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_grayscale", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_f_12PygameShader_6shader_median_grayscale(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 403, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.median_grayscale", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0404:         object surface_,
 0405:         int kernel_size_=2
 0406: ):
 0407:     """
 0408:     SHADER MEDIAN FILTER (GRAYSCALE)
 0409: 
 0410:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 0411:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 0412:     be adapted for a real time application. 
 0413: 
 0414:     In the state, this shader can be used for texture/surface transformation offline
 0415: 
 0416:     The surface is compatible 24 - 32 bit with or without alpha layer
 0417:     
 0418:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0419:       new surface.  
 0420: 
 0421:     :param surface_: pygame.Surface; compatible 24 - 32 bit with or without alpha layer
 0422:     :param kernel_size_: integer; Kernel size (must be > 0), default value = 2
 0423:     :return: void 
 0424:     """
+0425:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 425, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0426:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 426, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 425, __pyx_L1_error)
    }
  }
  #endif
 0427: 
+0428:     assert kernel_size_ > 0, "\nArgument kernel_size_ cannot be <= 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_kernel_size_ > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_kernel_size__cannot_be);
      __PYX_ERR(1, 428, __pyx_L1_error)
    }
  }
  #endif
 0429: 
+0430:     shader_median_grayscale_filter24_inplace_c(pixels3d(surface_), kernel_size_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 430, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 430, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 430, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_f_12PygameShader_6shader_shader_median_grayscale_filter24_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0431: 
 0432: 
+0433: cpdef inline void median_avg(
static PyObject *__pyx_pw_12PygameShader_6shader_13median_avg(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_median_avg(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_median_avg *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_avg", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.median_avg", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_13median_avg(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_12median_avg[] = "\n    SHADER MEDIAN FILTER (AVERAGE)\n    \n    This shader cannot be used for real time rendering as the performance of the algorithm are not\n    satisfactory. The code would have to be changed and improved with C or assembler in order to\n    be adapted for a real time application. \n\n    In the state, this shader can be used for texture/surface transformation offline\n\n    The surface is compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.  \n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit with or without alpha layer\n    :param kernel_size_: integer; Kernel size (must be > 0), default value = 2\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_13median_avg(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_kernel_size_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_avg (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_kernel_size,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_kernel_size);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "median_avg") < 0)) __PYX_ERR(1, 433, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_kernel_size_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_kernel_size_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 435, __pyx_L3_error)
    } else {
      __pyx_v_kernel_size_ = ((int)2);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("median_avg", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 433, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.median_avg", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_12median_avg(__pyx_self, __pyx_v_surface_, __pyx_v_kernel_size_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_12median_avg(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_kernel_size_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("median_avg", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_f_12PygameShader_6shader_median_avg(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 433, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.median_avg", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0434:         object surface_,
 0435:         int kernel_size_=2
 0436: ):
 0437:     """
 0438:     SHADER MEDIAN FILTER (AVERAGE)
 0439:     
 0440:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 0441:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 0442:     be adapted for a real time application. 
 0443: 
 0444:     In the state, this shader can be used for texture/surface transformation offline
 0445: 
 0446:     The surface is compatible 24 - 32 bit with or without alpha layer
 0447:     
 0448:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0449:       new surface.  
 0450: 
 0451:     :param surface_: pygame.Surface; compatible 24 - 32 bit with or without alpha layer
 0452:     :param kernel_size_: integer; Kernel size (must be > 0), default value = 2
 0453:     :return: void 
 0454:     """
 0455: 
+0456:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 456, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 456, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 456, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0457:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 457, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 456, __pyx_L1_error)
    }
  }
  #endif
 0458: 
+0459:     assert kernel_size_ > 0, "\nArgument kernel_size_ cannot be <= 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_kernel_size_ > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_kernel_size__cannot_be);
      __PYX_ERR(1, 459, __pyx_L1_error)
    }
  }
  #endif
 0460: 
+0461:     shader_median_filter24_avg_inplace_c(pixels3d(surface_), kernel_size_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 461, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 461, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 461, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.kernel_size_ = __pyx_v_kernel_size_;
  __pyx_f_12PygameShader_6shader_shader_median_filter24_avg_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0462: 
 0463: 
 0464: 
+0465: cpdef inline void color_reduction(
static PyObject *__pyx_pw_12PygameShader_6shader_15color_reduction(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_color_reduction(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_color_reduction *__pyx_optional_args) {
  int __pyx_v_color_ = ((int)8);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("color_reduction", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_color_ = __pyx_optional_args->color_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.color_reduction", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_15color_reduction(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_14color_reduction[] = "\n     COLOR REDUCTION SHADER\n\n    Decrease the amount of colors in the display or texture.\n    The method of color reduction is very simple: every color of the original picture is replaced\n    by an appropriate color from the limited palette that is accessible.\n    \n    The surface is compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface you do not need to create a \n      new surface.  \n      \n    e.g:\n    color_reduction(surface, 8)\n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit \n    :param color_: integer must be > 0 default 8\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_15color_reduction(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_color_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("color_reduction (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_color,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_color);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "color_reduction") < 0)) __PYX_ERR(1, 465, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_color_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_color_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 467, __pyx_L3_error)
    } else {
      __pyx_v_color_ = ((int)8);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("color_reduction", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 465, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.color_reduction", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_14color_reduction(__pyx_self, __pyx_v_surface_, __pyx_v_color_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_14color_reduction(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_color_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("color_reduction", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.color_ = __pyx_v_color_;
  __pyx_f_12PygameShader_6shader_color_reduction(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 465, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.color_reduction", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0466:         object surface_,
 0467:         int color_=8
 0468: ):
 0469:     """
 0470:      COLOR REDUCTION SHADER
 0471: 
 0472:     Decrease the amount of colors in the display or texture.
 0473:     The method of color reduction is very simple: every color of the original picture is replaced
 0474:     by an appropriate color from the limited palette that is accessible.
 0475:     
 0476:     The surface is compatible 24 - 32 bit with or without alpha layer
 0477:     
 0478:     * The changes are automatically applied inplace to the surface you do not need to create a 
 0479:       new surface.  
 0480:       
 0481:     e.g:
 0482:     color_reduction(surface, 8)
 0483: 
 0484:     :param surface_: pygame.Surface; compatible 24 - 32 bit 
 0485:     :param color_: integer must be > 0 default 8
 0486:     :return: void 
 0487:     """
+0488:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 488, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 488, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 488, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0489:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 489, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 488, __pyx_L1_error)
    }
  }
  #endif
 0490: 
+0491:     assert color_ > 0, "Argument color_number must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_color_ > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_color_number_must_be_0);
      __PYX_ERR(1, 491, __pyx_L1_error)
    }
  }
  #endif
 0492: 
+0493:     shader_color_reduction24_inplace_c(pixels3d(surface_), color_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 493, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 493, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 493, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_color_reduction24_inplace_c(__pyx_t_5, __pyx_v_color_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0494: 
 0495: 
+0496: cpdef inline void sobel(
static PyObject *__pyx_pw_12PygameShader_6shader_17sobel(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_sobel(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_sobel *__pyx_optional_args) {
  int __pyx_v_threshold_ = ((int)64);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold_ = __pyx_optional_args->threshold_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.sobel", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_17sobel(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_16sobel[] = "\n    SHADER SOBEL (EDGE DETECTION)\n\n    Transform the game display or a pygame surface into a sobel equivalent model\n    (surface edge detection)\n\n    The surface is compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    e.g:\n    sobel(surface, 64)\n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit \n    :param threshold_: integer; Value for detecting the edges default 64\n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_17sobel(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_threshold_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_threshold,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_threshold);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "sobel") < 0)) __PYX_ERR(1, 496, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_threshold_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_threshold_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 498, __pyx_L3_error)
    } else {
      __pyx_v_threshold_ = ((int)64);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("sobel", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 496, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.sobel", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_16sobel(__pyx_self, __pyx_v_surface_, __pyx_v_threshold_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_16sobel(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_threshold_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.threshold_ = __pyx_v_threshold_;
  __pyx_f_12PygameShader_6shader_sobel(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 496, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.sobel", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0497:         object surface_,
 0498:         int threshold_ = 64
 0499: ):
 0500:     """
 0501:     SHADER SOBEL (EDGE DETECTION)
 0502: 
 0503:     Transform the game display or a pygame surface into a sobel equivalent model
 0504:     (surface edge detection)
 0505: 
 0506:     The surface is compatible 24 - 32 bit with or without alpha layer
 0507:     
 0508:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0509:       new surface.  
 0510: 
 0511:     e.g:
 0512:     sobel(surface, 64)
 0513: 
 0514:     :param surface_: pygame.Surface; compatible 24 - 32 bit 
 0515:     :param threshold_: integer; Value for detecting the edges default 64
 0516:     :return:
 0517:     """
+0518:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 518, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 518, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 518, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0519:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 519, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 518, __pyx_L1_error)
    }
  }
  #endif
 0520: 
+0521:     assert -1 < threshold_ < 256, "\nArgument threshold must be an integer in range [0 ... 255]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1L < __pyx_v_threshold_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_threshold_ < 0x100);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_threshold_must_be_an_i);
      __PYX_ERR(1, 521, __pyx_L1_error)
    }
  }
  #endif
 0522: 
+0523:     shader_sobel24_inplace_c(pixels3d(surface_), threshold_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 523, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 523, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 523, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.threshold = __pyx_v_threshold_;
  __pyx_f_12PygameShader_6shader_shader_sobel24_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0524: 
 0525: 
+0526: cpdef inline void sobel_fast(
static PyObject *__pyx_pw_12PygameShader_6shader_19sobel_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_sobel_fast(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_sobel_fast *__pyx_optional_args) {
  int __pyx_v_threshold_ = ((int)64);
  unsigned short __pyx_v_factor_ = ((unsigned short)1);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel_fast", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold_ = __pyx_optional_args->threshold_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_factor_ = __pyx_optional_args->factor_;
      }
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.sobel_fast", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_19sobel_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_18sobel_fast[] = "\n    SHADER FAST SOBEL (EDGE DETECTION)\n\n    Transform the game display or a pygame surface into a sobel equivalent model\n    (surface edge detection).This version is slightly fastest than shader_sobel24_inplace_c as\n    it down-scale the array containing all the pixels and apply the sobel algorithm to a smaller\n    sample. When the processing is done, the array is re-scale to its original dimensions.\n    If this method is in theory faster than shader_sobel24_inplace_c, down-scaling and up-scaling\n    an array does have a side effect of decreasing the overall image definition\n    (jagged lines non-antialiasing)\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n      \n    e.g:\n    sobel_fast(surface, 64, factor_=1)\n\n    :param surface_: pygame.surface compatible 24-32 bit \n    :param threshold_: integer; default value is 24 \n    :param factor_: integer; default value is 1 (div by 2)\n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_19sobel_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_threshold_;
  unsigned short __pyx_v_factor_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel_fast (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_threshold,&__pyx_n_s_factor,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_threshold);
          if (value) { values[1] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "sobel_fast") < 0)) __PYX_ERR(1, 526, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_threshold_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_threshold_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 528, __pyx_L3_error)
    } else {
      __pyx_v_threshold_ = ((int)64);
    }
    if (values[2]) {
      __pyx_v_factor_ = __Pyx_PyInt_As_unsigned_short(values[2]); if (unlikely((__pyx_v_factor_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 529, __pyx_L3_error)
    } else {
      __pyx_v_factor_ = ((unsigned short)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("sobel_fast", 0, 1, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 526, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.sobel_fast", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_18sobel_fast(__pyx_self, __pyx_v_surface_, __pyx_v_threshold_, __pyx_v_factor_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_18sobel_fast(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_threshold_, unsigned short __pyx_v_factor_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sobel_fast", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 2;
  __pyx_t_1.threshold_ = __pyx_v_threshold_;
  __pyx_t_1.factor_ = __pyx_v_factor_;
  __pyx_f_12PygameShader_6shader_sobel_fast(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 526, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.sobel_fast", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0527:         object surface_,
 0528:         int threshold_ = 64,
 0529:         unsigned short factor_ = 1
 0530: ):
 0531:     """
 0532:     SHADER FAST SOBEL (EDGE DETECTION)
 0533: 
 0534:     Transform the game display or a pygame surface into a sobel equivalent model
 0535:     (surface edge detection).This version is slightly fastest than shader_sobel24_inplace_c as
 0536:     it down-scale the array containing all the pixels and apply the sobel algorithm to a smaller
 0537:     sample. When the processing is done, the array is re-scale to its original dimensions.
 0538:     If this method is in theory faster than shader_sobel24_inplace_c, down-scaling and up-scaling
 0539:     an array does have a side effect of decreasing the overall image definition
 0540:     (jagged lines non-antialiasing)
 0541:     
 0542:     Compatible 24 - 32 bit with or without alpha layer
 0543:     
 0544:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0545:       new surface.  
 0546:       
 0547:     e.g:
 0548:     sobel_fast(surface, 64, factor_=1)
 0549: 
 0550:     :param surface_: pygame.surface compatible 24-32 bit 
 0551:     :param threshold_: integer; default value is 24 
 0552:     :param factor_: integer; default value is 1 (div by 2)
 0553:     :return:
 0554:     """
+0555:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 555, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 555, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 555, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0556:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 556, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 555, __pyx_L1_error)
    }
  }
  #endif
 0557: 
+0558:     assert -1 < threshold_ < 256, "\nArgument threshold must be an integer in range [0 ... 255]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1L < __pyx_v_threshold_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_threshold_ < 0x100);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_threshold_must_be_an_i);
      __PYX_ERR(1, 558, __pyx_L1_error)
    }
  }
  #endif
+0559:     assert 0 < factor_ < 9, "\nArgument factor_ must be in range [1 ... 8]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (0 < __pyx_v_factor_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_factor_ < 9);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_factor__must_be_in_ran);
      __PYX_ERR(1, 559, __pyx_L1_error)
    }
  }
  #endif
 0560: 
+0561:     shader_sobel24_fast_inplace_c(surface_, threshold_, factor_)
  __pyx_t_4.__pyx_n = 2;
  __pyx_t_4.threshold_ = __pyx_v_threshold_;
  __pyx_t_4.factor_ = __pyx_v_factor_;
  __pyx_f_12PygameShader_6shader_shader_sobel24_fast_inplace_c(__pyx_v_surface_, &__pyx_t_4); 
 0562: 
 0563: 
 0564: 
 0565: 
+0566: cpdef inline void invert(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_21invert(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_invert(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("invert", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.invert", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_21invert(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_20invert[] = "\n    SHADER INVERT PIXELS\n    \n    Invert all pixels of the display or a given texture\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n    \n    e.g:\n    invert(surface)\n    \n    :param surface_: pygame.surface; compatible 24 - 32 bit surfaces\n    :return: void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_21invert(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("invert (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_20invert(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_20invert(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("invert", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_invert(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 566, __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("PygameShader.shader.invert", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0567:     """
 0568:     SHADER INVERT PIXELS
 0569:     
 0570:     Invert all pixels of the display or a given texture
 0571:     
 0572:     Compatible 24 - 32 bit with or without alpha layer
 0573:     
 0574:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0575:       new surface.  
 0576:     
 0577:     e.g:
 0578:     invert(surface)
 0579:     
 0580:     :param surface_: pygame.surface; compatible 24 - 32 bit surfaces
 0581:     :return: void
 0582:     """
+0583:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 583, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 583, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 583, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0584:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 584, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 583, __pyx_L1_error)
    }
  }
  #endif
 0585: 
+0586:     shader_invert_surface_24bit_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 586, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 586, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 586, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_invert_surface_24bit_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0587: 
 0588: 
 0589: 
+0590: cpdef inline void hsl_effect(object surface_, float shift_):
static PyObject *__pyx_pw_12PygameShader_6shader_23hsl_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_hsl_effect(PyObject *__pyx_v_surface_, float __pyx_v_shift_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_effect", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.hsl_effect", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_23hsl_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_22hsl_effect[] = "\n    ROTATE THE HUE OF THE GAME DISPLAY OR GIVEN TEXTURE\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n      \n    e.g:\n    hsl_effect(surface, 0.2)\n    \n    :param surface_: pygame.Surface; Compatible 24 - 32 bit surfaces\n    :param shift_: float; float value in range [-1.0 ... 1.0]\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_23hsl_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_effect (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("hsl_effect", 1, 2, 2, 1); __PYX_ERR(1, 590, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "hsl_effect") < 0)) __PYX_ERR(1, 590, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 590, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("hsl_effect", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 590, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.hsl_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_22hsl_effect(__pyx_self, __pyx_v_surface_, __pyx_v_shift_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_22hsl_effect(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_effect", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_hsl_effect(__pyx_v_surface_, __pyx_v_shift_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 590, __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("PygameShader.shader.hsl_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0591:     """
 0592:     ROTATE THE HUE OF THE GAME DISPLAY OR GIVEN TEXTURE
 0593:     
 0594:     Compatible 24 - 32 bit with or without alpha layer
 0595:     
 0596:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0597:       new surface.  
 0598:       
 0599:     e.g:
 0600:     hsl_effect(surface, 0.2)
 0601:     
 0602:     :param surface_: pygame.Surface; Compatible 24 - 32 bit surfaces
 0603:     :param shift_: float; float value in range [-1.0 ... 1.0]
 0604:     :return: void 
 0605:     """
+0606:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 606, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 606, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 606, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0607:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 607, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 606, __pyx_L1_error)
    }
  }
  #endif
 0608: 
+0609:     assert -1.0 <= shift_ <= 1.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift_must_be_in_range);
      __PYX_ERR(1, 609, __pyx_L1_error)
    }
  }
  #endif
 0610:         "Argument shift must be in range[-1.0 ... 1.0]"
 0611: 
+0612:     shader_hsl_surface24bit_inplace_c(pixels3d(surface_), shift_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 612, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_hsl_surface24bit_inplace_c(__pyx_t_5, __pyx_v_shift_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0613: 
 0614: 
 0615: # todo wiki
+0616: cpdef inline void hsl_fast(
static PyObject *__pyx_pw_12PygameShader_6shader_25hsl_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_hsl_fast(PyObject *__pyx_v_surface_, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_hsl_model_, __Pyx_memviewslice __pyx_v_rgb_model_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_fast", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.hsl_fast", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_25hsl_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_24hsl_fast[] = "    \n    ROTATE THE HUE OF AN IMAGE USING STORED HSL TO RGB AND RGB TO HSL VALUES\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    e.g:\n    rgb2hsl_model = hsl_to_rgb_model()\n    hsl2rgb_model = rgb_to_hsl_model()\n    hsl_fast(\n                image,\n                0.1,\n                hsl_model_=hsl2rgb_model,\n                rgb_model_=rgb2hsl_model)\n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit surfaces\n    :param shift_: float; value must be in range [ -1.0 ... + 1.0]\n    :param hsl_model_: 3d numpy.ndarray shape (256, 256, 256, 3) see hsl_to_rgb_model function \n    :param rgb_model_: 3d numpy.ndarray shape (256, 256, 256, 3) see rgb_to_hsl_model function\n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_25hsl_fast(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  __Pyx_memviewslice __pyx_v_hsl_model_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_rgb_model_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_fast (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,&__pyx_n_s_hsl_model,&__pyx_n_s_rgb_model,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("hsl_fast", 1, 4, 4, 1); __PYX_ERR(1, 616, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_hsl_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("hsl_fast", 1, 4, 4, 2); __PYX_ERR(1, 616, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rgb_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("hsl_fast", 1, 4, 4, 3); __PYX_ERR(1, 616, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "hsl_fast") < 0)) __PYX_ERR(1, 616, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 618, __pyx_L3_error)
    __pyx_v_hsl_model_ = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_float(values[2], PyBUF_WRITABLE); if (unlikely(!__pyx_v_hsl_model_.memview)) __PYX_ERR(1, 619, __pyx_L3_error)
    __pyx_v_rgb_model_ = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_unsigned_char(values[3], PyBUF_WRITABLE); if (unlikely(!__pyx_v_rgb_model_.memview)) __PYX_ERR(1, 620, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("hsl_fast", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 616, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.hsl_fast", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_24hsl_fast(__pyx_self, __pyx_v_surface_, __pyx_v_shift_, __pyx_v_hsl_model_, __pyx_v_rgb_model_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_24hsl_fast(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_hsl_model_, __Pyx_memviewslice __pyx_v_rgb_model_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_fast", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_hsl_model_.memview)) { __Pyx_RaiseUnboundLocalError("hsl_model_"); __PYX_ERR(1, 616, __pyx_L1_error) }
  if (unlikely(!__pyx_v_rgb_model_.memview)) { __Pyx_RaiseUnboundLocalError("rgb_model_"); __PYX_ERR(1, 616, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_hsl_fast(__pyx_v_surface_, __pyx_v_shift_, __pyx_v_hsl_model_, __pyx_v_rgb_model_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 616, __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("PygameShader.shader.hsl_fast", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_hsl_model_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_model_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0617:         object surface_,
 0618:         float shift_,
 0619:         float [:, :, :, ::1] hsl_model_,
 0620:         unsigned char [:, :, :, ::1] rgb_model_
 0621: ):
 0622:     """    
 0623:     ROTATE THE HUE OF AN IMAGE USING STORED HSL TO RGB AND RGB TO HSL VALUES
 0624:     
 0625:     Compatible 24 - 32 bit with or without alpha layer
 0626:     
 0627:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0628:       new surface.  
 0629: 
 0630:     e.g:
 0631:     rgb2hsl_model = hsl_to_rgb_model()
 0632:     hsl2rgb_model = rgb_to_hsl_model()
 0633:     hsl_fast(
 0634:                 image,
 0635:                 0.1,
 0636:                 hsl_model_=hsl2rgb_model,
 0637:                 rgb_model_=rgb2hsl_model)
 0638: 
 0639:     :param surface_: pygame.Surface; compatible 24 - 32 bit surfaces
 0640:     :param shift_: float; value must be in range [ -1.0 ... + 1.0]
 0641:     :param hsl_model_: 3d numpy.ndarray shape (256, 256, 256, 3) see hsl_to_rgb_model function 
 0642:     :param rgb_model_: 3d numpy.ndarray shape (256, 256, 256, 3) see rgb_to_hsl_model function
 0643:     :return:
 0644:     """
+0645:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 645, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 645, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 645, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0646:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 646, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 645, __pyx_L1_error)
    }
  }
  #endif
+0647:     assert -1.0 <= shift_ <= 1.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift_must_be_in_range);
      __PYX_ERR(1, 647, __pyx_L1_error)
    }
  }
  #endif
 0648:         "Argument shift must be in range[-1.0 ... 1.0]"
+0649:     assert PyObject_IsInstance(hsl_model_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_hsl_model_, 4, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 649, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 649, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 649, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 649, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 649, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0650:         "\nArgument hsl_model_ must be a numpy.ndarray or memoryview type, got %s " % type(
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_hsl_model__must_be_a_n, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 650, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 649, __pyx_L1_error)
    }
  }
  #endif
+0651:             hsl_model_)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_hsl_model_, 4, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 651, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
+0652:     assert PyObject_IsInstance(rgb_model_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_rgb_model_, 4, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 652, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 652, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 652, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 652, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 652, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0653:         "\nArgument rgb_model_ must be a numpy.ndarray or memoryview type, got %s " % type(
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_rgb_model__must_be_a_n, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 653, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 652, __pyx_L1_error)
    }
  }
  #endif
+0654:             rgb_model_)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_rgb_model_, 4, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 654, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
 0655: 
+0656:     shader_hsl_surface24bit_fast_inplace_c(pixels3d(surface_), shift_, hsl_model_, rgb_model_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 656, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 656, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 656, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_hsl_surface24bit_fast_inplace_c(__pyx_t_5, __pyx_v_shift_, __pyx_v_hsl_model_, __pyx_v_rgb_model_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0657: 
 0658: 
+0659: cpdef inline void blur(object surface_, t_=1):
static PyObject *__pyx_pw_12PygameShader_6shader_27blur(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_blur(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_blur *__pyx_optional_args) {
  PyObject *__pyx_v_t_ = ((PyObject *)__pyx_int_1);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blur", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_t_ = __pyx_optional_args->t_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.blur", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_27blur(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_26blur[] = "\n    APPLY A GAUSSIAN BLUR EFFECT TO THE GAME DISPLAY OR TO A GIVEN TEXTURE (KERNEL 5x5)\n\n    # Gaussian kernel 5x5\n        # |1   4   6   4  1|\n        # |4  16  24  16  4|\n        # |6  24  36  24  6|  x 1/256\n        # |4  16  24  16  4|\n        # |1  4    6   4  1|\n    This method is using convolution property and process the image in two passes,\n    first the horizontal convolution and last the vertical convolution\n    pixels convoluted outside image edges will be set to adjacent edge value\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit surfaces\n    :param t_      : integer; number if times must be >0\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_27blur(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  PyObject *__pyx_v_t_ = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blur (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_t,0};
    PyObject* values[2] = {0,0};
    values[1] = ((PyObject *)__pyx_int_1);
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_t);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "blur") < 0)) __PYX_ERR(1, 659, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_t_ = values[1];
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("blur", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 659, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.blur", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_26blur(__pyx_self, __pyx_v_surface_, __pyx_v_t_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_26blur(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, PyObject *__pyx_v_t_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blur", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.t_ = __pyx_v_t_;
  __pyx_f_12PygameShader_6shader_blur(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 659, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.blur", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0660:     """
 0661:     APPLY A GAUSSIAN BLUR EFFECT TO THE GAME DISPLAY OR TO A GIVEN TEXTURE (KERNEL 5x5)
 0662: 
 0663:     # Gaussian kernel 5x5
 0664:         # |1   4   6   4  1|
 0665:         # |4  16  24  16  4|
 0666:         # |6  24  36  24  6|  x 1/256
 0667:         # |4  16  24  16  4|
 0668:         # |1  4    6   4  1|
 0669:     This method is using convolution property and process the image in two passes,
 0670:     first the horizontal convolution and last the vertical convolution
 0671:     pixels convoluted outside image edges will be set to adjacent edge value
 0672:     
 0673:     Compatible 24 - 32 bit with or without alpha layer
 0674:     
 0675:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0676:       new surface.  
 0677: 
 0678:     :param surface_: pygame.Surface; compatible 24 - 32 bit surfaces
 0679:     :param t_      : integer; number if times must be >0
 0680:     :return: void 
 0681:     """
+0682:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 682, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 682, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 682, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0683:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 683, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 682, __pyx_L1_error)
    }
  }
  #endif
+0684:     assert t_ > 0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = PyObject_RichCompare(__pyx_v_t_, __pyx_int_0, Py_GT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 684, __pyx_L1_error)
    __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) __PYX_ERR(1, 684, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_3)) {
+0685:         "\nArgument t_ must be > 0, got %s " % t_
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_t__must_be_0_got_s, __pyx_v_t_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 685, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 684, __pyx_L1_error)
    }
  }
  #endif
 0686: 
+0687:     shader_blur5x5_array24_inplace_c(pixels3d(surface_), None, t_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 687, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 687, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 687, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 2;
  __pyx_t_6.mask = Py_None;
  __pyx_t_6.t = __pyx_v_t_;
  __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0688: 
 0689: 
+0690: cpdef inline void wave(object surface_, float rad, int size):
static PyObject *__pyx_pw_12PygameShader_6shader_29wave(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_wave(PyObject *__pyx_v_surface_, float __pyx_v_rad, int __pyx_v_size, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("wave", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.wave", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_29wave(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_28wave[] = "\n    CREATE A WAVE EFFECT TO THE GAME DISPLAY OR TO A GIVEN SURFACE\n\n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    e.g:\n    wave(surface, 8 * math.pi/180.0 + frame_number, 5)\n    \n    :param surface_: pygame.Surface; pygame surface compatible 24 - 32 bit  \n    :param rad     : float; angle in rad to rotate over time\n    :param size    : int; Number of sub-surfaces\n    :return        : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_29wave(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_rad;
  int __pyx_v_size;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("wave (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_rad,&__pyx_n_s_size,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rad)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("wave", 1, 3, 3, 1); __PYX_ERR(1, 690, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("wave", 1, 3, 3, 2); __PYX_ERR(1, 690, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "wave") < 0)) __PYX_ERR(1, 690, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_rad = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_rad == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 690, __pyx_L3_error)
    __pyx_v_size = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_size == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 690, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("wave", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 690, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.wave", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_28wave(__pyx_self, __pyx_v_surface_, __pyx_v_rad, __pyx_v_size);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_28wave(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_rad, int __pyx_v_size) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("wave", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_wave(__pyx_v_surface_, __pyx_v_rad, __pyx_v_size, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 690, __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("PygameShader.shader.wave", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0691:     """
 0692:     CREATE A WAVE EFFECT TO THE GAME DISPLAY OR TO A GIVEN SURFACE
 0693: 
 0694:     Compatible 24 - 32 bit with or without alpha layer
 0695:     
 0696:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0697:       new surface.  
 0698: 
 0699:     e.g:
 0700:     wave(surface, 8 * math.pi/180.0 + frame_number, 5)
 0701:     
 0702:     :param surface_: pygame.Surface; pygame surface compatible 24 - 32 bit  
 0703:     :param rad     : float; angle in rad to rotate over time
 0704:     :param size    : int; Number of sub-surfaces
 0705:     :return        : void
 0706:     """
+0707:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 707, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 707, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 707, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0708:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 708, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 707, __pyx_L1_error)
    }
  }
  #endif
+0709:     assert size > 0, "Argument size must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_size > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_size_must_be_0);
      __PYX_ERR(1, 709, __pyx_L1_error)
    }
  }
  #endif
 0710: 
+0711:     shader_wave24bit_inplace_c(pixels3d(surface_), rad, size)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 711, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 711, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 711, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_wave24bit_inplace_c(__pyx_t_5, __pyx_v_rad, __pyx_v_size);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0712: 
 0713: 
+0714: cpdef inline void swirl(object surface_, float degrees):
static PyObject *__pyx_pw_12PygameShader_6shader_31swirl(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_swirl(PyObject *__pyx_v_surface_, float __pyx_v_degrees, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.swirl", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_31swirl(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_30swirl[] = "\n    SWIRL AN IMAGE (ANGLE APPROXIMATION METHOD)\n\n    This algorithm uses a table of cos and sin.\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    e.g:\n    swirl(surface, 1.0)\n    \n    :param surface_: pygame.Surface, compatible 24 - 32 bit \n    :param degrees : float; angle in degrees \n    :return        : void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_31swirl(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_degrees;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_degrees,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_degrees)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("swirl", 1, 2, 2, 1); __PYX_ERR(1, 714, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "swirl") < 0)) __PYX_ERR(1, 714, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_degrees = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_degrees == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 714, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("swirl", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 714, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.swirl", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_30swirl(__pyx_self, __pyx_v_surface_, __pyx_v_degrees);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_30swirl(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_degrees) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_swirl(__pyx_v_surface_, __pyx_v_degrees, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 714, __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("PygameShader.shader.swirl", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0715:     """
 0716:     SWIRL AN IMAGE (ANGLE APPROXIMATION METHOD)
 0717: 
 0718:     This algorithm uses a table of cos and sin.
 0719:     
 0720:     Compatible 24 - 32 bit with or without alpha layer
 0721:     
 0722:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0723:       new surface.  
 0724: 
 0725:     e.g:
 0726:     swirl(surface, 1.0)
 0727:     
 0728:     :param surface_: pygame.Surface, compatible 24 - 32 bit 
 0729:     :param degrees : float; angle in degrees 
 0730:     :return        : void 
 0731:     """
+0732:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 732, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 732, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 732, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0733:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 733, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 732, __pyx_L1_error)
    }
  }
  #endif
 0734: 
+0735:     shader_swirl24bit_inplace_c(pixels3d(surface_), degrees)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 735, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_swirl24bit_inplace_c(__pyx_t_5, __pyx_v_degrees);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0736: 
 0737: 
 0738: 
+0739: cpdef inline void swirl2(object surface_, float degrees):
static PyObject *__pyx_pw_12PygameShader_6shader_33swirl2(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_swirl2(PyObject *__pyx_v_surface_, float __pyx_v_degrees, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl2", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.swirl2", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_33swirl2(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_32swirl2[] = "\n    SWIRL AN IMAGE WITHOUT ANGLE APPROXIMATION\n\n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n      \n    e.g:\n    swirl(surface_, frame_number)\n    \n    :param surface_: pygame.Surface, compatible 24 - 32 bit \n    :param degrees : float; angle in degrees\n    :return        : void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_33swirl2(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_degrees;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl2 (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_degrees,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_degrees)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("swirl2", 1, 2, 2, 1); __PYX_ERR(1, 739, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "swirl2") < 0)) __PYX_ERR(1, 739, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_degrees = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_degrees == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 739, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("swirl2", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 739, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.swirl2", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_32swirl2(__pyx_self, __pyx_v_surface_, __pyx_v_degrees);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_32swirl2(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_degrees) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("swirl2", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_swirl2(__pyx_v_surface_, __pyx_v_degrees, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 739, __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("PygameShader.shader.swirl2", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0740:     """
 0741:     SWIRL AN IMAGE WITHOUT ANGLE APPROXIMATION
 0742: 
 0743:     Compatible 24 - 32 bit with or without alpha layer
 0744:     
 0745:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0746:       new surface.  
 0747:       
 0748:     e.g:
 0749:     swirl(surface_, frame_number)
 0750:     
 0751:     :param surface_: pygame.Surface, compatible 24 - 32 bit 
 0752:     :param degrees : float; angle in degrees
 0753:     :return        : void 
 0754:     """
+0755:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 755, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 755, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 755, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0756:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 756, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 755, __pyx_L1_error)
    }
  }
  #endif
 0757: 
+0758:     shader_swirl24bit_inplace_c1(pixels3d(surface_), degrees)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 758, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 758, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 758, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_swirl24bit_inplace_c1(__pyx_t_5, __pyx_v_degrees);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0759: 
 0760: 
 0761: 
+0762: cpdef inline void plasma_config(
static PyObject *__pyx_pw_12PygameShader_6shader_35plasma_config(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_plasma_config(PyObject *__pyx_v_surface_, int __pyx_v_frame, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_plasma_config *__pyx_optional_args) {
  float __pyx_v_hue_ = __pyx_k__3;
  float __pyx_v_sat_ = __pyx_k__4;
  float __pyx_v_value_ = __pyx_k__5;
  float __pyx_v_a_ = __pyx_k__6;
  float __pyx_v_b_ = __pyx_k__7;
  float __pyx_v_c_ = __pyx_k__8;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma_config", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_hue_ = __pyx_optional_args->hue_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_sat_ = __pyx_optional_args->sat_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_value_ = __pyx_optional_args->value_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_a_ = __pyx_optional_args->a_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_b_ = __pyx_optional_args->b_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_c_ = __pyx_optional_args->c_;
              }
            }
          }
        }
      }
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.plasma_config", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_35plasma_config(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_34plasma_config[] = "\n\n    CREATE A BASIC PLASMA EFFECT ON THE TOP OF A PYGAME SURFACE\n\n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n\n    e.g:\n    plasma_config(surface, frame_number)\n\n    :param a_           : float; default value 1.0/255.0 control the plasma equation\n    :param b_           : float; default value 1.0/12.0 control the plasma equation\n    :param c_           : float; default value 1.0/12.0 control the plasma equation\n    :param value_       : float; default value 1.0/8.0 value factor\n    :param sat_         : float; default value 1.0/6.0 saturation value\n    :param hue_         : float; default value 1.0/6.0 hue value factor\n    :param surface_     : pygame.surface; compatible 24 - 32 bit\n    :param frame        : integer; Variable that need to change over time\n    :return             : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_35plasma_config(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_frame;
  float __pyx_v_hue_;
  float __pyx_v_sat_;
  float __pyx_v_value_;
  float __pyx_v_a_;
  float __pyx_v_b_;
  float __pyx_v_c_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma_config (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_frame,&__pyx_n_s_hue,&__pyx_n_s_sat,&__pyx_n_s_value,&__pyx_n_s_a,&__pyx_n_s_b,&__pyx_n_s_c,0};
    PyObject* values[8] = {0,0,0,0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_frame)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("plasma_config", 0, 2, 8, 1); __PYX_ERR(1, 762, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_hue);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sat);
          if (value) { values[3] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_value);
          if (value) { values[4] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_a);
          if (value) { values[5] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_b);
          if (value) { values[6] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  7:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_c);
          if (value) { values[7] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "plasma_config") < 0)) __PYX_ERR(1, 762, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_frame = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_frame == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 764, __pyx_L3_error)
    if (values[2]) {
      __pyx_v_hue_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_hue_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 765, __pyx_L3_error)
    } else {
      __pyx_v_hue_ = __pyx_k__3;
    }
    if (values[3]) {
      __pyx_v_sat_ = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_sat_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 766, __pyx_L3_error)
    } else {
      __pyx_v_sat_ = __pyx_k__4;
    }
    if (values[4]) {
      __pyx_v_value_ = __pyx_PyFloat_AsFloat(values[4]); if (unlikely((__pyx_v_value_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 767, __pyx_L3_error)
    } else {
      __pyx_v_value_ = __pyx_k__5;
    }
    if (values[5]) {
      __pyx_v_a_ = __pyx_PyFloat_AsFloat(values[5]); if (unlikely((__pyx_v_a_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 768, __pyx_L3_error)
    } else {
      __pyx_v_a_ = __pyx_k__6;
    }
    if (values[6]) {
      __pyx_v_b_ = __pyx_PyFloat_AsFloat(values[6]); if (unlikely((__pyx_v_b_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 769, __pyx_L3_error)
    } else {
      __pyx_v_b_ = __pyx_k__7;
    }
    if (values[7]) {
      __pyx_v_c_ = __pyx_PyFloat_AsFloat(values[7]); if (unlikely((__pyx_v_c_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 770, __pyx_L3_error)
    } else {
      __pyx_v_c_ = __pyx_k__8;
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("plasma_config", 0, 2, 8, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 762, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.plasma_config", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_34plasma_config(__pyx_self, __pyx_v_surface_, __pyx_v_frame, __pyx_v_hue_, __pyx_v_sat_, __pyx_v_value_, __pyx_v_a_, __pyx_v_b_, __pyx_v_c_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_34plasma_config(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_frame, float __pyx_v_hue_, float __pyx_v_sat_, float __pyx_v_value_, float __pyx_v_a_, float __pyx_v_b_, float __pyx_v_c_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma_config", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 6;
  __pyx_t_1.hue_ = __pyx_v_hue_;
  __pyx_t_1.sat_ = __pyx_v_sat_;
  __pyx_t_1.value_ = __pyx_v_value_;
  __pyx_t_1.a_ = __pyx_v_a_;
  __pyx_t_1.b_ = __pyx_v_b_;
  __pyx_t_1.c_ = __pyx_v_c_;
  __pyx_f_12PygameShader_6shader_plasma_config(__pyx_v_surface_, __pyx_v_frame, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 762, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.plasma_config", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0763:         object surface_,
 0764:         int frame,
+0765:         float hue_=1.0/6.0,
  __pyx_k__3 = (1.0 / 6.0);
/* … */
  __pyx_k__3 = (1.0 / 6.0);
+0766:         float sat_=1.0/6.0,
  __pyx_k__4 = (1.0 / 6.0);
/* … */
  __pyx_k__4 = (1.0 / 6.0);
+0767:         float value_=1.0/8.0,
  __pyx_k__5 = (1.0 / 8.0);
/* … */
  __pyx_k__5 = (1.0 / 8.0);
+0768:         float a_=1.0/255.0,
  __pyx_k__6 = (1.0 / 255.0);
/* … */
  __pyx_k__6 = (1.0 / 255.0);
+0769:         float b_=1.0/12.0,
  __pyx_k__7 = (1.0 / 12.0);
/* … */
  __pyx_k__7 = (1.0 / 12.0);
+0770:         float c_=1.0/12.0
  __pyx_k__8 = (1.0 / 12.0);
/* … */
  __pyx_k__8 = (1.0 / 12.0);
 0771: ):
 0772:     """
 0773: 
 0774:     CREATE A BASIC PLASMA EFFECT ON THE TOP OF A PYGAME SURFACE
 0775: 
 0776:     Compatible 24 - 32 bit with or without alpha layer
 0777:     
 0778:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0779:       new surface.  
 0780: 
 0781:     e.g:
 0782:     plasma_config(surface, frame_number)
 0783: 
 0784:     :param a_           : float; default value 1.0/255.0 control the plasma equation
 0785:     :param b_           : float; default value 1.0/12.0 control the plasma equation
 0786:     :param c_           : float; default value 1.0/12.0 control the plasma equation
 0787:     :param value_       : float; default value 1.0/8.0 value factor
 0788:     :param sat_         : float; default value 1.0/6.0 saturation value
 0789:     :param hue_         : float; default value 1.0/6.0 hue value factor
 0790:     :param surface_     : pygame.surface; compatible 24 - 32 bit
 0791:     :param frame        : integer; Variable that need to change over time
 0792:     :return             : void
 0793:     """
+0794:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 794, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 794, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 794, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0795:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 795, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 794, __pyx_L1_error)
    }
  }
  #endif
 0796: 
+0797:     shader_plasma24bit_inplace_c(pixels3d(surface_), frame, hue_, sat_, value_, a_, b_, c_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 797, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 797, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 797, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 6;
  __pyx_t_6.hue_ = __pyx_v_hue_;
  __pyx_t_6.sat_ = __pyx_v_sat_;
  __pyx_t_6.value_ = __pyx_v_value_;
  __pyx_t_6.a_ = __pyx_v_a_;
  __pyx_t_6.b_ = __pyx_v_b_;
  __pyx_t_6.c_ = __pyx_v_c_;
  __pyx_f_12PygameShader_6shader_shader_plasma24bit_inplace_c(__pyx_t_5, __pyx_v_frame, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0798: 
 0799: 
+0800: cpdef inline void plasma(surface_, float frame, unsigned int [::1] palette_):
static PyObject *__pyx_pw_12PygameShader_6shader_37plasma(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_plasma(PyObject *__pyx_v_surface_, float __pyx_v_frame, __Pyx_memviewslice __pyx_v_palette_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.plasma", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_37plasma(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_36plasma[] = "\n    CREATE A PLASMA EFFECT INPLACE\n\n    e.g:\n    plasma(surface, frame_number, palette_)\n    \n    :param surface_: pygame.Surface; compatible 24 - 32 bit \n    :param frame   : float; frame number\n    :param palette_: 1d array containing colors\n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_37plasma(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_frame;
  __Pyx_memviewslice __pyx_v_palette_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_frame,&__pyx_n_s_palette,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_frame)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("plasma", 1, 3, 3, 1); __PYX_ERR(1, 800, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_palette)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("plasma", 1, 3, 3, 2); __PYX_ERR(1, 800, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "plasma") < 0)) __PYX_ERR(1, 800, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_frame = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_frame == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 800, __pyx_L3_error)
    __pyx_v_palette_ = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(values[2], PyBUF_WRITABLE); if (unlikely(!__pyx_v_palette_.memview)) __PYX_ERR(1, 800, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("plasma", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 800, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.plasma", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_36plasma(__pyx_self, __pyx_v_surface_, __pyx_v_frame, __pyx_v_palette_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_36plasma(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_frame, __Pyx_memviewslice __pyx_v_palette_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("plasma", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_palette_.memview)) { __Pyx_RaiseUnboundLocalError("palette_"); __PYX_ERR(1, 800, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_plasma(__pyx_v_surface_, __pyx_v_frame, __pyx_v_palette_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 800, __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("PygameShader.shader.plasma", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0801:     """
 0802:     CREATE A PLASMA EFFECT INPLACE
 0803: 
 0804:     e.g:
 0805:     plasma(surface, frame_number, palette_)
 0806:     
 0807:     :param surface_: pygame.Surface; compatible 24 - 32 bit 
 0808:     :param frame   : float; frame number
 0809:     :param palette_: 1d array containing colors
 0810:     :return:
 0811:     """
+0812:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 812, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 812, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 812, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0813:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 813, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 812, __pyx_L1_error)
    }
  }
  #endif
+0814:     shader_plasma_c(surface_, frame, palette_)
  __pyx_f_12PygameShader_6shader_shader_plasma_c(__pyx_v_surface_, __pyx_v_frame, __pyx_v_palette_);
 0815: 
 0816: 
 0817: # todo wiki
+0818: cpdef inline float [:, :, :, ::1] rgb_to_hsl_model():
static PyObject *__pyx_pw_12PygameShader_6shader_39rgb_to_hsl_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static CYTHON_INLINE __Pyx_memviewslice __pyx_f_12PygameShader_6shader_rgb_to_hsl_model(CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_memviewslice __pyx_r = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_hsl_model", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __pyx_r.data = NULL;
  __pyx_r.memview = NULL;
  __Pyx_AddTraceback("PygameShader.shader.rgb_to_hsl_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  goto __pyx_L2;
  __pyx_L0:;
  if (unlikely(!__pyx_r.memview)) {
    PyErr_SetString(PyExc_TypeError, "Memoryview return value is not initialized");
  }
  __pyx_L2:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_39rgb_to_hsl_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static char __pyx_doc_12PygameShader_6shader_38rgb_to_hsl_model[] = "\n    Create an HSL model containing all the values\n    :return: Return a cython.view.memoryview shape (256, 256, 256, 3)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_39rgb_to_hsl_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_hsl_model (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_38rgb_to_hsl_model(__pyx_self);

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_38rgb_to_hsl_model(CYTHON_UNUSED PyObject *__pyx_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_hsl_model", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_rgb_to_hsl_model(0); if (unlikely(!__pyx_t_1.memview)) __PYX_ERR(1, 818, __pyx_L1_error)
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_t_1, 4, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 818, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __pyx_t_1.memview = NULL;
  __pyx_t_1.data = NULL;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.rgb_to_hsl_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0819:     """
 0820:     Create an HSL model containing all the values
 0821:     :return: Return a cython.view.memoryview shape (256, 256, 256, 3)
 0822:     """
+0823:     return rgb_to_hsl_model_c()
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_rgb_to_hsl_model_c(); if (unlikely(!__pyx_t_1.memview)) __PYX_ERR(1, 823, __pyx_L1_error)
  __pyx_r = __pyx_t_1;
  __pyx_t_1.memview = NULL;
  __pyx_t_1.data = NULL;
  goto __pyx_L0;
 0824: 
 0825: 
 0826: # todo wiki
+0827: cpdef inline unsigned char [:, :, :, ::1] hsl_to_rgb_model():
static PyObject *__pyx_pw_12PygameShader_6shader_41hsl_to_rgb_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static CYTHON_INLINE __Pyx_memviewslice __pyx_f_12PygameShader_6shader_hsl_to_rgb_model(CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_memviewslice __pyx_r = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_to_rgb_model", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __pyx_r.data = NULL;
  __pyx_r.memview = NULL;
  __Pyx_AddTraceback("PygameShader.shader.hsl_to_rgb_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  goto __pyx_L2;
  __pyx_L0:;
  if (unlikely(!__pyx_r.memview)) {
    PyErr_SetString(PyExc_TypeError, "Memoryview return value is not initialized");
  }
  __pyx_L2:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_41hsl_to_rgb_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
static char __pyx_doc_12PygameShader_6shader_40hsl_to_rgb_model[] = "\n    Create an RGB model containing all the values\n    :return: Return a cython.view.memoryview shape (256, 256, 256, 3)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_41hsl_to_rgb_model(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_to_rgb_model (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_40hsl_to_rgb_model(__pyx_self);

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_40hsl_to_rgb_model(CYTHON_UNUSED PyObject *__pyx_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_to_rgb_model", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_hsl_to_rgb_model(0); if (unlikely(!__pyx_t_1.memview)) __PYX_ERR(1, 827, __pyx_L1_error)
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_t_1, 4, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 827, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __pyx_t_1.memview = NULL;
  __pyx_t_1.data = NULL;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __PYX_XDEC_MEMVIEW(&__pyx_t_1, 1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.hsl_to_rgb_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0828:     """
 0829:     Create an RGB model containing all the values
 0830:     :return: Return a cython.view.memoryview shape (256, 256, 256, 3)
 0831:     """
+0832:     return hsl_to_rgb_model_c()
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_hsl_to_rgb_model_c(); if (unlikely(!__pyx_t_1.memview)) __PYX_ERR(1, 832, __pyx_L1_error)
  __pyx_r = __pyx_t_1;
  __pyx_t_1.memview = NULL;
  __pyx_t_1.data = NULL;
  goto __pyx_L0;
 0833: 
 0834: 
 0835: 
+0836: cpdef inline void brightness(object surface_, float shift_):
static PyObject *__pyx_pw_12PygameShader_6shader_43brightness(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_brightness(PyObject *__pyx_v_surface_, float __pyx_v_shift_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.brightness", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_43brightness(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_42brightness[] = "\n    SHADER BRIGHTNESS\n\n    This shader control the pygame display brightness level\n    It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb\n    \n    Parameter shift_ is a float value in range [ -1.0 ... 1.0]. with +1.0 for the \n    maximum brightness. A value of 0.0 will not perform any changes to the original \n    surface\n    \n    Compatible 24 - 32 bit with or without alpha layer\n    \n    * The changes are automatically applied inplace to the surface, you do not need to create a \n      new surface.  \n      \n    e.g:\n    brightness(surface, 0.2)\n    \n    :param surface_ : pygame.surface; \n    :param shift_   : float must be in range [ -1.0 ... 1.0 ]\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_43brightness(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("brightness", 1, 2, 2, 1); __PYX_ERR(1, 836, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "brightness") < 0)) __PYX_ERR(1, 836, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 836, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("brightness", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 836, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.brightness", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_42brightness(__pyx_self, __pyx_v_surface_, __pyx_v_shift_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_42brightness(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_brightness(__pyx_v_surface_, __pyx_v_shift_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 836, __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("PygameShader.shader.brightness", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0837:     """
 0838:     SHADER BRIGHTNESS
 0839: 
 0840:     This shader control the pygame display brightness level
 0841:     It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb
 0842:     
 0843:     Parameter shift_ is a float value in range [ -1.0 ... 1.0]. with +1.0 for the 
 0844:     maximum brightness. A value of 0.0 will not perform any changes to the original 
 0845:     surface
 0846:     
 0847:     Compatible 24 - 32 bit with or without alpha layer
 0848:     
 0849:     * The changes are automatically applied inplace to the surface, you do not need to create a 
 0850:       new surface.  
 0851:       
 0852:     e.g:
 0853:     brightness(surface, 0.2)
 0854:     
 0855:     :param surface_ : pygame.surface; 
 0856:     :param shift_   : float must be in range [ -1.0 ... 1.0 ]
 0857:     :return         : void
 0858:     """
+0859:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 859, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 859, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 859, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0860:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 860, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 859, __pyx_L1_error)
    }
  }
  #endif
 0861: 
+0862:     if shift_ == 0.0:
  __pyx_t_3 = ((__pyx_v_shift_ == 0.0) != 0);
  if (__pyx_t_3) {
/* … */
  }
+0863:         return
    goto __pyx_L0;
 0864: 
+0865:     assert -1.0 <= shift_ <= 1.0, "\nArgument shift_ must be in range [-1.0 ... 1.0]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift__must_be_in_rang);
      __PYX_ERR(1, 865, __pyx_L1_error)
    }
  }
  #endif
 0866: 
+0867:     shader_brightness24_inplace_c(pixels3d(surface_), shift_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 867, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 867, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 867, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.shift_ = __pyx_v_shift_;
  __pyx_f_12PygameShader_6shader_shader_brightness24_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0868: 
 0869: 
+0870: cpdef inline void brightness_exclude(
static PyObject *__pyx_pw_12PygameShader_6shader_45brightness_exclude(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_brightness_exclude(PyObject *__pyx_v_surface_, float __pyx_v_shift_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_brightness_exclude *__pyx_optional_args) {
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.brightness_exclude", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_45brightness_exclude(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_44brightness_exclude[] = "\n\n    INCREASE/DECREASE A SURFACE BRIGHTNESS (OPTIONAL EXCLUDE COLOR)\n    \n    The optional setting (color_) allow you to select a color that will not \n    be included in the processing. This can be useful if you know the background \n    color RGB values and do not wish the background to undergo a change in brightness    \n    \n    Parameter shift_ is a float value in range [ -1.0 ... 1.0]. with +1.0 for the \n    maximum brightness. A value of 0.0 will not perform any changes to the original \n    surface\n   \n    Parameter color_ is a tuple of RGB colors e.g (1, 1, 1) \n\n    :param surface_ : pygame.surface; \n    :param shift_   : float must be in range [ -1.0 ... 1.0 ]\n    :param color_   : tuple RGB to be excluded from the process\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_45brightness_exclude(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  PyObject *__pyx_v_color_ = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_exclude (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,&__pyx_n_s_color,0};
    PyObject* values[3] = {0,0,0};
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_44brightness_exclude(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_, PyObject *__pyx_v_color_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_exclude", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.color_ = __pyx_v_color_;
  __pyx_f_12PygameShader_6shader_brightness_exclude(__pyx_v_surface_, __pyx_v_shift_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 870, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.brightness_exclude", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0871:         object surface_,
 0872:         float shift_,
+0873:         color_=(0, 0, 0)
  PyObject *__pyx_v_color_ = ((PyObject *)__pyx_tuple__9);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_exclude", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_color_ = __pyx_optional_args->color_;
    }
  }
/* … */
    values[2] = ((PyObject *)__pyx_tuple__9);
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("brightness_exclude", 0, 2, 3, 1); __PYX_ERR(1, 870, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_color);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "brightness_exclude") < 0)) __PYX_ERR(1, 870, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 872, __pyx_L3_error)
    __pyx_v_color_ = values[2];
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("brightness_exclude", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 870, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.brightness_exclude", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_44brightness_exclude(__pyx_self, __pyx_v_surface_, __pyx_v_shift_, __pyx_v_color_);
/* … */
  __pyx_tuple__9 = PyTuple_Pack(3, __pyx_int_0, __pyx_int_0, __pyx_int_0); if (unlikely(!__pyx_tuple__9)) __PYX_ERR(1, 873, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__9);
  __Pyx_GIVEREF(__pyx_tuple__9);
 0874: ):
 0875:     """
 0876: 
 0877:     INCREASE/DECREASE A SURFACE BRIGHTNESS (OPTIONAL EXCLUDE COLOR)
 0878:     
 0879:     The optional setting (color_) allow you to select a color that will not 
 0880:     be included in the processing. This can be useful if you know the background 
 0881:     color RGB values and do not wish the background to undergo a change in brightness    
 0882:     
 0883:     Parameter shift_ is a float value in range [ -1.0 ... 1.0]. with +1.0 for the 
 0884:     maximum brightness. A value of 0.0 will not perform any changes to the original 
 0885:     surface
 0886:    
 0887:     Parameter color_ is a tuple of RGB colors e.g (1, 1, 1) 
 0888: 
 0889:     :param surface_ : pygame.surface; 
 0890:     :param shift_   : float must be in range [ -1.0 ... 1.0 ]
 0891:     :param color_   : tuple RGB to be excluded from the process
 0892:     :return         : void
 0893:     """
+0894:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 894, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 894, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 894, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0895:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 895, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 894, __pyx_L1_error)
    }
  }
  #endif
 0896: 
+0897:     if shift_ == 0.0:
  __pyx_t_3 = ((__pyx_v_shift_ == 0.0) != 0);
  if (__pyx_t_3) {
/* … */
  }
+0898:         return
    goto __pyx_L0;
 0899: 
+0900:     assert -1.0 <= shift_ <= 1.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift__must_be_in_range);
      __PYX_ERR(1, 900, __pyx_L1_error)
    }
  }
  #endif
 0901:         "Argument shift_ must be in range[-1.0 ... 1.0]"
 0902: 
+0903:     shader_brightness24_exclude_inplace_c(pixels3d(surface_), shift_, color_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 903, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 903, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 903, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 2;
  __pyx_t_6.shift_ = __pyx_v_shift_;
  __pyx_t_6.color_ = __pyx_v_color_;
  __pyx_f_12PygameShader_6shader_shader_brightness24_exclude_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0904: 
 0905: 
 0906: 
+0907: cpdef inline void brightness_bpf(
static PyObject *__pyx_pw_12PygameShader_6shader_47brightness_bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_brightness_bpf(PyObject *__pyx_v_surface_, float __pyx_v_shift_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_brightness_bpf *__pyx_optional_args) {
  unsigned char __pyx_v_bpf_threshold = ((unsigned char)64);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_bpf", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_bpf_threshold = __pyx_optional_args->bpf_threshold;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.brightness_bpf", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_47brightness_bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_46brightness_bpf[] = "\n\n    INCREASE/DECREASE SURFACE BRIGHTNESS \n\n    bpf_threshold is an integer value in range [0..255] that \n    determines the pixels threshold for the brightness algorithm. \n    The sum RGB below this threshold will not be included in the process  \n    R + G + B < Threshold \n\n\n    :param surface_: Pygame.Surface compatible 24 - 32 bit \n\n    :param shift_: float, must be in range [-1.00 ... +1.00]\n\n    :param bpf_threshold : integer value in range [0 ... 255].\n    threshold RGB. Values R+G+B < threshold will not be included in the process\n    :return: void \n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_47brightness_bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  unsigned char __pyx_v_bpf_threshold;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_bpf (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,&__pyx_n_s_bpf_threshold,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("brightness_bpf", 0, 2, 3, 1); __PYX_ERR(1, 907, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bpf_threshold);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "brightness_bpf") < 0)) __PYX_ERR(1, 907, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 909, __pyx_L3_error)
    if (values[2]) {
      __pyx_v_bpf_threshold = __Pyx_PyInt_As_unsigned_char(values[2]); if (unlikely((__pyx_v_bpf_threshold == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 910, __pyx_L3_error)
    } else {
      __pyx_v_bpf_threshold = ((unsigned char)64);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("brightness_bpf", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 907, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.brightness_bpf", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_46brightness_bpf(__pyx_self, __pyx_v_surface_, __pyx_v_shift_, __pyx_v_bpf_threshold);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_46brightness_bpf(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_, unsigned char __pyx_v_bpf_threshold) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_bpf", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.bpf_threshold = __pyx_v_bpf_threshold;
  __pyx_f_12PygameShader_6shader_brightness_bpf(__pyx_v_surface_, __pyx_v_shift_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 907, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.brightness_bpf", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0908:         object surface_,
 0909:         float shift_,
 0910:         unsigned char bpf_threshold = 64):
 0911:     """
 0912: 
 0913:     INCREASE/DECREASE SURFACE BRIGHTNESS 
 0914: 
 0915:     bpf_threshold is an integer value in range [0..255] that 
 0916:     determines the pixels threshold for the brightness algorithm. 
 0917:     The sum RGB below this threshold will not be included in the process  
 0918:     R + G + B < Threshold 
 0919: 
 0920: 
 0921:     :param surface_: Pygame.Surface compatible 24 - 32 bit 
 0922: 
 0923:     :param shift_: float, must be in range [-1.00 ... +1.00]
 0924: 
 0925:     :param bpf_threshold : integer value in range [0 ... 255].
 0926:     threshold RGB. Values R+G+B < threshold will not be included in the process
 0927:     :return: void 
 0928: 
 0929:     """
+0930:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 930, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 930, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 930, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0931:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 931, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 930, __pyx_L1_error)
    }
  }
  #endif
 0932: 
+0933:     assert -1.0 <= shift_ <= 1.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift_must_be_in_range);
      __PYX_ERR(1, 933, __pyx_L1_error)
    }
  }
  #endif
 0934:         "Argument shift must be in range[-1.0 ... 1.0]"
 0935: 
+0936:     shader_brightness24_bpf_c(pixels3d(surface_), shift_, bpf_threshold)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 936, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 936, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 936, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 2;
  __pyx_t_6.shift_ = __pyx_v_shift_;
  __pyx_t_6.bpf_treshold_ = __pyx_v_bpf_threshold;
  __pyx_f_12PygameShader_6shader_shader_brightness24_bpf_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0937: 
 0938: 
+0939: cpdef inline void brightness_model(
static PyObject *__pyx_pw_12PygameShader_6shader_49brightness_model(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_brightness_model(PyObject *__pyx_v_surface_, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_rgb_to_hsl_model, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_model", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.brightness_model", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_49brightness_model(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_48brightness_model[] = "\n    \n    SHADER BRIGHTNESS (EXCLUDE A SPECIFIC COLOR FROM THE PROCESS, DEFAULT BLACK COLOR)\n\n    This shader control the pygame display brightness level\n    It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb\n\n    e.g:\n    brightness_exclude(surface, 0.2)\n    \n    :param surface_ : pygame.surface; compatible 24 - 32 bit \n    :param shift_   : float in range [-1.0 ... 1.0 ]\n    :param rgb_to_hsl_model : numpy.ndarray shape (256, 256, 256, 3)\n    :return : void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_49brightness_model(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  __Pyx_memviewslice __pyx_v_rgb_to_hsl_model = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_model (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,&__pyx_n_s_rgb_to_hsl_model,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("brightness_model", 1, 3, 3, 1); __PYX_ERR(1, 939, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rgb_to_hsl_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("brightness_model", 1, 3, 3, 2); __PYX_ERR(1, 939, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "brightness_model") < 0)) __PYX_ERR(1, 939, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 941, __pyx_L3_error)
    __pyx_v_rgb_to_hsl_model = __Pyx_PyObject_to_MemoryviewSlice_dsdsdsds_float(values[2], PyBUF_WRITABLE); if (unlikely(!__pyx_v_rgb_to_hsl_model.memview)) __PYX_ERR(1, 942, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("brightness_model", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 939, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.brightness_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_48brightness_model(__pyx_self, __pyx_v_surface_, __pyx_v_shift_, __pyx_v_rgb_to_hsl_model);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_48brightness_model(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_rgb_to_hsl_model) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("brightness_model", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_rgb_to_hsl_model.memview)) { __Pyx_RaiseUnboundLocalError("rgb_to_hsl_model"); __PYX_ERR(1, 939, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_brightness_model(__pyx_v_surface_, __pyx_v_shift_, __pyx_v_rgb_to_hsl_model, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 939, __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("PygameShader.shader.brightness_model", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_to_hsl_model, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0940:         object surface_,
 0941:         float shift_,
 0942:         float [:, :, :, :] rgb_to_hsl_model
 0943: ):
 0944:     """
 0945:     
 0946:     SHADER BRIGHTNESS (EXCLUDE A SPECIFIC COLOR FROM THE PROCESS, DEFAULT BLACK COLOR)
 0947: 
 0948:     This shader control the pygame display brightness level
 0949:     It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb
 0950: 
 0951:     e.g:
 0952:     brightness_exclude(surface, 0.2)
 0953:     
 0954:     :param surface_ : pygame.surface; compatible 24 - 32 bit 
 0955:     :param shift_   : float in range [-1.0 ... 1.0 ]
 0956:     :param rgb_to_hsl_model : numpy.ndarray shape (256, 256, 256, 3)
 0957:     :return : void 
 0958:     """
+0959:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 959, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 959, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 959, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0960:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 960, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 959, __pyx_L1_error)
    }
  }
  #endif
 0961: 
+0962:     warnings.warn("Deprecated version, use shader_brightness_24_inplace (fastest version)",
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_warnings); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_warn); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* … */
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_tuple__10, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
/* … */
  __pyx_tuple__10 = PyTuple_Pack(2, __pyx_kp_s_Deprecated_version_use_shader_br, __pyx_builtin_DeprecationWarning); if (unlikely(!__pyx_tuple__10)) __PYX_ERR(1, 962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__10);
  __Pyx_GIVEREF(__pyx_tuple__10);
 0963:                   DeprecationWarning)
+0964:     assert -1.0 <= shift_ <= 1.0, "\nArgument shift_ must be in range [-1.0 ... 1.0]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift__must_be_in_rang);
      __PYX_ERR(1, 964, __pyx_L1_error)
    }
  }
  #endif
 0965: 
+0966:     shader_brightness_24_inplace1_c(pixels3d(surface_), shift_, rgb_to_hsl_model)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 966, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 966, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 966, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_brightness_24_inplace1_c(__pyx_t_5, __pyx_v_shift_, __pyx_v_rgb_to_hsl_model);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0967: 
 0968: 
 0969: 
 0970: 
+0971: cpdef inline void saturation(object surface_, float shift_):
static PyObject *__pyx_pw_12PygameShader_6shader_51saturation(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_saturation(PyObject *__pyx_v_surface_, float __pyx_v_shift_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("saturation", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.saturation", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_51saturation(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_50saturation[] = "\n    SHADER SATURATION\n\n    This shader control the saturation level of the pygame display or surface/texture\n\n    e.g:\n    saturation(surface, 0.2)\n    \n    \n    :param surface_: pygame.Surface; compatible 24 - 32 bit\n    :param shift_  : float must be in range [ -1.0 ... 1.0] \n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_51saturation(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_shift_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("saturation (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_shift,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shift)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("saturation", 1, 2, 2, 1); __PYX_ERR(1, 971, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "saturation") < 0)) __PYX_ERR(1, 971, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_shift_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_shift_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 971, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("saturation", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 971, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.saturation", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_50saturation(__pyx_self, __pyx_v_surface_, __pyx_v_shift_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_50saturation(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_shift_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("saturation", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_saturation(__pyx_v_surface_, __pyx_v_shift_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 971, __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("PygameShader.shader.saturation", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0972:     """
 0973:     SHADER SATURATION
 0974: 
 0975:     This shader control the saturation level of the pygame display or surface/texture
 0976: 
 0977:     e.g:
 0978:     saturation(surface, 0.2)
 0979:     
 0980:     
 0981:     :param surface_: pygame.Surface; compatible 24 - 32 bit
 0982:     :param shift_  : float must be in range [ -1.0 ... 1.0] 
 0983:     :return:
 0984:     """
+0985:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 985, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+0986:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 986, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 985, __pyx_L1_error)
    }
  }
  #endif
 0987: 
+0988:     assert -1.0 <= shift_ <= 1.0, "\nArgument shift_ must be in range [-1.0 ... 1.0]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_3) {
      __pyx_t_3 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_3 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift__must_be_in_rang);
      __PYX_ERR(1, 988, __pyx_L1_error)
    }
  }
  #endif
 0989: 
+0990:     shader_saturation_array24_inplace_c(pixels3d(surface_), shift_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 990, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_saturation_array24_inplace_c(__pyx_t_5, __pyx_v_shift_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 0991: 
 0992: 
 0993: 
+0994: cpdef inline void heatwave_vertical(
static PyObject *__pyx_pw_12PygameShader_6shader_53heatwave_vertical(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_heatwave_vertical(PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_mask, float __pyx_v_factor_, float __pyx_v_center_, float __pyx_v_sigma_, float __pyx_v_mu_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatwave_vertical", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.heatwave_vertical", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_53heatwave_vertical(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_52heatwave_vertical[] = "\n\n    APPLY A GAUSSIAN TRANSFORMATION TO A SURFACE\n\n    This effect can be use to simulate air turbulence or heat flow/convection\n\n    :param surface_  : pygame.Surface; compatible 24 - 32 bit \n    :param mask      : numpy.ndarray shape (x, y) uint8, (values 255 or 0).\n                       Apply transformation to the original array\n                       if the value @(x, y) is 255 else remain unchanged.\n    :param factor_   : Control the maximum of the gaussian equation.\n                       No transformation if factor_ equal zero\n    :param center_   : Control the center of the gaussian equation (if center_ equal zero,\n                       the Gauss equation is centered\n                       at x=0 and maximum is 0.4 with amplitude_ = 1.0)\n    :param sigma_    : float; sigma value of the gauss equation\n    :param mu_       : float; mu value of the gauss equation\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_53heatwave_vertical(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  __Pyx_memviewslice __pyx_v_mask = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_factor_;
  float __pyx_v_center_;
  float __pyx_v_sigma_;
  float __pyx_v_mu_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatwave_vertical (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_mask,&__pyx_n_s_factor,&__pyx_n_s_center,&__pyx_n_s_sigma,&__pyx_n_s_mu,0};
    PyObject* values[6] = {0,0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_mask)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, 1); __PYX_ERR(1, 994, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, 2); __PYX_ERR(1, 994, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_center)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, 3); __PYX_ERR(1, 994, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sigma)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, 4); __PYX_ERR(1, 994, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (likely((values[5] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_mu)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, 5); __PYX_ERR(1, 994, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "heatwave_vertical") < 0)) __PYX_ERR(1, 994, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 6) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
      values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
      values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_mask = __Pyx_PyObject_to_MemoryviewSlice_dsds_unsigned_char(values[1], PyBUF_WRITABLE); if (unlikely(!__pyx_v_mask.memview)) __PYX_ERR(1, 996, __pyx_L3_error)
    __pyx_v_factor_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_factor_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 997, __pyx_L3_error)
    __pyx_v_center_ = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_center_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 998, __pyx_L3_error)
    __pyx_v_sigma_ = __pyx_PyFloat_AsFloat(values[4]); if (unlikely((__pyx_v_sigma_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 999, __pyx_L3_error)
    __pyx_v_mu_ = __pyx_PyFloat_AsFloat(values[5]); if (unlikely((__pyx_v_mu_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1000, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("heatwave_vertical", 1, 6, 6, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 994, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.heatwave_vertical", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_52heatwave_vertical(__pyx_self, __pyx_v_surface_, __pyx_v_mask, __pyx_v_factor_, __pyx_v_center_, __pyx_v_sigma_, __pyx_v_mu_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_52heatwave_vertical(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_mask, float __pyx_v_factor_, float __pyx_v_center_, float __pyx_v_sigma_, float __pyx_v_mu_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatwave_vertical", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_mask.memview)) { __Pyx_RaiseUnboundLocalError("mask"); __PYX_ERR(1, 994, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_heatwave_vertical(__pyx_v_surface_, __pyx_v_mask, __pyx_v_factor_, __pyx_v_center_, __pyx_v_sigma_, __pyx_v_mu_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 994, __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("PygameShader.shader.heatwave_vertical", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_mask, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 0995:         object surface_,
 0996:         unsigned char [:, :] mask,
 0997:         float factor_,
 0998:         float center_,
 0999:         float sigma_,
 1000:         float mu_):
 1001:     """
 1002: 
 1003:     APPLY A GAUSSIAN TRANSFORMATION TO A SURFACE
 1004: 
 1005:     This effect can be use to simulate air turbulence or heat flow/convection
 1006: 
 1007:     :param surface_  : pygame.Surface; compatible 24 - 32 bit 
 1008:     :param mask      : numpy.ndarray shape (x, y) uint8, (values 255 or 0).
 1009:                        Apply transformation to the original array
 1010:                        if the value @(x, y) is 255 else remain unchanged.
 1011:     :param factor_   : Control the maximum of the gaussian equation.
 1012:                        No transformation if factor_ equal zero
 1013:     :param center_   : Control the center of the gaussian equation (if center_ equal zero,
 1014:                        the Gauss equation is centered
 1015:                        at x=0 and maximum is 0.4 with amplitude_ = 1.0)
 1016:     :param sigma_    : float; sigma value of the gauss equation
 1017:     :param mu_       : float; mu value of the gauss equation
 1018:     """
+1019:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1019, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1019, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1019, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1020:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1020, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1019, __pyx_L1_error)
    }
  }
  #endif
 1021: 
+1022:     assert PyObject_IsInstance(mask, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_mask, 2, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1022, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1022, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1022, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1022, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1022, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1023:         "\nArgument mask must be a numpy.array or memoryview type, got %s " % type(mask)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_mask, 2, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1023, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_mask_must_be_a_numpy_a, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1023, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1022, __pyx_L1_error)
    }
  }
  #endif
 1024: 
+1025:     shader_heatwave24_vertical_inplace_c(pixels3d(surface_), mask, factor_, center_, sigma_, mu_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1025, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1025, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1025, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_heatwave24_vertical_inplace_c(__pyx_t_5, __pyx_v_mask, __pyx_v_factor_, __pyx_v_center_, __pyx_v_sigma_, __pyx_v_mu_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1026: 
 1027: 
 1028: 
+1029: cpdef inline void horizontal_glitch(
static PyObject *__pyx_pw_12PygameShader_6shader_55horizontal_glitch(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_horizontal_glitch(PyObject *__pyx_v_surface_, float __pyx_v_rad1_, float __pyx_v_frequency_, float __pyx_v_amplitude_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("horizontal_glitch", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.horizontal_glitch", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_55horizontal_glitch(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_54horizontal_glitch[] = "\n    SHADER GLITCH EFFECT\n\n    Deform the pygame display to create a glitch effect\n\n    :param surface_  : pygame.Surface; compatible 24 - 32 bit \n    :param rad1_     : float; Angle in radians, this value control the angle variation over the time\n    :param frequency_: float; signal frequency, factor that amplify the angle variation\n    :param amplitude_: float; cos amplitude value\n    :return: void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_55horizontal_glitch(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  float __pyx_v_rad1_;
  float __pyx_v_frequency_;
  float __pyx_v_amplitude_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("horizontal_glitch (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_rad1,&__pyx_n_s_frequency,&__pyx_n_s_amplitude,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rad1)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("horizontal_glitch", 1, 4, 4, 1); __PYX_ERR(1, 1029, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_frequency)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("horizontal_glitch", 1, 4, 4, 2); __PYX_ERR(1, 1029, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_amplitude)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("horizontal_glitch", 1, 4, 4, 3); __PYX_ERR(1, 1029, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "horizontal_glitch") < 0)) __PYX_ERR(1, 1029, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_rad1_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_rad1_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1031, __pyx_L3_error)
    __pyx_v_frequency_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_frequency_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1032, __pyx_L3_error)
    __pyx_v_amplitude_ = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_amplitude_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1033, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("horizontal_glitch", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1029, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.horizontal_glitch", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_54horizontal_glitch(__pyx_self, __pyx_v_surface_, __pyx_v_rad1_, __pyx_v_frequency_, __pyx_v_amplitude_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_54horizontal_glitch(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, float __pyx_v_rad1_, float __pyx_v_frequency_, float __pyx_v_amplitude_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("horizontal_glitch", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_horizontal_glitch(__pyx_v_surface_, __pyx_v_rad1_, __pyx_v_frequency_, __pyx_v_amplitude_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1029, __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("PygameShader.shader.horizontal_glitch", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1030:         object surface_,
 1031:         float rad1_,
 1032:         float frequency_,
 1033:         float amplitude_
 1034: ):
 1035:     """
 1036:     SHADER GLITCH EFFECT
 1037: 
 1038:     Deform the pygame display to create a glitch effect
 1039: 
 1040:     :param surface_  : pygame.Surface; compatible 24 - 32 bit 
 1041:     :param rad1_     : float; Angle in radians, this value control the angle variation over the time
 1042:     :param frequency_: float; signal frequency, factor that amplify the angle variation
 1043:     :param amplitude_: float; cos amplitude value
 1044:     :return: void
 1045:     """
+1046:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1046, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1046, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1046, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1047:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1047, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1046, __pyx_L1_error)
    }
  }
  #endif
 1048: 
+1049:     shader_horizontal_glitch24_inplace_c(pixels3d(surface_), rad1_, frequency_, amplitude_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1049, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_horizontal_glitch24_inplace_c(__pyx_t_5, __pyx_v_rad1_, __pyx_v_frequency_, __pyx_v_amplitude_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1050: 
 1051: 
 1052: 
+1053: cpdef inline void bpf(object surface_, int threshold = 128):
static PyObject *__pyx_pw_12PygameShader_6shader_57bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_bpf(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_bpf *__pyx_optional_args) {
  int __pyx_v_threshold = ((int)0x80);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bpf", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold = __pyx_optional_args->threshold;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.bpf", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_57bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_56bpf[] = "\n    \n    SHADER BRIGHT PASS FILTER (INPLACE)\n\n    Conserve only the brightest pixels in a surface\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :param threshold: integer; Bright pass threshold default 128\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_57bpf(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_threshold;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bpf (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_threshold_2,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_threshold_2);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "bpf") < 0)) __PYX_ERR(1, 1053, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_threshold = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_threshold == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1053, __pyx_L3_error)
    } else {
      __pyx_v_threshold = ((int)0x80);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("bpf", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1053, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.bpf", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_56bpf(__pyx_self, __pyx_v_surface_, __pyx_v_threshold);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_56bpf(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_threshold) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bpf", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.threshold = __pyx_v_threshold;
  __pyx_f_12PygameShader_6shader_bpf(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1053, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.bpf", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1054:     """
 1055:     
 1056:     SHADER BRIGHT PASS FILTER (INPLACE)
 1057: 
 1058:     Conserve only the brightest pixels in a surface
 1059: 
 1060:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 1061:     :param threshold: integer; Bright pass threshold default 128
 1062:     :return: void 
 1063:     """
+1064:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1064, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1064, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1064, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1065:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1065, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1064, __pyx_L1_error)
    }
  }
  #endif
 1066: 
+1067:     shader_bpf24_inplace_c(pixels3d(surface_), threshold)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1067, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1067, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1067, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.threshold = __pyx_v_threshold;
  __pyx_f_12PygameShader_6shader_shader_bpf24_inplace_c(__pyx_t_5, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1068: 
 1069: 
 1070: 
+1071: cpdef inline void bloom(object surface_, int threshold_, bint fast_=False):
static PyObject *__pyx_pw_12PygameShader_6shader_59bloom(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_bloom(PyObject *__pyx_v_surface_, int __pyx_v_threshold_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_bloom *__pyx_optional_args) {
  int __pyx_v_fast_ = ((int)0);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bloom", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_fast_ = __pyx_optional_args->fast_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.bloom", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_59bloom(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_58bloom[] = "\n    \n    CREATE A BLOOM EFFECT\n\n    * Surface must be a pygame Surface 24-32 bit format\n\n    :param surface_     : pygame.Surface; Game display or texture\n    :param threshold_   : integer; Threshold value uint8 in range [0 ... 255].\n                          The threshold value is used by a bright\n                          pass filter to determine the bright pixels above the given threshold.\n                          Below 128 the bloom effect will be more\n                          noticeable and above 128 a bit less.\n    :param fast_        : bool; True | False; If True the bloom effect will be approximated\n                          and only the x16 subsurface\n                          will be processed to maximize the overall processing time, \n                          default is False).\n    :return             : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_59bloom(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_threshold_;
  int __pyx_v_fast_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bloom (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_threshold,&__pyx_n_s_fast,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_threshold)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("bloom", 0, 2, 3, 1); __PYX_ERR(1, 1071, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fast);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "bloom") < 0)) __PYX_ERR(1, 1071, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_threshold_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_threshold_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1071, __pyx_L3_error)
    if (values[2]) {
      __pyx_v_fast_ = __Pyx_PyObject_IsTrue(values[2]); if (unlikely((__pyx_v_fast_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1071, __pyx_L3_error)
    } else {
      __pyx_v_fast_ = ((int)0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("bloom", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1071, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.bloom", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_58bloom(__pyx_self, __pyx_v_surface_, __pyx_v_threshold_, __pyx_v_fast_);

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_58bloom(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_threshold_, int __pyx_v_fast_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bloom", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.fast_ = __pyx_v_fast_;
  __pyx_f_12PygameShader_6shader_bloom(__pyx_v_surface_, __pyx_v_threshold_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1071, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.bloom", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1072:     """
 1073:     
 1074:     CREATE A BLOOM EFFECT
 1075: 
 1076:     * Surface must be a pygame Surface 24-32 bit format
 1077: 
 1078:     :param surface_     : pygame.Surface; Game display or texture
 1079:     :param threshold_   : integer; Threshold value uint8 in range [0 ... 255].
 1080:                           The threshold value is used by a bright
 1081:                           pass filter to determine the bright pixels above the given threshold.
 1082:                           Below 128 the bloom effect will be more
 1083:                           noticeable and above 128 a bit less.
 1084:     :param fast_        : bool; True | False; If True the bloom effect will be approximated
 1085:                           and only the x16 subsurface
 1086:                           will be processed to maximize the overall processing time, 
 1087:                           default is False).
 1088:     :return             : void
 1089:     
 1090:     """
+1091:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1091, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1091, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1091, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1092:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1092, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1091, __pyx_L1_error)
    }
  }
  #endif
 1093: 
+1094:     shader_bloom_effect_array24_c(surface_, threshold_, fast_)
  __pyx_t_4.__pyx_n = 1;
  __pyx_t_4.fast_ = __pyx_v_fast_;
  __pyx_f_12PygameShader_6shader_shader_bloom_effect_array24_c(__pyx_v_surface_, __pyx_v_threshold_, &__pyx_t_4); 
 1095: 
 1096: 
 1097: 
+1098: cpdef inline fisheye_footprint(int w, int h):
static PyObject *__pyx_pw_12PygameShader_6shader_61fisheye_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_fisheye_footprint(int __pyx_v_w, int __pyx_v_h, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye_footprint", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("PygameShader.shader.fisheye_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_61fisheye_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_60fisheye_footprint[] = "\n\n    :param w: integer; width of the fisheye model\n    :param h: integer; height of the fisheye model\n    :return: Return a numpy.ndarray type (w, h, 2) representing the fisheye model (coordinates\n    of all surface pixels passing through the fisheye lens model)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_61fisheye_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_w;
  int __pyx_v_h;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye_footprint (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_w,&__pyx_n_s_h,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_w)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_h)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fisheye_footprint", 1, 2, 2, 1); __PYX_ERR(1, 1098, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fisheye_footprint") < 0)) __PYX_ERR(1, 1098, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_w = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_w == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1098, __pyx_L3_error)
    __pyx_v_h = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_h == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1098, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("fisheye_footprint", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1098, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.fisheye_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_60fisheye_footprint(__pyx_self, __pyx_v_w, __pyx_v_h);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_60fisheye_footprint(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_w, int __pyx_v_h) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye_footprint", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_fisheye_footprint(__pyx_v_w, __pyx_v_h, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1098, __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("PygameShader.shader.fisheye_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1099:     """
 1100: 
 1101:     :param w: integer; width of the fisheye model
 1102:     :param h: integer; height of the fisheye model
 1103:     :return: Return a numpy.ndarray type (w, h, 2) representing the fisheye model (coordinates
 1104:     of all surface pixels passing through the fisheye lens model)
 1105:     """
+1106:     return shader_fisheye24_footprint_c(w, h)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_shader_fisheye24_footprint_c(__pyx_v_w, __pyx_v_h); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1106, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 1107: 
 1108: 
 1109: 
 1110: 
+1111: cpdef inline void fisheye(
static PyObject *__pyx_pw_12PygameShader_6shader_63fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_fisheye(PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_fisheye_model, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_63fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_62fisheye[] = "\n    THIS SHADER CAN BE USE TO DISPLAY THE GAME THROUGH A LENS EFFECT\n\n    Display a fisheye effect in real time given a surface referencing the\n    pixels RGB. In order to accomplish a real time calculation, \n    this algorithm is using a pre-calculated transformation stored\n    in the array fisheye_model.\n    \n    The function shader_fisheye24_footprint_c has to be called prior\n    shader_fisheye24_inplace_c in order to store the transformation values.\n\n    This shader can be applied directly to the pygame display\n\n    :param fisheye_model    : numpy.ndarray shape (width, height, 2) int32, fisheye model\n    containing the pixels\n    coordinates after the fisheye transformation\n    :return                 : void\n    \n    :param surface_      : pygame.Surface; compatible 24 - 32 bit \n    :param fisheye_model : numpy.ndarray or cython memoryview shape (width, height, 2) int32, \n                           fisheye model containing the pixels\n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_63fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  __Pyx_memviewslice __pyx_v_fisheye_model = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_fisheye_model,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fisheye_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fisheye", 1, 2, 2, 1); __PYX_ERR(1, 1111, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fisheye") < 0)) __PYX_ERR(1, 1111, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_fisheye_model = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_int(values[1], PyBUF_WRITABLE); if (unlikely(!__pyx_v_fisheye_model.memview)) __PYX_ERR(1, 1112, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("fisheye", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1111, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_62fisheye(__pyx_self, __pyx_v_surface_, __pyx_v_fisheye_model);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_62fisheye(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_fisheye_model) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fisheye", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_fisheye_model.memview)) { __Pyx_RaiseUnboundLocalError("fisheye_model"); __PYX_ERR(1, 1111, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_fisheye(__pyx_v_surface_, __pyx_v_fisheye_model, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1111, __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("PygameShader.shader.fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_fisheye_model, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1112:         object surface_, unsigned int [:, :, :] fisheye_model):
 1113:     """
 1114:     THIS SHADER CAN BE USE TO DISPLAY THE GAME THROUGH A LENS EFFECT
 1115: 
 1116:     Display a fisheye effect in real time given a surface referencing the
 1117:     pixels RGB. In order to accomplish a real time calculation, 
 1118:     this algorithm is using a pre-calculated transformation stored
 1119:     in the array fisheye_model.
 1120:     
 1121:     The function shader_fisheye24_footprint_c has to be called prior
 1122:     shader_fisheye24_inplace_c in order to store the transformation values.
 1123: 
 1124:     This shader can be applied directly to the pygame display
 1125: 
 1126:     :param fisheye_model    : numpy.ndarray shape (width, height, 2) int32, fisheye model
 1127:     containing the pixels
 1128:     coordinates after the fisheye transformation
 1129:     :return                 : void
 1130:     
 1131:     :param surface_      : pygame.Surface; compatible 24 - 32 bit 
 1132:     :param fisheye_model : numpy.ndarray or cython memoryview shape (width, height, 2) int32, 
 1133:                            fisheye model containing the pixels
 1134:     :return: void 
 1135:     """
 1136: 
 1137:     # TODO EXPERIMENT WITH ORDER = 'C'
+1138:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1138, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1138, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1138, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1139:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1139, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1138, __pyx_L1_error)
    }
  }
  #endif
 1140: 
+1141:     assert PyObject_IsInstance(fisheye_model, (cython.view.memoryview, numpy.ndarray)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1141, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1141, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1141, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1141, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_4);
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1141, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
 1142:         "\nArgument fisheye_model must be a numpy.ndarray or a cython.view.memoryview  type, " \
+1143:         "got %s " % type(fisheye_model)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1143, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_fisheye_model_must_be, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1143, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1141, __pyx_L1_error)
    }
  }
  #endif
 1144: 
+1145:     shader_fisheye24_inplace_c(pixels3d(surface_), fisheye_model)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1145, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1145, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1145, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_fisheye24_inplace_c(__pyx_t_5, __pyx_v_fisheye_model);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1146: 
 1147: 
 1148: 
 1149: # TODO DOC
+1150: cpdef inline tuple rain_footprint(int w, int h):
static PyObject *__pyx_pw_12PygameShader_6shader_65rain_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_rain_footprint(int __pyx_v_w, int __pyx_v_h, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_footprint", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("PygameShader.shader.rain_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_65rain_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_64rain_footprint[] = "\n    \n    CREATE A FISH EYE LENS DEFORMATION MAP/TEXTURE\n\n    * This function create a texture and its equivalent numpy.ndarray containing the coordinates\n      for each pixels after deformation.\n    * This method must be called once outside of your game main loop\n    * The model can be re-use to display your video game animation without being re-calculated for\n      each frame. This method allow a high FPS rate\n\n    :param w    : integer; Width of the fish eye effect\n    :param h    : integer; height of the fish eye effect\n    :return     : Pygame Surface representing the fish-eye effect and its\n                  equivalent numpy.ndarray\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_65rain_footprint(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_w;
  int __pyx_v_h;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_footprint (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_w,&__pyx_n_s_h,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_w)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_h)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("rain_footprint", 1, 2, 2, 1); __PYX_ERR(1, 1150, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rain_footprint") < 0)) __PYX_ERR(1, 1150, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_w = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_w == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1150, __pyx_L3_error)
    __pyx_v_h = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_h == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1150, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("rain_footprint", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1150, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.rain_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_64rain_footprint(__pyx_self, __pyx_v_w, __pyx_v_h);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_64rain_footprint(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_w, int __pyx_v_h) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_footprint", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_rain_footprint(__pyx_v_w, __pyx_v_h, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1150, __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("PygameShader.shader.rain_footprint", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1151:     """
 1152:     
 1153:     CREATE A FISH EYE LENS DEFORMATION MAP/TEXTURE
 1154: 
 1155:     * This function create a texture and its equivalent numpy.ndarray containing the coordinates
 1156:       for each pixels after deformation.
 1157:     * This method must be called once outside of your game main loop
 1158:     * The model can be re-use to display your video game animation without being re-calculated for
 1159:       each frame. This method allow a high FPS rate
 1160: 
 1161:     :param w    : integer; Width of the fish eye effect
 1162:     :param h    : integer; height of the fish eye effect
 1163:     :return     : Pygame Surface representing the fish-eye effect and its
 1164:                   equivalent numpy.ndarray
 1165:     """
+1166:     return shader_rain_footprint_inplace_c(w, h)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_shader_rain_footprint_inplace_c(__pyx_v_w, __pyx_v_h); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1166, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;
  goto __pyx_L0;
 1167: 
 1168: 
 1169: 
 1170: 
 1171: # TODO DOC
+1172: cpdef inline void rain_fisheye(
static PyObject *__pyx_pw_12PygameShader_6shader_67rain_fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_rain_fisheye(PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_rain_fisheye_model, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_fisheye", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.rain_fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_67rain_fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_66rain_fisheye[] = "\n    THIS SHADER CAN BE USED TO SIMULATE RAIN DROPLET OR BUBBLE DISPLAYED ON THE TOP OF\n    THE SCREEN SURFACE.\n\n    Both surface and rain_fisheye_model must have the exact same size\n\n    1) Always call the method shader_rain_footprint_inplace_c before the main loop.\n       The transformation model doesn't have to be calculated every frames.\n       The above method will generate a pygame texture (24bit) containing the location\n       of each pixels after deformation. It does also return a numpy.ndarray equivalent\n       pixel format that can be used instead of the surface if needed.\n\n    It uses a fish eye lens deformation to reproduce the deformed background image onto\n    the final image. The operation apply inplace and the surface referenced by the rgb_array_\n    will be modified directly.\n    The fish-eye lens deformation will recreate you game scene into the rain droplet or bubble\n    and create the illusion of animation inside the bubble.\n\n    * This shader cannot be applied directly to the pygame display as the array passed to the\n    function is a scaled format of the pygame.display (copy not referencing directly the\n    surface pixels)\n\n    * This algorithm use a pre-calculated fish-eye lens deformation model to boost the overall\n    FPS performances, the texture pixel is then transformed with the model without any intensive\n    math calculation.\n\n    :param surface_             : pygame.Surface compatible 24 - 32 bit \n    :param rain_fisheye_model   : numpy.ndarray or memoryview type (w, h, 3) unsigned int \n                                  containing the the coordinate for each pixels\n    :return                     : void\n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_67rain_fisheye(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  __Pyx_memviewslice __pyx_v_rain_fisheye_model = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_fisheye (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_rain_fisheye_model,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rain_fisheye_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("rain_fisheye", 1, 2, 2, 1); __PYX_ERR(1, 1172, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rain_fisheye") < 0)) __PYX_ERR(1, 1172, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_rain_fisheye_model = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_int(values[1], PyBUF_WRITABLE); if (unlikely(!__pyx_v_rain_fisheye_model.memview)) __PYX_ERR(1, 1174, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("rain_fisheye", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1172, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.rain_fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_66rain_fisheye(__pyx_self, __pyx_v_surface_, __pyx_v_rain_fisheye_model);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_66rain_fisheye(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_rain_fisheye_model) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rain_fisheye", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_rain_fisheye_model.memview)) { __Pyx_RaiseUnboundLocalError("rain_fisheye_model"); __PYX_ERR(1, 1172, __pyx_L1_error) }
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_rain_fisheye(__pyx_v_surface_, __pyx_v_rain_fisheye_model, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1172, __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("PygameShader.shader.rain_fisheye", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rain_fisheye_model, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1173:         object surface_,
 1174:         unsigned int [:, :, ::1] rain_fisheye_model
 1175: ):
 1176:     """
 1177:     THIS SHADER CAN BE USED TO SIMULATE RAIN DROPLET OR BUBBLE DISPLAYED ON THE TOP OF
 1178:     THE SCREEN SURFACE.
 1179: 
 1180:     Both surface and rain_fisheye_model must have the exact same size
 1181: 
 1182:     1) Always call the method shader_rain_footprint_inplace_c before the main loop.
 1183:        The transformation model doesn't have to be calculated every frames.
 1184:        The above method will generate a pygame texture (24bit) containing the location
 1185:        of each pixels after deformation. It does also return a numpy.ndarray equivalent
 1186:        pixel format that can be used instead of the surface if needed.
 1187: 
 1188:     It uses a fish eye lens deformation to reproduce the deformed background image onto
 1189:     the final image. The operation apply inplace and the surface referenced by the rgb_array_
 1190:     will be modified directly.
 1191:     The fish-eye lens deformation will recreate you game scene into the rain droplet or bubble
 1192:     and create the illusion of animation inside the bubble.
 1193: 
 1194:     * This shader cannot be applied directly to the pygame display as the array passed to the
 1195:     function is a scaled format of the pygame.display (copy not referencing directly the
 1196:     surface pixels)
 1197: 
 1198:     * This algorithm use a pre-calculated fish-eye lens deformation model to boost the overall
 1199:     FPS performances, the texture pixel is then transformed with the model without any intensive
 1200:     math calculation.
 1201: 
 1202:     :param surface_             : pygame.Surface compatible 24 - 32 bit 
 1203:     :param rain_fisheye_model   : numpy.ndarray or memoryview type (w, h, 3) unsigned int 
 1204:                                   containing the the coordinate for each pixels
 1205:     :return                     : void
 1206: 
 1207:     """
+1208:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1208, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1208, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1208, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1209:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1209, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1208, __pyx_L1_error)
    }
  }
  #endif
 1210: 
+1211:     assert PyObject_IsInstance(rain_fisheye_model, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_rain_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1211, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1211, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1211, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1211, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1211, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
 1212:         "\nArgument rain_fisheye_model must be a " \
+1213:         "numpy.ndarray or a cython memoryview type, got %s " % type(rain_fisheye_model)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_rain_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1213, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_rain_fisheye_model_mus, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1213, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1211, __pyx_L1_error)
    }
  }
  #endif
 1214: 
+1215:     shader_rain_fisheye24_inplace_c(pixels3d(surface_), rain_fisheye_model)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1215, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1215, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1215, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_rain_fisheye24_inplace_c(__pyx_t_5, __pyx_v_rain_fisheye_model);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1216: 
 1217: 
 1218: 
 1219: 
+1220: cpdef inline void tv_scan(surface_, int space=5):
static PyObject *__pyx_pw_12PygameShader_6shader_69tv_scan(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_tv_scan(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_tv_scan *__pyx_optional_args) {
  int __pyx_v_space = ((int)5);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tv_scan", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_space = __pyx_optional_args->space;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.tv_scan", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_69tv_scan(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_68tv_scan[] = "\n    \n    SHADER CREATING A TV SCANLINE EFFECT ON PYGAME SURFACE\n\n    The space between each scanline can by adjusted with the space value.\n    The scanline intensity/colors is lower that the original image\n\n    :param surface_     : pygame.Surface compatible 24-32 bit \n    :param space        : integer; space between the lines\n    :return             : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_69tv_scan(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_space;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tv_scan (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_space,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_space);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "tv_scan") < 0)) __PYX_ERR(1, 1220, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_space = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_space == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1220, __pyx_L3_error)
    } else {
      __pyx_v_space = ((int)5);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("tv_scan", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1220, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.tv_scan", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_68tv_scan(__pyx_self, __pyx_v_surface_, __pyx_v_space);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_68tv_scan(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_space) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tv_scan", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.space = __pyx_v_space;
  __pyx_f_12PygameShader_6shader_tv_scan(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1220, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.tv_scan", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1221:     """
 1222:     
 1223:     SHADER CREATING A TV SCANLINE EFFECT ON PYGAME SURFACE
 1224: 
 1225:     The space between each scanline can by adjusted with the space value.
 1226:     The scanline intensity/colors is lower that the original image
 1227: 
 1228:     :param surface_     : pygame.Surface compatible 24-32 bit 
 1229:     :param space        : integer; space between the lines
 1230:     :return             : void
 1231:     
 1232:     """
 1233:     # TODO SCANLINE VERTICAL | HORIZONTAL
 1234: 
+1235:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1235, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1235, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1235, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1236:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1236, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1235, __pyx_L1_error)
    }
  }
  #endif
 1237: 
+1238:     assert space > 0, "Argument space cannot be <=0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_space > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_space_cannot_be_0);
      __PYX_ERR(1, 1238, __pyx_L1_error)
    }
  }
  #endif
 1239: 
+1240:     shader_tv_scanline_inplace_c(pixels3d(surface_), space)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1240, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_tv_scanline_inplace_c(__pyx_t_5, __pyx_v_space);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1241: 
 1242: 
 1243: 
 1244: 
+1245: cpdef inline void rgb_split(object surface_, int offset_=10):
static PyObject *__pyx_pw_12PygameShader_6shader_71rgb_split(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_rgb_split(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_rgb_split *__pyx_optional_args) {
  int __pyx_v_offset_ = ((int)10);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_offset_ = __pyx_optional_args->offset_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.rgb_split", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_71rgb_split(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_70rgb_split[] = "\n    \n    THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)\n    The transformation apply inplace\n\n    The original surface will be used and used for the subsurface blit operation.\n    Each channels will be blit sequentially in the following order RGB\n    Note that channel green and blue will be blit with an additional flag BLEND_RGB_ADD, to mix\n    the channel with the lower layers.\n\n    * FPS BOOST\n    In order to boost the fps frame rate the original surface to process can be downscale x2\n    and rescale after processing.\n\n\n    :param surface_ : pygame Surface to process (24bit format)\n    :param offset_  : integer; offset for (x, y) to add to each channels RGB\n    :return         : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_71rgb_split(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_offset_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_offset,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rgb_split") < 0)) __PYX_ERR(1, 1245, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_offset_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_offset_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1245, __pyx_L3_error)
    } else {
      __pyx_v_offset_ = ((int)10);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("rgb_split", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1245, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.rgb_split", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_70rgb_split(__pyx_self, __pyx_v_surface_, __pyx_v_offset_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_70rgb_split(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_offset_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.offset_ = __pyx_v_offset_;
  __pyx_f_12PygameShader_6shader_rgb_split(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1245, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.rgb_split", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1246:     """
 1247:     
 1248:     THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)
 1249:     The transformation apply inplace
 1250: 
 1251:     The original surface will be used and used for the subsurface blit operation.
 1252:     Each channels will be blit sequentially in the following order RGB
 1253:     Note that channel green and blue will be blit with an additional flag BLEND_RGB_ADD, to mix
 1254:     the channel with the lower layers.
 1255: 
 1256:     * FPS BOOST
 1257:     In order to boost the fps frame rate the original surface to process can be downscale x2
 1258:     and rescale after processing.
 1259: 
 1260: 
 1261:     :param surface_ : pygame Surface to process (24bit format)
 1262:     :param offset_  : integer; offset for (x, y) to add to each channels RGB
 1263:     :return         : void
 1264:     
 1265:     """
+1266:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1266, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1266, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1266, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1267:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1267, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1266, __pyx_L1_error)
    }
  }
  #endif
 1268: 
+1269:     shader_rgb_split_inplace_c(surface_, offset_)
  __pyx_f_12PygameShader_6shader_shader_rgb_split_inplace_c(__pyx_v_surface_, __pyx_v_offset_);
 1270: 
 1271: 
 1272: 
+1273: cpdef object rgb_split_clean(object surface_, int offset_=10):
static PyObject *__pyx_pw_12PygameShader_6shader_73rgb_split_clean(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_rgb_split_clean(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_rgb_split_clean *__pyx_optional_args) {
  int __pyx_v_offset_ = ((int)10);
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split_clean", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_offset_ = __pyx_optional_args->offset_;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.rgb_split_clean", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_73rgb_split_clean(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_72rgb_split_clean[] = "\n\n    THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)\n    The final image has a different width and height since the offset value is removed to keep only \n    the overlapping R, G, B channels \n    Setting the Offset_ to zero will have no effect to the original image.\n\n    :param surface_ : pygame Surface to process (24bit format)\n    :param offset_  : integer; offset for (x, y) to add to each channels RGB\n    :return         : void\n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_73rgb_split_clean(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_offset_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split_clean (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_offset,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_offset);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rgb_split_clean") < 0)) __PYX_ERR(1, 1273, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_offset_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_offset_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1273, __pyx_L3_error)
    } else {
      __pyx_v_offset_ = ((int)10);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("rgb_split_clean", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1273, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.rgb_split_clean", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_72rgb_split_clean(__pyx_self, __pyx_v_surface_, __pyx_v_offset_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_72rgb_split_clean(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_offset_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_split_clean", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.offset_ = __pyx_v_offset_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_rgb_split_clean(__pyx_v_surface_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1273, __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("PygameShader.shader.rgb_split_clean", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1274:     """
 1275: 
 1276:     THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)
 1277:     The final image has a different width and height since the offset value is removed to keep only 
 1278:     the overlapping R, G, B channels 
 1279:     Setting the Offset_ to zero will have no effect to the original image.
 1280: 
 1281:     :param surface_ : pygame Surface to process (24bit format)
 1282:     :param offset_  : integer; offset for (x, y) to add to each channels RGB
 1283:     :return         : void
 1284: 
 1285:     """
+1286:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1286, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1286, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1286, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1287:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1287, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1286, __pyx_L1_error)
    }
  }
  #endif
 1288: 
+1289:     assert isinstance(offset_, int), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1289, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyInt_Check(__pyx_t_2); 
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1290:         "\nArgument offset_ must be an int type, got %s" % type(offset_)
      __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1290, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_offset__must_be_an_int, ((PyObject *)Py_TYPE(__pyx_t_2))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1290, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 1289, __pyx_L1_error)
    }
  }
  #endif
 1291: 
+1292:     if offset_==0:
  __pyx_t_3 = ((__pyx_v_offset_ == 0) != 0);
  if (__pyx_t_3) {
/* … */
  }
+1293:         return surface_
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_surface_);
    __pyx_r = __pyx_v_surface_;
    goto __pyx_L0;
 1294: 
+1295:     return shader_rgb_split_c(surface_, offset_)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_shader_rgb_split_c(__pyx_v_surface_, __pyx_v_offset_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1295, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 1296: 
 1297: 
 1298: 
 1299: 
+1300: cpdef inline tuple ripple(
static PyObject *__pyx_pw_12PygameShader_6shader_75ripple(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_ripple(int __pyx_v_rows_, int __pyx_v_cols_, __Pyx_memviewslice __pyx_v_previous_, __Pyx_memviewslice __pyx_v_current_, __Pyx_memviewslice __pyx_v_array_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  Py_ssize_t __pyx_v_prev_w;
  Py_ssize_t __pyx_v_prev_h;
  Py_ssize_t __pyx_v_curr_w;
  Py_ssize_t __pyx_v_curr_h;
  Py_ssize_t __pyx_v_arr_w;
  Py_ssize_t __pyx_v_arr_h;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ripple", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_AddTraceback("PygameShader.shader.ripple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_75ripple(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_74ripple[] = "\n    \n    THIS SHADER CREATE A WATER EFFECT ON A PYGAME SURFACE\n    This version does not include any background deformation to keep a reasonable FPS rate\n\n    * NOTE this shader cannot be apply to the screen directly (screen referencing\n    pygame.display.get_surface()),\n\n    :param rows_        : integer; Array width\n    :param cols_        : integer; Array height\n    :param previous_    : numpy.ndarray type (w, h) type float; array use for the transformation\n    :param current_     : numpy.ndarray type (w, h) type float; array use for the transformation\n    :param array_       : numpy.ndarray type (w, h, 3) type unsigned char\n    :return             : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_75ripple(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_rows_;
  int __pyx_v_cols_;
  __Pyx_memviewslice __pyx_v_previous_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_current_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_array_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ripple (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_rows,&__pyx_n_s_cols,&__pyx_n_s_previous,&__pyx_n_s_current,&__pyx_n_s_array,0};
    PyObject* values[5] = {0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rows)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_cols)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("ripple", 1, 5, 5, 1); __PYX_ERR(1, 1300, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_previous)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("ripple", 1, 5, 5, 2); __PYX_ERR(1, 1300, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_current)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("ripple", 1, 5, 5, 3); __PYX_ERR(1, 1300, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_array)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("ripple", 1, 5, 5, 4); __PYX_ERR(1, 1300, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "ripple") < 0)) __PYX_ERR(1, 1300, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 5) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
      values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
    }
    __pyx_v_rows_ = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_rows_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1301, __pyx_L3_error)
    __pyx_v_cols_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_cols_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1302, __pyx_L3_error)
    __pyx_v_previous_ = __Pyx_PyObject_to_MemoryviewSlice_d_dc_float(values[2], PyBUF_WRITABLE); if (unlikely(!__pyx_v_previous_.memview)) __PYX_ERR(1, 1303, __pyx_L3_error)
    __pyx_v_current_ = __Pyx_PyObject_to_MemoryviewSlice_d_dc_float(values[3], PyBUF_WRITABLE); if (unlikely(!__pyx_v_current_.memview)) __PYX_ERR(1, 1304, __pyx_L3_error)
    __pyx_v_array_ = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(values[4], PyBUF_WRITABLE); if (unlikely(!__pyx_v_array_.memview)) __PYX_ERR(1, 1305, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("ripple", 1, 5, 5, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1300, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.ripple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_74ripple(__pyx_self, __pyx_v_rows_, __pyx_v_cols_, __pyx_v_previous_, __pyx_v_current_, __pyx_v_array_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_74ripple(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_rows_, int __pyx_v_cols_, __Pyx_memviewslice __pyx_v_previous_, __Pyx_memviewslice __pyx_v_current_, __Pyx_memviewslice __pyx_v_array_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ripple", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_previous_.memview)) { __Pyx_RaiseUnboundLocalError("previous_"); __PYX_ERR(1, 1300, __pyx_L1_error) }
  if (unlikely(!__pyx_v_current_.memview)) { __Pyx_RaiseUnboundLocalError("current_"); __PYX_ERR(1, 1300, __pyx_L1_error) }
  if (unlikely(!__pyx_v_array_.memview)) { __Pyx_RaiseUnboundLocalError("array_"); __PYX_ERR(1, 1300, __pyx_L1_error) }
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_ripple(__pyx_v_rows_, __pyx_v_cols_, __pyx_v_previous_, __pyx_v_current_, __pyx_v_array_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1300, __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("PygameShader.shader.ripple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_previous_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_current_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_array_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1301:         int rows_,
 1302:         int cols_,
 1303:         float [:, ::1] previous_,
 1304:         float [:, ::1] current_,
 1305:         unsigned char [:, :, ::1] array_
 1306: ):
 1307:     """
 1308:     
 1309:     THIS SHADER CREATE A WATER EFFECT ON A PYGAME SURFACE
 1310:     This version does not include any background deformation to keep a reasonable FPS rate
 1311: 
 1312:     * NOTE this shader cannot be apply to the screen directly (screen referencing
 1313:     pygame.display.get_surface()),
 1314: 
 1315:     :param rows_        : integer; Array width
 1316:     :param cols_        : integer; Array height
 1317:     :param previous_    : numpy.ndarray type (w, h) type float; array use for the transformation
 1318:     :param current_     : numpy.ndarray type (w, h) type float; array use for the transformation
 1319:     :param array_       : numpy.ndarray type (w, h, 3) type unsigned char
 1320:     :return             : void
 1321:     
 1322:     """
+1323:     assert PyObject_IsInstance(previous_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_previous_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_3 = 0;
    __pyx_t_4 = PyObject_IsInstance(__pyx_t_1, __pyx_t_2); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1323, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_4 != 0))) {
+1324:         "\nArgument previous must be a numpy.ndarray type got %s " % type(previous_)
      __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_previous_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1324, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_previous_must_be_a_num, ((PyObject *)Py_TYPE(__pyx_t_2))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1324, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 1323, __pyx_L1_error)
    }
  }
  #endif
 1325: 
+1326:     assert PyObject_IsInstance(current_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_current_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1326, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1326, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1326, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1326, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_3 = 0;
    __pyx_t_4 = PyObject_IsInstance(__pyx_t_1, __pyx_t_2); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1326, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_4 != 0))) {
+1327:         "\nArgument current must be a numpy.ndarray type got %s " % type(current_)
      __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_current_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1327, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_current_must_be_a_nump, ((PyObject *)Py_TYPE(__pyx_t_2))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1327, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 1326, __pyx_L1_error)
    }
  }
  #endif
 1328: 
+1329:     assert PyObject_IsInstance(array_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1329, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1329, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1329, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1329, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_3 = 0;
    __pyx_t_4 = PyObject_IsInstance(__pyx_t_1, __pyx_t_2); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1329, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_4 != 0))) {
+1330:         "\nArgument array must be a numpy.ndarray type got %s " % type(array_)
      __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1330, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_array_must_be_a_numpy, ((PyObject *)Py_TYPE(__pyx_t_2))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1330, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 1329, __pyx_L1_error)
    }
  }
  #endif
 1331: 
 1332:     cdef Py_ssize_t prev_w, prev_h
+1333:     prev_w, prev_h = previous_.shape[:2]
  __pyx_t_5 = __pyx_v_previous_.shape;
  __pyx_t_6 = (__pyx_t_5[0]);
  __pyx_t_7 = (__pyx_t_5[1]);
  __pyx_v_prev_w = __pyx_t_6;
  __pyx_v_prev_h = __pyx_t_7;
 1334: 
 1335:     cdef Py_ssize_t curr_w, curr_h
+1336:     curr_w, curr_h = current_.shape[:2]
  __pyx_t_5 = __pyx_v_current_.shape;
  __pyx_t_7 = (__pyx_t_5[0]);
  __pyx_t_6 = (__pyx_t_5[1]);
  __pyx_v_curr_w = __pyx_t_7;
  __pyx_v_curr_h = __pyx_t_6;
 1337: 
 1338:     cdef Py_ssize_t arr_w, arr_h
+1339:     arr_w, arr_h = array_.shape[:2]
  __pyx_t_5 = __pyx_v_array_.shape;
  __pyx_t_6 = (__pyx_t_5[0]);
  __pyx_t_7 = (__pyx_t_5[1]);
  __pyx_v_arr_w = __pyx_t_6;
  __pyx_v_arr_h = __pyx_t_7;
 1340: 
+1341:     assert prev_w == curr_w and prev_w == arr_w \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_8 = ((__pyx_v_prev_w == __pyx_v_curr_w) != 0);
    if (__pyx_t_8) {
    } else {
      __pyx_t_4 = __pyx_t_8;
      goto __pyx_L3_bool_binop_done;
    }
/* … */
    __pyx_t_8 = ((__pyx_v_prev_w == __pyx_v_arr_w) != 0);
    if (__pyx_t_8) {
    } else {
      __pyx_t_4 = __pyx_t_8;
      goto __pyx_L3_bool_binop_done;
    }
+1342:            and prev_h == curr_h and prev_h == arr_h, \
    __pyx_t_8 = ((__pyx_v_prev_h == __pyx_v_curr_h) != 0);
    if (__pyx_t_8) {
    } else {
      __pyx_t_4 = __pyx_t_8;
      goto __pyx_L3_bool_binop_done;
    }
    __pyx_t_8 = ((__pyx_v_prev_h == __pyx_v_arr_h) != 0);
    __pyx_t_4 = __pyx_t_8;
    __pyx_L3_bool_binop_done:;
    if (unlikely(!__pyx_t_4)) {
 1343:         "\n Array sizes mismatch (previous w: %s, h: %s; " \
+1344:         "current w: %s, h: %s; array_ w: %s, h: %s " % (prev_w, prev_h, curr_w, curr_h,
      __pyx_t_1 = PyInt_FromSsize_t(__pyx_v_prev_w); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_prev_h); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_curr_w); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_9 = PyInt_FromSsize_t(__pyx_v_curr_h); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
/* … */
      __pyx_t_12 = PyTuple_New(6); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_GIVEREF(__pyx_t_1);
      PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_1);
      __Pyx_GIVEREF(__pyx_t_2);
      PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_2);
      __Pyx_GIVEREF(__pyx_t_3);
      PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_t_3);
      __Pyx_GIVEREF(__pyx_t_9);
      PyTuple_SET_ITEM(__pyx_t_12, 3, __pyx_t_9);
      __Pyx_GIVEREF(__pyx_t_10);
      PyTuple_SET_ITEM(__pyx_t_12, 4, __pyx_t_10);
      __Pyx_GIVEREF(__pyx_t_11);
      PyTuple_SET_ITEM(__pyx_t_12, 5, __pyx_t_11);
      __pyx_t_1 = 0;
      __pyx_t_2 = 0;
      __pyx_t_3 = 0;
      __pyx_t_9 = 0;
      __pyx_t_10 = 0;
      __pyx_t_11 = 0;
      __pyx_t_11 = __Pyx_PyString_Format(__pyx_kp_s_Array_sizes_mismatch_previous_w, __pyx_t_12); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 1344, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_11);
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __PYX_ERR(1, 1341, __pyx_L1_error)
    }
  }
  #endif
+1345:         arr_w, arr_h)
      __pyx_t_10 = PyInt_FromSsize_t(__pyx_v_arr_w); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 1345, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_11 = PyInt_FromSsize_t(__pyx_v_arr_h); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 1345, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
 1346: 
+1347:     return shader_ripple_c(rows_, cols_, previous_, current_, array_)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_11 = __pyx_f_12PygameShader_6shader_shader_ripple_c(__pyx_v_rows_, __pyx_v_cols_, __pyx_v_previous_, __pyx_v_current_, __pyx_v_array_); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 1347, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_r = ((PyObject*)__pyx_t_11);
  __pyx_t_11 = 0;
  goto __pyx_L0;
 1348: 
 1349: 
 1350: 
 1351: 
+1352: cpdef inline void heatmap(object surface_, bint rgb_=True):
static PyObject *__pyx_pw_12PygameShader_6shader_77heatmap(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_heatmap(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_heatmap *__pyx_optional_args) {
  int __pyx_v_rgb_ = ((int)1);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_rgb_ = __pyx_optional_args->rgb_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.heatmap", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_77heatmap(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_76heatmap[] = "\n    TRANSFORM AN IMAGE INTO A HEATMAP EQUIVALENT\n\n    :param surface_ : pygame.Surface\n    :param rgb_     : boolean; True transformed the image into a RGB heatmap model of False (BGR)\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_77heatmap(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_rgb_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_rgb,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rgb);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "heatmap") < 0)) __PYX_ERR(1, 1352, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_rgb_ = __Pyx_PyObject_IsTrue(values[1]); if (unlikely((__pyx_v_rgb_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1352, __pyx_L3_error)
    } else {
      __pyx_v_rgb_ = ((int)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("heatmap", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1352, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.heatmap", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_76heatmap(__pyx_self, __pyx_v_surface_, __pyx_v_rgb_);

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_76heatmap(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_rgb_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.rgb_ = __pyx_v_rgb_;
  __pyx_f_12PygameShader_6shader_heatmap(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1352, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.heatmap", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1353:     """
 1354:     TRANSFORM AN IMAGE INTO A HEATMAP EQUIVALENT
 1355: 
 1356:     :param surface_ : pygame.Surface
 1357:     :param rgb_     : boolean; True transformed the image into a RGB heatmap model of False (BGR)
 1358:     :return         : void
 1359:     """
+1360:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1360, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1361:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1361, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1360, __pyx_L1_error)
    }
  }
  #endif
 1362: 
+1363:     heatmap_convert(surface_, rgb_)
  __pyx_t_4.__pyx_n = 1;
  __pyx_t_4.rgb_ = __pyx_v_rgb_;
  __pyx_f_12PygameShader_6shader_heatmap_convert(__pyx_v_surface_, 0, &__pyx_t_4); 
 1364: 
 1365: 
 1366: 
 1367: 
 1368: 
+1369: cpdef inline predator_vision(
static PyObject *__pyx_pw_12PygameShader_6shader_79predator_vision(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_predator_vision(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_predator_vision *__pyx_optional_args) {
  unsigned int __pyx_v_sobel_threshold = ((unsigned int)12);
  unsigned int __pyx_v_bpf_threshold = ((unsigned int)50);
  unsigned int __pyx_v_bloom_threshold = ((unsigned int)50);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_AddTraceback("PygameShader.shader.predator_vision", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_surface_copy);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_79predator_vision(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_78predator_vision[] = "\n    CONVERT A SURFACE OR DISPLAY TO AN EQUIVALENT PREDATOR MODE \n\n    :param surface_        : pygame.Surface; compatible 24 - 32 bit \n    :param sobel_threshold : integer; value for sobel edge detection, default is 12 \n    :param bpf_threshold   : integer; value for the bright pass filter pixel detection, \n                             default is 50\n    :param bloom_threshold : integer; Value for the bloom effect intensity default is 50\n    :param inv_colormap    : boolean True | False inverse the colormap aspect, default is False\n    :param fast            : boolean True | False for a fast process, default is False\n    :param blend           : boolean True | False; final blending mode (New in version 1.0.4)  \n    :return                : Return a pygame surface  \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_79predator_vision(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  unsigned int __pyx_v_sobel_threshold;
  unsigned int __pyx_v_bpf_threshold;
  unsigned int __pyx_v_bloom_threshold;
  int __pyx_v_inv_colormap;
  int __pyx_v_fast;
  int __pyx_v_blend;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("predator_vision (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_sobel_threshold,&__pyx_n_s_bpf_threshold,&__pyx_n_s_bloom_threshold,&__pyx_n_s_inv_colormap,&__pyx_n_s_fast_2,&__pyx_n_s_blend,0};
    PyObject* values[7] = {0,0,0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sobel_threshold);
          if (value) { values[1] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bpf_threshold);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bloom_threshold);
          if (value) { values[3] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_inv_colormap);
          if (value) { values[4] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fast_2);
          if (value) { values[5] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_blend);
          if (value) { values[6] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "predator_vision") < 0)) __PYX_ERR(1, 1369, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_sobel_threshold = __Pyx_PyInt_As_unsigned_int(values[1]); if (unlikely((__pyx_v_sobel_threshold == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1371, __pyx_L3_error)
    } else {
      __pyx_v_sobel_threshold = ((unsigned int)12);
    }
    if (values[2]) {
      __pyx_v_bpf_threshold = __Pyx_PyInt_As_unsigned_int(values[2]); if (unlikely((__pyx_v_bpf_threshold == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1372, __pyx_L3_error)
    } else {
      __pyx_v_bpf_threshold = ((unsigned int)50);
    }
    if (values[3]) {
      __pyx_v_bloom_threshold = __Pyx_PyInt_As_unsigned_int(values[3]); if (unlikely((__pyx_v_bloom_threshold == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1373, __pyx_L3_error)
    } else {
      __pyx_v_bloom_threshold = ((unsigned int)50);
    }
    if (values[4]) {
      __pyx_v_inv_colormap = __Pyx_PyObject_IsTrue(values[4]); if (unlikely((__pyx_v_inv_colormap == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1374, __pyx_L3_error)
    } else {
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_78predator_vision(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, unsigned int __pyx_v_sobel_threshold, unsigned int __pyx_v_bpf_threshold, unsigned int __pyx_v_bloom_threshold, int __pyx_v_inv_colormap, int __pyx_v_fast, int __pyx_v_blend) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("predator_vision", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 6;
  __pyx_t_2.sobel_threshold = __pyx_v_sobel_threshold;
  __pyx_t_2.bpf_threshold = __pyx_v_bpf_threshold;
  __pyx_t_2.bloom_threshold = __pyx_v_bloom_threshold;
  __pyx_t_2.inv_colormap = __pyx_v_inv_colormap;
  __pyx_t_2.fast = __pyx_v_fast;
  __pyx_t_2.blend = __pyx_v_blend;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_predator_vision(__pyx_v_surface_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1369, __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("PygameShader.shader.predator_vision", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1370:         object surface_,
 1371:         unsigned int sobel_threshold=12,
 1372:         unsigned int bpf_threshold=50,
 1373:         unsigned int bloom_threshold=50,
+1374:         bint inv_colormap=False,
  int __pyx_v_inv_colormap = ((int)0);
/* … */
      __pyx_v_inv_colormap = ((int)0);
    }
    if (values[5]) {
      __pyx_v_fast = __Pyx_PyObject_IsTrue(values[5]); if (unlikely((__pyx_v_fast == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1375, __pyx_L3_error)
    } else {
+1375:         bint fast=False,
  int __pyx_v_fast = ((int)0);
  int __pyx_v_blend = __pyx_k__11;
  PyObject *__pyx_v_surface_copy = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("predator_vision", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_sobel_threshold = __pyx_optional_args->sobel_threshold;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_bpf_threshold = __pyx_optional_args->bpf_threshold;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_bloom_threshold = __pyx_optional_args->bloom_threshold;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_inv_colormap = __pyx_optional_args->inv_colormap;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_fast = __pyx_optional_args->fast;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_blend = __pyx_optional_args->blend;
              }
            }
          }
        }
      }
    }
  }
/* … */
      __pyx_v_fast = ((int)0);
    }
    if (values[6]) {
      __pyx_v_blend = __Pyx_PyInt_As_int(values[6]); if (unlikely((__pyx_v_blend == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1376, __pyx_L3_error)
    } else {
      __pyx_v_blend = __pyx_k__11;
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("predator_vision", 0, 1, 7, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1369, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.predator_vision", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_78predator_vision(__pyx_self, __pyx_v_surface_, __pyx_v_sobel_threshold, __pyx_v_bpf_threshold, __pyx_v_bloom_threshold, __pyx_v_inv_colormap, __pyx_v_fast, __pyx_v_blend);
+1376:         int blend=pygame.BLEND_RGB_ADD
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_pygame); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __pyx_t_30 = __Pyx_PyObject_GetAttrStr(__pyx_t_33, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_30); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __pyx_k__11 = __pyx_t_7;
/* … */
  __Pyx_GetModuleGlobalName(__pyx_t_30, __pyx_n_s_pygame); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
/* … */
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_30, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_33); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1376, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_k__11 = __pyx_t_7;
 1377: ):
 1378:     """
 1379:     CONVERT A SURFACE OR DISPLAY TO AN EQUIVALENT PREDATOR MODE 
 1380: 
 1381:     :param surface_        : pygame.Surface; compatible 24 - 32 bit 
 1382:     :param sobel_threshold : integer; value for sobel edge detection, default is 12 
 1383:     :param bpf_threshold   : integer; value for the bright pass filter pixel detection, 
 1384:                              default is 50
 1385:     :param bloom_threshold : integer; Value for the bloom effect intensity default is 50
 1386:     :param inv_colormap    : boolean True | False inverse the colormap aspect, default is False
 1387:     :param fast            : boolean True | False for a fast process, default is False
 1388:     :param blend           : boolean True | False; final blending mode (New in version 1.0.4)  
 1389:     :return                : Return a pygame surface  
 1390:     """
 1391: 
+1392:     surface_copy = surface_.copy()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_copy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1392, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1392, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_surface_copy = __pyx_t_1;
  __pyx_t_1 = 0;
 1393: 
+1394:     if fast:
  __pyx_t_4 = (__pyx_v_fast != 0);
  if (__pyx_t_4) {
/* … */
    goto __pyx_L3;
  }
+1395:         sobel_fast(surface_copy, sobel_threshold, factor_=1)
    __pyx_t_5.__pyx_n = 2;
    __pyx_t_5.threshold_ = __pyx_v_sobel_threshold;
    __pyx_t_5.factor_ = 1;
    __pyx_f_12PygameShader_6shader_sobel_fast(__pyx_v_surface_copy, 0, &__pyx_t_5); 
 1396:     else:
+1397:         sobel(surface_copy, sobel_threshold)
  /*else*/ {
    __pyx_t_6.__pyx_n = 1;
    __pyx_t_6.threshold_ = __pyx_v_sobel_threshold;
    __pyx_f_12PygameShader_6shader_sobel(__pyx_v_surface_copy, 0, &__pyx_t_6); 
  }
  __pyx_L3:;
 1398: 
+1399:     bpf(surface_, bpf_threshold)
  __pyx_t_7.__pyx_n = 1;
  __pyx_t_7.threshold = __pyx_v_bpf_threshold;
  __pyx_f_12PygameShader_6shader_bpf(__pyx_v_surface_, 0, &__pyx_t_7); 
+1400:     shader_bloom_effect_array24_c(surface_, bloom_threshold, fast_=True)
  __pyx_t_8.__pyx_n = 1;
  __pyx_t_8.fast_ = 1;
  __pyx_f_12PygameShader_6shader_shader_bloom_effect_array24_c(__pyx_v_surface_, __pyx_v_bloom_threshold, &__pyx_t_8); 
+1401:     heatmap_convert(surface_, inv_colormap)
  __pyx_t_9.__pyx_n = 1;
  __pyx_t_9.rgb_ = __pyx_v_inv_colormap;
  __pyx_f_12PygameShader_6shader_heatmap_convert(__pyx_v_surface_, 0, &__pyx_t_9); 
+1402:     surface_.blit(surface_copy, (0, 0), special_flags=blend)
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_v_surface_copy);
  __Pyx_GIVEREF(__pyx_v_surface_copy);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_surface_copy);
  __Pyx_INCREF(__pyx_tuple__12);
  __Pyx_GIVEREF(__pyx_tuple__12);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_tuple__12);
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_10 = __Pyx_PyInt_From_int(__pyx_v_blend); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_special_flags, __pyx_t_10) < 0) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_2, __pyx_t_3); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
/* … */
  __pyx_tuple__12 = PyTuple_Pack(2, __pyx_int_0, __pyx_int_0); if (unlikely(!__pyx_tuple__12)) __PYX_ERR(1, 1402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__12);
  __Pyx_GIVEREF(__pyx_tuple__12);
 1403: 
+1404:     return surface_.convert()
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_convert); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1404, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_10 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 1404, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_r = __pyx_t_10;
  __pyx_t_10 = 0;
  goto __pyx_L0;
 1405: 
 1406: 
 1407: 
 1408: 
+1409: cpdef inline blood(object surface_, float [:, :] mask_, float perc_):
static PyObject *__pyx_pw_12PygameShader_6shader_81blood(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_blood(PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_mask_, float __pyx_v_perc_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  Py_ssize_t __pyx_v_mask_w;
  Py_ssize_t __pyx_v_mask_h;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blood", 0);
/* … */
  /* function exit code */
  __pyx_r = Py_None; __Pyx_INCREF(Py_None);
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_AddTraceback("PygameShader.shader.blood", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_81blood(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_80blood[] = "\n    SHADER 2D GAME \"HURT EFFECT\"\n    \n    This effect is used in 2D game when the player is being hurt\n    THE MASK DETERMINE THE CONTOUR USED FOR THE BLOOD EFFECT.\n\n    :param surface_ : pygame.Surface; compatible surface 24 - 32 bit\n    :param mask_    : numpy.ndarray shape (w, h) of float values in range [0.0...1.0]\n    :param perc_    : Percentage value in range [0.0 ... 1.0] with 1.0 being 100%\n    :return         : void\n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_81blood(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  __Pyx_memviewslice __pyx_v_mask_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_perc_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blood (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_mask_2,&__pyx_n_s_perc,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_mask_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("blood", 1, 3, 3, 1); __PYX_ERR(1, 1409, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_perc)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("blood", 1, 3, 3, 2); __PYX_ERR(1, 1409, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "blood") < 0)) __PYX_ERR(1, 1409, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_mask_ = __Pyx_PyObject_to_MemoryviewSlice_dsds_float(values[1], PyBUF_WRITABLE); if (unlikely(!__pyx_v_mask_.memview)) __PYX_ERR(1, 1409, __pyx_L3_error)
    __pyx_v_perc_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_perc_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1409, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("blood", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1409, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.blood", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_80blood(__pyx_self, __pyx_v_surface_, __pyx_v_mask_, __pyx_v_perc_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_80blood(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, __Pyx_memviewslice __pyx_v_mask_, float __pyx_v_perc_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blood", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_mask_.memview)) { __Pyx_RaiseUnboundLocalError("mask_"); __PYX_ERR(1, 1409, __pyx_L1_error) }
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_blood(__pyx_v_surface_, __pyx_v_mask_, __pyx_v_perc_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1409, __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("PygameShader.shader.blood", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_mask_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1410:     """
 1411:     SHADER 2D GAME "HURT EFFECT"
 1412:     
 1413:     This effect is used in 2D game when the player is being hurt
 1414:     THE MASK DETERMINE THE CONTOUR USED FOR THE BLOOD EFFECT.
 1415: 
 1416:     :param surface_ : pygame.Surface; compatible surface 24 - 32 bit
 1417:     :param mask_    : numpy.ndarray shape (w, h) of float values in range [0.0...1.0]
 1418:     :param perc_    : Percentage value in range [0.0 ... 1.0] with 1.0 being 100%
 1419:     :return         : void
 1420:     
 1421:     """
+1422:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1422, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1422, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1422, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1423:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1423, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1422, __pyx_L1_error)
    }
  }
  #endif
 1424: 
+1425:     assert PyObject_IsInstance(mask_, (numpy.ndarray, cython.view.memoryview)), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_mask_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1425, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
    __Pyx_INCREF(((PyObject *)__pyx_memoryview_type));
    __Pyx_GIVEREF(((PyObject *)__pyx_memoryview_type));
    PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_memoryview_type));
    __pyx_t_4 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1425, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1426:         "\nArgument mask_ must be a numpy.ndarray or cython memoryview types got %s " % type(mask_)
      __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_mask_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1426, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_mask__must_be_a_numpy, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1426, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1425, __pyx_L1_error)
    }
  }
  #endif
 1427: 
 1428:     cdef Py_ssize_t w, h
+1429:     w, h = surface_.get_size()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1429, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1429, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_2))) || (PyList_CheckExact(__pyx_t_2))) {
    PyObject* sequence = __pyx_t_2;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 1429, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_1 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_1 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_1);
    __Pyx_INCREF(__pyx_t_4);
    #else
    __pyx_t_1 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1429, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1429, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    #endif
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_5 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 1429, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_6 = Py_TYPE(__pyx_t_5)->tp_iternext;
    index = 0; __pyx_t_1 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_1)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_1);
    index = 1; __pyx_t_4 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_4)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_6(__pyx_t_5), 2) < 0) __PYX_ERR(1, 1429, __pyx_L1_error)
    __pyx_t_6 = NULL;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_6 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 1429, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 1429, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_8 = __Pyx_PyIndex_AsSsize_t(__pyx_t_4); if (unlikely((__pyx_t_8 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 1429, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_w = __pyx_t_7;
  __pyx_v_h = __pyx_t_8;
 1430: 
 1431:     cdef Py_ssize_t mask_w, mask_h
+1432:     mask_w, mask_h = mask_.shape[:2]
  __pyx_t_9 = __pyx_v_mask_.shape;
  __pyx_t_8 = (__pyx_t_9[0]);
  __pyx_t_7 = (__pyx_t_9[1]);
  __pyx_v_mask_w = __pyx_t_8;
  __pyx_v_mask_h = __pyx_t_7;
 1433: 
+1434:     assert w == mask_w and h == mask_h, "\nSurface size and mask size mismatch"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_10 = ((__pyx_v_w == __pyx_v_mask_w) != 0);
    if (__pyx_t_10) {
    } else {
      __pyx_t_3 = __pyx_t_10;
      goto __pyx_L5_bool_binop_done;
    }
    __pyx_t_10 = ((__pyx_v_h == __pyx_v_mask_h) != 0);
    __pyx_t_3 = __pyx_t_10;
    __pyx_L5_bool_binop_done:;
    if (unlikely(!__pyx_t_3)) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Surface_size_and_mask_size_mism);
      __PYX_ERR(1, 1434, __pyx_L1_error)
    }
  }
  #endif
 1435: 
+1436:     shader_blood_inplace_c(pixels3d(surface_), mask_, perc_)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 1436, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_1 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_1)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_2 = (__pyx_t_1) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_1, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1436, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 1436, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_blood_inplace_c(__pyx_t_11, __pyx_v_mask_, __pyx_v_perc_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 1437: 
 1438: 
 1439: # TODO DOC
+1440: cpdef inline object make_palette(int width, float fh, float fs, float fl):
static PyObject *__pyx_pw_12PygameShader_6shader_83make_palette(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_make_palette(int __pyx_v_width, float __pyx_v_fh, float __pyx_v_fs, float __pyx_v_fl, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("make_palette", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("PygameShader.shader.make_palette", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_83make_palette(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_82make_palette[] = "\n    \n    CREATE A PALETTE OF RGB COLORS\n\n    e.g:\n        # below: palette of 256 colors & surface (width=256, height=50).\n        # hue * 6, saturation = 255.0, lightness * 2.0\n        palette, surf = make_palette(256, 50, 6, 255, 2)\n        palette, surf = make_palette(256, 50, 4, 255, 2)\n\n    :param width  : integer, Palette width\n    :param fh     : float, hue factor\n    :param fs     : float, saturation factor\n    :param fl     : float, lightness factor\n    :return       : Return a 1D array palette\n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_83make_palette(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_width;
  float __pyx_v_fh;
  float __pyx_v_fs;
  float __pyx_v_fl;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("make_palette (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_width,&__pyx_n_s_fh,&__pyx_n_s_fs,&__pyx_n_s_fl,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_width)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fh)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("make_palette", 1, 4, 4, 1); __PYX_ERR(1, 1440, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fs)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("make_palette", 1, 4, 4, 2); __PYX_ERR(1, 1440, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fl)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("make_palette", 1, 4, 4, 3); __PYX_ERR(1, 1440, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "make_palette") < 0)) __PYX_ERR(1, 1440, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
    }
    __pyx_v_width = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_width == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1440, __pyx_L3_error)
    __pyx_v_fh = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_fh == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1440, __pyx_L3_error)
    __pyx_v_fs = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_fs == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1440, __pyx_L3_error)
    __pyx_v_fl = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_fl == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1440, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("make_palette", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1440, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.make_palette", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_82make_palette(__pyx_self, __pyx_v_width, __pyx_v_fh, __pyx_v_fs, __pyx_v_fl);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_82make_palette(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_width, float __pyx_v_fh, float __pyx_v_fs, float __pyx_v_fl) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("make_palette", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_make_palette(__pyx_v_width, __pyx_v_fh, __pyx_v_fs, __pyx_v_fl, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1440, __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("PygameShader.shader.make_palette", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1441:     """
 1442:     
 1443:     CREATE A PALETTE OF RGB COLORS
 1444: 
 1445:     e.g:
 1446:         # below: palette of 256 colors & surface (width=256, height=50).
 1447:         # hue * 6, saturation = 255.0, lightness * 2.0
 1448:         palette, surf = make_palette(256, 50, 6, 255, 2)
 1449:         palette, surf = make_palette(256, 50, 4, 255, 2)
 1450: 
 1451:     :param width  : integer, Palette width
 1452:     :param fh     : float, hue factor
 1453:     :param fs     : float, saturation factor
 1454:     :param fl     : float, lightness factor
 1455:     :return       : Return a 1D array palette
 1456: 
 1457:     """
 1458: 
+1459:     return make_palette_c(width, fh, fs, fl)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_make_palette_c(__pyx_v_width, __pyx_v_fh, __pyx_v_fs, __pyx_v_fl); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1459, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 1460: 
 1461: 
 1462: # todo develop DOC
+1463: cpdef inline fire_sub(
static PyObject *__pyx_pw_12PygameShader_6shader_85fire_sub(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_fire_sub(int __pyx_v_width, int __pyx_v_height, float __pyx_v_factor, __Pyx_memviewslice __pyx_v_palette, __Pyx_memviewslice __pyx_v_fire, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_sub", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("PygameShader.shader.fire_sub", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_85fire_sub(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_84fire_sub[] = "\n\n    CREATE A FIRE EFFECT\n\n    :param width    : integer; max width of the effect\n    :param height   : integer; max height of the effect\n    :param factor   : float; factor to reduce the flame effect\n    :param palette  : ndarray; Color palette 1d numpy array (colors buffer unsigned int values)\n    :param fire     : ndarray; 2d array (x, y) (contiguous) containing float values\n    :return         : Return a numpy array containing the fire effect array shape\n     (w, h, 3) of RGB pixels\n     \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_85fire_sub(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_width;
  int __pyx_v_height;
  float __pyx_v_factor;
  __Pyx_memviewslice __pyx_v_palette = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_fire = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_sub (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_width,&__pyx_n_s_height,&__pyx_n_s_factor_2,&__pyx_n_s_palette_2,&__pyx_n_s_fire,0};
    PyObject* values[5] = {0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_width)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_height)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_sub", 1, 5, 5, 1); __PYX_ERR(1, 1463, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_sub", 1, 5, 5, 2); __PYX_ERR(1, 1463, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_palette_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_sub", 1, 5, 5, 3); __PYX_ERR(1, 1463, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fire)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_sub", 1, 5, 5, 4); __PYX_ERR(1, 1463, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fire_sub") < 0)) __PYX_ERR(1, 1463, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 5) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
      values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
    }
    __pyx_v_width = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_width == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1464, __pyx_L3_error)
    __pyx_v_height = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_height == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1465, __pyx_L3_error)
    __pyx_v_factor = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_factor == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1466, __pyx_L3_error)
    __pyx_v_palette = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(values[3], PyBUF_WRITABLE); if (unlikely(!__pyx_v_palette.memview)) __PYX_ERR(1, 1467, __pyx_L3_error)
    __pyx_v_fire = __Pyx_PyObject_to_MemoryviewSlice_d_dc_float(values[4], PyBUF_WRITABLE); if (unlikely(!__pyx_v_fire.memview)) __PYX_ERR(1, 1468, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("fire_sub", 1, 5, 5, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1463, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.fire_sub", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_84fire_sub(__pyx_self, __pyx_v_width, __pyx_v_height, __pyx_v_factor, __pyx_v_palette, __pyx_v_fire);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_84fire_sub(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_width, int __pyx_v_height, float __pyx_v_factor, __Pyx_memviewslice __pyx_v_palette, __Pyx_memviewslice __pyx_v_fire) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_sub", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_palette.memview)) { __Pyx_RaiseUnboundLocalError("palette"); __PYX_ERR(1, 1463, __pyx_L1_error) }
  if (unlikely(!__pyx_v_fire.memview)) { __Pyx_RaiseUnboundLocalError("fire"); __PYX_ERR(1, 1463, __pyx_L1_error) }
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_fire_sub(__pyx_v_width, __pyx_v_height, __pyx_v_factor, __pyx_v_palette, __pyx_v_fire, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1463, __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("PygameShader.shader.fire_sub", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_fire, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1464:         int width,
 1465:         int height,
 1466:         float factor,
 1467:         unsigned int [::1] palette,
 1468:         float [:, ::1] fire
 1469: ):
 1470:     """
 1471: 
 1472:     CREATE A FIRE EFFECT
 1473: 
 1474:     :param width    : integer; max width of the effect
 1475:     :param height   : integer; max height of the effect
 1476:     :param factor   : float; factor to reduce the flame effect
 1477:     :param palette  : ndarray; Color palette 1d numpy array (colors buffer unsigned int values)
 1478:     :param fire     : ndarray; 2d array (x, y) (contiguous) containing float values
 1479:     :return         : Return a numpy array containing the fire effect array shape
 1480:      (w, h, 3) of RGB pixels
 1481:      
 1482:     """
 1483: 
+1484:     return fire_surface24_c(width, height, factor, palette, fire)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_fire_surface24_c(__pyx_v_width, __pyx_v_height, __pyx_v_factor, __pyx_v_palette, __pyx_v_fire, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1484, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 1485: 
 1486: 
 1487: 
 1488: 
+1489: cpdef inline fire_effect(
static PyObject *__pyx_pw_12PygameShader_6shader_87fire_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_fire_effect(int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_fire_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_fire_effect *__pyx_optional_args) {
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)3);
  unsigned short __pyx_v_fire_intensity_ = ((unsigned short)32);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("PygameShader.shader.fire_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_87fire_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_86fire_effect[] = "\n    FIRE SHADER EFFECT \n\n    * FIRE TEXTURE SIZES \n    \n    input width_  : integer,  \n    input height_ : integer\n    \n    width_ and height_ values define the size of the texture e.g Surface(width x height)\n\n    * FIRE ASPECT (CONTROL OVER THE WIDTH): \n    \n    inputs low_ : integer  \n    input high_ : integer \n    \n    Optional arguments low_ & high_ (integer values) define the width 's limits of the fire effect. \n    low_ for the starting point and high_ for the ending of the effect.\n    e.g low_ = 10 and high_ = 200. The fire effect will be contain within width = 10 and 200\n    low_ & high_ values must be in range [0 ... width_]  \n        \n    * FIRE HEIGHT:\n    \n    input factor_ : float\n    \n    The fire maximum height can be adjust with the variable factor_ (float value)\n    value > 3.95 will contain the effect within the display \n    value < 3.95 will enlarge the effect over the display height  \n    Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually \n    to contain the fire effect within the display\n        \n    * SPEED CONSIDERATION\n    \n    input reduce_factor_ : integer\n    \n    The argument reduce_factor_ control the size of the texture to be processed \n    e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)\n    Smaller texture improve the overall performances but will slightly degrade the fire aspect, \n    especially if the blur and smooth option are not enabled.\n    Recommended value for reduce_factor_ is 3 (fast process)   \n    reduce_factor_ values must be an integer in range [ 0 ... 4] \n    The reduce_factor_ value will have a significant impact on the fire effect maximum height, \n    adjust the argument factor_ accordingly\n\n    * FIRE INTENSITY AT THE SOURCE\n    \n    input fire_intensity_: integer\n    \n    Set the fire intensity with the variable fire_intensity_, 0 low flame,\n    32 maximum flame effect\n    Values must be an ""int in range [0 ... 32] \n\n    * SMOOTHING THE EFFECT\n    \n    input smooth_: True | False\n    \n    When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear \n    filtering) or False the final texture will be adjust with the scale function.\n    Set this variable to False if you need the best performance for the effect or if you require\n    a pixelated fire effect. Otherwise set the variable to True for a more realistic effect. \n\n    \n    * BLOOM EFFECT \n    \n    input bloom_         : True | False\n    input fast_bloom_    : True | False\n    input bpf_threshold_ : integer\n       \n    Fire effect produce a bright and smooth light effect to the background texture where the fire \n    intensity is at its maximum.\n    Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances\n    The flag fast_bloom_ define a very fast bloom algo using only the smallest texture \n    to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect \n    project for more details.\n    When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will \n    produce a more realistic fire effect (this will slightly degrade the overall performances). \n    If the fire effect is too bright, you can always adjust the bright pass filter value\n    bpf_threshold_(this will adjust the bloom intensity)\n    bpf_threshold_ value must be in range [ 0 ... 255]   \n    Below 128 the bloom effect will be more noticeable and above 128 only the brightest\n    area will be enhanced.\n\n    * LIGHT EFFECT INTENSITY\n\n    input brightness_            : True | False\n    input brightness_intensity_  : float\n\n    When the flag is set to True, the algorithm will use an external function, \n    <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture\n    A custom color can be passed to the function defining the pixels to be ignored during t""he \n    process (default is black color).\n    the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness \n    of the flame effect and positive values will increase the brightness of the effect (causing\n    bright white patches on the fire texture). \n    Values below -0.4 will cause the fire effect to be translucent and this effect can also be \n    used for simulating ascending heat convection effects on a background texture.\n    \n    \n    * OPTIONAL SURFACE\n      \n    input surface_ : pygame.Surface\n      \n    This is an optional surface that can be passed to the shader to improve the performances \n    and to avoid a new surface to be generated every iterations. The surface size must match \n    exactly the reduce texture dimensions otherwise an exception will be raise. \n    see reduce_factor_ option to determine the fire texture size that will be processed.\n    \n    * COLOR PALETTE ADJUSTMENT  \n    \n    input adjust_palette_ : True | False\n    input hsl_            : (10, 80, 1.8)\n\n    Set this flag to True to modify the color palette of the fire texture. \n    This allow the HSL color model to be apply to the palette values\n    You can redefine the palette when the flag is True and by customizing a tuple of 3 float \n    values, default is (10, 80, 1.8). \n    The first value control the palette hue value, the second is for the saturation and last, \n    the palette color lightness. \n    With the variable hsl_ you can rotate the palette colors and define a new flame\n    aspect/color/intensity\n    If adjust_palette_ is True the original palette define by the argument palette_, will \n    be disregarded.Instead a new palette will be created with the hsl values\n\n    * FLAME ORIENTATION / DIRECTION & BORDER FLAME EFFECT\n     \n    input transpose_ = True | False,\n    input border_    = True | False,\n    \n    transpose_ = True, this will transpose the final array \n    for e.g :  \n    If the final fire tex""ture is (w, h) after setting the transpose flag, the final \n    fire texture will become (h, w). As a result the fire effect will be transversal (starting \n    from the right of the display to the left side). \n    You can always transpose / flip the texture to get the right flame orientation  \n    BORDER FLAME EFFECT \n    border_ = True to create a flame effect burning the edge of the display. This version is only\n    compatible with symmetrical display or textures (same width & height). If the display \n    is asymmetric, the final border fire effect will be shown within the display and not neccessary \n    on the frame border \n    \n    * FINAL TOUCH\n    \n    input blur_ : True | False\n    \n    This will will blur the fire effect for a more realistic appearance, remove all the jagged \n    edge when and pixelated effect\n    \n    \n    :param width_           : integer; Size (width) of the surface or display in pixels\n    :param height_          : integer; size (height) of the surface or display in pixels\n    :param factor_          : float; Value controlling the fire height value\n                              must be in range [3.95 ... 4.2].\n                              The value 3.95 gives the highest flame effect\n    :param palette_         : numpy.ndarray, buffer containing mapped RGB colors (uint values)\n    :param fire_            : numpy.ndarray shape (w, h) containing float values (fire intensity).\n                              For better performance it is advised to set the array to the size \n                              of the texture after applying the reduction_factor_.\n                              For example if the reduction_factor_ is 2, the texture would have \n                              width >> 1 and height >> 1 and the fire_array should be set to \n                              numpy.empty((height >> 1, width >> 1), float32)\n    :param reduce_factor_   : unsigned short int ; Can be either 0, 1, 2, 3, 4. \n            ""                  2 and 3 provide the best performance and the best looking effect.\n    :param fire_intensity_  : Integer; Control the original amount of energy at the\n                              bottom of the fire, must be in range of [0 ... 32]. \n                              32 being the maximum value and the maximum fire intensity\n    :param smooth_          : boolean; True smoothscale (bi-linear filtering) or\n                              scale algorithm jagged edges (mush faster)\n    :param bloom_           : boolean; True or False, True apply a bloom effect to the fire effect\n    :param fast_bloom_      : boolean; Fastest bloom. This reduce the amount of calculation\n    :param bpf_threshold_   : integer; control the bright pass filter threshold\n                              value, must be in range [0 ... 255].\n                              Maximum brightness amplification with threshold = 0, \n                              when bpf_threshold_ = 255, no change.\n    :param low_             : integer; Starting position x for the fire effect\n    :param high_            : integer; Ending position x for the fire effect\n    :param brightness_      : boolean; True apply a bright filter shader to the array.\n                              Increase overall brightness of the effect\n    :param brightness_intensity_: float; must be in range [-1.0 ... 1.0] control\n                              the brightness intensity\n                              of the effect\n    :param surface_         : pygame.Surface. Pass a surface to the shader for\n                              better performance, otherwise a new surface will be created each \n                              calls.\n    :param adjust_palette_  : boolean; True adjust the palette setting HSL\n                              (hue, saturation, luminescence).\n                              Be aware that if adjust_palette is True, the optional palette \n                              passed to the Shader wil""l be disregarded\n    :param hsl_             : tuple; float values of hue, saturation and luminescence.\n                              Hue in range [0.0 ... 100],  saturation [0...100], \n                              luminescence [0.0 ... 2.0]\n    :param transpose_       : boolean; Transpose the array (w, h) become (h, w).\n                              The fire effect will start from the left and move to the right\n    :param border_          : boolean; Flame effect affect the border of the texture\n    :param blur_            : boolean; Blur the fire effect\n    :return                 : Return a pygame surface that can be blit directly to the game display\n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_87fire_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_width_;
  int __pyx_v_height_;
  float __pyx_v_factor_;
  __Pyx_memviewslice __pyx_v_palette_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_fire_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned short __pyx_v_reduce_factor_;
  unsigned short __pyx_v_fire_intensity_;
  int __pyx_v_smooth_;
  int __pyx_v_bloom_;
  int __pyx_v_fast_bloom_;
  unsigned char __pyx_v_bpf_threshold_;
  unsigned int __pyx_v_low_;
  unsigned int __pyx_v_high_;
  int __pyx_v_brightness_;
  float __pyx_v_brightness_intensity_;
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_adjust_palette_;
  PyObject *__pyx_v_hsl_ = 0;
  int __pyx_v_transpose_;
  int __pyx_v_border_;
  int __pyx_v_blur_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_effect (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_width_2,&__pyx_n_s_height_2,&__pyx_n_s_factor,&__pyx_n_s_palette,&__pyx_n_s_fire_2,&__pyx_n_s_reduce_factor,&__pyx_n_s_fire_intensity,&__pyx_n_s_smooth,&__pyx_n_s_bloom,&__pyx_n_s_fast_bloom,&__pyx_n_s_bpf_threshold_2,&__pyx_n_s_low,&__pyx_n_s_high,&__pyx_n_s_brightness,&__pyx_n_s_brightness_intensity,&__pyx_n_s_surface,&__pyx_n_s_adjust_palette,&__pyx_n_s_hsl,&__pyx_n_s_transpose,&__pyx_n_s_border,&__pyx_n_s_blur,0};
    PyObject* values[21] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_86fire_effect(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_fire_, unsigned short __pyx_v_reduce_factor_, unsigned short __pyx_v_fire_intensity_, int __pyx_v_smooth_, int __pyx_v_bloom_, int __pyx_v_fast_bloom_, unsigned char __pyx_v_bpf_threshold_, unsigned int __pyx_v_low_, unsigned int __pyx_v_high_, int __pyx_v_brightness_, float __pyx_v_brightness_intensity_, PyObject *__pyx_v_surface_, int __pyx_v_adjust_palette_, PyObject *__pyx_v_hsl_, int __pyx_v_transpose_, int __pyx_v_border_, int __pyx_v_blur_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_effect", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_palette_.memview)) { __Pyx_RaiseUnboundLocalError("palette_"); __PYX_ERR(1, 1489, __pyx_L1_error) }
  if (unlikely(!__pyx_v_fire_.memview)) { __Pyx_RaiseUnboundLocalError("fire_"); __PYX_ERR(1, 1489, __pyx_L1_error) }
  __pyx_t_2.__pyx_n = 16;
  __pyx_t_2.reduce_factor_ = __pyx_v_reduce_factor_;
  __pyx_t_2.fire_intensity_ = __pyx_v_fire_intensity_;
  __pyx_t_2.smooth_ = __pyx_v_smooth_;
  __pyx_t_2.bloom_ = __pyx_v_bloom_;
  __pyx_t_2.fast_bloom_ = __pyx_v_fast_bloom_;
  __pyx_t_2.bpf_threshold_ = __pyx_v_bpf_threshold_;
  __pyx_t_2.low_ = __pyx_v_low_;
  __pyx_t_2.high_ = __pyx_v_high_;
  __pyx_t_2.brightness_ = __pyx_v_brightness_;
  __pyx_t_2.brightness_intensity_ = __pyx_v_brightness_intensity_;
  __pyx_t_2.surface_ = __pyx_v_surface_;
  __pyx_t_2.adjust_palette_ = __pyx_v_adjust_palette_;
  __pyx_t_2.hsl_ = __pyx_v_hsl_;
  __pyx_t_2.transpose_ = __pyx_v_transpose_;
  __pyx_t_2.border_ = __pyx_v_border_;
  __pyx_t_2.blur_ = __pyx_v_blur_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_fire_effect(__pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_fire_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1489, __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("PygameShader.shader.fire_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_fire_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1490:         int width_,
 1491:         int height_,
 1492:         float factor_,
 1493:         unsigned int [::1] palette_,
 1494:         float [:, ::1] fire_,
 1495: 
 1496:         # OPTIONAL
 1497:         unsigned short int reduce_factor_ = 3,
 1498:         unsigned short int fire_intensity_= 32,
+1499:         bint smooth_                      = True,
  int __pyx_v_smooth_ = ((int)1);
/* … */
      __pyx_v_smooth_ = ((int)1);
    }
    if (values[8]) {
      __pyx_v_bloom_ = __Pyx_PyObject_IsTrue(values[8]); if (unlikely((__pyx_v_bloom_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1500, __pyx_L3_error)
    } else {
+1500:         bint bloom_                       = True,
  int __pyx_v_bloom_ = ((int)1);
/* … */
      __pyx_v_bloom_ = ((int)1);
    }
    if (values[9]) {
      __pyx_v_fast_bloom_ = __Pyx_PyObject_IsTrue(values[9]); if (unlikely((__pyx_v_fast_bloom_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1501, __pyx_L3_error)
    } else {
+1501:         bint fast_bloom_                  = True,
  int __pyx_v_fast_bloom_ = ((int)1);
  unsigned char __pyx_v_bpf_threshold_ = ((unsigned char)0);
  unsigned int __pyx_v_low_ = ((unsigned int)0);
  unsigned int __pyx_v_high_ = ((unsigned int)0x258);
/* … */
      __pyx_v_fast_bloom_ = ((int)1);
    }
    if (values[10]) {
      __pyx_v_bpf_threshold_ = __Pyx_PyInt_As_unsigned_char(values[10]); if (unlikely((__pyx_v_bpf_threshold_ == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 1502, __pyx_L3_error)
    } else {
      __pyx_v_bpf_threshold_ = ((unsigned char)0);
    }
    if (values[11]) {
      __pyx_v_low_ = __Pyx_PyInt_As_unsigned_int(values[11]); if (unlikely((__pyx_v_low_ == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1503, __pyx_L3_error)
    } else {
      __pyx_v_low_ = ((unsigned int)0);
    }
    if (values[12]) {
      __pyx_v_high_ = __Pyx_PyInt_As_unsigned_int(values[12]); if (unlikely((__pyx_v_high_ == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1504, __pyx_L3_error)
    } else {
      __pyx_v_high_ = ((unsigned int)0x258);
    }
    if (values[13]) {
      __pyx_v_brightness_ = __Pyx_PyObject_IsTrue(values[13]); if (unlikely((__pyx_v_brightness_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1505, __pyx_L3_error)
    } else {
 1502:         unsigned char bpf_threshold_      = 0,
 1503:         unsigned int low_                 = 0,
 1504:         unsigned int high_                = 600,
+1505:         bint brightness_                  = True,
  int __pyx_v_brightness_ = ((int)1);
  float __pyx_v_brightness_intensity_ = ((float)0.15);
/* … */
      __pyx_v_brightness_ = ((int)1);
    }
    if (values[14]) {
      __pyx_v_brightness_intensity_ = __pyx_PyFloat_AsFloat(values[14]); if (unlikely((__pyx_v_brightness_intensity_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1506, __pyx_L3_error)
    } else {
      __pyx_v_brightness_intensity_ = ((float)0.15);
    }
    __pyx_v_surface_ = values[15];
    if (values[16]) {
      __pyx_v_adjust_palette_ = __Pyx_PyObject_IsTrue(values[16]); if (unlikely((__pyx_v_adjust_palette_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1508, __pyx_L3_error)
    } else {
 1506:         float brightness_intensity_       = 0.15,
+1507:         object surface_                   = None,
  PyObject *__pyx_v_surface_ = ((PyObject *)Py_None);
/* … */
    values[15] = ((PyObject *)Py_None);
+1508:         bint adjust_palette_              = False,
  int __pyx_v_adjust_palette_ = ((int)0);
/* … */
      __pyx_v_adjust_palette_ = ((int)0);
    }
    __pyx_v_hsl_ = ((PyObject*)values[17]);
    if (values[18]) {
      __pyx_v_transpose_ = __Pyx_PyObject_IsTrue(values[18]); if (unlikely((__pyx_v_transpose_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1510, __pyx_L3_error)
    } else {
+1509:         tuple hsl_                        = (10, 80, 1.8),
  PyObject *__pyx_v_hsl_ = ((PyObject*)__pyx_tuple__13);
/* … */
  __pyx_tuple__13 = PyTuple_Pack(3, __pyx_int_10, __pyx_int_80, __pyx_float_1_8); if (unlikely(!__pyx_tuple__13)) __PYX_ERR(1, 1509, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__13);
  __Pyx_GIVEREF(__pyx_tuple__13);
/* … */
    values[17] = ((PyObject*)__pyx_tuple__14);
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case 21: values[20] = PyTuple_GET_ITEM(__pyx_args, 20);
        CYTHON_FALLTHROUGH;
        case 20: values[19] = PyTuple_GET_ITEM(__pyx_args, 19);
        CYTHON_FALLTHROUGH;
        case 19: values[18] = PyTuple_GET_ITEM(__pyx_args, 18);
        CYTHON_FALLTHROUGH;
        case 18: values[17] = PyTuple_GET_ITEM(__pyx_args, 17);
        CYTHON_FALLTHROUGH;
        case 17: values[16] = PyTuple_GET_ITEM(__pyx_args, 16);
        CYTHON_FALLTHROUGH;
        case 16: values[15] = PyTuple_GET_ITEM(__pyx_args, 15);
        CYTHON_FALLTHROUGH;
        case 15: values[14] = PyTuple_GET_ITEM(__pyx_args, 14);
        CYTHON_FALLTHROUGH;
        case 14: values[13] = PyTuple_GET_ITEM(__pyx_args, 13);
        CYTHON_FALLTHROUGH;
        case 13: values[12] = PyTuple_GET_ITEM(__pyx_args, 12);
        CYTHON_FALLTHROUGH;
        case 12: values[11] = PyTuple_GET_ITEM(__pyx_args, 11);
        CYTHON_FALLTHROUGH;
        case 11: values[10] = PyTuple_GET_ITEM(__pyx_args, 10);
        CYTHON_FALLTHROUGH;
        case 10: values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
        CYTHON_FALLTHROUGH;
        case  9: values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
        CYTHON_FALLTHROUGH;
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_width_2)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_height_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_effect", 0, 5, 21, 1); __PYX_ERR(1, 1489, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_effect", 0, 5, 21, 2); __PYX_ERR(1, 1489, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_palette)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_effect", 0, 5, 21, 3); __PYX_ERR(1, 1489, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fire_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("fire_effect", 0, 5, 21, 4); __PYX_ERR(1, 1489, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_reduce_factor);
          if (value) { values[5] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fire_intensity);
          if (value) { values[6] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  7:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_smooth);
          if (value) { values[7] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  8:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bloom);
          if (value) { values[8] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  9:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fast_bloom);
          if (value) { values[9] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 10:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bpf_threshold_2);
          if (value) { values[10] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 11:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_low);
          if (value) { values[11] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 12:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_high);
          if (value) { values[12] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 13:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_brightness);
          if (value) { values[13] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 14:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_brightness_intensity);
          if (value) { values[14] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 15:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface);
          if (value) { values[15] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 16:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_adjust_palette);
          if (value) { values[16] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 17:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_hsl);
          if (value) { values[17] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 18:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_transpose);
          if (value) { values[18] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 19:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_border);
          if (value) { values[19] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 20:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_blur);
          if (value) { values[20] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "fire_effect") < 0)) __PYX_ERR(1, 1489, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case 21: values[20] = PyTuple_GET_ITEM(__pyx_args, 20);
        CYTHON_FALLTHROUGH;
        case 20: values[19] = PyTuple_GET_ITEM(__pyx_args, 19);
        CYTHON_FALLTHROUGH;
        case 19: values[18] = PyTuple_GET_ITEM(__pyx_args, 18);
        CYTHON_FALLTHROUGH;
        case 18: values[17] = PyTuple_GET_ITEM(__pyx_args, 17);
        CYTHON_FALLTHROUGH;
        case 17: values[16] = PyTuple_GET_ITEM(__pyx_args, 16);
        CYTHON_FALLTHROUGH;
        case 16: values[15] = PyTuple_GET_ITEM(__pyx_args, 15);
        CYTHON_FALLTHROUGH;
        case 15: values[14] = PyTuple_GET_ITEM(__pyx_args, 14);
        CYTHON_FALLTHROUGH;
        case 14: values[13] = PyTuple_GET_ITEM(__pyx_args, 13);
        CYTHON_FALLTHROUGH;
        case 13: values[12] = PyTuple_GET_ITEM(__pyx_args, 12);
        CYTHON_FALLTHROUGH;
        case 12: values[11] = PyTuple_GET_ITEM(__pyx_args, 11);
        CYTHON_FALLTHROUGH;
        case 11: values[10] = PyTuple_GET_ITEM(__pyx_args, 10);
        CYTHON_FALLTHROUGH;
        case 10: values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
        CYTHON_FALLTHROUGH;
        case  9: values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
        CYTHON_FALLTHROUGH;
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_width_ = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_width_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1490, __pyx_L3_error)
    __pyx_v_height_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_height_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1491, __pyx_L3_error)
    __pyx_v_factor_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_factor_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1492, __pyx_L3_error)
    __pyx_v_palette_ = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(values[3], PyBUF_WRITABLE); if (unlikely(!__pyx_v_palette_.memview)) __PYX_ERR(1, 1493, __pyx_L3_error)
    __pyx_v_fire_ = __Pyx_PyObject_to_MemoryviewSlice_d_dc_float(values[4], PyBUF_WRITABLE); if (unlikely(!__pyx_v_fire_.memview)) __PYX_ERR(1, 1494, __pyx_L3_error)
    if (values[5]) {
      __pyx_v_reduce_factor_ = __Pyx_PyInt_As_unsigned_short(values[5]); if (unlikely((__pyx_v_reduce_factor_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 1497, __pyx_L3_error)
    } else {
      __pyx_v_reduce_factor_ = ((unsigned short)3);
    }
    if (values[6]) {
      __pyx_v_fire_intensity_ = __Pyx_PyInt_As_unsigned_short(values[6]); if (unlikely((__pyx_v_fire_intensity_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 1498, __pyx_L3_error)
    } else {
      __pyx_v_fire_intensity_ = ((unsigned short)32);
    }
    if (values[7]) {
      __pyx_v_smooth_ = __Pyx_PyObject_IsTrue(values[7]); if (unlikely((__pyx_v_smooth_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1499, __pyx_L3_error)
    } else {
  __pyx_tuple__14 = PyTuple_Pack(3, __pyx_int_10, __pyx_int_80, __pyx_float_1_8); if (unlikely(!__pyx_tuple__14)) __PYX_ERR(1, 1509, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__14);
  __Pyx_GIVEREF(__pyx_tuple__14);
+1510:         bint transpose_                   = False,
  int __pyx_v_transpose_ = ((int)0);
/* … */
      __pyx_v_transpose_ = ((int)0);
    }
    if (values[19]) {
      __pyx_v_border_ = __Pyx_PyObject_IsTrue(values[19]); if (unlikely((__pyx_v_border_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1511, __pyx_L3_error)
    } else {
+1511:         bint border_                      = False,
  int __pyx_v_border_ = ((int)0);
/* … */
      __pyx_v_border_ = ((int)0);
    }
    if (values[20]) {
      __pyx_v_blur_ = __Pyx_PyObject_IsTrue(values[20]); if (unlikely((__pyx_v_blur_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1512, __pyx_L3_error)
    } else {
+1512:         bint blur_                        = True
  int __pyx_v_blur_ = ((int)1);
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_effect", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_fire_intensity_ = __pyx_optional_args->fire_intensity_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_smooth_ = __pyx_optional_args->smooth_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_bloom_ = __pyx_optional_args->bloom_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_fast_bloom_ = __pyx_optional_args->fast_bloom_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_bpf_threshold_ = __pyx_optional_args->bpf_threshold_;
                if (__pyx_optional_args->__pyx_n > 6) {
                  __pyx_v_low_ = __pyx_optional_args->low_;
                  if (__pyx_optional_args->__pyx_n > 7) {
                    __pyx_v_high_ = __pyx_optional_args->high_;
                    if (__pyx_optional_args->__pyx_n > 8) {
                      __pyx_v_brightness_ = __pyx_optional_args->brightness_;
                      if (__pyx_optional_args->__pyx_n > 9) {
                        __pyx_v_brightness_intensity_ = __pyx_optional_args->brightness_intensity_;
                        if (__pyx_optional_args->__pyx_n > 10) {
                          __pyx_v_surface_ = __pyx_optional_args->surface_;
                          if (__pyx_optional_args->__pyx_n > 11) {
                            __pyx_v_adjust_palette_ = __pyx_optional_args->adjust_palette_;
                            if (__pyx_optional_args->__pyx_n > 12) {
                              __pyx_v_hsl_ = __pyx_optional_args->hsl_;
                              if (__pyx_optional_args->__pyx_n > 13) {
                                __pyx_v_transpose_ = __pyx_optional_args->transpose_;
                                if (__pyx_optional_args->__pyx_n > 14) {
                                  __pyx_v_border_ = __pyx_optional_args->border_;
                                  if (__pyx_optional_args->__pyx_n > 15) {
                                    __pyx_v_blur_ = __pyx_optional_args->blur_;
                                  }
                                }
                              }
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
/* … */
      __pyx_v_blur_ = ((int)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("fire_effect", 0, 5, 21, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1489, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.fire_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_hsl_), (&PyTuple_Type), 1, "hsl_", 1))) __PYX_ERR(1, 1509, __pyx_L1_error)
  __pyx_r = __pyx_pf_12PygameShader_6shader_86fire_effect(__pyx_self, __pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_fire_, __pyx_v_reduce_factor_, __pyx_v_fire_intensity_, __pyx_v_smooth_, __pyx_v_bloom_, __pyx_v_fast_bloom_, __pyx_v_bpf_threshold_, __pyx_v_low_, __pyx_v_high_, __pyx_v_brightness_, __pyx_v_brightness_intensity_, __pyx_v_surface_, __pyx_v_adjust_palette_, __pyx_v_hsl_, __pyx_v_transpose_, __pyx_v_border_, __pyx_v_blur_);
 1513:         ):
 1514:     """
 1515:     FIRE SHADER EFFECT 
 1516: 
 1517:     * FIRE TEXTURE SIZES 
 1518:     
 1519:     input width_  : integer,  
 1520:     input height_ : integer
 1521:     
 1522:     width_ and height_ values define the size of the texture e.g Surface(width x height)
 1523: 
 1524:     * FIRE ASPECT (CONTROL OVER THE WIDTH): 
 1525:     
 1526:     inputs low_ : integer  
 1527:     input high_ : integer 
 1528:     
 1529:     Optional arguments low_ & high_ (integer values) define the width 's limits of the fire effect. 
 1530:     low_ for the starting point and high_ for the ending of the effect.
 1531:     e.g low_ = 10 and high_ = 200. The fire effect will be contain within width = 10 and 200
 1532:     low_ & high_ values must be in range [0 ... width_]  
 1533:         
 1534:     * FIRE HEIGHT:
 1535:     
 1536:     input factor_ : float
 1537:     
 1538:     The fire maximum height can be adjust with the variable factor_ (float value)
 1539:     value > 3.95 will contain the effect within the display 
 1540:     value < 3.95 will enlarge the effect over the display height  
 1541:     Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually 
 1542:     to contain the fire effect within the display
 1543:         
 1544:     * SPEED CONSIDERATION
 1545:     
 1546:     input reduce_factor_ : integer
 1547:     
 1548:     The argument reduce_factor_ control the size of the texture to be processed 
 1549:     e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)
 1550:     Smaller texture improve the overall performances but will slightly degrade the fire aspect, 
 1551:     especially if the blur and smooth option are not enabled.
 1552:     Recommended value for reduce_factor_ is 3 (fast process)   
 1553:     reduce_factor_ values must be an integer in range [ 0 ... 4] 
 1554:     The reduce_factor_ value will have a significant impact on the fire effect maximum height, 
 1555:     adjust the argument factor_ accordingly
 1556: 
 1557:     * FIRE INTENSITY AT THE SOURCE
 1558:     
 1559:     input fire_intensity_: integer
 1560:     
 1561:     Set the fire intensity with the variable fire_intensity_, 0 low flame,
 1562:     32 maximum flame effect
 1563:     Values must be an int in range [0 ... 32] 
 1564: 
 1565:     * SMOOTHING THE EFFECT
 1566:     
 1567:     input smooth_: True | False
 1568:     
 1569:     When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear 
 1570:     filtering) or False the final texture will be adjust with the scale function.
 1571:     Set this variable to False if you need the best performance for the effect or if you require
 1572:     a pixelated fire effect. Otherwise set the variable to True for a more realistic effect. 
 1573: 
 1574:     
 1575:     * BLOOM EFFECT 
 1576:     
 1577:     input bloom_         : True | False
 1578:     input fast_bloom_    : True | False
 1579:     input bpf_threshold_ : integer
 1580:        
 1581:     Fire effect produce a bright and smooth light effect to the background texture where the fire 
 1582:     intensity is at its maximum.
 1583:     Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances
 1584:     The flag fast_bloom_ define a very fast bloom algo using only the smallest texture 
 1585:     to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect 
 1586:     project for more details.
 1587:     When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will 
 1588:     produce a more realistic fire effect (this will slightly degrade the overall performances). 
 1589:     If the fire effect is too bright, you can always adjust the bright pass filter value
 1590:     bpf_threshold_(this will adjust the bloom intensity)
 1591:     bpf_threshold_ value must be in range [ 0 ... 255]   
 1592:     Below 128 the bloom effect will be more noticeable and above 128 only the brightest
 1593:     area will be enhanced.
 1594: 
 1595:     * LIGHT EFFECT INTENSITY
 1596: 
 1597:     input brightness_            : True | False
 1598:     input brightness_intensity_  : float
 1599: 
 1600:     When the flag is set to True, the algorithm will use an external function, 
 1601:     <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture
 1602:     A custom color can be passed to the function defining the pixels to be ignored during the 
 1603:     process (default is black color).
 1604:     the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness 
 1605:     of the flame effect and positive values will increase the brightness of the effect (causing
 1606:     bright white patches on the fire texture). 
 1607:     Values below -0.4 will cause the fire effect to be translucent and this effect can also be 
 1608:     used for simulating ascending heat convection effects on a background texture.
 1609:     
 1610:     
 1611:     * OPTIONAL SURFACE
 1612:       
 1613:     input surface_ : pygame.Surface
 1614:       
 1615:     This is an optional surface that can be passed to the shader to improve the performances 
 1616:     and to avoid a new surface to be generated every iterations. The surface size must match 
 1617:     exactly the reduce texture dimensions otherwise an exception will be raise. 
 1618:     see reduce_factor_ option to determine the fire texture size that will be processed.
 1619:     
 1620:     * COLOR PALETTE ADJUSTMENT  
 1621:     
 1622:     input adjust_palette_ : True | False
 1623:     input hsl_            : (10, 80, 1.8)
 1624: 
 1625:     Set this flag to True to modify the color palette of the fire texture. 
 1626:     This allow the HSL color model to be apply to the palette values
 1627:     You can redefine the palette when the flag is True and by customizing a tuple of 3 float 
 1628:     values, default is (10, 80, 1.8). 
 1629:     The first value control the palette hue value, the second is for the saturation and last, 
 1630:     the palette color lightness. 
 1631:     With the variable hsl_ you can rotate the palette colors and define a new flame
 1632:     aspect/color/intensity
 1633:     If adjust_palette_ is True the original palette define by the argument palette_, will 
 1634:     be disregarded.Instead a new palette will be created with the hsl values
 1635: 
 1636:     * FLAME ORIENTATION / DIRECTION & BORDER FLAME EFFECT
 1637:      
 1638:     input transpose_ = True | False,
 1639:     input border_    = True | False,
 1640:     
 1641:     transpose_ = True, this will transpose the final array 
 1642:     for e.g :  
 1643:     If the final fire texture is (w, h) after setting the transpose flag, the final 
 1644:     fire texture will become (h, w). As a result the fire effect will be transversal (starting 
 1645:     from the right of the display to the left side). 
 1646:     You can always transpose / flip the texture to get the right flame orientation  
 1647:     BORDER FLAME EFFECT 
 1648:     border_ = True to create a flame effect burning the edge of the display. This version is only
 1649:     compatible with symmetrical display or textures (same width & height). If the display 
 1650:     is asymmetric, the final border fire effect will be shown within the display and not neccessary 
 1651:     on the frame border 
 1652:     
 1653:     * FINAL TOUCH
 1654:     
 1655:     input blur_ : True | False
 1656:     
 1657:     This will will blur the fire effect for a more realistic appearance, remove all the jagged 
 1658:     edge when and pixelated effect
 1659:     
 1660:     
 1661:     :param width_           : integer; Size (width) of the surface or display in pixels
 1662:     :param height_          : integer; size (height) of the surface or display in pixels
 1663:     :param factor_          : float; Value controlling the fire height value
 1664:                               must be in range [3.95 ... 4.2].
 1665:                               The value 3.95 gives the highest flame effect
 1666:     :param palette_         : numpy.ndarray, buffer containing mapped RGB colors (uint values)
 1667:     :param fire_            : numpy.ndarray shape (w, h) containing float values (fire intensity).
 1668:                               For better performance it is advised to set the array to the size 
 1669:                               of the texture after applying the reduction_factor_.
 1670:                               For example if the reduction_factor_ is 2, the texture would have 
 1671:                               width >> 1 and height >> 1 and the fire_array should be set to 
 1672:                               numpy.empty((height >> 1, width >> 1), float32)
 1673:     :param reduce_factor_   : unsigned short int ; Can be either 0, 1, 2, 3, 4. 
 1674:                               2 and 3 provide the best performance and the best looking effect.
 1675:     :param fire_intensity_  : Integer; Control the original amount of energy at the
 1676:                               bottom of the fire, must be in range of [0 ... 32]. 
 1677:                               32 being the maximum value and the maximum fire intensity
 1678:     :param smooth_          : boolean; True smoothscale (bi-linear filtering) or
 1679:                               scale algorithm jagged edges (mush faster)
 1680:     :param bloom_           : boolean; True or False, True apply a bloom effect to the fire effect
 1681:     :param fast_bloom_      : boolean; Fastest bloom. This reduce the amount of calculation
 1682:     :param bpf_threshold_   : integer; control the bright pass filter threshold
 1683:                               value, must be in range [0 ... 255].
 1684:                               Maximum brightness amplification with threshold = 0, 
 1685:                               when bpf_threshold_ = 255, no change.
 1686:     :param low_             : integer; Starting position x for the fire effect
 1687:     :param high_            : integer; Ending position x for the fire effect
 1688:     :param brightness_      : boolean; True apply a bright filter shader to the array.
 1689:                               Increase overall brightness of the effect
 1690:     :param brightness_intensity_: float; must be in range [-1.0 ... 1.0] control
 1691:                               the brightness intensity
 1692:                               of the effect
 1693:     :param surface_         : pygame.Surface. Pass a surface to the shader for
 1694:                               better performance, otherwise a new surface will be created each 
 1695:                               calls.
 1696:     :param adjust_palette_  : boolean; True adjust the palette setting HSL
 1697:                               (hue, saturation, luminescence).
 1698:                               Be aware that if adjust_palette is True, the optional palette 
 1699:                               passed to the Shader will be disregarded
 1700:     :param hsl_             : tuple; float values of hue, saturation and luminescence.
 1701:                               Hue in range [0.0 ... 100],  saturation [0...100], 
 1702:                               luminescence [0.0 ... 2.0]
 1703:     :param transpose_       : boolean; Transpose the array (w, h) become (h, w).
 1704:                               The fire effect will start from the left and move to the right
 1705:     :param border_          : boolean; Flame effect affect the border of the texture
 1706:     :param blur_            : boolean; Blur the fire effect
 1707:     :return                 : Return a pygame surface that can be blit directly to the game display
 1708: 
 1709:     """
 1710:     # todo reduce_factor=0 and border = True crash
 1711: 
+1712:     assert reduce_factor_ in (0, 1, 2, 3, 4), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    switch (__pyx_v_reduce_factor_) {
      case 0:
      case 1:
      case 2:
      case 3:
      case 4:
      __pyx_t_1 = 1;
      break;
      default:
      __pyx_t_1 = 0;
      break;
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_reduce_factor_must_be_i);
      __PYX_ERR(1, 1712, __pyx_L1_error)
    }
  }
  #endif
 1713:         "Argument reduce factor must be in range 0 ... 4 " \
 1714:         "\n reduce_factor_ = 1 correspond to dividing the image size by 2" \
 1715:         "\n reduce_factor_ = 2 correspond to dividing the image size by 4"
+1716:     assert 0 <= fire_intensity_ < 33, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (0 <= __pyx_v_fire_intensity_);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_fire_intensity_ < 33);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
+1717:         "Argument fire_intensity_ must be in range [0 ... 32] got %s" % fire_intensity_
      __pyx_t_2 = __Pyx_PyInt_From_unsigned_short(__pyx_v_fire_intensity_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1717, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = __Pyx_PyString_Format(__pyx_kp_s_Argument_fire_intensity__must_be, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1717, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 1716, __pyx_L1_error)
    }
  }
  #endif
 1718: 
+1719:     assert width_ > 0 and height_ > 0, "Argument width or height cannot be null or < 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_4 = ((__pyx_v_width_ > 0) != 0);
    if (__pyx_t_4) {
    } else {
      __pyx_t_1 = __pyx_t_4;
      goto __pyx_L3_bool_binop_done;
    }
    __pyx_t_4 = ((__pyx_v_height_ > 0) != 0);
    __pyx_t_1 = __pyx_t_4;
    __pyx_L3_bool_binop_done:;
    if (unlikely(!__pyx_t_1)) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_width_or_height_cannot);
      __PYX_ERR(1, 1719, __pyx_L1_error)
    }
  }
  #endif
+1720:     assert factor_ > 0, "Argument factor_ cannot be null or < 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_factor_ > 0.0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_factor__cannot_be_null);
      __PYX_ERR(1, 1720, __pyx_L1_error)
    }
  }
  #endif
 1721: 
+1722:     return shader_fire_effect_c(
  __Pyx_XDECREF(__pyx_r);
/* … */
  __pyx_t_5.__pyx_n = 16;
  __pyx_t_5.reduce_factor_ = __pyx_v_reduce_factor_;
  __pyx_t_5.fire_intensity_ = __pyx_v_fire_intensity_;
  __pyx_t_5.smooth_ = __pyx_v_smooth_;
  __pyx_t_5.bloom_ = __pyx_v_bloom_;
  __pyx_t_5.fast_bloom_ = __pyx_v_fast_bloom_;
  __pyx_t_5.bpf_threshold_ = __pyx_v_bpf_threshold_;
  __pyx_t_5.low_ = __pyx_v_low_;
  __pyx_t_5.high_ = __pyx_v_high_;
  __pyx_t_5.brightness_ = __pyx_v_brightness_;
  __pyx_t_5.brightness_intensity_ = __pyx_v_brightness_intensity_;
  __pyx_t_5.surface_ = __pyx_v_surface_;
  __pyx_t_5.adjust_palette_ = __pyx_v_adjust_palette_;
  __pyx_t_5.hsl_ = __pyx_v_hsl_;
  __pyx_t_5.transpose_ = __pyx_v_transpose_;
  __pyx_t_5.border_ = __pyx_v_border_;
  __pyx_t_5.blur_ = __pyx_v_blur_;
  __pyx_t_3 = __pyx_f_12PygameShader_6shader_shader_fire_effect_c(__pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_fire_, &__pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1722, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 1723:         width_, height_, factor_, palette_, fire_,
 1724:         reduce_factor_, fire_intensity_, smooth_,
 1725:         bloom_, fast_bloom_, bpf_threshold_, low_, high_, brightness_,
 1726:         brightness_intensity_, surface_, adjust_palette_,
 1727:         hsl_, transpose_, border_, blur_
 1728:     )
 1729: 
 1730: 
 1731: 
+1732: cpdef inline cloud_effect(
static PyObject *__pyx_pw_12PygameShader_6shader_89cloud_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_cloud_effect(int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_cloud_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_cloud_effect *__pyx_optional_args) {
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)2);
  unsigned short __pyx_v_cloud_intensity_ = ((unsigned short)16);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("PygameShader.shader.cloud_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_89cloud_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_88cloud_effect[] = "\n    GENERATE CLOUD /SMOKE ON THE GAME DISPLAY \n    \n    * CLOUD TEXTURE SIZES \n    \n    input width_  : integer,  \n    input height_ : integer\n    \n    width_ and height_ values define the size of the texture e.g Surface(width x height)\n\n    * CLOUD ASPECT (CONTROL OVER THE WIDTH): \n    \n    inputs low_ : integer  \n    input high_ : integer \n    \n    Optional arguments low_ & high_ (integer values) define the width 's limits of the cloud \n    effect. low_ for the starting point and high_ for the ending of the effect.\n    e.g low_ = 10 and high_ = 200. The cloud effect will be contain within width = 10 and 200\n    low_ & high_ values must be in range [0 ... width_]  \n        \n    * CLOUD HEIGHT:\n    \n    input factor_ : float\n    \n    The cloud maximum height can be adjust with the variable factor_ (float value)\n    value > 3.95 will contain the effect within the display \n    value < 3.95 will enlarge the effect over the display height  \n    Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually \n    to contain the cloud effect within the display\n        \n    * SPEED CONSIDERATION\n    \n    input reduce_factor_ : integer\n    \n    The argument reduce_factor_ control the size of the texture to be processed \n    e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)\n    Smaller texture improve the overall performances but will slightly degrade the cloud aspect, \n    especially if the blur and smooth option are not enabled.\n    Recommended value for reduce_factor_ is 3 (fast process)   \n    reduce_factor_ values must be an integer in range [ 0 ... 4] \n    The reduce_factor_ value will have a significant impact on the cloud effect maximum height, \n    adjust the argument factor_ accordingly\n\n    * CLOUD INTENSITY AT THE SOURCE\n    \n    input cloud_intensity_: integer\n    \n    Set the cloud intensity with the variable cloud_intensity_, 0 low flame,\n    32 maxi""mum flame effect\n    Values must be an int in range [0 ... 32] \n\n    * SMOOTHING THE EFFECT\n    \n    input smooth_: True | False\n    \n    When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear \n    filtering) or False the final texture will be adjust with the scale function.\n    Set this variable to False if you need the best performance for the effect or if you require\n    a pixelated cloud effect. Otherwise set the variable to True for a more realistic effect. \n   \n    * BLOOM EFFECT \n    \n    input bloom_         : True | False\n    input fast_bloom_    : True | False\n    input bpf_threshold_ : integer\n       \n    Bloom effect produce a bright and smooth light effect to the background texture where the cloud \n    intensity is at its maximum.\n    Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances\n    The flag fast_bloom_ define a very fast bloom algo using only the smallest texture \n    to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect \n    project for more details.\n    When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will \n    produce a more realistic cloud effect (this will slightly degrade the overall performances). \n    If the cloud effect is too bright, you can always adjust the bright pass filter value\n    bpf_threshold_(this will adjust the bloom intensity)\n    bpf_threshold_ value must be in range [ 0 ... 255]   \n    Below 128 the bloom effect will be more noticeable and above 128 only the brightest\n    area will be enhanced.\n\n    * LIGHT EFFECT INTENSITY\n\n    input brightness_            : True | False\n    input brightness_intensity_  : float\n\n    When the flag is set to True, the algorithm will use an external function, \n    <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture\n    A custom color can be passed to the function ""defining the pixels to be ignored during the \n    process (default is black color).\n    the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness \n    of the cloud effect and positive values will increase the brightness of the effect (causing\n    bright white patches on the cloud texture). \n    Values below -0.4 will cause the cloud effect to be translucent \n    \n    \n    * OPTIONAL SURFACE\n      \n    input surface_ : pygame.Surface\n      \n    This is an optional surface that can be passed to the shader to improve the performances \n    and to avoid a new surface to be generated every iterations. The surface size must match \n    exactly the reduce texture dimensions otherwise an exception will be raise. \n    see reduce_factor_ option to determine the cloud texture size that will be processed.\n    \n\n    * CLOUD ORIENTATION / DIRECTION \n     \n    input transpose_ = True | False,\n    \n    transpose_ = True, this will transpose the final array \n    for e.g :  \n    If the final cloud texture is (w, h) after setting the transpose flag, the final \n    cloud texture will become (h, w). As a result the cloud effect will be transversal (starting \n    from the right of the display to the left side). \n    You can always transpose / flip the texture to get the right cloud orientation  \n    \n    * FINAL TOUCH\n    \n    input blur_ : True | False\n    \n    This will will blur the cloud effect for a more realistic appearance, remove all the jagged \n    edge when and pixelated effect\n    \n    :param width_               : integer; Texture size (width) \n    :param height_              : integer; Texture size (height)\n    :param factor_              : float; Floating value used to control the size of the cloud\n                                  effect. Value must be in range [3.95 ... 4.2]. Value > 3.95 \n                                  will contain the smoke/ cloud effect within the display. \n                      ""            Values < 3.95 will enlarge the smoke effect.                              \n    :param palette_             : numpy.ndarray or cython memoryview containing the color for the \n                                  cloud effect (buffer containing mapped RGB colors (uint values))\n    :param cloud_               : numpy.ndarray shape (w, h) containing float values \n                                  (cloud intensity). For better performance it is advised to set the\n                                  array to the size of the texture after applying the \n                                  reduction_factor_. For example if the reduction_factor_ is 2, \n                                  the texture would have to be width >> 1 and height >> 1 and the \n                                  cloud_ array should be equivalent to numpy.empty((height >> 1, \n                                  width >> 1), float32)\n    :param reduce_factor_       : integer; unsigned short int ; Can be either 0, 1, 2, 3, 4. \n                                  2 and 3 provide the best performance and the best looking effect.\n    :param cloud_intensity_     : integer; Determine the amount of smoke the cloud\n                                  effect will generate at the base of the effect (value must be in \n                                  range [0 .. 260]). If you provide zero a random value between \n                                  0 ... 260 will be assigned. If you provide 250, a random value \n                                  between 250 and 260 will be set for the amount of smoke. \n                                  The highest the value, the more dense the cloud effect will be\n    :param smooth_              : boolean; True use a smoothscale (bi-linear filtering) or\n                                  False -> scale algorithm jagged edges (mush faster)\n    :param bloom_               : True | False, Add a bloom effect when the flag is set to True\n                                  Th""e bloom effect will smooth the cloud and create a dense smoke \n                                  areas where the cloud is the brightest.  \n    :param fast_bloom_          : True | False; This set a fast algorithm for the bloom effect (the \n                                  bloom effect will use the smallest texture)\n    :param bpf_threshold_       : integer; Bright pass filter value must be in range [ 0 ... 255]\n                                  0 produce the maximum bloom effect\n    :param low_                 : integer; must be in range [ 0 ... width_], left position of the \n                                  cloud effect \n    :param high_                : integer; must be in range [ 0 ... height_], right position of the\n                                  cloud effect\n    :param brightness_          : True | False; Increase the brightness of the cloud effect when \n                                  True\n    :param brightness_intensity_: float; Set the brightness intensity of the cloud. The value must \n                                  be in range [-1.0 ... +1.0]. Changing the value overtime will \n                                  generate a realistic cloud effect. Negative value will generate \n                                  translucent patch of smoke on the background image\n    :param surface_             : Pygame.Surface; Pass a surface to the shader for\n                                  better performance, otherwise a new surface will be created each \n                                  calls.\n    :param transpose_           : boolean; Transpose the array (w, h) become (h, w).\n                                  The cloud effect will start from the left and move to the right\n    :param blur_                : boolean; Blur the cloud effect\n    :return                     : Return a pygame surface that can be blit directly to the game \n                                  display\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_89cloud_effect(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_width_;
  int __pyx_v_height_;
  float __pyx_v_factor_;
  __Pyx_memviewslice __pyx_v_palette_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_cloud_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned short __pyx_v_reduce_factor_;
  unsigned short __pyx_v_cloud_intensity_;
  int __pyx_v_smooth_;
  int __pyx_v_bloom_;
  int __pyx_v_fast_bloom_;
  unsigned char __pyx_v_bpf_threshold_;
  unsigned int __pyx_v_low_;
  unsigned int __pyx_v_high_;
  int __pyx_v_brightness_;
  float __pyx_v_brightness_intensity_;
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_transpose_;
  int __pyx_v_blur_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cloud_effect (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_width_2,&__pyx_n_s_height_2,&__pyx_n_s_factor,&__pyx_n_s_palette,&__pyx_n_s_cloud,&__pyx_n_s_reduce_factor,&__pyx_n_s_cloud_intensity,&__pyx_n_s_smooth,&__pyx_n_s_bloom,&__pyx_n_s_fast_bloom,&__pyx_n_s_bpf_threshold_2,&__pyx_n_s_low,&__pyx_n_s_high,&__pyx_n_s_brightness,&__pyx_n_s_brightness_intensity,&__pyx_n_s_surface,&__pyx_n_s_transpose,&__pyx_n_s_blur,0};
    PyObject* values[18] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_88cloud_effect(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_cloud_, unsigned short __pyx_v_reduce_factor_, unsigned short __pyx_v_cloud_intensity_, int __pyx_v_smooth_, int __pyx_v_bloom_, int __pyx_v_fast_bloom_, unsigned char __pyx_v_bpf_threshold_, unsigned int __pyx_v_low_, unsigned int __pyx_v_high_, int __pyx_v_brightness_, float __pyx_v_brightness_intensity_, PyObject *__pyx_v_surface_, int __pyx_v_transpose_, int __pyx_v_blur_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cloud_effect", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_palette_.memview)) { __Pyx_RaiseUnboundLocalError("palette_"); __PYX_ERR(1, 1732, __pyx_L1_error) }
  if (unlikely(!__pyx_v_cloud_.memview)) { __Pyx_RaiseUnboundLocalError("cloud_"); __PYX_ERR(1, 1732, __pyx_L1_error) }
  __pyx_t_2.__pyx_n = 13;
  __pyx_t_2.reduce_factor_ = __pyx_v_reduce_factor_;
  __pyx_t_2.cloud_intensity_ = __pyx_v_cloud_intensity_;
  __pyx_t_2.smooth_ = __pyx_v_smooth_;
  __pyx_t_2.bloom_ = __pyx_v_bloom_;
  __pyx_t_2.fast_bloom_ = __pyx_v_fast_bloom_;
  __pyx_t_2.bpf_threshold_ = __pyx_v_bpf_threshold_;
  __pyx_t_2.low_ = __pyx_v_low_;
  __pyx_t_2.high_ = __pyx_v_high_;
  __pyx_t_2.brightness_ = __pyx_v_brightness_;
  __pyx_t_2.brightness_intensity_ = __pyx_v_brightness_intensity_;
  __pyx_t_2.surface_ = __pyx_v_surface_;
  __pyx_t_2.transpose_ = __pyx_v_transpose_;
  __pyx_t_2.blur_ = __pyx_v_blur_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_cloud_effect(__pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_cloud_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1732, __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("PygameShader.shader.cloud_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_cloud_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1733:         int width_,
 1734:         int height_,
 1735:         float factor_,
 1736:         unsigned int [::1] palette_,
 1737:         float [:, ::1] cloud_,
 1738: 
 1739:         # OPTIONAL
 1740:         unsigned short int reduce_factor_   = 2,
 1741:         unsigned short int cloud_intensity_ = 16,
+1742:         bint smooth_                        = True,
  int __pyx_v_smooth_ = ((int)1);
/* … */
      __pyx_v_smooth_ = ((int)1);
    }
    if (values[8]) {
      __pyx_v_bloom_ = __Pyx_PyObject_IsTrue(values[8]); if (unlikely((__pyx_v_bloom_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1743, __pyx_L3_error)
    } else {
+1743:         bint bloom_                         = False,
  int __pyx_v_bloom_ = ((int)0);
/* … */
      __pyx_v_bloom_ = ((int)0);
    }
    if (values[9]) {
      __pyx_v_fast_bloom_ = __Pyx_PyObject_IsTrue(values[9]); if (unlikely((__pyx_v_fast_bloom_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1744, __pyx_L3_error)
    } else {
+1744:         bint fast_bloom_                    = True,
  int __pyx_v_fast_bloom_ = ((int)1);
  unsigned char __pyx_v_bpf_threshold_ = ((unsigned char)0x80);
  unsigned int __pyx_v_low_ = ((unsigned int)0);
  unsigned int __pyx_v_high_ = ((unsigned int)0);
/* … */
      __pyx_v_fast_bloom_ = ((int)1);
    }
    if (values[10]) {
      __pyx_v_bpf_threshold_ = __Pyx_PyInt_As_unsigned_char(values[10]); if (unlikely((__pyx_v_bpf_threshold_ == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 1745, __pyx_L3_error)
    } else {
      __pyx_v_bpf_threshold_ = ((unsigned char)0x80);
    }
    if (values[11]) {
      __pyx_v_low_ = __Pyx_PyInt_As_unsigned_int(values[11]); if (unlikely((__pyx_v_low_ == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1746, __pyx_L3_error)
    } else {
      __pyx_v_low_ = ((unsigned int)0);
    }
    if (values[12]) {
      __pyx_v_high_ = __Pyx_PyInt_As_unsigned_int(values[12]); if (unlikely((__pyx_v_high_ == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1747, __pyx_L3_error)
    } else {
      __pyx_v_high_ = ((unsigned int)0);
    }
    if (values[13]) {
      __pyx_v_brightness_ = __Pyx_PyObject_IsTrue(values[13]); if (unlikely((__pyx_v_brightness_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1748, __pyx_L3_error)
    } else {
 1745:         unsigned char bpf_threshold_        = 128,
 1746:         unsigned int low_                   = 0,
 1747:         unsigned int high_                  = 0,
+1748:         bint brightness_                    = False,
  int __pyx_v_brightness_ = ((int)0);
  float __pyx_v_brightness_intensity_ = ((float)0.0);
/* … */
      __pyx_v_brightness_ = ((int)0);
    }
    if (values[14]) {
      __pyx_v_brightness_intensity_ = __pyx_PyFloat_AsFloat(values[14]); if (unlikely((__pyx_v_brightness_intensity_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1749, __pyx_L3_error)
    } else {
      __pyx_v_brightness_intensity_ = ((float)0.0);
    }
    __pyx_v_surface_ = values[15];
    if (values[16]) {
      __pyx_v_transpose_ = __Pyx_PyObject_IsTrue(values[16]); if (unlikely((__pyx_v_transpose_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1751, __pyx_L3_error)
    } else {
 1749:         float brightness_intensity_         = 0.0,
+1750:         object surface_                     = None,
  PyObject *__pyx_v_surface_ = ((PyObject *)Py_None);
/* … */
    values[15] = ((PyObject *)Py_None);
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case 18: values[17] = PyTuple_GET_ITEM(__pyx_args, 17);
        CYTHON_FALLTHROUGH;
        case 17: values[16] = PyTuple_GET_ITEM(__pyx_args, 16);
        CYTHON_FALLTHROUGH;
        case 16: values[15] = PyTuple_GET_ITEM(__pyx_args, 15);
        CYTHON_FALLTHROUGH;
        case 15: values[14] = PyTuple_GET_ITEM(__pyx_args, 14);
        CYTHON_FALLTHROUGH;
        case 14: values[13] = PyTuple_GET_ITEM(__pyx_args, 13);
        CYTHON_FALLTHROUGH;
        case 13: values[12] = PyTuple_GET_ITEM(__pyx_args, 12);
        CYTHON_FALLTHROUGH;
        case 12: values[11] = PyTuple_GET_ITEM(__pyx_args, 11);
        CYTHON_FALLTHROUGH;
        case 11: values[10] = PyTuple_GET_ITEM(__pyx_args, 10);
        CYTHON_FALLTHROUGH;
        case 10: values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
        CYTHON_FALLTHROUGH;
        case  9: values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
        CYTHON_FALLTHROUGH;
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_width_2)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_height_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("cloud_effect", 0, 5, 18, 1); __PYX_ERR(1, 1732, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("cloud_effect", 0, 5, 18, 2); __PYX_ERR(1, 1732, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_palette)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("cloud_effect", 0, 5, 18, 3); __PYX_ERR(1, 1732, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_cloud)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("cloud_effect", 0, 5, 18, 4); __PYX_ERR(1, 1732, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_reduce_factor);
          if (value) { values[5] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_cloud_intensity);
          if (value) { values[6] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  7:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_smooth);
          if (value) { values[7] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  8:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bloom);
          if (value) { values[8] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  9:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_fast_bloom);
          if (value) { values[9] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 10:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_bpf_threshold_2);
          if (value) { values[10] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 11:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_low);
          if (value) { values[11] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 12:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_high);
          if (value) { values[12] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 13:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_brightness);
          if (value) { values[13] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 14:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_brightness_intensity);
          if (value) { values[14] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 15:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface);
          if (value) { values[15] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 16:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_transpose);
          if (value) { values[16] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case 17:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_blur);
          if (value) { values[17] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "cloud_effect") < 0)) __PYX_ERR(1, 1732, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case 18: values[17] = PyTuple_GET_ITEM(__pyx_args, 17);
        CYTHON_FALLTHROUGH;
        case 17: values[16] = PyTuple_GET_ITEM(__pyx_args, 16);
        CYTHON_FALLTHROUGH;
        case 16: values[15] = PyTuple_GET_ITEM(__pyx_args, 15);
        CYTHON_FALLTHROUGH;
        case 15: values[14] = PyTuple_GET_ITEM(__pyx_args, 14);
        CYTHON_FALLTHROUGH;
        case 14: values[13] = PyTuple_GET_ITEM(__pyx_args, 13);
        CYTHON_FALLTHROUGH;
        case 13: values[12] = PyTuple_GET_ITEM(__pyx_args, 12);
        CYTHON_FALLTHROUGH;
        case 12: values[11] = PyTuple_GET_ITEM(__pyx_args, 11);
        CYTHON_FALLTHROUGH;
        case 11: values[10] = PyTuple_GET_ITEM(__pyx_args, 10);
        CYTHON_FALLTHROUGH;
        case 10: values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
        CYTHON_FALLTHROUGH;
        case  9: values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
        CYTHON_FALLTHROUGH;
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_width_ = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_width_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1733, __pyx_L3_error)
    __pyx_v_height_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_height_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1734, __pyx_L3_error)
    __pyx_v_factor_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_factor_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 1735, __pyx_L3_error)
    __pyx_v_palette_ = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(values[3], PyBUF_WRITABLE); if (unlikely(!__pyx_v_palette_.memview)) __PYX_ERR(1, 1736, __pyx_L3_error)
    __pyx_v_cloud_ = __Pyx_PyObject_to_MemoryviewSlice_d_dc_float(values[4], PyBUF_WRITABLE); if (unlikely(!__pyx_v_cloud_.memview)) __PYX_ERR(1, 1737, __pyx_L3_error)
    if (values[5]) {
      __pyx_v_reduce_factor_ = __Pyx_PyInt_As_unsigned_short(values[5]); if (unlikely((__pyx_v_reduce_factor_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 1740, __pyx_L3_error)
    } else {
      __pyx_v_reduce_factor_ = ((unsigned short)2);
    }
    if (values[6]) {
      __pyx_v_cloud_intensity_ = __Pyx_PyInt_As_unsigned_short(values[6]); if (unlikely((__pyx_v_cloud_intensity_ == (unsigned short)-1) && PyErr_Occurred())) __PYX_ERR(1, 1741, __pyx_L3_error)
    } else {
      __pyx_v_cloud_intensity_ = ((unsigned short)16);
    }
    if (values[7]) {
      __pyx_v_smooth_ = __Pyx_PyObject_IsTrue(values[7]); if (unlikely((__pyx_v_smooth_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1742, __pyx_L3_error)
    } else {
+1751:         bint transpose_                     = False,
  int __pyx_v_transpose_ = ((int)0);
/* … */
      __pyx_v_transpose_ = ((int)0);
    }
    if (values[17]) {
      __pyx_v_blur_ = __Pyx_PyObject_IsTrue(values[17]); if (unlikely((__pyx_v_blur_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 1752, __pyx_L3_error)
    } else {
+1752:         bint blur_                          = True
  int __pyx_v_blur_ = ((int)1);
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cloud_effect", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_cloud_intensity_ = __pyx_optional_args->cloud_intensity_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_smooth_ = __pyx_optional_args->smooth_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_bloom_ = __pyx_optional_args->bloom_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_fast_bloom_ = __pyx_optional_args->fast_bloom_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_bpf_threshold_ = __pyx_optional_args->bpf_threshold_;
                if (__pyx_optional_args->__pyx_n > 6) {
                  __pyx_v_low_ = __pyx_optional_args->low_;
                  if (__pyx_optional_args->__pyx_n > 7) {
                    __pyx_v_high_ = __pyx_optional_args->high_;
                    if (__pyx_optional_args->__pyx_n > 8) {
                      __pyx_v_brightness_ = __pyx_optional_args->brightness_;
                      if (__pyx_optional_args->__pyx_n > 9) {
                        __pyx_v_brightness_intensity_ = __pyx_optional_args->brightness_intensity_;
                        if (__pyx_optional_args->__pyx_n > 10) {
                          __pyx_v_surface_ = __pyx_optional_args->surface_;
                          if (__pyx_optional_args->__pyx_n > 11) {
                            __pyx_v_transpose_ = __pyx_optional_args->transpose_;
                            if (__pyx_optional_args->__pyx_n > 12) {
                              __pyx_v_blur_ = __pyx_optional_args->blur_;
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
/* … */
      __pyx_v_blur_ = ((int)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("cloud_effect", 0, 5, 18, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1732, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.cloud_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_88cloud_effect(__pyx_self, __pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_cloud_, __pyx_v_reduce_factor_, __pyx_v_cloud_intensity_, __pyx_v_smooth_, __pyx_v_bloom_, __pyx_v_fast_bloom_, __pyx_v_bpf_threshold_, __pyx_v_low_, __pyx_v_high_, __pyx_v_brightness_, __pyx_v_brightness_intensity_, __pyx_v_surface_, __pyx_v_transpose_, __pyx_v_blur_);
 1753:         ):
 1754:     """
 1755:     GENERATE CLOUD /SMOKE ON THE GAME DISPLAY 
 1756:     
 1757:     * CLOUD TEXTURE SIZES 
 1758:     
 1759:     input width_  : integer,  
 1760:     input height_ : integer
 1761:     
 1762:     width_ and height_ values define the size of the texture e.g Surface(width x height)
 1763: 
 1764:     * CLOUD ASPECT (CONTROL OVER THE WIDTH): 
 1765:     
 1766:     inputs low_ : integer  
 1767:     input high_ : integer 
 1768:     
 1769:     Optional arguments low_ & high_ (integer values) define the width 's limits of the cloud 
 1770:     effect. low_ for the starting point and high_ for the ending of the effect.
 1771:     e.g low_ = 10 and high_ = 200. The cloud effect will be contain within width = 10 and 200
 1772:     low_ & high_ values must be in range [0 ... width_]  
 1773:         
 1774:     * CLOUD HEIGHT:
 1775:     
 1776:     input factor_ : float
 1777:     
 1778:     The cloud maximum height can be adjust with the variable factor_ (float value)
 1779:     value > 3.95 will contain the effect within the display 
 1780:     value < 3.95 will enlarge the effect over the display height  
 1781:     Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually 
 1782:     to contain the cloud effect within the display
 1783:         
 1784:     * SPEED CONSIDERATION
 1785:     
 1786:     input reduce_factor_ : integer
 1787:     
 1788:     The argument reduce_factor_ control the size of the texture to be processed 
 1789:     e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)
 1790:     Smaller texture improve the overall performances but will slightly degrade the cloud aspect, 
 1791:     especially if the blur and smooth option are not enabled.
 1792:     Recommended value for reduce_factor_ is 3 (fast process)   
 1793:     reduce_factor_ values must be an integer in range [ 0 ... 4] 
 1794:     The reduce_factor_ value will have a significant impact on the cloud effect maximum height, 
 1795:     adjust the argument factor_ accordingly
 1796: 
 1797:     * CLOUD INTENSITY AT THE SOURCE
 1798:     
 1799:     input cloud_intensity_: integer
 1800:     
 1801:     Set the cloud intensity with the variable cloud_intensity_, 0 low flame,
 1802:     32 maximum flame effect
 1803:     Values must be an int in range [0 ... 32] 
 1804: 
 1805:     * SMOOTHING THE EFFECT
 1806:     
 1807:     input smooth_: True | False
 1808:     
 1809:     When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear 
 1810:     filtering) or False the final texture will be adjust with the scale function.
 1811:     Set this variable to False if you need the best performance for the effect or if you require
 1812:     a pixelated cloud effect. Otherwise set the variable to True for a more realistic effect. 
 1813:    
 1814:     * BLOOM EFFECT 
 1815:     
 1816:     input bloom_         : True | False
 1817:     input fast_bloom_    : True | False
 1818:     input bpf_threshold_ : integer
 1819:        
 1820:     Bloom effect produce a bright and smooth light effect to the background texture where the cloud 
 1821:     intensity is at its maximum.
 1822:     Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances
 1823:     The flag fast_bloom_ define a very fast bloom algo using only the smallest texture 
 1824:     to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect 
 1825:     project for more details.
 1826:     When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will 
 1827:     produce a more realistic cloud effect (this will slightly degrade the overall performances). 
 1828:     If the cloud effect is too bright, you can always adjust the bright pass filter value
 1829:     bpf_threshold_(this will adjust the bloom intensity)
 1830:     bpf_threshold_ value must be in range [ 0 ... 255]   
 1831:     Below 128 the bloom effect will be more noticeable and above 128 only the brightest
 1832:     area will be enhanced.
 1833: 
 1834:     * LIGHT EFFECT INTENSITY
 1835: 
 1836:     input brightness_            : True | False
 1837:     input brightness_intensity_  : float
 1838: 
 1839:     When the flag is set to True, the algorithm will use an external function, 
 1840:     <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture
 1841:     A custom color can be passed to the function defining the pixels to be ignored during the 
 1842:     process (default is black color).
 1843:     the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness 
 1844:     of the cloud effect and positive values will increase the brightness of the effect (causing
 1845:     bright white patches on the cloud texture). 
 1846:     Values below -0.4 will cause the cloud effect to be translucent 
 1847:     
 1848:     
 1849:     * OPTIONAL SURFACE
 1850:       
 1851:     input surface_ : pygame.Surface
 1852:       
 1853:     This is an optional surface that can be passed to the shader to improve the performances 
 1854:     and to avoid a new surface to be generated every iterations. The surface size must match 
 1855:     exactly the reduce texture dimensions otherwise an exception will be raise. 
 1856:     see reduce_factor_ option to determine the cloud texture size that will be processed.
 1857:     
 1858: 
 1859:     * CLOUD ORIENTATION / DIRECTION 
 1860:      
 1861:     input transpose_ = True | False,
 1862:     
 1863:     transpose_ = True, this will transpose the final array 
 1864:     for e.g :  
 1865:     If the final cloud texture is (w, h) after setting the transpose flag, the final 
 1866:     cloud texture will become (h, w). As a result the cloud effect will be transversal (starting 
 1867:     from the right of the display to the left side). 
 1868:     You can always transpose / flip the texture to get the right cloud orientation  
 1869:     
 1870:     * FINAL TOUCH
 1871:     
 1872:     input blur_ : True | False
 1873:     
 1874:     This will will blur the cloud effect for a more realistic appearance, remove all the jagged 
 1875:     edge when and pixelated effect
 1876:     
 1877:     :param width_               : integer; Texture size (width) 
 1878:     :param height_              : integer; Texture size (height)
 1879:     :param factor_              : float; Floating value used to control the size of the cloud
 1880:                                   effect. Value must be in range [3.95 ... 4.2]. Value > 3.95 
 1881:                                   will contain the smoke/ cloud effect within the display. 
 1882:                                   Values < 3.95 will enlarge the smoke effect.                              
 1883:     :param palette_             : numpy.ndarray or cython memoryview containing the color for the 
 1884:                                   cloud effect (buffer containing mapped RGB colors (uint values))
 1885:     :param cloud_               : numpy.ndarray shape (w, h) containing float values 
 1886:                                   (cloud intensity). For better performance it is advised to set the
 1887:                                   array to the size of the texture after applying the 
 1888:                                   reduction_factor_. For example if the reduction_factor_ is 2, 
 1889:                                   the texture would have to be width >> 1 and height >> 1 and the 
 1890:                                   cloud_ array should be equivalent to numpy.empty((height >> 1, 
 1891:                                   width >> 1), float32)
 1892:     :param reduce_factor_       : integer; unsigned short int ; Can be either 0, 1, 2, 3, 4. 
 1893:                                   2 and 3 provide the best performance and the best looking effect.
 1894:     :param cloud_intensity_     : integer; Determine the amount of smoke the cloud
 1895:                                   effect will generate at the base of the effect (value must be in 
 1896:                                   range [0 .. 260]). If you provide zero a random value between 
 1897:                                   0 ... 260 will be assigned. If you provide 250, a random value 
 1898:                                   between 250 and 260 will be set for the amount of smoke. 
 1899:                                   The highest the value, the more dense the cloud effect will be
 1900:     :param smooth_              : boolean; True use a smoothscale (bi-linear filtering) or
 1901:                                   False -> scale algorithm jagged edges (mush faster)
 1902:     :param bloom_               : True | False, Add a bloom effect when the flag is set to True
 1903:                                   The bloom effect will smooth the cloud and create a dense smoke 
 1904:                                   areas where the cloud is the brightest.  
 1905:     :param fast_bloom_          : True | False; This set a fast algorithm for the bloom effect (the 
 1906:                                   bloom effect will use the smallest texture)
 1907:     :param bpf_threshold_       : integer; Bright pass filter value must be in range [ 0 ... 255]
 1908:                                   0 produce the maximum bloom effect
 1909:     :param low_                 : integer; must be in range [ 0 ... width_], left position of the 
 1910:                                   cloud effect 
 1911:     :param high_                : integer; must be in range [ 0 ... height_], right position of the
 1912:                                   cloud effect
 1913:     :param brightness_          : True | False; Increase the brightness of the cloud effect when 
 1914:                                   True
 1915:     :param brightness_intensity_: float; Set the brightness intensity of the cloud. The value must 
 1916:                                   be in range [-1.0 ... +1.0]. Changing the value overtime will 
 1917:                                   generate a realistic cloud effect. Negative value will generate 
 1918:                                   translucent patch of smoke on the background image
 1919:     :param surface_             : Pygame.Surface; Pass a surface to the shader for
 1920:                                   better performance, otherwise a new surface will be created each 
 1921:                                   calls.
 1922:     :param transpose_           : boolean; Transpose the array (w, h) become (h, w).
 1923:                                   The cloud effect will start from the left and move to the right
 1924:     :param blur_                : boolean; Blur the cloud effect
 1925:     :return                     : Return a pygame surface that can be blit directly to the game 
 1926:                                   display
 1927:     """
 1928: 
+1929:     assert reduce_factor_ in (0, 1, 2, 3, 4), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    switch (__pyx_v_reduce_factor_) {
      case 0:
      case 1:
      case 2:
      case 3:
      case 4:
      __pyx_t_1 = 1;
      break;
      default:
      __pyx_t_1 = 0;
      break;
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_reduce_factor_must_be_i);
      __PYX_ERR(1, 1929, __pyx_L1_error)
    }
  }
  #endif
 1930:         "Argument reduce factor must be in range 0 ... 4 " \
 1931:         "\n reduce_factor_ = 1 correspond to dividing the image size by 2" \
 1932:         "\n reduce_factor_ = 2 correspond to dividing the image size by 4"
 1933: 
+1934:     assert width_ > 0 and height_ > 0, "Argument width or height cannot be null or < 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = ((__pyx_v_width_ > 0) != 0);
    if (__pyx_t_2) {
    } else {
      __pyx_t_1 = __pyx_t_2;
      goto __pyx_L3_bool_binop_done;
    }
    __pyx_t_2 = ((__pyx_v_height_ > 0) != 0);
    __pyx_t_1 = __pyx_t_2;
    __pyx_L3_bool_binop_done:;
    if (unlikely(!__pyx_t_1)) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_width_or_height_cannot);
      __PYX_ERR(1, 1934, __pyx_L1_error)
    }
  }
  #endif
+1935:     assert factor_ > 0, "Argument factor_ cannot be null or < 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_factor_ > 0.0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_factor__cannot_be_null);
      __PYX_ERR(1, 1935, __pyx_L1_error)
    }
  }
  #endif
 1936: 
+1937:     return shader_cloud_effect_c(
  __Pyx_XDECREF(__pyx_r);
/* … */
  __pyx_t_4.__pyx_n = 13;
  __pyx_t_4.reduce_factor_ = __pyx_v_reduce_factor_;
  __pyx_t_4.cloud_intensity_ = __pyx_v_cloud_intensity_;
  __pyx_t_4.smooth_ = __pyx_v_smooth_;
  __pyx_t_4.bloom_ = __pyx_v_bloom_;
  __pyx_t_4.fast_bloom_ = __pyx_v_fast_bloom_;
  __pyx_t_4.bpf_threshold_ = __pyx_v_bpf_threshold_;
  __pyx_t_4.low_ = __pyx_v_low_;
  __pyx_t_4.high_ = __pyx_v_high_;
  __pyx_t_4.brightness_ = __pyx_v_brightness_;
  __pyx_t_4.brightness_intensity_ = __pyx_v_brightness_intensity_;
  __pyx_t_4.surface_ = __pyx_v_surface_;
  __pyx_t_4.transpose_ = __pyx_v_transpose_;
  __pyx_t_4.blur_ = __pyx_v_blur_;
  __pyx_t_3 = __pyx_f_12PygameShader_6shader_shader_cloud_effect_c(__pyx_v_width_, __pyx_v_height_, __pyx_v_factor_, __pyx_v_palette_, __pyx_v_cloud_, &__pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1937, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 1938:         width_, height_, factor_, palette_, cloud_,
 1939:         reduce_factor_, cloud_intensity_, smooth_,
 1940:         bloom_, fast_bloom_, bpf_threshold_, low_, high_, brightness_,
 1941:         brightness_intensity_, surface_, transpose_, blur_
 1942:     )
 1943: 
 1944: 
 1945: 
+1946: cpdef inline mirroring_array(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_91mirroring_array(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_mirroring_array(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring_array", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_AddTraceback("PygameShader.shader.mirroring_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_91mirroring_array(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_90mirroring_array[] = "\n    \n    SHADER MIRRORING\n\n    This method create a mirror image \n    \n    Compatible 24 - 32 bit image / surface\n    \n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return         : returns a numpy ndarray shape (w, h, 3) \n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_91mirroring_array(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring_array (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_90mirroring_array(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_90mirroring_array(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring_array", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_mirroring_array(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1946, __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("PygameShader.shader.mirroring_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1947:     """
 1948:     
 1949:     SHADER MIRRORING
 1950: 
 1951:     This method create a mirror image 
 1952:     
 1953:     Compatible 24 - 32 bit image / surface
 1954:     
 1955:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 1956:     :return         : returns a numpy ndarray shape (w, h, 3) 
 1957:     
 1958:     """
+1959:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1959, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1959, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1959, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1960:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1960, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1959, __pyx_L1_error)
    }
  }
  #endif
 1961: 
+1962:     return mirroring_c(pixels3d(surface_))
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1962, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __pyx_f_12PygameShader_6shader_mirroring_c(__pyx_t_5); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;
 1963: 
 1964: 
 1965: 
 1966: 
+1967: cpdef inline void mirroring(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_93mirroring(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_mirroring(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.mirroring", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_93mirroring(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_92mirroring[] = "\n    SHADER MIRRORING (INPLACE)\n\n    This method create a mirror image \n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_93mirroring(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_92mirroring(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_92mirroring(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_mirroring(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1967, __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("PygameShader.shader.mirroring", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1968:     """
 1969:     SHADER MIRRORING (INPLACE)
 1970: 
 1971:     This method create a mirror image 
 1972: 
 1973:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 1974:     :return : void
 1975:     """
+1976:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1976, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1977:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1977, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1976, __pyx_L1_error)
    }
  }
  #endif
 1978: 
+1979:     mirroring_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1979, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1979, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1979, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __pyx_f_12PygameShader_6shader_mirroring_inplace_c(__pyx_t_5); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1979, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 1980: 
 1981: # cpdef inline transpose_inplace(object surface_):
 1982: #     return tranpose_c(pixels3d(surface_))
 1983: 
 1984: 
 1985: 
 1986: 
+1987: cpdef inline void sharpen(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_95sharpen(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_sharpen(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sharpen", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.sharpen", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_95sharpen(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_94sharpen[] = "\n    \n    SHARPEN IMAGE APPLYING THE BELOW 3 X 3 KERNEL OVER EVERY PIXELS.\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return         : void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_95sharpen(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sharpen (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_94sharpen(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_94sharpen(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("sharpen", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_sharpen(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1987, __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("PygameShader.shader.sharpen", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 1988:     """
 1989:     
 1990:     SHARPEN IMAGE APPLYING THE BELOW 3 X 3 KERNEL OVER EVERY PIXELS.
 1991: 
 1992:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 1993:     :return         : void 
 1994:     """
+1995:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1995, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1995, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 1995, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+1996:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1996, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 1995, __pyx_L1_error)
    }
  }
  #endif
 1997: 
+1998:     shader_sharpen_filter_inplace_c(pixels3d(surface_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1998, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 1998, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 1998, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_f_12PygameShader_6shader_shader_sharpen_filter_inplace_c(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 1999: 
 2000: 
+2001: cpdef inline void dirt_lens(
static PyObject *__pyx_pw_12PygameShader_6shader_97dirt_lens(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_dirt_lens(PyObject *__pyx_v_surface_, PyObject *__pyx_v_lens_model_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_dirt_lens *__pyx_optional_args) {
  int __pyx_v_flag_ = __pyx_k__15;
  float __pyx_v_light_ = ((float)0.0);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dirt_lens", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_flag_ = __pyx_optional_args->flag_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_light_ = __pyx_optional_args->light_;
      }
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.dirt_lens", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_97dirt_lens(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_96dirt_lens[] = "\n    DIRT LENS EFFECT \n    \n    This function display a dirt lens texture on the top of your game display to \n    simulate a camera artefact or realistic camera effect when the light from the\n    scene is oriented directly toward the camera. \n    \n    Choose a lens texture from the Assets directory (free textures provided in Assets directory \n    of this project). All textures are sizes 5184x3456 and would have to be re-sized to  \n    your game display and used by function `dirt_lens`. \n    The function dirt_lens will not resize the texture for you.\n    \n    The setting light_ is a float values cap between -1.0 to 0.2 and allow you to increase the \n    light source oriented toward the camera. Values <0.0 will decrease the lens dirt \n    effect and values >0.0 will increase the brightness of the display and increase the \n    amount of dirt on the camera lens (your display).\n    \n    Optionally the setting flag_ can be changed from BLEND_RGB_ADD to any other pygame optional \n    flags value. BLEND_RGB_ADD is the default setting and allow the pixels from the dirt lens \n    texture to be blended (added) to the display and provide the brightest and better looking \n    effect. \n    \n    This effect can be used for real time rendering for surfaces resolution 1024x768  \n    \n    Assets/Bokeh__Lens_Dirt_9.jpg\n    Assets/Bokeh__Lens_Dirt_38.jpg\n    Assets/Bokeh__Lens_Dirt_46.jpg\n    Assets/Bokeh__Lens_Dirt_50.jpg\n    Assets/Bokeh__Lens_Dirt_54.jpg\n    Assets/Bokeh__Lens_Dirt_67.jpg\n    \n    :param surface_   : Surface 24 - 32 bit represent the surface or the display \n    \n    :param lens_model_: Surface The Lens model is a pygame Surface. PygameShader provide a 6 \n     different surfaces that can be used as a layer to generate a dirt lens effect on your game \n     display. See above for the name of the free dirt lens textures. \n     The texture has to be loaded prior calling this effect and passed as an argument. By default \n     the textu""res sizes are 5184x3456 (width & height). The texture would have also to be re-scale \n     once to the game display dimensions (e.g 1027x768) or to the size of your texture.\n     \n    :param flag_      : integer; pygame flags such as BLEND_RGB_ADD, BLEND_RGB_MAX etc. These flags \n     will change the overall appearance of the effect blending the dirt lens\n     image with a different mathematical expression. BLEND_RGB_ADD is the \n     default flag and blend together the dirt_lens and the game display \n     providing a very bright aspect and vivid effect.\n    \n    :param light_     : float; Float value cap between [-1.0 ... 0.2] to increase or decrease \n     the overall brightness of the dirt lens texture. Tis setting can be used to simulate a \n     texture transition when sweeping the values from -1.0 toward 0.2 by a small increment.\n     Values < 0 will tend to diminish the effect and values > 0 will increase the brightness \n     and the dirt lens effect. \n     \n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_97dirt_lens(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  PyObject *__pyx_v_lens_model_ = 0;
  int __pyx_v_flag_;
  float __pyx_v_light_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dirt_lens (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_lens_model,&__pyx_n_s_flag,&__pyx_n_s_light,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_lens_model)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("dirt_lens", 0, 2, 4, 1); __PYX_ERR(1, 2001, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_flag);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_light);
          if (value) { values[3] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "dirt_lens") < 0)) __PYX_ERR(1, 2001, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_lens_model_ = values[1];
    if (values[2]) {
      __pyx_v_flag_ = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_flag_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2004, __pyx_L3_error)
    } else {
      __pyx_v_flag_ = __pyx_k__15;
    }
    if (values[3]) {
      __pyx_v_light_ = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_light_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 2005, __pyx_L3_error)
    } else {
      __pyx_v_light_ = ((float)0.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dirt_lens", 0, 2, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2001, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.dirt_lens", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_96dirt_lens(__pyx_self, __pyx_v_surface_, __pyx_v_lens_model_, __pyx_v_flag_, __pyx_v_light_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_96dirt_lens(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, PyObject *__pyx_v_lens_model_, int __pyx_v_flag_, float __pyx_v_light_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dirt_lens", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 2;
  __pyx_t_1.flag_ = __pyx_v_flag_;
  __pyx_t_1.light_ = __pyx_v_light_;
  __pyx_f_12PygameShader_6shader_dirt_lens(__pyx_v_surface_, __pyx_v_lens_model_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2001, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.dirt_lens", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2002:         object surface_,
 2003:         object lens_model_,
+2004:         int flag_=BLEND_RGB_ADD,
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 2004, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_33); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2004, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_k__15 = __pyx_t_7;
/* … */
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 2004, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
/* … */
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_33); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2004, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_k__15 = __pyx_t_7;
 2005:         float light_ = 0.0
 2006: ):
 2007:     """
 2008:     DIRT LENS EFFECT 
 2009:     
 2010:     This function display a dirt lens texture on the top of your game display to 
 2011:     simulate a camera artefact or realistic camera effect when the light from the
 2012:     scene is oriented directly toward the camera. 
 2013:     
 2014:     Choose a lens texture from the Assets directory (free textures provided in Assets directory 
 2015:     of this project). All textures are sizes 5184x3456 and would have to be re-sized to  
 2016:     your game display and used by function `dirt_lens`. 
 2017:     The function dirt_lens will not resize the texture for you.
 2018:     
 2019:     The setting light_ is a float values cap between -1.0 to 0.2 and allow you to increase the 
 2020:     light source oriented toward the camera. Values <0.0 will decrease the lens dirt 
 2021:     effect and values >0.0 will increase the brightness of the display and increase the 
 2022:     amount of dirt on the camera lens (your display).
 2023:     
 2024:     Optionally the setting flag_ can be changed from BLEND_RGB_ADD to any other pygame optional 
 2025:     flags value. BLEND_RGB_ADD is the default setting and allow the pixels from the dirt lens 
 2026:     texture to be blended (added) to the display and provide the brightest and better looking 
 2027:     effect. 
 2028:     
 2029:     This effect can be used for real time rendering for surfaces resolution 1024x768  
 2030:     
 2031:     Assets/Bokeh__Lens_Dirt_9.jpg
 2032:     Assets/Bokeh__Lens_Dirt_38.jpg
 2033:     Assets/Bokeh__Lens_Dirt_46.jpg
 2034:     Assets/Bokeh__Lens_Dirt_50.jpg
 2035:     Assets/Bokeh__Lens_Dirt_54.jpg
 2036:     Assets/Bokeh__Lens_Dirt_67.jpg
 2037:     
 2038:     :param surface_   : Surface 24 - 32 bit represent the surface or the display 
 2039:     
 2040:     :param lens_model_: Surface The Lens model is a pygame Surface. PygameShader provide a 6 
 2041:      different surfaces that can be used as a layer to generate a dirt lens effect on your game 
 2042:      display. See above for the name of the free dirt lens textures. 
 2043:      The texture has to be loaded prior calling this effect and passed as an argument. By default 
 2044:      the textures sizes are 5184x3456 (width & height). The texture would have also to be re-scale 
 2045:      once to the game display dimensions (e.g 1027x768) or to the size of your texture.
 2046:      
 2047:     :param flag_      : integer; pygame flags such as BLEND_RGB_ADD, BLEND_RGB_MAX etc. These flags 
 2048:      will change the overall appearance of the effect blending the dirt lens
 2049:      image with a different mathematical expression. BLEND_RGB_ADD is the 
 2050:      default flag and blend together the dirt_lens and the game display 
 2051:      providing a very bright aspect and vivid effect.
 2052:     
 2053:     :param light_     : float; Float value cap between [-1.0 ... 0.2] to increase or decrease 
 2054:      the overall brightness of the dirt lens texture. Tis setting can be used to simulate a 
 2055:      texture transition when sweeping the values from -1.0 toward 0.2 by a small increment.
 2056:      Values < 0 will tend to diminish the effect and values > 0 will increase the brightness 
 2057:      and the dirt lens effect. 
 2058:      
 2059:     :return: void 
 2060:     """
+2061:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2061, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2061, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2061, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2062:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2062, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2061, __pyx_L1_error)
    }
  }
  #endif
 2063: 
+2064:     assert PyObject_IsInstance(lens_model_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_pygame); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2064, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2064, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_lens_model_, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2064, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2065:         "\nArgument lens_model_ must be a pygame.Surface type, got %s " % type(lens_model_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_lens_model__must_be_a, ((PyObject *)Py_TYPE(__pyx_v_lens_model_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2065, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2064, __pyx_L1_error)
    }
  }
  #endif
 2066: 
+2067:     assert PyObject_IsInstance(light_, float), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = PyFloat_FromDouble(__pyx_v_light_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2067, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_1, ((PyObject *)(&PyFloat_Type))); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2067, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2068:         "\nArgument light_ must be a float type, got %s " % type(light_)
      __pyx_t_1 = PyFloat_FromDouble(__pyx_v_light_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2068, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_light__must_be_a_float, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2068, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2067, __pyx_L1_error)
    }
  }
  #endif
 2069: 
+2070:     if light_ > 0.2:
  __pyx_t_3 = ((__pyx_v_light_ > 0.2) != 0);
  if (__pyx_t_3) {
/* … */
    goto __pyx_L3;
  }
+2071:         light_ = 0.2
    __pyx_v_light_ = 0.2;
+2072:     elif light_ < -1.0:
  __pyx_t_3 = ((__pyx_v_light_ < -1.0) != 0);
  if (__pyx_t_3) {
/* … */
  }
  __pyx_L3:;
+2073:         light_ = 1.0
    __pyx_v_light_ = 1.0;
 2074: 
+2075:     assert PyObject_IsInstance(flag_, int), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_flag_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2075, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyObject_IsInstance(__pyx_t_2, ((PyObject *)(&PyInt_Type))); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2075, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2076:         "\nArgument flag_ must be a int type, got %s " % type(flag_)
      __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_flag_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2076, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_flag__must_be_a_int_ty, ((PyObject *)Py_TYPE(__pyx_t_2))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2076, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2075, __pyx_L1_error)
    }
  }
  #endif
 2077: 
+2078:     dirt_lens_c(surface_, lens_model_, flag_, light_)
  __pyx_t_4.__pyx_n = 1;
  __pyx_t_4.light_ = __pyx_v_light_;
  __pyx_f_12PygameShader_6shader_dirt_lens_c(__pyx_v_surface_, __pyx_v_lens_model_, __pyx_v_flag_, &__pyx_t_4); 
 2079: 
 2080: 
 2081: # *******************************************************************
 2082: 
 2083: @cython.binding(False)
 2084: @cython.boundscheck(False)
 2085: @cython.wraparound(False)
 2086: @cython.nonecheck(False)
 2087: @cython.cdivision(True)
+2088: cpdef inline void end_game(object surface):
static PyObject *__pyx_pw_12PygameShader_6shader_99end_game(PyObject *__pyx_self, PyObject *__pyx_v_surface); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_end_game(CYTHON_UNUSED PyObject *__pyx_v_surface, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("end_game", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_WriteUnraisable("PygameShader.shader.end_game", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_99end_game(PyObject *__pyx_self, PyObject *__pyx_v_surface); /*proto*/
static char __pyx_doc_12PygameShader_6shader_98end_game[] = "\n    \n    :param surface: \n    :return: \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_99end_game(PyObject *__pyx_self, PyObject *__pyx_v_surface) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("end_game (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_98end_game(__pyx_self, ((PyObject *)__pyx_v_surface));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_98end_game(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("end_game", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_end_game(__pyx_v_surface, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2088, __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("PygameShader.shader.end_game", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2089:     """
 2090:     
 2091:     :param surface: 
 2092:     :return: 
 2093:     """
+2094:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2094, __pyx_L1_error)
 2095: 
 2096: @cython.binding(False)
 2097: @cython.boundscheck(False)
 2098: @cython.wraparound(False)
 2099: @cython.nonecheck(False)
 2100: @cython.cdivision(True)
+2101: cpdef inline void level_clear(object surface):
static PyObject *__pyx_pw_12PygameShader_6shader_101level_clear(PyObject *__pyx_self, PyObject *__pyx_v_surface); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_level_clear(CYTHON_UNUSED PyObject *__pyx_v_surface, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("level_clear", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_WriteUnraisable("PygameShader.shader.level_clear", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_101level_clear(PyObject *__pyx_self, PyObject *__pyx_v_surface); /*proto*/
static char __pyx_doc_12PygameShader_6shader_100level_clear[] = "\n    \n    :param surface: \n    :return: \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_101level_clear(PyObject *__pyx_self, PyObject *__pyx_v_surface) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("level_clear (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_100level_clear(__pyx_self, ((PyObject *)__pyx_v_surface));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_100level_clear(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("level_clear", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_level_clear(__pyx_v_surface, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2101, __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("PygameShader.shader.level_clear", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2102:     """
 2103:     
 2104:     :param surface: 
 2105:     :return: 
 2106:     """
+2107:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2107, __pyx_L1_error)
 2108: 
 2109: @cython.binding(False)
 2110: @cython.boundscheck(False)
 2111: @cython.wraparound(False)
 2112: @cython.nonecheck(False)
 2113: @cython.cdivision(True)
+2114: cpdef object dithering(object surface_, int factor_=2):
static PyObject *__pyx_pw_12PygameShader_6shader_103dithering(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_dithering(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_dithering *__pyx_optional_args) {
  int __pyx_v_factor_ = ((int)2);
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_factor_ = __pyx_optional_args->factor_;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __Pyx_AddTraceback("PygameShader.shader.dithering", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_103dithering(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_102dithering[] = "\n    Dithering is used in computer graphics to create the illusion of \"color depth\" in images with\n    a limited color palette - a technique also known as color quantization. In a dithered image,\n    colors that are not available in the palette are approximated by a diffusion of colored pixels\n    from within the available palette. The human eye perceives the diffusion as a mixture of \n    the colors within it (see color vision). Dithered images, particularly those with relatively\n     few colors, can often be distinguished by a characteristic graininess or speckled appearance\n    \n    Take a pygame surface as argument format 24-32 bit and convert it to a 3d array format \n    (w, h, 3) type float (float32, single precision). \n    As the image is converted to a different data type format (uint8 to float32), \n    the transformation cannot be applied inplace. The image returned by the method dithering \n    is a copy of the original image.   \n    \n    :param surface_: Pygame surface format 24-32 bit \n    :param factor_ : integer; Value must be > 1 otherwise an exception will be thrown \n    :return        : Surface; \n    \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_103dithering(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_factor_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_factor,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "dithering") < 0)) __PYX_ERR(1, 2114, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_factor_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_factor_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2114, __pyx_L3_error)
    } else {
      __pyx_v_factor_ = ((int)2);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dithering", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2114, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.dithering", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_102dithering(__pyx_self, __pyx_v_surface_, __pyx_v_factor_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_102dithering(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_factor_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.factor_ = __pyx_v_factor_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_dithering(__pyx_v_surface_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2114, __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("PygameShader.shader.dithering", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2115: 
 2116:     """
 2117:     Dithering is used in computer graphics to create the illusion of "color depth" in images with
 2118:     a limited color palette - a technique also known as color quantization. In a dithered image,
 2119:     colors that are not available in the palette are approximated by a diffusion of colored pixels
 2120:     from within the available palette. The human eye perceives the diffusion as a mixture of 
 2121:     the colors within it (see color vision). Dithered images, particularly those with relatively
 2122:      few colors, can often be distinguished by a characteristic graininess or speckled appearance
 2123:     
 2124:     Take a pygame surface as argument format 24-32 bit and convert it to a 3d array format 
 2125:     (w, h, 3) type float (float32, single precision). 
 2126:     As the image is converted to a different data type format (uint8 to float32), 
 2127:     the transformation cannot be applied inplace. The image returned by the method dithering 
 2128:     is a copy of the original image.   
 2129:     
 2130:     :param surface_: Pygame surface format 24-32 bit 
 2131:     :param factor_ : integer; Value must be > 1 otherwise an exception will be thrown 
 2132:     :return        : Surface; 
 2133:     
 2134:     """
+2135:     assert PyObject_IsInstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2135, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2135, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2136:         'Argument surface_ must be a pygame.Surface got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyga, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2136, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2135, __pyx_L1_error)
    }
  }
  #endif
 2137: 
+2138:     assert PyObject_IsInstance(factor_, int), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_factor_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2138, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_t_1, ((PyObject *)(&PyInt_Type))); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2138, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2139:         'Argument factor_ must be an int got %s ' % type(factor_)
      __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_factor_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2139, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_factor__must_be_an_int, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2139, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 2138, __pyx_L1_error)
    }
  }
  #endif
 2140: 
+2141:     assert factor_ > 1, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_factor_ > 1) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_factor__must_be_1);
      __PYX_ERR(1, 2141, __pyx_L1_error)
    }
  }
  #endif
 2142:         "Argument factor_ must be > 1"
 2143: 
+2144:     return dithering_c(numpy.divide(pixels3d(surface_), 255.0).astype(float32), factor_)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_divide); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_7)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
    }
  }
  __pyx_t_4 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_6, __pyx_t_7, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = NULL;
  __pyx_t_8 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
      __pyx_t_8 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_4, __pyx_float_255_0};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_8, 2+__pyx_t_8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2144, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_4, __pyx_float_255_0};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_8, 2+__pyx_t_8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2144, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_7 = PyTuple_New(2+__pyx_t_8); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 2144, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (__pyx_t_6) {
      __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __pyx_t_6 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_8, __pyx_t_4);
    __Pyx_INCREF(__pyx_float_255_0);
    __Pyx_GIVEREF(__pyx_float_255_0);
    PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_8, __pyx_float_255_0);
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_7, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2144, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_astype); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_float32); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_7 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_7)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_3 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_7, __pyx_t_1) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_float(__pyx_t_3, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __pyx_f_12PygameShader_6shader_dithering_c(__pyx_t_9, __pyx_v_factor_); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2144, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 2145: 
 2146: @cython.binding(False)
 2147: @cython.boundscheck(False)
 2148: @cython.wraparound(False)
 2149: @cython.nonecheck(False)
 2150: @cython.cdivision(True)
+2151: cpdef inline void dithering_int(object surface_, int factor_=2):
static PyObject *__pyx_pw_12PygameShader_6shader_105dithering_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_dithering_int(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_dithering_int *__pyx_optional_args) {
  int __pyx_v_factor_ = ((int)2);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering_int", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_factor_ = __pyx_optional_args->factor_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.dithering_int", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_105dithering_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_104dithering_int[] = "\n    Dithering is used in computer graphics to create the illusion of \"color depth\" in images with\n    a limited color palette - a technique also known as color quantization. In a dithered image,\n    colors that are not available in the palette are approximated by a diffusion of colored pixels\n    from within the available palette. The human eye perceives the diffusion as a mixture of \n    the colors within it (see color vision). Dithered images, particularly those with relatively\n     few colors, can often be distinguished by a characteristic graininess or speckled appearance\n\n    Take a pygame surface as argument format 24-32 bit and convert it to a 3d array format \n    (w, h, 3) type float (float32, single precision). \n    As the image is converted to a different data type format (uint8 to float32), \n    the transformation cannot be applied inplace. The image returned by the method dithering \n    is a copy of the original image.   \n\n    :param surface_: Pygame surface format 24-32 bit \n    :param factor_ : integer; Value must be > 1 otherwise an exception will be thrown \n    :return        : Surface; \n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_105dithering_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_factor_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering_int (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_factor,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_factor);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "dithering_int") < 0)) __PYX_ERR(1, 2151, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_factor_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_factor_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2151, __pyx_L3_error)
    } else {
      __pyx_v_factor_ = ((int)2);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dithering_int", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2151, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.dithering_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_104dithering_int(__pyx_self, __pyx_v_surface_, __pyx_v_factor_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_104dithering_int(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_factor_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering_int", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.factor_ = __pyx_v_factor_;
  __pyx_f_12PygameShader_6shader_dithering_int(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2151, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.dithering_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2152:     """
 2153:     Dithering is used in computer graphics to create the illusion of "color depth" in images with
 2154:     a limited color palette - a technique also known as color quantization. In a dithered image,
 2155:     colors that are not available in the palette are approximated by a diffusion of colored pixels
 2156:     from within the available palette. The human eye perceives the diffusion as a mixture of 
 2157:     the colors within it (see color vision). Dithered images, particularly those with relatively
 2158:      few colors, can often be distinguished by a characteristic graininess or speckled appearance
 2159: 
 2160:     Take a pygame surface as argument format 24-32 bit and convert it to a 3d array format 
 2161:     (w, h, 3) type float (float32, single precision). 
 2162:     As the image is converted to a different data type format (uint8 to float32), 
 2163:     the transformation cannot be applied inplace. The image returned by the method dithering 
 2164:     is a copy of the original image.   
 2165: 
 2166:     :param surface_: Pygame surface format 24-32 bit 
 2167:     :param factor_ : integer; Value must be > 1 otherwise an exception will be thrown 
 2168:     :return        : Surface; 
 2169: 
 2170:     """
+2171:     assert PyObject_IsInstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2171, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2171, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2172:         'Argument surface_ must be a pygame.Surface got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyga, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2172, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2171, __pyx_L1_error)
    }
  }
  #endif
 2173: 
+2174:     assert PyObject_IsInstance(factor_, int), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_factor_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2174, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_t_1, ((PyObject *)(&PyInt_Type))); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2174, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2175:         'Argument factor_ must be an int got %s ' % type(factor_)
      __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_factor_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2175, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_factor__must_be_an_int, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2175, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 2174, __pyx_L1_error)
    }
  }
  #endif
 2176: 
+2177:     assert factor_ > 1, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_factor_ > 1) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_factor__must_be_1);
      __PYX_ERR(1, 2177, __pyx_L1_error)
    }
  }
  #endif
 2178:         "Argument factor_ must be > 1"
 2179: 
+2180:     dithering_int_c(pixels3d(surface_), factor_)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2180, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_4, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2180, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_3, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 2180, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_f_12PygameShader_6shader_dithering_int_c(__pyx_t_5, __pyx_v_factor_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
 2181: 
 2182: @cython.binding(False)
 2183: @cython.boundscheck(False)
 2184: @cython.wraparound(False)
 2185: @cython.nonecheck(False)
 2186: @cython.cdivision(True)
+2187: cpdef object pixelation(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_107pixelation(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_pixelation(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  PyObject *__pyx_v_small = 0;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("pixelation", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_AddTraceback("PygameShader.shader.pixelation", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_small);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_107pixelation(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_106pixelation[] = "\n    Pixelate a pygame.Surface \n    \n    This method cannot be used for the game display as the change \n    is applied in a new Surface\n    \n    :param surface_: pygame.Surface; \n    :return: pixelated surface\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_107pixelation(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("pixelation (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_106pixelation(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_106pixelation(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("pixelation", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_pixelation(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2187, __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("PygameShader.shader.pixelation", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2188:     """
 2189:     Pixelate a pygame.Surface 
 2190:     
 2191:     This method cannot be used for the game display as the change 
 2192:     is applied in a new Surface
 2193:     
 2194:     :param surface_: pygame.Surface; 
 2195:     :return: pixelated surface
 2196:     """
+2197:     assert PyObject_IsInstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2197, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2197, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2198:         'Argument surface_ must be a pygame.Surface got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyga, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2198, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2197, __pyx_L1_error)
    }
  }
  #endif
 2199: 
 2200:     cdef Py_ssize_t w, h
 2201:     # todo percentage of pixelation
+2202:     w, h = surface_.get_size()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2202, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2202, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 2202, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_3 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_4);
    #else
    __pyx_t_3 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2202, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2202, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_5 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2202, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_6 = Py_TYPE(__pyx_t_5)->tp_iternext;
    index = 0; __pyx_t_3 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    index = 1; __pyx_t_4 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_4)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_6(__pyx_t_5), 2) < 0) __PYX_ERR(1, 2202, __pyx_L1_error)
    __pyx_t_6 = NULL;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_6 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 2202, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 2202, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyIndex_AsSsize_t(__pyx_t_4); if (unlikely((__pyx_t_8 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 2202, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_w = __pyx_t_7;
  __pyx_v_h = __pyx_t_8;
+2203:     cdef object small = smoothscale(surface_, (32, 32))
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_surface_, __pyx_tuple__16};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2203, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_surface_, __pyx_tuple__16};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2203, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
  } else
  #endif
  {
    __pyx_t_5 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2203, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface_);
    __Pyx_GIVEREF(__pyx_v_surface_);
    PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_9, __pyx_v_surface_);
    __Pyx_INCREF(__pyx_tuple__16);
    __Pyx_GIVEREF(__pyx_tuple__16);
    PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_9, __pyx_tuple__16);
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2203, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_small = __pyx_t_1;
  __pyx_t_1 = 0;
/* … */
  __pyx_tuple__16 = PyTuple_Pack(2, __pyx_int_32, __pyx_int_32); if (unlikely(!__pyx_tuple__16)) __PYX_ERR(1, 2203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__16);
  __Pyx_GIVEREF(__pyx_tuple__16);
+2204:     return scale(small, (w, h))
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_scale); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2204, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2204, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2204, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_10 = PyTuple_New(2); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 2204, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_10, 1, __pyx_t_3);
  __pyx_t_5 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_small, __pyx_t_10};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2204, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_small, __pyx_t_10};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2204, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  } else
  #endif
  {
    __pyx_t_5 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2204, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_INCREF(__pyx_v_small);
    __Pyx_GIVEREF(__pyx_v_small);
    PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_9, __pyx_v_small);
    __Pyx_GIVEREF(__pyx_t_10);
    PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_9, __pyx_t_10);
    __pyx_t_10 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2204, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 2205: 
 2206: @cython.binding(False)
 2207: @cython.boundscheck(False)
 2208: @cython.wraparound(False)
 2209: @cython.nonecheck(False)
 2210: @cython.cdivision(True)
+2211: cpdef inline zoom_in(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_109zoom_in(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_zoom_in(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("zoom_in", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.zoom_in", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_109zoom_in(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_108zoom_in[] = "\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_109zoom_in(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("zoom_in (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_108zoom_in(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_108zoom_in(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("zoom_in", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_zoom_in(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2211, __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("PygameShader.shader.zoom_in", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2212:     """
 2213: 
 2214:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 2215:     :return:
 2216:     """
+2217:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2217, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2217, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2217, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2218:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2218, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2217, __pyx_L1_error)
    }
  }
  #endif
 2219: 
+2220:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2220, __pyx_L1_error)
 2221: 
 2222: 
 2223: @cython.binding(False)
 2224: @cython.boundscheck(False)
 2225: @cython.wraparound(False)
 2226: @cython.nonecheck(False)
 2227: @cython.cdivision(True)
+2228: cpdef inline electric(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_111electric(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_electric(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("electric", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.electric", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_111electric(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_110electric[] = "\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_111electric(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("electric (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_110electric(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_110electric(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("electric", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_electric(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2228, __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("PygameShader.shader.electric", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2229:     """
 2230: 
 2231:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 2232:     :return:
 2233:     """
+2234:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2234, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2234, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2234, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2235:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2235, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2234, __pyx_L1_error)
    }
  }
  #endif
 2236: 
+2237:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2237, __pyx_L1_error)
 2238: 
 2239: 
 2240: @cython.binding(False)
 2241: @cython.boundscheck(False)
 2242: @cython.wraparound(False)
 2243: @cython.nonecheck(False)
 2244: @cython.cdivision(True)
+2245: cpdef inline filmstrips(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_113filmstrips(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_filmstrips(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("filmstrips", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.filmstrips", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_113filmstrips(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_112filmstrips[] = "\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_113filmstrips(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("filmstrips (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_112filmstrips(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_112filmstrips(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("filmstrips", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_filmstrips(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2245, __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("PygameShader.shader.filmstrips", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2246:     """
 2247: 
 2248:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 2249:     :return:
 2250:     """
+2251:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2251, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2252:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2252, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2251, __pyx_L1_error)
    }
  }
  #endif
 2253: 
+2254:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2254, __pyx_L1_error)
 2255: 
 2256: 
 2257: @cython.binding(False)
 2258: @cython.boundscheck(False)
 2259: @cython.wraparound(False)
 2260: @cython.nonecheck(False)
 2261: @cython.cdivision(True)
+2262: cpdef cubism(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_115cubism(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_cubism(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cubism", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.cubism", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_115cubism(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_114cubism[] = "\n\n    :param surface_ : pygame.Surface; compatible 24 - 32 bit \n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_115cubism(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cubism (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_114cubism(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_114cubism(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cubism", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_cubism(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2262, __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("PygameShader.shader.cubism", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2263:     """
 2264: 
 2265:     :param surface_ : pygame.Surface; compatible 24 - 32 bit 
 2266:     :return:
 2267:     """
+2268:     assert isinstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2268, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2268, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2268, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2269:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2269, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2268, __pyx_L1_error)
    }
  }
  #endif
+2270:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2270, __pyx_L1_error)
 2271: 
 2272: 
 2273: @cython.binding(False)
 2274: @cython.boundscheck(False)
 2275: @cython.wraparound(False)
 2276: @cython.nonecheck(False)
 2277: @cython.cdivision(True)
+2278: cpdef code_listing(object surface_, size_):
static PyObject *__pyx_pw_12PygameShader_6shader_117code_listing(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_code_listing(PyObject *__pyx_v_surface_, CYTHON_UNUSED PyObject *__pyx_v_size_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("code_listing", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.code_listing", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_117code_listing(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_116code_listing[] = "\n\n    :param surface_: pygame.Surface; compatible 24 - 32 bit \n    :param size_:\n    :return:\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_117code_listing(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  PyObject *__pyx_v_size_ = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("code_listing (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_size_2,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_size_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("code_listing", 1, 2, 2, 1); __PYX_ERR(1, 2278, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "code_listing") < 0)) __PYX_ERR(1, 2278, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_size_ = values[1];
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("code_listing", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2278, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.code_listing", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_116code_listing(__pyx_self, __pyx_v_surface_, __pyx_v_size_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_116code_listing(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, PyObject *__pyx_v_size_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("code_listing", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_code_listing(__pyx_v_surface_, __pyx_v_size_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2278, __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("PygameShader.shader.code_listing", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2279:     """
 2280: 
 2281:     :param surface_: pygame.Surface; compatible 24 - 32 bit 
 2282:     :param size_:
 2283:     :return:
 2284:     """
+2285:     assert PyObject_IsInstance(surface_, pygame.Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pygame); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2285, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2285, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_2); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(1, 2285, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!(__pyx_t_3 != 0))) {
+2286:         "\nArgument surface_ must be a pygame.Surface type, got %s " % type(surface_)
      __pyx_t_2 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_pyg, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 2286, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 2285, __pyx_L1_error)
    }
  }
  #endif
 2287: 
+2288:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2288, __pyx_L1_error)
 2289: 
 2290: @cython.binding(False)
 2291: @cython.boundscheck(False)
 2292: @cython.wraparound(False)
 2293: @cython.nonecheck(False)
 2294: @cython.cdivision(True)
+2295: cpdef ascii_char(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_119ascii_char(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_ascii_char(CYTHON_UNUSED PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ascii_char", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_AddTraceback("PygameShader.shader.ascii_char", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_119ascii_char(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_118ascii_char[] = "\n    \n    :param surface_: \n    :return: \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_119ascii_char(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ascii_char (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_118ascii_char(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_118ascii_char(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("ascii_char", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_ascii_char(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2295, __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("PygameShader.shader.ascii_char", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2296:     """
 2297:     
 2298:     :param surface_: 
 2299:     :return: 
 2300:     """
+2301:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2301, __pyx_L1_error)
 2302: 
 2303: @cython.binding(False)
 2304: @cython.boundscheck(False)
 2305: @cython.wraparound(False)
 2306: @cython.nonecheck(False)
 2307: @cython.cdivision(True)
+2308: cpdef object blend(object source_, object destination_, float percentage_):
static PyObject *__pyx_pw_12PygameShader_6shader_121blend(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_blend(PyObject *__pyx_v_source_, PyObject *__pyx_v_destination_, float __pyx_v_percentage_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blend", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("PygameShader.shader.blend", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_121blend(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_120blend[] = "\n    BLEND A SOURCE TEXTURE TOWARD A DESTINATION TEXTURE \n    \n    The shader create a new image from both source_ and destination_\n\n    * Video system must be initialised \n    * source_ & destination_ Textures must be same sizes\n    * Compatible with 24 - 32 bit surface\n    * Output create a new surface\n    * Image returned is converted for fast blit (convert())\n\n    :param source_     : pygame.Surface (Source)\n    :param destination_: pygame.Surface (Destination)\n    :param percentage_ : float; Percentage value between [0.0 ... 100.0]\n    :return: return    : Return a 24 bit pygame.Surface and blended with a percentage\n                         of the destination texture.\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_121blend(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_source_ = 0;
  PyObject *__pyx_v_destination_ = 0;
  float __pyx_v_percentage_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blend (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_source,&__pyx_n_s_destination,&__pyx_n_s_percentage,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_source)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_destination)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("blend", 1, 3, 3, 1); __PYX_ERR(1, 2308, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_percentage)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("blend", 1, 3, 3, 2); __PYX_ERR(1, 2308, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "blend") < 0)) __PYX_ERR(1, 2308, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_source_ = values[0];
    __pyx_v_destination_ = values[1];
    __pyx_v_percentage_ = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_percentage_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 2308, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("blend", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2308, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.blend", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_120blend(__pyx_self, __pyx_v_source_, __pyx_v_destination_, __pyx_v_percentage_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_120blend(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_source_, PyObject *__pyx_v_destination_, float __pyx_v_percentage_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blend", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_blend(__pyx_v_source_, __pyx_v_destination_, __pyx_v_percentage_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2308, __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("PygameShader.shader.blend", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2309:     """
 2310:     BLEND A SOURCE TEXTURE TOWARD A DESTINATION TEXTURE 
 2311:     
 2312:     The shader create a new image from both source_ and destination_
 2313: 
 2314:     * Video system must be initialised 
 2315:     * source_ & destination_ Textures must be same sizes
 2316:     * Compatible with 24 - 32 bit surface
 2317:     * Output create a new surface
 2318:     * Image returned is converted for fast blit (convert())
 2319: 
 2320:     :param source_     : pygame.Surface (Source)
 2321:     :param destination_: pygame.Surface (Destination)
 2322:     :param percentage_ : float; Percentage value between [0.0 ... 100.0]
 2323:     :return: return    : Return a 24 bit pygame.Surface and blended with a percentage
 2324:                          of the destination texture.
 2325:     """
+2326:     assert PyObject_IsInstance(source_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2326, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_source_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2326, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2327:         'Argument source_ must be a pygame.Surface got %s ' % type(source_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_source__must_be_a_pygam, ((PyObject *)Py_TYPE(__pyx_v_source_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2327, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2326, __pyx_L1_error)
    }
  }
  #endif
 2328: 
+2329:     assert PyObject_IsInstance(destination_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2329, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_destination_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2329, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2330:         'Argument destination_ must be a pygame.Surface got %s ' % type(destination_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_destination__must_be_a, ((PyObject *)Py_TYPE(__pyx_v_destination_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2330, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2329, __pyx_L1_error)
    }
  }
  #endif
 2331: 
+2332:     assert 0.0 <= percentage_ <= 100.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_2 = (0.0 <= __pyx_v_percentage_);
    if (__pyx_t_2) {
      __pyx_t_2 = (__pyx_v_percentage_ <= 100.0);
    }
    if (unlikely(!(__pyx_t_2 != 0))) {
+2333:         "\nIncorrect value for argument percentage should be [0.0 ... 100.0] got %s " % percentage_
      __pyx_t_1 = PyFloat_FromDouble(__pyx_v_percentage_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2333, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyString_Format(__pyx_kp_s_Incorrect_value_for_argument_pe, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2333, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 2332, __pyx_L1_error)
    }
  }
  #endif
 2334: 
+2335:     if percentage_ == 0.0:
  __pyx_t_2 = ((__pyx_v_percentage_ == 0.0) != 0);
  if (__pyx_t_2) {
/* … */
  }
+2336:         return source_
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_source_);
    __pyx_r = __pyx_v_source_;
    goto __pyx_L0;
 2337: 
+2338:     assert source_.get_size() == destination_.get_size(), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_source_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_1, function);
      }
    }
    __pyx_t_3 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_destination_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_4);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_4, function);
      }
    }
    __pyx_t_1 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_4);
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = PyObject_RichCompare(__pyx_t_3, __pyx_t_1, Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(1, 2338, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_2)) {
 2339:         'Source and Destination surfaces must have same dimensions: ' \
+2340:         'Source (w:%s, h:%s), destination (w:%s, h:%s).' % \
      __pyx_t_1 = __Pyx_PyString_Format(__pyx_kp_s_Source_and_Destination_surfaces, __pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2340, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2338, __pyx_L1_error)
    }
  }
  #endif
+2341:         (*source_.get_size(), *destination_.get_size())
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_source_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_5 = NULL;
      if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
        __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
        if (likely(__pyx_t_5)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
          __Pyx_INCREF(__pyx_t_5);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_3, function);
        }
      }
      __pyx_t_1 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_4 = PySequence_List(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_destination_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_5 = NULL;
      if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
        __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
        if (likely(__pyx_t_5)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
          __Pyx_INCREF(__pyx_t_5);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_3, function);
        }
      }
      __pyx_t_1 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (__Pyx_PyList_Extend(__pyx_t_4, __pyx_t_1) < 0) __PYX_ERR(1, 2341, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      {
        PyObject *__pyx_temp = PyList_AsTuple(__pyx_t_4);
        __Pyx_DECREF(__pyx_t_4);
        __pyx_t_4 = __pyx_temp; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2341, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
 2342: 
+2343:     return blending(source_, destination_, percentage_)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_blending(__pyx_v_source_, __pyx_v_destination_, __pyx_v_percentage_); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2343, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 2344: 
 2345: 
 2346: 
 2347: @cython.binding(False)
 2348: @cython.boundscheck(False)
 2349: @cython.wraparound(False)
 2350: @cython.nonecheck(False)
 2351: @cython.cdivision(True)
+2352: cpdef cartoon(
static PyObject *__pyx_pw_12PygameShader_6shader_123cartoon(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_cartoon(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_cartoon *__pyx_optional_args) {
  int __pyx_v_sobel_threshold_ = ((int)0x80);
  int __pyx_v_median_kernel_ = ((int)2);
  PyObject *__pyx_v_color_ = ((PyObject *)__pyx_int_8);
  PyObject *__pyx_v_flag_ = __pyx_k__17;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cartoon", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_sobel_threshold_ = __pyx_optional_args->sobel_threshold_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_median_kernel_ = __pyx_optional_args->median_kernel_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_color_ = __pyx_optional_args->color_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_flag_ = __pyx_optional_args->flag_;
          }
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("PygameShader.shader.cartoon", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_123cartoon(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_122cartoon[] = "\n    CREATE A CARTOON EFFECT FROM A GIVEN SURFACE \n    \n    * This shader cannot be use online or real time due to the amout of \n      transformation. You can use this shader while editing your textures \n      befre the main loop \n    \n    * Compatible with 24 - 32 bit image \n    \n    :param surface_: pygame.Surface compatible 24 - 32 bit \n    :param sobel_threshold_: integer sobel threshold\n    :param median_kernel_  : integer median kernel  \n    :param color_          : integer; color reduction value (max color)\n    :param flag_           : integer; Blend flag e.g (BLEND_RGB_ADD, BLEND_RGB_SUB, \n                             BLEND_RGB_MULT, BLEND_RGB_MAX, BLEND_RGB_MIN  \n    :return                : Return a pygame Surface with the cartoon effect \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_123cartoon(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_sobel_threshold_;
  int __pyx_v_median_kernel_;
  PyObject *__pyx_v_color_ = 0;
  PyObject *__pyx_v_flag_ = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cartoon (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_sobel_threshold_2,&__pyx_n_s_median_kernel,&__pyx_n_s_color,&__pyx_n_s_flag,0};
    PyObject* values[5] = {0,0,0,0,0};
    values[3] = ((PyObject *)__pyx_int_8);
    values[4] = __pyx_k__17;
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sobel_threshold_2);
          if (value) { values[1] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_median_kernel);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_color);
          if (value) { values[3] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_flag);
          if (value) { values[4] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "cartoon") < 0)) __PYX_ERR(1, 2352, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_sobel_threshold_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_sobel_threshold_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2354, __pyx_L3_error)
    } else {
      __pyx_v_sobel_threshold_ = ((int)0x80);
    }
    if (values[2]) {
      __pyx_v_median_kernel_ = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_median_kernel_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2355, __pyx_L3_error)
    } else {
      __pyx_v_median_kernel_ = ((int)2);
    }
    __pyx_v_color_ = values[3];
    __pyx_v_flag_ = values[4];
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("cartoon", 0, 1, 5, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2352, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.cartoon", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_122cartoon(__pyx_self, __pyx_v_surface_, __pyx_v_sobel_threshold_, __pyx_v_median_kernel_, __pyx_v_color_, __pyx_v_flag_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_122cartoon(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_sobel_threshold_, int __pyx_v_median_kernel_, PyObject *__pyx_v_color_, PyObject *__pyx_v_flag_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cartoon", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 4;
  __pyx_t_2.sobel_threshold_ = __pyx_v_sobel_threshold_;
  __pyx_t_2.median_kernel_ = __pyx_v_median_kernel_;
  __pyx_t_2.color_ = __pyx_v_color_;
  __pyx_t_2.flag_ = __pyx_v_flag_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_cartoon(__pyx_v_surface_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2352, __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("PygameShader.shader.cartoon", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2353:         object surface_,
 2354:         int sobel_threshold_ = 128,
 2355:         int median_kernel_   = 2,
 2356:         color_               = 8,
+2357:         flag_                = BLEND_RGB_ADD
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 2357, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __pyx_k__17 = __pyx_t_33;
  __Pyx_GIVEREF(__pyx_t_33);
  __pyx_t_33 = 0;
/* … */
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 2357, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __pyx_k__17 = __pyx_t_33;
  __Pyx_GIVEREF(__pyx_t_33);
  __pyx_t_33 = 0;
 2358: ):
 2359:     """
 2360:     CREATE A CARTOON EFFECT FROM A GIVEN SURFACE 
 2361:     
 2362:     * This shader cannot be use online or real time due to the amout of 
 2363:       transformation. You can use this shader while editing your textures 
 2364:       befre the main loop 
 2365:     
 2366:     * Compatible with 24 - 32 bit image 
 2367:     
 2368:     :param surface_: pygame.Surface compatible 24 - 32 bit 
 2369:     :param sobel_threshold_: integer sobel threshold
 2370:     :param median_kernel_  : integer median kernel  
 2371:     :param color_          : integer; color reduction value (max color)
 2372:     :param flag_           : integer; Blend flag e.g (BLEND_RGB_ADD, BLEND_RGB_SUB, 
 2373:                              BLEND_RGB_MULT, BLEND_RGB_MAX, BLEND_RGB_MIN  
 2374:     :return                : Return a pygame Surface with the cartoon effect 
 2375:     """
 2376: 
+2377:     return cartoon_effect(surface_, sobel_threshold_, median_kernel_, color_, flag_)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_As_int(__pyx_v_color_); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2377, __pyx_L1_error)
  __pyx_t_2 = __Pyx_PyInt_As_int(__pyx_v_flag_); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2377, __pyx_L1_error)
  __pyx_t_3 = __pyx_f_12PygameShader_6shader_cartoon_effect(__pyx_v_surface_, __pyx_v_sobel_threshold_, __pyx_v_median_kernel_, __pyx_t_1, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2377, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 2378: 
 2379: 
 2380: @cython.binding(False)
 2381: @cython.boundscheck(False)
 2382: @cython.wraparound(False)
 2383: @cython.nonecheck(False)
 2384: @cython.cdivision(True)
+2385: cpdef explode(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_125explode(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_explode(CYTHON_UNUSED PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("explode", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_AddTraceback("PygameShader.shader.explode", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_125explode(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_124explode[] = "\n\n    :param surface_: \n    :return: \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_125explode(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("explode (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_124explode(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_124explode(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("explode", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_explode(__pyx_v_surface_, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2385, __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("PygameShader.shader.explode", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2386:     """
 2387: 
 2388:     :param surface_: 
 2389:     :return: 
 2390:     """
+2391:     raise NotImplementedError
  __Pyx_Raise(__pyx_builtin_NotImplementedError, 0, 0, 0);
  __PYX_ERR(1, 2391, __pyx_L1_error)
 2392: 
 2393: @cython.binding(False)
 2394: @cython.boundscheck(False)
 2395: @cython.wraparound(False)
 2396: @cython.nonecheck(False)
 2397: @cython.cdivision(True)
+2398: cpdef object spectrum(int width, int height, float gamma=1.0):
static PyObject *__pyx_pw_12PygameShader_6shader_127spectrum(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_spectrum(int __pyx_v_width, int __pyx_v_height, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_spectrum *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("spectrum", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("PygameShader.shader.spectrum", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_127spectrum(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_126spectrum[] = "\n    CREATE A PYGAME SURFACE DISPLAYING THE LIGHT SPECTRUM 380-750 nm\n\n    Color   Wavelength(nm) Frequency(THz)\n    Red     620-750        484-400\n    Orange  590-620        508-484\n    Yellow  570-590        526-508\n    Green   495-570        606-526\n    Blue    450-495        668-606\n    Violet  380-450        789-668\n\n    :param width: integer; width of the image\n    :param height: integer; height of the image\n    :param gamma: float; gamma value \n    :return: Return a pygame surface 24-bit (width, height) converted for fast \n    blit \n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_127spectrum(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_width;
  int __pyx_v_height;
  float __pyx_v_gamma;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("spectrum (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_width,&__pyx_n_s_height,&__pyx_n_s_gamma,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_width)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_height)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("spectrum", 0, 2, 3, 1); __PYX_ERR(1, 2398, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_gamma);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "spectrum") < 0)) __PYX_ERR(1, 2398, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_width = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_width == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2398, __pyx_L3_error)
    __pyx_v_height = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_height == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2398, __pyx_L3_error)
    if (values[2]) {
      __pyx_v_gamma = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_gamma == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 2398, __pyx_L3_error)
    } else {
      __pyx_v_gamma = ((float)1.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("spectrum", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2398, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.spectrum", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_126spectrum(__pyx_self, __pyx_v_width, __pyx_v_height, __pyx_v_gamma);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_126spectrum(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_width, int __pyx_v_height, float __pyx_v_gamma) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("spectrum", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_spectrum(__pyx_v_width, __pyx_v_height, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2398, __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("PygameShader.shader.spectrum", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2399:     """
 2400:     CREATE A PYGAME SURFACE DISPLAYING THE LIGHT SPECTRUM 380-750 nm
 2401: 
 2402:     Color   Wavelength(nm) Frequency(THz)
 2403:     Red     620-750        484-400
 2404:     Orange  590-620        508-484
 2405:     Yellow  570-590        526-508
 2406:     Green   495-570        606-526
 2407:     Blue    450-495        668-606
 2408:     Violet  380-450        789-668
 2409: 
 2410:     :param width: integer; width of the image
 2411:     :param height: integer; height of the image
 2412:     :param gamma: float; gamma value 
 2413:     :return: Return a pygame surface 24-bit (width, height) converted for fast 
 2414:     blit 
 2415: 
 2416:     """
 2417: 
+2418:     return spectrum_c(width, height, gamma)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_spectrum_c(__pyx_v_width, __pyx_v_height, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2418, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 2419: 
 2420: 
 2421: @cython.boundscheck(False)
 2422: @cython.wraparound(False)
 2423: @cython.nonecheck(False)
 2424: @cython.cdivision(True)
+2425: cpdef inline void convert_27colors(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_129convert_27colors(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_convert_27colors(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_v_array_ = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("convert_27colors", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.convert_27colors", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_array_);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_129convert_27colors(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_128convert_27colors[] = "\n    THIS ALGORITHM CONVERT AN IMAGE USING 27 COLORS ONLY\n\n    :param surface_: numpy.ndarray; containing the pixels RGB. Array shape (w, h, 3)  \n    :return: void \n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_129convert_27colors(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("convert_27colors (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_128convert_27colors(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_128convert_27colors(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("convert_27colors", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_convert_27colors(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2425, __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("PygameShader.shader.convert_27colors", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2426: 
 2427:     """
 2428:     THIS ALGORITHM CONVERT AN IMAGE USING 27 COLORS ONLY
 2429: 
 2430:     :param surface_: numpy.ndarray; containing the pixels RGB. Array shape (w, h, 3)  
 2431:     :return: void 
 2432:     """
+2433:     assert isinstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2433, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2433, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2434:         'Argument surface_ must be a valid Surface, got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_vali, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2434, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2433, __pyx_L1_error)
    }
  }
  #endif
 2435: 
+2436:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_3);
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }
+2437:         array_ = pixels3d(surface_)
      __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2437, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_7 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_6);
        if (likely(__pyx_t_7)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
          __Pyx_INCREF(__pyx_t_7);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_6, function);
        }
      }
      __pyx_t_1 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_6, __pyx_t_7, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_v_surface_);
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2437, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __pyx_v_array_ = __pyx_t_1;
      __pyx_t_1 = 0;
 2438: 
+2439:     except (pygame.error, ValueError):
    __Pyx_ErrFetch(&__pyx_t_1, &__pyx_t_6, &__pyx_t_7);
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_pygame); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 2439, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_error); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2439, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_t_9) || __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_builtin_ValueError);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_ErrRestore(__pyx_t_1, __pyx_t_6, __pyx_t_7);
    __pyx_t_1 = 0; __pyx_t_6 = 0; __pyx_t_7 = 0;
    if (__pyx_t_10) {
      __Pyx_AddTraceback("PygameShader.shader.convert_27colors", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_6, &__pyx_t_1) < 0) __PYX_ERR(1, 2439, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_GOTREF(__pyx_t_1);
+2440:         raise ValueError('\nTexture/image is not compatible.')
      __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2440, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_Raise(__pyx_t_9, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __PYX_ERR(1, 2440, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;
    __pyx_L5_except_error:;
/* … */
  __pyx_tuple__18 = PyTuple_Pack(1, __pyx_kp_s_Texture_image_is_not_compatible); if (unlikely(!__pyx_tuple__18)) __PYX_ERR(1, 2440, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__18);
  __Pyx_GIVEREF(__pyx_tuple__18);
 2441: 
+2442:     convert_27colors_c(array_)
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2442, __pyx_L1_error)
  __pyx_f_12PygameShader_6shader_convert_27colors_c(__pyx_t_11);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 2443: 
 2444: 
 2445: 
 2446: @cython.boundscheck(False)
 2447: @cython.wraparound(False)
 2448: @cython.nonecheck(False)
 2449: @cython.cdivision(True)
+2450: cpdef object bilateral(object image, float sigma_s, float sigma_i):
static PyObject *__pyx_pw_12PygameShader_6shader_131bilateral(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_bilateral(PyObject *__pyx_v_image, float __pyx_v_sigma_s, float __pyx_v_sigma_i, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_v_array_ = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bilateral", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_AddTraceback("PygameShader.shader.bilateral", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_array_);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_131bilateral(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_130bilateral[] = "\n    A bilateral filter is a non-linear, edge-preserving, and noise-reducing\n    smoothing filter for images. It replaces the intensity of each pixel with a\n    weighted average of intensity values from nearby pixels. This weight can be\n    based on a Gaussian distribution.\n\n    Here, the normalization factor and the range weight are new terms added to \n    the previous equation. sigma_s  denotes the spatial extent of the kernel, i.e. \n    the size of the neighborhood, and sigma_r  denotes the minimum amplitude of an edge.\n    It ensures that only those pixels with intensity values similar to that of the\n    central pixel are considered for blurring, while sharp intensity changes are maintained.\n    The smaller the value of sigma_i ( or sigma_r), the sharper the edge. As sigma_r  tends to \n    infinity, the equation tends to a Gaussian blur.\n       \n    e.g:\n    \n    bilateral(surface, sigma_s = 16, sigma_i = 18)\n    \n    :param image: Surface, Pygame Surface format 24-32 bit format (alpha channel will be ignored)\n    \n    :param sigma_s: float sigma_s : Spatial extent of the kernel, size of the \n    considered neighborhood\n    \n    :param sigma_i: float sigma_i (also call sigma_r) range kernel, minimum amplitude of an edge.\n    \n    :return: return a filtered Surface\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_131bilateral(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_image = 0;
  float __pyx_v_sigma_s;
  float __pyx_v_sigma_i;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bilateral (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_image,&__pyx_n_s_sigma_s,&__pyx_n_s_sigma_i,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_image)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sigma_s)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("bilateral", 1, 3, 3, 1); __PYX_ERR(1, 2450, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_sigma_i)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("bilateral", 1, 3, 3, 2); __PYX_ERR(1, 2450, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "bilateral") < 0)) __PYX_ERR(1, 2450, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_image = values[0];
    __pyx_v_sigma_s = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_sigma_s == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 2450, __pyx_L3_error)
    __pyx_v_sigma_i = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_sigma_i == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 2450, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("bilateral", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2450, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.bilateral", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_130bilateral(__pyx_self, __pyx_v_image, __pyx_v_sigma_s, __pyx_v_sigma_i);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_130bilateral(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_image, float __pyx_v_sigma_s, float __pyx_v_sigma_i) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bilateral", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_bilateral(__pyx_v_image, __pyx_v_sigma_s, __pyx_v_sigma_i, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2450, __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("PygameShader.shader.bilateral", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2451:     """
 2452:     A bilateral filter is a non-linear, edge-preserving, and noise-reducing
 2453:     smoothing filter for images. It replaces the intensity of each pixel with a
 2454:     weighted average of intensity values from nearby pixels. This weight can be
 2455:     based on a Gaussian distribution.
 2456: 
 2457:     Here, the normalization factor and the range weight are new terms added to 
 2458:     the previous equation. sigma_s  denotes the spatial extent of the kernel, i.e. 
 2459:     the size of the neighborhood, and sigma_r  denotes the minimum amplitude of an edge.
 2460:     It ensures that only those pixels with intensity values similar to that of the
 2461:     central pixel are considered for blurring, while sharp intensity changes are maintained.
 2462:     The smaller the value of sigma_i ( or sigma_r), the sharper the edge. As sigma_r  tends to 
 2463:     infinity, the equation tends to a Gaussian blur.
 2464:        
 2465:     e.g:
 2466:     
 2467:     bilateral(surface, sigma_s = 16, sigma_i = 18)
 2468:     
 2469:     :param image: Surface, Pygame Surface format 24-32 bit format (alpha channel will be ignored)
 2470:     
 2471:     :param sigma_s: float sigma_s : Spatial extent of the kernel, size of the 
 2472:     considered neighborhood
 2473:     
 2474:     :param sigma_i: float sigma_i (also call sigma_r) range kernel, minimum amplitude of an edge.
 2475:     
 2476:     :return: return a filtered Surface
 2477:     """
 2478: 
+2479:     assert isinstance(image, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2479, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_image, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2479, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2480:         'Argument image must be a valid Surface, got %s ' % type(image)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_image_must_be_a_valid_S, ((PyObject *)Py_TYPE(__pyx_v_image))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2480, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2479, __pyx_L1_error)
    }
  }
  #endif
 2481: 
+2482:     assert isinstance(sigma_s, float), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = PyFloat_FromDouble(__pyx_v_sigma_s); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2482, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyFloat_Check(__pyx_t_1); 
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2483:         'Argument sigma_s must be a valid Surface, got %s ' % type(sigma_s)
      __pyx_t_1 = PyFloat_FromDouble(__pyx_v_sigma_s); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2483, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_sigma_s_must_be_a_valid, ((PyObject *)Py_TYPE(__pyx_t_1))); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2483, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 2482, __pyx_L1_error)
    }
  }
  #endif
 2484: 
+2485:     assert isinstance(sigma_i, float), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_3 = PyFloat_FromDouble(__pyx_v_sigma_i); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2485, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_2 = PyFloat_Check(__pyx_t_3); 
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2486:         'Argument sigma_i must be a valid Surface, got %s ' % type(sigma_i)
      __pyx_t_3 = PyFloat_FromDouble(__pyx_v_sigma_i); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2486, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_sigma_i_must_be_a_valid, ((PyObject *)Py_TYPE(__pyx_t_3))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2486, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2485, __pyx_L1_error)
    }
  }
  #endif
 2487: 
+2488:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }
+2489:         array_ = pixels3d(image)
      __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2489, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_7 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_3);
        if (likely(__pyx_t_7)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
          __Pyx_INCREF(__pyx_t_7);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_3, function);
        }
      }
      __pyx_t_1 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_7, __pyx_v_image) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_image);
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2489, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_v_array_ = __pyx_t_1;
      __pyx_t_1 = 0;
 2490: 
+2491:     except (pygame.error, ValueError):
    __Pyx_ErrFetch(&__pyx_t_1, &__pyx_t_3, &__pyx_t_7);
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_pygame); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 2491, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_error); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2491, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_t_9) || __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_builtin_ValueError);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_ErrRestore(__pyx_t_1, __pyx_t_3, __pyx_t_7);
    __pyx_t_1 = 0; __pyx_t_3 = 0; __pyx_t_7 = 0;
    if (__pyx_t_10) {
      __Pyx_AddTraceback("PygameShader.shader.bilateral", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_3, &__pyx_t_1) < 0) __PYX_ERR(1, 2491, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_GOTREF(__pyx_t_1);
+2492:         raise ValueError('\nTexture/image is not compatible.')
      __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2492, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_Raise(__pyx_t_9, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __PYX_ERR(1, 2492, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;
    __pyx_L5_except_error:;
 2493: 
 2494: 
+2495:     return bilateral_filter24_c(array_, sigma_s, sigma_i)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2495, __pyx_L1_error)
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_bilateral_filter24_c(__pyx_t_11, __pyx_v_sigma_s, __pyx_v_sigma_i); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2495, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 2496: 
 2497: @cython.boundscheck(False)
 2498: @cython.wraparound(False)
 2499: @cython.nonecheck(False)
 2500: @cython.cdivision(True)
+2501: cpdef object emboss(object surface_, unsigned int flag=0):
static PyObject *__pyx_pw_12PygameShader_6shader_133emboss(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_emboss(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_emboss *__pyx_optional_args) {
  unsigned int __pyx_v_flag = ((unsigned int)0);
  PyObject *__pyx_v_array_ = NULL;
  PyObject *__pyx_v_emb = 0;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("emboss", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_flag = __pyx_optional_args->flag;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_AddTraceback("PygameShader.shader.emboss", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_array_);
  __Pyx_XDECREF(__pyx_v_emb);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_133emboss(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_132emboss[] = "\n    EMBOSS A PYGAME SURFACE \n    \n    :param surface_: pygame.Surface; compatible 24-32 bit\n    :param flag    : integer; special pygame flag such as BLEND_RGB_ADD, BLEND_RGB_MULT etc\n    :return        : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_133emboss(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  unsigned int __pyx_v_flag;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("emboss (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_flag_2,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_flag_2);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "emboss") < 0)) __PYX_ERR(1, 2501, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_flag = __Pyx_PyInt_As_unsigned_int(values[1]); if (unlikely((__pyx_v_flag == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 2501, __pyx_L3_error)
    } else {
      __pyx_v_flag = ((unsigned int)0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("emboss", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2501, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.emboss", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_132emboss(__pyx_self, __pyx_v_surface_, __pyx_v_flag);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_132emboss(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, unsigned int __pyx_v_flag) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("emboss", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.flag = __pyx_v_flag;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_emboss(__pyx_v_surface_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2501, __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("PygameShader.shader.emboss", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2502:     """
 2503:     EMBOSS A PYGAME SURFACE 
 2504:     
 2505:     :param surface_: pygame.Surface; compatible 24-32 bit
 2506:     :param flag    : integer; special pygame flag such as BLEND_RGB_ADD, BLEND_RGB_MULT etc
 2507:     :return        : void
 2508:     """
 2509: 
+2510:     assert isinstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2510, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2510, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2511:         'Argument surface_ must be a valid Surface, got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_vali, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2511, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2510, __pyx_L1_error)
    }
  }
  #endif
 2512: 
+2513:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_3);
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_4, __pyx_t_5);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }
+2514:         array_ = pixels3d(surface_)
      __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2514, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_7 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_6);
        if (likely(__pyx_t_7)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
          __Pyx_INCREF(__pyx_t_7);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_6, function);
        }
      }
      __pyx_t_1 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_6, __pyx_t_7, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_v_surface_);
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2514, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __pyx_v_array_ = __pyx_t_1;
      __pyx_t_1 = 0;
 2515: 
+2516:     except (pygame.error, ValueError):
    __Pyx_ErrFetch(&__pyx_t_1, &__pyx_t_6, &__pyx_t_7);
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_pygame); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 2516, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_error); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2516, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_t_9) || __Pyx_PyErr_GivenExceptionMatches(__pyx_t_1, __pyx_builtin_ValueError);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_ErrRestore(__pyx_t_1, __pyx_t_6, __pyx_t_7);
    __pyx_t_1 = 0; __pyx_t_6 = 0; __pyx_t_7 = 0;
    if (__pyx_t_10) {
      __Pyx_AddTraceback("PygameShader.shader.emboss", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_6, &__pyx_t_1) < 0) __PYX_ERR(1, 2516, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_GOTREF(__pyx_t_1);
+2517:         raise ValueError('\nTexture/image is not compatible.')
      __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2517, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_Raise(__pyx_t_9, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __PYX_ERR(1, 2517, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;
    __pyx_L5_except_error:;
 2518: 
+2519:     cdef object emb = emboss5x5_c(array_)
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2519, __pyx_L1_error)
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_emboss5x5_c(__pyx_t_11); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2519, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
  __pyx_v_emb = __pyx_t_1;
  __pyx_t_1 = 0;
 2520: 
+2521:     if flag != 0:
  __pyx_t_2 = ((__pyx_v_flag != 0) != 0);
  if (__pyx_t_2) {
/* … */
  }
+2522:         del array_
    __Pyx_DECREF(__pyx_v_array_);
    __pyx_v_array_ = NULL;
+2523:         surface_.blit(emb, (0, 0), special_flags=flag)
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_INCREF(__pyx_v_emb);
    __Pyx_GIVEREF(__pyx_v_emb);
    PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_v_emb);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_tuple__12);
    __pyx_t_7 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_9 = __Pyx_PyInt_From_unsigned_int(__pyx_v_flag); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_special_flags, __pyx_t_9) < 0) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2523, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
+2524:         return surface_
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_surface_);
    __pyx_r = __pyx_v_surface_;
    goto __pyx_L0;
 2525: 
+2526:     return emboss5x5_c(array_)
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2526, __pyx_L1_error)
  __pyx_t_9 = __pyx_f_12PygameShader_6shader_emboss5x5_c(__pyx_t_11); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2526, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
  __pyx_r = __pyx_t_9;
  __pyx_t_9 = 0;
  goto __pyx_L0;
 2527: 
 2528: 
 2529: 
 2530: 
 2531: @cython.binding(False)
 2532: @cython.boundscheck(False)
 2533: @cython.wraparound(False)
 2534: @cython.nonecheck(False)
 2535: @cython.cdivision(True)
+2536: cpdef void palette_change(
static PyObject *__pyx_pw_12PygameShader_6shader_135palette_change(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static void __pyx_f_12PygameShader_6shader_palette_change(PyObject *__pyx_v_surface_, PyObject *__pyx_v_palette_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_v_array_ = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("palette_change", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_12, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.palette_change", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_array_);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_135palette_change(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_134palette_change[] = "\n    CHANGE AN IMAGE BY CHANGING THE COLOR PALETTE \n    \n    LIST_PALETTES contains all the palettes available\n    in the project.\n    \n    e.g: \n    from PygameShader.Palette import LIST_PALETTES\n    print(LIST_PALETTES.keys())\n    \n    :param surface_: pygame.Surface; \n    :param palette_: numpy.ndarray containing all the RGB color values \n    :return: void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_135palette_change(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  PyObject *__pyx_v_palette_ = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("palette_change (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_palette,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_palette)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("palette_change", 1, 2, 2, 1); __PYX_ERR(1, 2536, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "palette_change") < 0)) __PYX_ERR(1, 2536, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_palette_ = values[1];
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("palette_change", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 2536, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.palette_change", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_134palette_change(__pyx_self, __pyx_v_surface_, __pyx_v_palette_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_134palette_change(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, PyObject *__pyx_v_palette_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("palette_change", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_palette_change(__pyx_v_surface_, __pyx_v_palette_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2536, __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("PygameShader.shader.palette_change", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 2537:         object surface_,
 2538:         object palette_):
 2539:     """
 2540:     CHANGE AN IMAGE BY CHANGING THE COLOR PALETTE 
 2541:     
 2542:     LIST_PALETTES contains all the palettes available
 2543:     in the project.
 2544:     
 2545:     e.g: 
 2546:     from PygameShader.Palette import LIST_PALETTES
 2547:     print(LIST_PALETTES.keys())
 2548:     
 2549:     :param surface_: pygame.Surface; 
 2550:     :param palette_: numpy.ndarray containing all the RGB color values 
 2551:     :return: void
 2552:     """
 2553: 
+2554:     assert isinstance(surface_, Surface), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2554, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_1); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2554, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2555:         'Argument surface_ must be a valid Surface, got %s ' % type(surface_)
      __pyx_t_1 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_vali, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2555, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_1);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(1, 2554, __pyx_L1_error)
    }
  }
  #endif
 2556: 
+2557:     assert isinstance(palette_, numpy.ndarray), \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2557, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_ndarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2557, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_2 = PyObject_IsInstance(__pyx_v_palette_, __pyx_t_3); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(1, 2557, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!(__pyx_t_2 != 0))) {
+2558:         'Argument surface_ must be a valid Surface, got %s ' % type(palette_)
      __pyx_t_3 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_vali, ((PyObject *)Py_TYPE(__pyx_v_palette_))); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2558, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 2557, __pyx_L1_error)
    }
  }
  #endif
+2559:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_4);
    __Pyx_XGIVEREF(__pyx_t_5);
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_ExceptionReset(__pyx_t_4, __pyx_t_5, __pyx_t_6);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }
+2560:         array_ = pixels3d(surface_)
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 2560, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_7 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_1);
        if (likely(__pyx_t_7)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
          __Pyx_INCREF(__pyx_t_7);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_1, function);
        }
      }
      __pyx_t_3 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_7, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_v_surface_);
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 2560, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_v_array_ = __pyx_t_3;
      __pyx_t_3 = 0;
 2561: 
+2562:     except (pygame.error, ValueError):
    __Pyx_ErrFetch(&__pyx_t_3, &__pyx_t_1, &__pyx_t_7);
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_pygame); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 2562, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_error); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2562, __pyx_L5_except_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = __Pyx_PyErr_GivenExceptionMatches(__pyx_t_3, __pyx_t_9) || __Pyx_PyErr_GivenExceptionMatches(__pyx_t_3, __pyx_builtin_ValueError);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_ErrRestore(__pyx_t_3, __pyx_t_1, __pyx_t_7);
    __pyx_t_3 = 0; __pyx_t_1 = 0; __pyx_t_7 = 0;
    if (__pyx_t_10) {
      __Pyx_AddTraceback("PygameShader.shader.palette_change", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_1, &__pyx_t_3) < 0) __PYX_ERR(1, 2562, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_GOTREF(__pyx_t_3);
+2563:         raise ValueError('\nTexture/image is not compatible.')
      __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__18, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2563, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_Raise(__pyx_t_9, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __PYX_ERR(1, 2563, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;
    __pyx_L5_except_error:;
 2564: 
+2565:     palette_change_c(array_, palette_)
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2565, __pyx_L1_error)
  __pyx_t_12 = __Pyx_PyObject_to_MemoryviewSlice_dsds_float(__pyx_v_palette_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_12.memview)) __PYX_ERR(1, 2565, __pyx_L1_error)
  __pyx_f_12PygameShader_6shader_palette_change_c(__pyx_t_11, __pyx_t_12);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
  __PYX_XDEC_MEMVIEW(&__pyx_t_12, 1);
  __pyx_t_12.memview = NULL;
  __pyx_t_12.data = NULL;
 2566: 
 2567: # ******************************************************************
 2568: 
 2569: 
 2570: 
 2571: @cython.boundscheck(False)
 2572: @cython.wraparound(False)
 2573: @cython.nonecheck(False)
 2574: @cython.cdivision(True)
+2575: cdef inline float damped_oscillation(float t)nogil:
static CYTHON_INLINE float __pyx_f_12PygameShader_6shader_damped_oscillation(float __pyx_v_t) {
  float __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}
 2576:     """
 2577:     
 2578:     :param t: 
 2579:     :return: 
 2580:     """
+2581:     return <float>(exp(-t * 0.1) * <float>cos(M_PI * t))
  __pyx_r = ((float)(exp(((-__pyx_v_t) * 0.1)) * ((float)cos((__pyx_v_12PygameShader_6shader_M_PI * __pyx_v_t)))));
  goto __pyx_L0;
 2582: 
 2583: 
+2584: cdef float C1_ = <float>1.0 / <float>sqrt(M_2PI)
  __pyx_v_12PygameShader_6shader_C1_ = (((float)1.0) / ((float)sqrt(__pyx_v_12PygameShader_6shader_M_2PI)));
 2585: 
+2586: cdef inline float gauss(float x, float c, float sigma=1.0, float mu=0.0)nogil:
static CYTHON_INLINE float __pyx_f_12PygameShader_6shader_gauss(float __pyx_v_x, float __pyx_v_c, struct __pyx_opt_args_12PygameShader_6shader_gauss *__pyx_optional_args) {
  float __pyx_v_sigma = ((float)1.0);
  float __pyx_v_mu = ((float)0.0);
  float __pyx_r;
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_sigma = __pyx_optional_args->sigma;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_mu = __pyx_optional_args->mu;
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_gauss {
  int __pyx_n;
  float sigma;
  float mu;
};
 2587:     """
 2588:     
 2589:     :param x: 
 2590:     :param c: 
 2591:     :param sigma: 
 2592:     :param mu: 
 2593:     :return: 
 2594:     """
+2595:     x -= c
  __pyx_v_x = (__pyx_v_x - __pyx_v_c);
+2596:     return (1.0 / sigma * C1_) * exp(-0.5 * ((x - mu) * (x - mu)) / (sigma * sigma))
  __pyx_r = (((1.0 / __pyx_v_sigma) * __pyx_v_12PygameShader_6shader_C1_) * exp(((-0.5 * ((__pyx_v_x - __pyx_v_mu) * (__pyx_v_x - __pyx_v_mu))) / (__pyx_v_sigma * __pyx_v_sigma))));
  goto __pyx_L0;
 2597: 
 2598: 
 2599: @cython.boundscheck(False)
 2600: @cython.wraparound(False)
 2601: @cython.nonecheck(False)
 2602: @cython.cdivision(True)
+2603: cdef inline void shader_rgb_to_bgr_inplace_c(unsigned char [:, :, :] rgb_array):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_rgb_to_bgr_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_tmp;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rgb_to_bgr_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 2604:     """
 2605:     SHADER RGB to BGR
 2606: 
 2607:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 2608:     please refer to pygame function pixels3d or array3d to convert an image into a
 2609:     3d array (library surfarray)
 2610: 
 2611:     Convert your game display from RGB to BGR format
 2612:     This algorithm can also be used to transform pygame texture in the equivalent bgr format
 2613: 
 2614:     e.g:
 2615:     rgb_to_bgr(surface)
 2616: 
 2617:     :param rgb_array    : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 2618:     pygame display pixels format RGB. Apply the transformation inplace by swapping the channel
 2619:     Red to channel blue and vice versa
 2620:     :return             : void
 2621:     """
 2622: 
 2623:     cdef Py_ssize_t w, h
+2624:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 2625: 
 2626:     cdef:
+2627:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 2628:         unsigned char tmp
 2629: 
+2630:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 2631: 
+2632:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_tmp) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_tmp) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_tmp = ((unsigned char)'?');
+2633:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
+2634:                 tmp = rgb_array[i, j, 0]  # keep the blue color
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_tmp = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) )));
+2635:                 rgb_array[i, j, 0]  = rgb_array[i, j, 2]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 2;
                              __pyx_t_11 = __pyx_v_i;
                              __pyx_t_12 = __pyx_v_j;
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_11 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_12 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) )));
+2636:                 rgb_array[i, j, 2]  = tmp
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_tmp;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 2637: 
 2638: 
 2639: @cython.boundscheck(False)
 2640: @cython.wraparound(False)
 2641: @cython.nonecheck(False)
 2642: @cython.cdivision(True)
+2643: cdef inline void shader_rgb_to_brg_inplace_c(unsigned char [:, :, :] rgb_array):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_rgb_to_brg_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_tmp_r;
  unsigned char __pyx_v_tmp_g;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rgb_to_brg_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 2644:     """
 2645: 
 2646:     SHADER RGB TO BRG
 2647: 
 2648:     Convert your game display from RGB to BRG format.
 2649:     This algorithm can also be used to transform pygame texture in the equivalent BRG format
 2650: 
 2651:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 2652:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 2653:     (library surfarray)
 2654: 
 2655:     e.g:
 2656:     rgb_to_brg(surface)
 2657: 
 2658:     :param rgb_array    : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 2659:     pygame display pixels format RGB
 2660:     :return             : void
 2661:     """
 2662: 
 2663:     cdef Py_ssize_t w, h
+2664:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 2665: 
 2666:     cdef:
+2667:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 2668:         unsigned char tmp_r, tmp_g
 2669:         unsigned char *r
 2670:         unsigned char *g
 2671:         unsigned char *b
 2672: 
+2673:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 2674: 
+2675:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_tmp_g) lastprivate(__pyx_v_tmp_r) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_tmp_g) lastprivate(__pyx_v_tmp_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_tmp_g = ((unsigned char)'?');
                            __pyx_v_tmp_r = ((unsigned char)'?');
+2676:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
+2677:                 tmp_r = rgb_array[i, j, 0]  # keep the red color
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_tmp_r = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) )));
+2678:                 tmp_g = rgb_array[i, j, 1]  # keep the green color
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_tmp_g = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) )));
+2679:                 rgb_array[i, j, 0] = rgb_array[i, j, 2] # r-->b
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_t_11 = __pyx_v_i;
                              __pyx_t_12 = __pyx_v_j;
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_11 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_12 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) )));
+2680:                 rgb_array[i, j, 1] = tmp_r  # g --> r
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_tmp_r;
+2681:                 rgb_array[i, j, 2] = tmp_g
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_tmp_g;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 2682: 
 2683: 
 2684: 
 2685: @cython.boundscheck(False)
 2686: @cython.wraparound(False)
 2687: @cython.nonecheck(False)
 2688: @cython.cdivision(True)
+2689: cdef inline void shader_greyscale_luminosity24_inplace_c(unsigned char [:, :, :] rgb_array):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_greyscale_luminosity24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_luminosity;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_greyscale_luminosity24_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 2690:     """
 2691:     SHADER GRAYSCALE (CONSERVE LUMINOSITY)
 2692: 
 2693:     This shader transform the game display on a grayscale video game effect
 2694:     This shader can also be applied to pygame textures/surface to transform them into
 2695:     an equivalent grayscale model
 2696: 
 2697:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 2698:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 2699:     (library surfarray)
 2700: 
 2701:     e.g:
 2702:     greyscale(surface)
 2703: 
 2704:     :param rgb_array    : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 2705:     pygame display pixels format RGB
 2706:     :return             : void
 2707:     """
 2708: 
 2709:     cdef Py_ssize_t w, h
+2710:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 2711: 
 2712:     cdef:
 2713:         int i, j
 2714:         unsigned char luminosity
 2715:         unsigned char *r
 2716:         unsigned char *g
 2717:         unsigned char *b
 2718: 
+2719:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+2720:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_luminosity) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_luminosity) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_luminosity = ((unsigned char)'?');
                            __pyx_v_r = ((unsigned char *)1);
+2721:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
+2722:                 r = &rgb_array[i, j, 0]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+2723:                 g = &rgb_array[i, j, 1]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+2724:                 b = &rgb_array[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+2725:                 luminosity = <unsigned char>(r[0] * 0.2126 + g[0] * 0.7152 + b[0] * 0.072)
                              __pyx_v_luminosity = ((unsigned char)((((__pyx_v_r[0]) * 0.2126) + ((__pyx_v_g[0]) * 0.7152)) + ((__pyx_v_b[0]) * 0.072)));
+2726:                 r[0] = luminosity
                              (__pyx_v_r[0]) = __pyx_v_luminosity;
+2727:                 g[0] = luminosity
                              (__pyx_v_g[0]) = __pyx_v_luminosity;
+2728:                 b[0] = luminosity
                              (__pyx_v_b[0]) = __pyx_v_luminosity;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 2729: 
 2730: 
 2731: @cython.boundscheck(False)
 2732: @cython.wraparound(False)
 2733: @cython.nonecheck(False)
 2734: @cython.cdivision(True)
+2735: cdef inline void shader_sepia24_inplace_c(unsigned char [:, :, :] rgb_array):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_sepia24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_rr;
  float __pyx_v_gg;
  float __pyx_v_bb;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_sepia24_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 2736: 
 2737:     """
 2738:     SHADER SEPIA MODEL
 2739: 
 2740:     Transform your video game into an equivalent sepia model
 2741:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 2742:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 2743:     (library surfarray)
 2744: 
 2745:     e.g:
 2746:     sepia(surface)
 2747: 
 2748:     :param rgb_array    : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 2749:     pygame display pixels format RGB
 2750:     :return             : void
 2751:     """
 2752:     cdef Py_ssize_t w, h
+2753:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 2754: 
 2755:     cdef:
+2756:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 2757:         float rr, gg, bb
 2758:         unsigned char *r
 2759:         unsigned char *g
 2760:         unsigned char *b
 2761: 
+2762:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+2763:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_bb = ((float)__PYX_NAN());
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_gg = ((float)__PYX_NAN());
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_rr = ((float)__PYX_NAN());
+2764:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
 2765: 
+2766:                 r = &rgb_array[i, j, 0]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+2767:                 g = &rgb_array[i, j, 1]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+2768:                 b = &rgb_array[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
 2769: 
+2770:                 rr = r[0] * <float>0.393 + g[0] * <float>0.769 + b[0] * <float>0.189
                              __pyx_v_rr = ((((__pyx_v_r[0]) * ((float)0.393)) + ((__pyx_v_g[0]) * ((float)0.769))) + ((__pyx_v_b[0]) * ((float)0.189)));
+2771:                 gg = r[0] * <float>0.349 + g[0] * <float>0.686 + b[0] * <float>0.168
                              __pyx_v_gg = ((((__pyx_v_r[0]) * ((float)0.349)) + ((__pyx_v_g[0]) * ((float)0.686))) + ((__pyx_v_b[0]) * ((float)0.168)));
+2772:                 bb = r[0] * <float>0.272 + g[0] * <float>0.534 + b[0] * <float>0.131
                              __pyx_v_bb = ((((__pyx_v_r[0]) * ((float)0.272)) + ((__pyx_v_g[0]) * ((float)0.534))) + ((__pyx_v_b[0]) * ((float)0.131)));
+2773:                 if rr > 255:
                              __pyx_t_11 = ((__pyx_v_rr > 255.0) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+2774:                     rr = 255
                                __pyx_v_rr = 255.0;
+2775:                 if gg > 255:
                              __pyx_t_11 = ((__pyx_v_gg > 255.0) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+2776:                     gg = 255
                                __pyx_v_gg = 255.0;
+2777:                 if bb > 255:
                              __pyx_t_11 = ((__pyx_v_bb > 255.0) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+2778:                     bb = 255
                                __pyx_v_bb = 255.0;
+2779:                 r[0] = <unsigned char> rr
                              (__pyx_v_r[0]) = ((unsigned char)__pyx_v_rr);
+2780:                 g[0] = <unsigned char> gg
                              (__pyx_v_g[0]) = ((unsigned char)__pyx_v_gg);
+2781:                 b[0] = <unsigned char> bb
                              (__pyx_v_b[0]) = ((unsigned char)__pyx_v_bb);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 2782: 
 2783: # ************* SORTING ALGORITHM FOR MEDIAN FILTER
 2784: @cython.boundscheck(False)
 2785: @cython.wraparound(False)
 2786: @cython.nonecheck(False)
 2787: @cython.cdivision(True)
+2788: cdef inline void bubble_sort(unsigned char [::1] nums, int size)nogil:
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_bubble_sort(__Pyx_memviewslice __pyx_v_nums, int __pyx_v_size) {
  int __pyx_v_i;
  unsigned char *__pyx_v_p;
  unsigned char *__pyx_v_p1;
  int __pyx_v_swapped;
/* … */
  /* function exit code */
}
 2789:     """
 2790:     
 2791:     :param nums: 
 2792:     :param size: 
 2793:     :return: 
 2794:     """
 2795:     # We set swapped to True so the loop looks runs at least once
 2796:     cdef:
 2797:         int i, j
 2798:         unsigned char *p
 2799:         unsigned char *p1
 2800:         bint swapped
 2801: 
+2802:     swapped = True
  __pyx_v_swapped = 1;
+2803:     while swapped:
  while (1) {
    __pyx_t_1 = (__pyx_v_swapped != 0);
    if (!__pyx_t_1) break;
+2804:         swapped = False
    __pyx_v_swapped = 0;
+2805:         for i in range(size - 1):
    __pyx_t_2 = (__pyx_v_size - 1);
    __pyx_t_3 = __pyx_t_2;
    for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_3; __pyx_t_4+=1) {
      __pyx_v_i = __pyx_t_4;
+2806:             p  = &nums[i]
      __pyx_t_5 = __pyx_v_i;
      __pyx_v_p = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_5)) ))));
+2807:             p1 = &nums[i+1]
      __pyx_t_5 = (__pyx_v_i + 1);
      __pyx_v_p1 = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_5)) ))));
+2808:             if p[0] > p1[0]:
      __pyx_t_1 = (((__pyx_v_p[0]) > (__pyx_v_p1[0])) != 0);
      if (__pyx_t_1) {
/* … */
      }
    }
  }
+2809:                 p[0], p1[0] = p1[0], p[0]
        __pyx_t_6 = (__pyx_v_p1[0]);
        __pyx_t_7 = (__pyx_v_p[0]);
        (__pyx_v_p[0]) = __pyx_t_6;
        (__pyx_v_p1[0]) = __pyx_t_7;
+2810:                 swapped = True
        __pyx_v_swapped = 1;
 2811: 
 2812: 
 2813: @cython.boundscheck(False)
 2814: @cython.wraparound(False)
 2815: @cython.nonecheck(False)
 2816: @cython.cdivision(True)
+2817: cdef inline void insertion_sort(unsigned char [::1] nums, int size)nogil:
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_insertion_sort(__Pyx_memviewslice __pyx_v_nums, CYTHON_UNUSED int __pyx_v_size) {
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_item_to_insert;
/* … */
  /* function exit code */
}
 2818:     """
 2819:     
 2820:     :param nums: 
 2821:     :param size: 
 2822:     :return: 
 2823:     """
 2824: 
 2825:     cdef:
 2826:         int i, j
 2827:         unsigned char item_to_insert
 2828: 
+2829:     for i in prange(1, size, schedule='static', num_threads=THREADS):
  __pyx_t_1 = __pyx_v_size;
  if ((1 == 0)) abort();
  {
      #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
          #undef likely
          #undef unlikely
          #define likely(x)   (x)
          #define unlikely(x) (x)
      #endif
      __pyx_t_3 = (__pyx_t_1 - 1 + 1 - 1/abs(1)) / 1;
      if (__pyx_t_3 > 0)
      {
          #ifdef _OPENMP
          #pragma omp parallel
          #endif /* _OPENMP */
          {
              #ifdef _OPENMP
              #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_item_to_insert) lastprivate(__pyx_v_j) schedule(static)
/* … */
  __pyx_t_1 = __pyx_v_size;
  if ((1 == 0)) abort();
  {
      #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
          #undef likely
          #undef unlikely
          #define likely(x)   (x)
          #define unlikely(x) (x)
      #endif
      __pyx_t_3 = (__pyx_t_1 - 1 + 1 - 1/abs(1)) / 1;
      if (__pyx_t_3 > 0)
      {
          #ifdef _OPENMP
          #pragma omp parallel
          #endif /* _OPENMP */
          {
              #ifdef _OPENMP
              #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_item_to_insert) lastprivate(__pyx_v_j) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
              #endif /* _OPENMP */
              for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_3; __pyx_t_2++){
                  {
                      __pyx_v_i = (int)(1 + 1 * __pyx_t_2);
                      /* Initialize private variables to invalid values */
                      __pyx_v_item_to_insert = ((unsigned char)'?');
                      __pyx_v_j = ((int)0xbad0bad0);
+2830:         item_to_insert = nums[i]
                      __pyx_t_4 = __pyx_v_i;
                      __pyx_v_item_to_insert = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) )));
 2831: 
+2832:         j = i - 1
                      __pyx_v_j = (__pyx_v_i - 1);
+2833:         while j >= 0 and nums[j] > item_to_insert:
                      while (1) {
                        __pyx_t_6 = ((__pyx_v_j >= 0) != 0);
                        if (__pyx_t_6) {
                        } else {
                          __pyx_t_5 = __pyx_t_6;
                          goto __pyx_L9_bool_binop_done;
                        }
                        __pyx_t_4 = __pyx_v_j;
                        __pyx_t_6 = (((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) ))) > __pyx_v_item_to_insert) != 0);
                        __pyx_t_5 = __pyx_t_6;
                        __pyx_L9_bool_binop_done:;
                        if (!__pyx_t_5) break;
+2834:             nums[j + 1] = nums[j]
                        __pyx_t_4 = __pyx_v_j;
                        __pyx_t_7 = (__pyx_v_j + 1);
                        *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_7)) )) = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) )));
+2835:             j = j - 1
                        __pyx_v_j = (__pyx_v_j - 1);
                      }
 2836:         # Insert the item
+2837:         nums[j + 1] = item_to_insert
                      __pyx_t_4 = (__pyx_v_j + 1);
                      *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) )) = __pyx_v_item_to_insert;
                  }
              }
          }
      }
  }
  #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
      #undef likely
      #undef unlikely
      #define likely(x)   __builtin_expect(!!(x), 1)
      #define unlikely(x) __builtin_expect(!!(x), 0)
  #endif
 2838: 
 2839: 
 2840: 
 2841: @cython.boundscheck(False)
 2842: @cython.wraparound(False)
 2843: @cython.nonecheck(False)
 2844: @cython.cdivision(True)
 2845: # There are different ways to do a Quick Sort partition, this implements the
 2846: # Hoare partition scheme. Tony Hoare also created the Quick Sort algorithm.
+2847: cdef inline int partition(unsigned char [::1] nums, int low, int high)nogil:
static CYTHON_INLINE int __pyx_f_12PygameShader_6shader_partition(__Pyx_memviewslice __pyx_v_nums, int __pyx_v_low, int __pyx_v_high) {
  int __pyx_v_pivot;
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_r;
/* … */
  /* function exit code */
  __pyx_r = 0;
  __pyx_L0:;
  return __pyx_r;
}
 2848:     """
 2849:     
 2850:     :param nums: 
 2851:     :param low: 
 2852:     :param high: 
 2853:     :return: 
 2854:     """
 2855:     cdef:
 2856:         int pivot
 2857:         int i, j
+2858:     pivot = nums[(low + high) >> 1]
  __pyx_t_1 = ((__pyx_v_low + __pyx_v_high) >> 1);
  __pyx_v_pivot = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) )));
+2859:     i = low - 1
  __pyx_v_i = (__pyx_v_low - 1);
+2860:     j = high + 1
  __pyx_v_j = (__pyx_v_high + 1);
+2861:     while True:
  while (1) {
+2862:         i += 1
    __pyx_v_i = (__pyx_v_i + 1);
+2863:         while nums[i] < pivot:
    while (1) {
      __pyx_t_1 = __pyx_v_i;
      __pyx_t_2 = (((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) ))) < __pyx_v_pivot) != 0);
      if (!__pyx_t_2) break;
+2864:             i += 1
      __pyx_v_i = (__pyx_v_i + 1);
    }
 2865: 
+2866:         j -= 1
    __pyx_v_j = (__pyx_v_j - 1);
+2867:         while nums[j] > pivot:
    while (1) {
      __pyx_t_1 = __pyx_v_j;
      __pyx_t_2 = (((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) ))) > __pyx_v_pivot) != 0);
      if (!__pyx_t_2) break;
+2868:             j -= 1
      __pyx_v_j = (__pyx_v_j - 1);
    }
 2869: 
+2870:         if i >= j:
    __pyx_t_2 = ((__pyx_v_i >= __pyx_v_j) != 0);
    if (__pyx_t_2) {
/* … */
    }
+2871:             return j
      __pyx_r = __pyx_v_j;
      goto __pyx_L0;
 2872: 
+2873:         nums[i], nums[j] = nums[j], nums[i]
    __pyx_t_1 = __pyx_v_j;
    __pyx_t_3 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) )));
    __pyx_t_1 = __pyx_v_i;
    __pyx_t_4 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) )));
    __pyx_t_1 = __pyx_v_i;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) )) = __pyx_t_3;
    __pyx_t_1 = __pyx_v_j;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_1)) )) = __pyx_t_4;
  }
 2874: 
 2875: 
 2876: @cython.boundscheck(False)
 2877: @cython.wraparound(False)
 2878: @cython.nonecheck(False)
 2879: @cython.cdivision(True)
+2880: cdef inline void _quick_sort(unsigned char [::1] items, int low, int high)nogil:
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader__quick_sort(__Pyx_memviewslice __pyx_v_items, int __pyx_v_low, int __pyx_v_high) {
  int __pyx_v_split_index;
/* … */
  /* function exit code */
}
 2881:     """
 2882:     
 2883:     :param items: 
 2884:     :param low: 
 2885:     :param high: 
 2886:     :return: 
 2887:     """
 2888:     cdef int split_index
+2889:     if low < high:
  __pyx_t_1 = ((__pyx_v_low < __pyx_v_high) != 0);
  if (__pyx_t_1) {
/* … */
  }
+2890:         split_index = partition(items, low, high)
    __pyx_v_split_index = __pyx_f_12PygameShader_6shader_partition(__pyx_v_items, __pyx_v_low, __pyx_v_high);
+2891:         _quick_sort(items, low, split_index)
    __pyx_f_12PygameShader_6shader__quick_sort(__pyx_v_items, __pyx_v_low, __pyx_v_split_index);
+2892:         _quick_sort(items, split_index + 1, high)
    __pyx_f_12PygameShader_6shader__quick_sort(__pyx_v_items, (__pyx_v_split_index + 1), __pyx_v_high);
 2893: 
 2894: 
 2895: @cython.boundscheck(False)
 2896: @cython.wraparound(False)
 2897: @cython.nonecheck(False)
 2898: @cython.cdivision(True)
+2899: cdef inline void heapify(unsigned char [::1] nums, int heap_size, int root_index)nogil:
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_heapify(__Pyx_memviewslice __pyx_v_nums, int __pyx_v_heap_size, int __pyx_v_root_index) {
  int __pyx_v_largest;
  int __pyx_v_left_child;
  int __pyx_v_right_child;
/* … */
  /* function exit code */
}
 2900:     """
 2901:     
 2902:     :param nums: 
 2903:     :param heap_size: 
 2904:     :param root_index: 
 2905:     :return: 
 2906:     """
 2907:     # Assume the index of the largest element is the root index
+2908:     cdef int largest = root_index
  __pyx_v_largest = __pyx_v_root_index;
+2909:     cdef int left_child = (2 * root_index) + 1
  __pyx_v_left_child = ((2 * __pyx_v_root_index) + 1);
+2910:     cdef int right_child = (2 * root_index) + 2
  __pyx_v_right_child = ((2 * __pyx_v_root_index) + 2);
 2911: 
+2912:     if left_child < heap_size and nums[left_child] > nums[largest]:
  __pyx_t_2 = ((__pyx_v_left_child < __pyx_v_heap_size) != 0);
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = __pyx_v_left_child;
  __pyx_t_4 = __pyx_v_largest;
  __pyx_t_2 = (((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) ))) > (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) )))) != 0);
  __pyx_t_1 = __pyx_t_2;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_1) {
/* … */
  }
+2913:         largest = left_child
    __pyx_v_largest = __pyx_v_left_child;
 2914: 
+2915:     if right_child < heap_size and nums[right_child] > nums[largest]:
  __pyx_t_2 = ((__pyx_v_right_child < __pyx_v_heap_size) != 0);
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L7_bool_binop_done;
  }
  __pyx_t_4 = __pyx_v_right_child;
  __pyx_t_3 = __pyx_v_largest;
  __pyx_t_2 = (((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_4)) ))) > (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) )))) != 0);
  __pyx_t_1 = __pyx_t_2;
  __pyx_L7_bool_binop_done:;
  if (__pyx_t_1) {
/* … */
  }
+2916:         largest = right_child
    __pyx_v_largest = __pyx_v_right_child;
 2917: 
+2918:     if largest != root_index:
  __pyx_t_1 = ((__pyx_v_largest != __pyx_v_root_index) != 0);
  if (__pyx_t_1) {
/* … */
  }
+2919:         nums[root_index], nums[largest] = nums[largest], nums[root_index]
    __pyx_t_3 = __pyx_v_largest;
    __pyx_t_5 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) )));
    __pyx_t_3 = __pyx_v_root_index;
    __pyx_t_6 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) )));
    __pyx_t_3 = __pyx_v_root_index;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) )) = __pyx_t_5;
    __pyx_t_3 = __pyx_v_largest;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_3)) )) = __pyx_t_6;
+2920:         heapify(nums, heap_size, largest)
    __pyx_f_12PygameShader_6shader_heapify(__pyx_v_nums, __pyx_v_heap_size, __pyx_v_largest);
 2921: 
 2922: 
 2923: 
 2924: @cython.boundscheck(False)
 2925: @cython.wraparound(False)
 2926: @cython.nonecheck(False)
 2927: @cython.cdivision(True)
+2928: cdef inline void heap_sort(unsigned char [::1] nums, int n)nogil:
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_heap_sort(__Pyx_memviewslice __pyx_v_nums, int __pyx_v_n) {
  long __pyx_v_i;
/* … */
  /* function exit code */
}
 2929:     """
 2930:     
 2931:     :param nums: 
 2932:     :param n: 
 2933:     :return: 
 2934:     """
 2935: 
+2936:     for i in range(n, -1, -1):
  for (__pyx_t_1 = __pyx_v_n; __pyx_t_1 > -1L; __pyx_t_1-=1) {
    __pyx_v_i = __pyx_t_1;
+2937:         heapify(nums, n, i)
    __pyx_f_12PygameShader_6shader_heapify(__pyx_v_nums, __pyx_v_n, __pyx_v_i);
  }
 2938: 
+2939:     for i in range(n - 1, 0, -1):
  for (__pyx_t_1 = (__pyx_v_n - 1); __pyx_t_1 > 0; __pyx_t_1-=1) {
    __pyx_v_i = __pyx_t_1;
+2940:         nums[i], nums[0] = nums[0], nums[i]
    __pyx_t_2 = 0;
    __pyx_t_3 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_2)) )));
    __pyx_t_2 = __pyx_v_i;
    __pyx_t_4 = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_2)) )));
    __pyx_t_2 = __pyx_v_i;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_2)) )) = __pyx_t_3;
    __pyx_t_2 = 0;
    *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_nums.data) + __pyx_t_2)) )) = __pyx_t_4;
+2941:         heapify(nums, i, 0)
    __pyx_f_12PygameShader_6shader_heapify(__pyx_v_nums, __pyx_v_i, 0);
  }
 2942: 
 2943: 
 2944: 
 2945: # *********** END OF SORTING ALGORITHM
 2946: 
 2947: 
 2948: @cython.boundscheck(False)
 2949: @cython.wraparound(False)
 2950: @cython.nonecheck(False)
 2951: @cython.cdivision(True)
+2952: cdef inline void shader_median_filter24_inplace_heapsort_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_median_filter24_inplace_heapsort_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_inplace_heapsort_c *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_k;
  int __pyx_v_k_size;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_ky;
  int __pyx_v_kx;
  Py_ssize_t __pyx_v_ii;
  Py_ssize_t __pyx_v_jj;
  __Pyx_memviewslice __pyx_v_tmp_red = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_tmp_green = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_tmp_blue = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_index;
  CYTHON_UNUSED Py_ssize_t __pyx_v_w_1;
  Py_ssize_t __pyx_v_h_1;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_median_filter24_inplace_heapsort_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_10, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_median_filter24_inplace_heapsort_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_red, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_green, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_blue, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_inplace_heapsort_c {
  int __pyx_n;
  int kernel_size_;
};
 2953:         unsigned char [:, :, :] rgb_array_, int kernel_size_=2):
 2954: 
 2955:     """
 2956:     SHADER MEDIAN FILTER
 2957: 
 2958:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 2959:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 2960:     be adapted for a real time application. Another version can also be written with a surface
 2961:     downscale prior processing /rescale method that would boost the fps performance.
 2962: 
 2963:     In the state, this shader can be used for texture/surface transformation offline
 2964: 
 2965:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 2966:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 2967:     (library surfarray)
 2968: 
 2969:     :param rgb_array_   : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 2970:     pygame display pixels format RGB
 2971:     :param kernel_size_ : integer; size of the kernel
 2972:     :return             : void
 2973:     """
 2974: 
 2975:     cdef Py_ssize_t w, h
+2976:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 2977: 
 2978:     cdef:
+2979:         int k = kernel_size_ >> 1
  __pyx_v_k = (__pyx_v_kernel_size_ >> 1);
+2980:         int k_size = kernel_size_ * kernel_size_
  __pyx_v_k_size = (__pyx_v_kernel_size_ * __pyx_v_kernel_size_);
 2981: 
 2982:     cdef:
 2983:         unsigned char [:, :, ::1] rgb_array_copy = \
+2984:             ascontiguousarray(numpy.array(rgb_array_, copy=True))
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_numpy); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_array_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6);
  __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 2984, __pyx_L1_error)
  __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_8, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_6, __pyx_t_9) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_9);
  __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_10 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_10.memview)) __PYX_ERR(1, 2984, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_10;
  __pyx_t_10.memview = NULL;
  __pyx_t_10.data = NULL;
 2985: 
+2986:         int i=0, j=0, ky, kx
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+2987:         Py_ssize_t ii=0, jj=0
  __pyx_v_ii = 0;
  __pyx_v_jj = 0;
 2988: 
+2989:         unsigned char [::1] tmp_red   = empty(k_size, numpy.uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_empty); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_k_size); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_numpy); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_n_s_uint8); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_6);
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 2989, __pyx_L1_error)
  __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_9, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_5, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2989, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_tmp_red = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
+2990:         unsigned char [::1] tmp_green = empty(k_size, numpy.uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_empty); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyInt_From_int(__pyx_v_k_size); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_numpy); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_n_s_uint8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_4);
  __pyx_t_6 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 2990, __pyx_L1_error)
  __pyx_t_6 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_9, __pyx_t_4); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_6, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2990, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_v_tmp_green = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
+2991:         unsigned char [::1] tmp_blue  = empty(k_size, numpy.uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_empty); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_k_size); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_numpy); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_5);
  __pyx_t_4 = 0;
  __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 2991, __pyx_L1_error)
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_t_9, __pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 2991, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_tmp_blue = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 2992: 
+2993:         int index = 0
  __pyx_v_index = 0;
+2994:         Py_ssize_t w_1 = w, h_1 = h
  __pyx_v_w_1 = __pyx_v_w;
  __pyx_v_h_1 = __pyx_v_h;
 2995: 
+2996:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+2997:         for i in prange(w_1, schedule='static', num_threads=THREADS, chunksize=2048):
        __pyx_t_3 = __pyx_v_w_1;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky)            __pyx_t_13 = 0x800;
/* … */
        __pyx_t_3 = __pyx_v_w_1;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) schedule(static, __pyx_t_13) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_12; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_ii = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_index = ((int)0xbad0bad0);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_jj = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_kx = ((int)0xbad0bad0);
                            __pyx_v_ky = ((int)0xbad0bad0);
+2998:             for j in range(h_1):
                            __pyx_t_14 = __pyx_v_h_1;
                            __pyx_t_15 = __pyx_t_14;
                            for (__pyx_t_16 = 0; __pyx_t_16 < __pyx_t_15; __pyx_t_16+=1) {
                              __pyx_v_j = __pyx_t_16;
 2999: 
+3000:                 index = 0
                              __pyx_v_index = 0;
 3001: 
+3002:                 for kx in range(-k, k):
                              __pyx_t_17 = __pyx_v_k;
                              __pyx_t_18 = __pyx_t_17;
                              for (__pyx_t_19 = (-__pyx_v_k); __pyx_t_19 < __pyx_t_18; __pyx_t_19+=1) {
                                __pyx_v_kx = __pyx_t_19;
+3003:                     for ky in range(-k, k):
                                __pyx_t_20 = __pyx_v_k;
                                __pyx_t_21 = __pyx_t_20;
                                for (__pyx_t_22 = (-__pyx_v_k); __pyx_t_22 < __pyx_t_21; __pyx_t_22+=1) {
                                  __pyx_v_ky = __pyx_t_22;
 3004: 
+3005:                         ii = i + kx
                                  __pyx_v_ii = (__pyx_v_i + __pyx_v_kx);
+3006:                         jj = j + ky
                                  __pyx_v_jj = (__pyx_v_j + __pyx_v_ky);
 3007: 
+3008:                         if ii < 0:
                                  __pyx_t_23 = ((__pyx_v_ii < 0) != 0);
                                  if (__pyx_t_23) {
/* … */
                                    goto __pyx_L16;
                                  }
+3009:                             ii = 0
                                    __pyx_v_ii = 0;
+3010:                         elif ii > w:
                                  __pyx_t_23 = ((__pyx_v_ii > __pyx_v_w) != 0);
                                  if (__pyx_t_23) {
/* … */
                                  }
                                  __pyx_L16:;
+3011:                             ii = w
                                    __pyx_v_ii = __pyx_v_w;
 3012: 
+3013:                         if jj < 0:
                                  __pyx_t_23 = ((__pyx_v_jj < 0) != 0);
                                  if (__pyx_t_23) {
/* … */
                                    goto __pyx_L17;
                                  }
+3014:                             jj = 0
                                    __pyx_v_jj = 0;
+3015:                         elif jj > h:
                                  __pyx_t_23 = ((__pyx_v_jj > __pyx_v_h) != 0);
                                  if (__pyx_t_23) {
/* … */
                                  }
                                  __pyx_L17:;
+3016:                             jj = h
                                    __pyx_v_jj = __pyx_v_h;
 3017: 
+3018:                         tmp_red[index]   = rgb_array_copy[ii, jj, 0]
                                  __pyx_t_24 = __pyx_v_ii;
                                  __pyx_t_25 = __pyx_v_jj;
                                  __pyx_t_26 = 0;
                                  __pyx_t_27 = __pyx_v_index;
                                  *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_red.data) + __pyx_t_27)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_24 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_26)) )));
+3019:                         tmp_green[index] = rgb_array_copy[ii, jj, 1]
                                  __pyx_t_26 = __pyx_v_ii;
                                  __pyx_t_25 = __pyx_v_jj;
                                  __pyx_t_24 = 1;
                                  __pyx_t_27 = __pyx_v_index;
                                  *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_green.data) + __pyx_t_27)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_26 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_24)) )));
+3020:                         tmp_blue[index]  = rgb_array_copy[ii, jj, 2]
                                  __pyx_t_24 = __pyx_v_ii;
                                  __pyx_t_25 = __pyx_v_jj;
                                  __pyx_t_26 = 2;
                                  __pyx_t_27 = __pyx_v_index;
                                  *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_blue.data) + __pyx_t_27)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_24 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_26)) )));
+3021:                         index = index + 1
                                  __pyx_v_index = (__pyx_v_index + 1);
                                }
                              }
 3022: 
+3023:                 heap_sort(tmp_red, k_size)
                              __pyx_f_12PygameShader_6shader_heap_sort(__pyx_v_tmp_red, __pyx_v_k_size);
+3024:                 heap_sort(tmp_green, k_size)
                              __pyx_f_12PygameShader_6shader_heap_sort(__pyx_v_tmp_green, __pyx_v_k_size);
+3025:                 heap_sort(tmp_blue, k_size)
                              __pyx_f_12PygameShader_6shader_heap_sort(__pyx_v_tmp_blue, __pyx_v_k_size);
 3026: 
+3027:                 rgb_array_[i, j, 0] = tmp_red[k + 1]
                              __pyx_t_26 = (__pyx_v_k + 1);
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_27 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_27 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_red.data) + __pyx_t_26)) )));
+3028:                 rgb_array_[i, j, 1] = tmp_green[k + 1]
                              __pyx_t_26 = (__pyx_v_k + 1);
                              __pyx_t_27 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_25 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_27 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_green.data) + __pyx_t_26)) )));
+3029:                 rgb_array_[i, j, 2]= tmp_blue[k + 1]
                              __pyx_t_26 = (__pyx_v_k + 1);
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_27 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_27 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_tmp_blue.data) + __pyx_t_26)) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3030: 
 3031: 
 3032: 
 3033: @cython.boundscheck(False)
 3034: @cython.wraparound(False)
 3035: @cython.nonecheck(False)
 3036: @cython.cdivision(True)
+3037: cdef inline void shader_median_filter24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_median_filter24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_inplace_c *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_ky;
  int __pyx_v_kx;
  Py_ssize_t __pyx_v_ii;
  Py_ssize_t __pyx_v_jj;
  int __pyx_v_k;
  int __pyx_v_k_size;
  int *__pyx_v_tmp_red;
  int *__pyx_v_tmp_green;
  int *__pyx_v_tmp_blue;
  __Pyx_memviewslice __pyx_v_tmp_red_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_tmp_green_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_tmp_blue_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  int *__pyx_v_tmpr;
  int *__pyx_v_tmpg;
  int *__pyx_v_tmpb;
  int __pyx_v_index;
  CYTHON_UNUSED Py_ssize_t __pyx_v_w_1;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h_1;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_median_filter24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_10, 1);
  __Pyx_XDECREF(((PyObject *)__pyx_t_11));
  __PYX_XDEC_MEMVIEW(&__pyx_t_12, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_median_filter24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_red_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_green_, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_tmp_blue_, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_inplace_c {
  int __pyx_n;
  int kernel_size_;
};
 3038:         unsigned char [:, :, :] rgb_array_, int kernel_size_=2):
 3039: 
 3040:     """
 3041:     SHADER MEDIAN FILTER
 3042: 
 3043:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 3044:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 3045:     be adapted for a real time application. Another version can also be written with a surface
 3046:     downscale prior processing /rescale method that would boost the fps performance.
 3047: 
 3048:     In the state, this shader can be used for texture/surface transformation offline
 3049: 
 3050:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3051:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 3052:     (library surfarray)
 3053: 
 3054:     :param rgb_array_   : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 3055:     pygame display pixels format RGB
 3056:     :param kernel_size_ : integer; size of the kernel
 3057:     :return             : void
 3058:     """
 3059: 
 3060:     cdef Py_ssize_t w, h
+3061:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3062: 
 3063:     cdef:
 3064:         unsigned char [:, :, ::1] rgb_array_copy = \
+3065:             ascontiguousarray(numpy.array(rgb_array_, copy=True))
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_numpy); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_array_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6);
  __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3065, __pyx_L1_error)
  __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_8, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_6, __pyx_t_9) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_9);
  __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_10 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_10.memview)) __PYX_ERR(1, 3065, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_10;
  __pyx_t_10.memview = NULL;
  __pyx_t_10.data = NULL;
 3066: 
+3067:         int i=0, j=0, ky, kx
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+3068:         Py_ssize_t ii=0, jj=0
  __pyx_v_ii = 0;
  __pyx_v_jj = 0;
+3069:         int k = kernel_size_ >> 1
  __pyx_v_k = (__pyx_v_kernel_size_ >> 1);
+3070:         int k_size = kernel_size_ * kernel_size_
  __pyx_v_k_size = (__pyx_v_kernel_size_ * __pyx_v_kernel_size_);
 3071: 
 3072:         # int [64] tmp_red   = empty(64, numpy.int16, order='C')
 3073:         # int [64] tmp_green = empty(64, numpy.int16, order='C')
 3074:         # int [64] tmp_blue  = empty(64, numpy.int16, order='C')
 3075: 
+3076:         int *tmp_red   = <int *> malloc(k_size * sizeof(int))
  __pyx_v_tmp_red = ((int *)malloc((__pyx_v_k_size * (sizeof(int)))));
+3077:         int *tmp_green = <int *> malloc(k_size * sizeof(int))
  __pyx_v_tmp_green = ((int *)malloc((__pyx_v_k_size * (sizeof(int)))));
+3078:         int *tmp_blue  = <int *> malloc(k_size * sizeof(int))
  __pyx_v_tmp_blue = ((int *)malloc((__pyx_v_k_size * (sizeof(int)))));
 3079: 
+3080:         int [::1] tmp_red_ = <int[:k_size]>tmp_red
  if (!__pyx_v_tmp_red) {
    PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer");
    __PYX_ERR(1, 3080, __pyx_L1_error)
  }
  __pyx_t_5 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_int); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3080, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = Py_BuildValue((char*) "("  __PYX_BUILD_PY_SSIZE_T  ")", ((Py_ssize_t)__pyx_v_k_size)); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3080, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_11 = __pyx_array_new(__pyx_t_4, sizeof(int), PyBytes_AS_STRING(__pyx_t_5), (char *) "c", (char *) __pyx_v_tmp_red);
  if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3080, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_12 = __Pyx_PyObject_to_MemoryviewSlice_dc_int(((PyObject *)__pyx_t_11), PyBUF_WRITABLE); if (unlikely(!__pyx_t_12.memview)) __PYX_ERR(1, 3080, __pyx_L1_error)
  __Pyx_DECREF(((PyObject *)__pyx_t_11)); __pyx_t_11 = 0;
  __pyx_v_tmp_red_ = __pyx_t_12;
  __pyx_t_12.memview = NULL;
  __pyx_t_12.data = NULL;
+3081:         int [::1] tmp_green_ = <int[:k_size]>tmp_green
  if (!__pyx_v_tmp_green) {
    PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer");
    __PYX_ERR(1, 3081, __pyx_L1_error)
  }
  __pyx_t_4 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_int); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3081, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = Py_BuildValue((char*) "("  __PYX_BUILD_PY_SSIZE_T  ")", ((Py_ssize_t)__pyx_v_k_size)); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3081, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_11 = __pyx_array_new(__pyx_t_5, sizeof(int), PyBytes_AS_STRING(__pyx_t_4), (char *) "c", (char *) __pyx_v_tmp_green);
  if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3081, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_12 = __Pyx_PyObject_to_MemoryviewSlice_dc_int(((PyObject *)__pyx_t_11), PyBUF_WRITABLE); if (unlikely(!__pyx_t_12.memview)) __PYX_ERR(1, 3081, __pyx_L1_error)
  __Pyx_DECREF(((PyObject *)__pyx_t_11)); __pyx_t_11 = 0;
  __pyx_v_tmp_green_ = __pyx_t_12;
  __pyx_t_12.memview = NULL;
  __pyx_t_12.data = NULL;
+3082:         int [::1] tmp_blue_ = <int[:k_size]>tmp_blue
  if (!__pyx_v_tmp_blue) {
    PyErr_SetString(PyExc_ValueError,"Cannot create cython.array from NULL pointer");
    __PYX_ERR(1, 3082, __pyx_L1_error)
  }
  __pyx_t_5 = __pyx_format_from_typeinfo(&__Pyx_TypeInfo_int); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3082, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = Py_BuildValue((char*) "("  __PYX_BUILD_PY_SSIZE_T  ")", ((Py_ssize_t)__pyx_v_k_size)); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3082, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_11 = __pyx_array_new(__pyx_t_4, sizeof(int), PyBytes_AS_STRING(__pyx_t_5), (char *) "c", (char *) __pyx_v_tmp_blue);
  if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3082, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_12 = __Pyx_PyObject_to_MemoryviewSlice_dc_int(((PyObject *)__pyx_t_11), PyBUF_WRITABLE); if (unlikely(!__pyx_t_12.memview)) __PYX_ERR(1, 3082, __pyx_L1_error)
  __Pyx_DECREF(((PyObject *)__pyx_t_11)); __pyx_t_11 = 0;
  __pyx_v_tmp_blue_ = __pyx_t_12;
  __pyx_t_12.memview = NULL;
  __pyx_t_12.data = NULL;
 3083: 
 3084:         int *tmpr
 3085:         int *tmpg
 3086:         int *tmpb
 3087: 
+3088:         int index = 0
  __pyx_v_index = 0;
+3089:         Py_ssize_t w_1 = w, h_1 = h
  __pyx_v_w_1 = __pyx_v_w;
  __pyx_v_h_1 = __pyx_v_h;
 3090: 
 3091: 
+3092:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3093:         for i in prange(w_1, schedule='static', num_threads=THREADS, chunksize=2048):
        __pyx_t_3 = __pyx_v_w_1;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_13 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_13 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_tmpb) lastprivate(__pyx_v_tmpg) lastprivate(__pyx_v_tmpr)            __pyx_t_14 = 0x800;
/* … */
        __pyx_t_3 = __pyx_v_w_1;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_13 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_13 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_tmpb) lastprivate(__pyx_v_tmpg) lastprivate(__pyx_v_tmpr) schedule(static, __pyx_t_14) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_13; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_ii = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_index = ((int)0xbad0bad0);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_jj = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_kx = ((int)0xbad0bad0);
                            __pyx_v_ky = ((int)0xbad0bad0);
                            __pyx_v_tmpb = ((int *)1);
                            __pyx_v_tmpg = ((int *)1);
                            __pyx_v_tmpr = ((int *)1);
+3094:             for j in prange(h_1):
                            __pyx_t_15 = __pyx_v_h_1;
                            if ((1 == 0)) abort();
                            {
                                __pyx_t_17 = (__pyx_t_15 - 0 + 1 - 1/abs(1)) / 1;
                                if (__pyx_t_17 > 0)
                                {
                                    #if 0
                                    #pragma omp parallel
                                    #endif /* _OPENMP */
                                    {
                                        #if 0
                                        #pragma omp for lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_tmpb) lastprivate(__pyx_v_tmpg) lastprivate(__pyx_v_tmpr)
                                        #endif /* _OPENMP */
                                        for (__pyx_t_16 = 0; __pyx_t_16 < __pyx_t_17; __pyx_t_16++){
                                            {
                                                __pyx_v_j = (int)(0 + 1 * __pyx_t_16);
                                                /* Initialize private variables to invalid values */
                                                __pyx_v_ii = ((Py_ssize_t)0xbad0bad0);
                                                __pyx_v_index = ((int)0xbad0bad0);
                                                __pyx_v_jj = ((Py_ssize_t)0xbad0bad0);
                                                __pyx_v_kx = ((int)0xbad0bad0);
                                                __pyx_v_ky = ((int)0xbad0bad0);
                                                __pyx_v_tmpb = ((int *)1);
                                                __pyx_v_tmpg = ((int *)1);
                                                __pyx_v_tmpr = ((int *)1);
 3095: 
+3096:                 index = 0
                                                __pyx_v_index = 0;
 3097: 
+3098:                 for kx in range(-k, k):
                                                __pyx_t_18 = __pyx_v_k;
                                                __pyx_t_19 = __pyx_t_18;
                                                for (__pyx_t_20 = (-__pyx_v_k); __pyx_t_20 < __pyx_t_19; __pyx_t_20+=1) {
                                                  __pyx_v_kx = __pyx_t_20;
+3099:                     for ky in range(-k, k):
                                                  __pyx_t_21 = __pyx_v_k;
                                                  __pyx_t_22 = __pyx_t_21;
                                                  for (__pyx_t_23 = (-__pyx_v_k); __pyx_t_23 < __pyx_t_22; __pyx_t_23+=1) {
                                                    __pyx_v_ky = __pyx_t_23;
 3100: 
+3101:                         ii = i + kx
                                                    __pyx_v_ii = (__pyx_v_i + __pyx_v_kx);
+3102:                         jj = j + ky
                                                    __pyx_v_jj = (__pyx_v_j + __pyx_v_ky);
 3103: 
+3104:                         if ii < 0:
                                                    __pyx_t_24 = ((__pyx_v_ii < 0) != 0);
                                                    if (__pyx_t_24) {
/* … */
                                                      goto __pyx_L18;
                                                    }
+3105:                             ii = 0
                                                      __pyx_v_ii = 0;
+3106:                         elif ii > w:
                                                    __pyx_t_24 = ((__pyx_v_ii > __pyx_v_w) != 0);
                                                    if (__pyx_t_24) {
/* … */
                                                    }
                                                    __pyx_L18:;
+3107:                             ii = w
                                                      __pyx_v_ii = __pyx_v_w;
 3108: 
+3109:                         if jj < 0:
                                                    __pyx_t_24 = ((__pyx_v_jj < 0) != 0);
                                                    if (__pyx_t_24) {
/* … */
                                                      goto __pyx_L19;
                                                    }
+3110:                             jj = 0
                                                      __pyx_v_jj = 0;
+3111:                         elif jj > h:
                                                    __pyx_t_24 = ((__pyx_v_jj > __pyx_v_h) != 0);
                                                    if (__pyx_t_24) {
/* … */
                                                    }
                                                    __pyx_L19:;
+3112:                             jj = h
                                                      __pyx_v_jj = __pyx_v_h;
 3113: 
+3114:                         tmp_red_[index]   = rgb_array_copy[ii, jj, 0]
                                                    __pyx_t_25 = __pyx_v_ii;
                                                    __pyx_t_26 = __pyx_v_jj;
                                                    __pyx_t_27 = 0;
                                                    __pyx_t_28 = __pyx_v_index;
                                                    *((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_tmp_red_.data) + __pyx_t_28)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_25 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_27)) )));
+3115:                         tmp_green_[index] = rgb_array_copy[ii, jj, 1]
                                                    __pyx_t_27 = __pyx_v_ii;
                                                    __pyx_t_26 = __pyx_v_jj;
                                                    __pyx_t_25 = 1;
                                                    __pyx_t_28 = __pyx_v_index;
                                                    *((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_tmp_green_.data) + __pyx_t_28)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_27 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_25)) )));
+3116:                         tmp_blue_[index]  = rgb_array_copy[ii, jj, 2]
                                                    __pyx_t_25 = __pyx_v_ii;
                                                    __pyx_t_26 = __pyx_v_jj;
                                                    __pyx_t_27 = 2;
                                                    __pyx_t_28 = __pyx_v_index;
                                                    *((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_tmp_blue_.data) + __pyx_t_28)) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_25 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_27)) )));
+3117:                         index = index + 1
                                                    __pyx_v_index = (__pyx_v_index + 1);
                                                  }
                                                }
 3118: 
 3119:                 # External C quicksort
+3120:                 tmpr = quickSort(&tmp_red_[0], 0, k_size)
                                                __pyx_t_27 = 0;
                                                __pyx_v_tmpr = quickSort((&(*((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_tmp_red_.data) + __pyx_t_27)) )))), 0, __pyx_v_k_size);
+3121:                 tmpg = quickSort(&tmp_green[0], 0, k_size)
                                                __pyx_v_tmpg = quickSort((&(__pyx_v_tmp_green[0])), 0, __pyx_v_k_size);
+3122:                 tmpb = quickSort(&tmp_blue[0], 0, k_size)
                                                __pyx_v_tmpb = quickSort((&(__pyx_v_tmp_blue[0])), 0, __pyx_v_k_size);
 3123: 
+3124:                 rgb_array_[i, j, 0] = tmpr[k + 1]
                                                __pyx_t_27 = __pyx_v_i;
                                                __pyx_t_26 = __pyx_v_j;
                                                __pyx_t_25 = 0;
                                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_27 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmpr[(__pyx_v_k + 1)]);
+3125:                 rgb_array_[i, j, 1] = tmpg[k + 1]
                                                __pyx_t_25 = __pyx_v_i;
                                                __pyx_t_26 = __pyx_v_j;
                                                __pyx_t_27 = 1;
                                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_27 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmpg[(__pyx_v_k + 1)]);
+3126:                 rgb_array_[i, j, 2] = tmpb[k + 1]
                                                __pyx_t_27 = __pyx_v_i;
                                                __pyx_t_26 = __pyx_v_j;
                                                __pyx_t_25 = 2;
                                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_27 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_26 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmpb[(__pyx_v_k + 1)]);
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3127: 
 3128: 
 3129: 
 3130: @cython.boundscheck(False)
 3131: @cython.wraparound(False)
 3132: @cython.nonecheck(False)
 3133: @cython.cdivision(True)
+3134: cdef inline void shader_median_filter24_avg_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_median_filter24_avg_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_avg_inplace_c *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  CYTHON_UNUSED __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_ky;
  int __pyx_v_kx;
  Py_ssize_t __pyx_v_ii;
  Py_ssize_t __pyx_v_jj;
  int __pyx_v_k;
  CYTHON_UNUSED int __pyx_v_k_size;
  Py_ssize_t __pyx_v_w_1;
  Py_ssize_t __pyx_v_h_1;
  unsigned char __pyx_v_max_r;
  unsigned char __pyx_v_min_r;
  unsigned char __pyx_v_max_g;
  unsigned char __pyx_v_min_g;
  unsigned char __pyx_v_max_b;
  unsigned char __pyx_v_min_b;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_median_filter24_avg_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_10, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_median_filter24_avg_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_median_filter24_avg_inplace_c {
  int __pyx_n;
  int kernel_size_;
};
 3135:         unsigned char [:, :, :] rgb_array_, int kernel_size_=2):
 3136: 
 3137:     """
 3138:     SHADER MEDIAN FILTER
 3139: 
 3140:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 3141:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 3142:     be adapted for a real time application. Another version can also be written with a surface
 3143:     downscale prior processing /rescale method that would boost the fps performance.
 3144: 
 3145:     In the state, this shader can be used for texture/surface transformation offline
 3146: 
 3147:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3148:     please refer to pygame function pixels3d or array3d to convert an image into a
 3149:     3d array (library surfarray)
 3150: 
 3151:     :param rgb_array_   : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 3152:     pygame display pixels format RGB
 3153:     :param kernel_size_ : integer; size of the kernel
 3154:     :return             : void
 3155:     """
 3156: 
 3157:     cdef Py_ssize_t w, h
+3158:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3159: 
 3160:     cdef:
 3161:         unsigned char [:, :, ::1] rgb_array_copy = \
+3162:             ascontiguousarray(numpy.array(rgb_array_, copy=True))
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_numpy); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_array_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6);
  __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3162, __pyx_L1_error)
  __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_8, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_6, __pyx_t_9) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_9);
  __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_10 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_10.memview)) __PYX_ERR(1, 3162, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_10;
  __pyx_t_10.memview = NULL;
  __pyx_t_10.data = NULL;
 3163: 
+3164:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 3165:         int ky, kx
+3166:         Py_ssize_t ii=0, jj=0
  __pyx_v_ii = 0;
  __pyx_v_jj = 0;
+3167:         int k = kernel_size_ >> 1
  __pyx_v_k = (__pyx_v_kernel_size_ >> 1);
+3168:         int k_size = kernel_size_ * kernel_size_
  __pyx_v_k_size = (__pyx_v_kernel_size_ * __pyx_v_kernel_size_);
 3169: 
+3170:         Py_ssize_t w_1 = w - 1, h_1 = h - 1
  __pyx_v_w_1 = (__pyx_v_w - 1);
  __pyx_v_h_1 = (__pyx_v_h - 1);
 3171:         int red, green, blue
 3172:         unsigned char max_r, min_r, max_g, min_g, max_b, min_b
 3173:         unsigned char *r
 3174:         unsigned char *g
 3175:         unsigned char *b
 3176: 
+3177:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3178:         for i in prange(w, schedule='static', num_threads=THREADS, chunksize=2048):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_max_b) lastprivate(__pyx_v_max_g) lastprivate(__pyx_v_max_r) lastprivate(__pyx_v_min_b) lastprivate(__pyx_v_min_g) lastprivate(__pyx_v_min_r) lastprivate(__pyx_v_r)            __pyx_t_12 = 0x800;
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_max_b) lastprivate(__pyx_v_max_g) lastprivate(__pyx_v_max_r) lastprivate(__pyx_v_min_b) lastprivate(__pyx_v_min_g) lastprivate(__pyx_v_min_r) lastprivate(__pyx_v_r) schedule(static, __pyx_t_12) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_11; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_ii = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_jj = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_kx = ((int)0xbad0bad0);
                            __pyx_v_ky = ((int)0xbad0bad0);
                            __pyx_v_max_b = ((unsigned char)'?');
                            __pyx_v_max_g = ((unsigned char)'?');
                            __pyx_v_max_r = ((unsigned char)'?');
                            __pyx_v_min_b = ((unsigned char)'?');
                            __pyx_v_min_g = ((unsigned char)'?');
                            __pyx_v_min_r = ((unsigned char)'?');
                            __pyx_v_r = ((unsigned char *)1);
+3179:             for j in range(h):
                            __pyx_t_13 = __pyx_v_h;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_14; __pyx_t_15+=1) {
                              __pyx_v_j = __pyx_t_15;
 3180: 
+3181:                 max_r = 0
                              __pyx_v_max_r = 0;
+3182:                 min_r = 0
                              __pyx_v_min_r = 0;
+3183:                 max_g = 0
                              __pyx_v_max_g = 0;
+3184:                 min_g = 0
                              __pyx_v_min_g = 0;
+3185:                 max_b = 0
                              __pyx_v_max_b = 0;
+3186:                 min_b = 0
                              __pyx_v_min_b = 0;
 3187: 
+3188:                 for kx in range(-k, k):
                              __pyx_t_16 = __pyx_v_k;
                              __pyx_t_17 = __pyx_t_16;
                              for (__pyx_t_18 = (-__pyx_v_k); __pyx_t_18 < __pyx_t_17; __pyx_t_18+=1) {
                                __pyx_v_kx = __pyx_t_18;
+3189:                     for ky in range(-k, k):
                                __pyx_t_19 = __pyx_v_k;
                                __pyx_t_20 = __pyx_t_19;
                                for (__pyx_t_21 = (-__pyx_v_k); __pyx_t_21 < __pyx_t_20; __pyx_t_21+=1) {
                                  __pyx_v_ky = __pyx_t_21;
+3190:                         ii = (i + kx)
                                  __pyx_v_ii = (__pyx_v_i + __pyx_v_kx);
+3191:                         jj = (j + ky)
                                  __pyx_v_jj = (__pyx_v_j + __pyx_v_ky);
 3192: 
+3193:                         if ii < 0:
                                  __pyx_t_22 = ((__pyx_v_ii < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L16;
                                  }
+3194:                             ii = 0
                                    __pyx_v_ii = 0;
+3195:                         elif ii > w_1:
                                  __pyx_t_22 = ((__pyx_v_ii > __pyx_v_w_1) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L16:;
+3196:                             ii = w_1
                                    __pyx_v_ii = __pyx_v_w_1;
 3197: 
+3198:                         if jj < 0:
                                  __pyx_t_22 = ((__pyx_v_jj < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L17;
                                  }
+3199:                             jj = 0
                                    __pyx_v_jj = 0;
+3200:                         elif jj > h_1:
                                  __pyx_t_22 = ((__pyx_v_jj > __pyx_v_h_1) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L17:;
+3201:                             jj = h_1
                                    __pyx_v_jj = __pyx_v_h_1;
 3202: 
+3203:                         r = &rgb_array_[ii, jj, 0]
                                  __pyx_t_23 = __pyx_v_ii;
                                  __pyx_t_24 = __pyx_v_jj;
                                  __pyx_t_25 = 0;
                                  __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) ))));
+3204:                         g = &rgb_array_[ii, jj, 1]
                                  __pyx_t_25 = __pyx_v_ii;
                                  __pyx_t_24 = __pyx_v_jj;
                                  __pyx_t_23 = 1;
                                  __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) ))));
+3205:                         b = &rgb_array_[ii, jj, 2]
                                  __pyx_t_23 = __pyx_v_ii;
                                  __pyx_t_24 = __pyx_v_jj;
                                  __pyx_t_25 = 2;
                                  __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) ))));
 3206: 
+3207:                         if r[0] > max_r:
                                  __pyx_t_22 = (((__pyx_v_r[0]) > __pyx_v_max_r) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
+3208:                             max_r = r[0]
                                    __pyx_v_max_r = (__pyx_v_r[0]);
+3209:                         if g[0] > max_g:
                                  __pyx_t_22 = (((__pyx_v_g[0]) > __pyx_v_max_g) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
+3210:                             max_g = g[0]
                                    __pyx_v_max_g = (__pyx_v_g[0]);
+3211:                         if b[0] > max_b:
                                  __pyx_t_22 = (((__pyx_v_b[0]) > __pyx_v_max_b) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
+3212:                             max_b = b[0]
                                    __pyx_v_max_b = (__pyx_v_b[0]);
 3213: 
+3214:                         if r[0] < min_r:
                                  __pyx_t_22 = (((__pyx_v_r[0]) < __pyx_v_min_r) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
+3215:                             min_r = r[0]
                                    __pyx_v_min_r = (__pyx_v_r[0]);
+3216:                         if g[0] < min_g:
                                  __pyx_t_22 = (((__pyx_v_g[0]) < __pyx_v_min_g) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
+3217:                             min_g = g[0]
                                    __pyx_v_min_g = (__pyx_v_g[0]);
+3218:                         if b[0] < min_b:
                                  __pyx_t_22 = (((__pyx_v_b[0]) < __pyx_v_min_b) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                }
                              }
+3219:                             min_b = b[0]
                                    __pyx_v_min_b = (__pyx_v_b[0]);
 3220: 
+3221:                 rgb_array_[i, j, 0] = <unsigned char>((max_r - min_r) *0.5)
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_23 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((__pyx_v_max_r - __pyx_v_min_r) * 0.5));
+3222:                 rgb_array_[i, j, 1] = <unsigned char>((max_g - min_g) *0.5)
                              __pyx_t_23 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_25 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((__pyx_v_max_g - __pyx_v_min_g) * 0.5));
+3223:                 rgb_array_[i, j, 2] = <unsigned char>((max_b - min_b) *0.5)
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_23 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((__pyx_v_max_b - __pyx_v_min_b) * 0.5));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3224: 
 3225: 
 3226: 
 3227: @cython.boundscheck(False)
 3228: @cython.wraparound(False)
 3229: @cython.nonecheck(False)
 3230: @cython.cdivision(True)
+3231: cdef inline void shader_median_grayscale_filter24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_median_grayscale_filter24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_median_grayscale_filter24_inplace_c *__pyx_optional_args) {
  int __pyx_v_kernel_size_ = ((int)2);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_ky;
  int __pyx_v_kx;
  Py_ssize_t __pyx_v_ii;
  Py_ssize_t __pyx_v_jj;
  int __pyx_v_k;
  int __pyx_v_k_size;
  int *__pyx_v_tmp_;
  int *__pyx_v_tmp;
  int __pyx_v_index;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_median_grayscale_filter24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_kernel_size_ = __pyx_optional_args->kernel_size_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __PYX_XDEC_MEMVIEW(&__pyx_t_10, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_median_grayscale_filter24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_median_grayscale_filter24_inplace_c {
  int __pyx_n;
  int kernel_size_;
};
 3232:         unsigned char [:, :, :] rgb_array_, int kernel_size_=2):
 3233: 
 3234:     """
 3235:     SHADER MEDIAN FILTER
 3236: 
 3237:     This shader cannot be used for real time rendering as the performance of the algorithm are not
 3238:     satisfactory. The code would have to be changed and improved with C or assembler in order to
 3239:     be adapted for a real time application. Another version can also be written with a surface
 3240:     downscale prior processing /rescale method that would boost the fps performance.
 3241: 
 3242:     In the state, this shader can be used for texture/surface transformation offline
 3243: 
 3244:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3245:     please refer to pygame function pixels3d or array3d to convert an image into a 3d
 3246:     array (library surfarray)
 3247: 
 3248:     :param rgb_array_   : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 3249:     pygame display pixels format RGB
 3250:     :param kernel_size_ : integer; size of the kernel
 3251:     :return             : void
 3252:     """
 3253: 
 3254:     cdef Py_ssize_t w, h
+3255:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3256: 
 3257:     cdef:
 3258:         unsigned char [:, :, ::1] rgb_array_copy = \
+3259:             ascontiguousarray(numpy.array(rgb_array_, copy=True))
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_numpy); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_array_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6);
  __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3259, __pyx_L1_error)
  __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_8, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_6, __pyx_t_9) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_9);
  __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_10 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_10.memview)) __PYX_ERR(1, 3259, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_10;
  __pyx_t_10.memview = NULL;
  __pyx_t_10.data = NULL;
 3260: 
+3261:         int i=0, j=0, ky, kx
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+3262:         Py_ssize_t ii=0, jj=0
  __pyx_v_ii = 0;
  __pyx_v_jj = 0;
 3263: 
+3264:         int k = kernel_size_ >> 1
  __pyx_v_k = (__pyx_v_kernel_size_ >> 1);
+3265:         int k_size = kernel_size_ * kernel_size_
  __pyx_v_k_size = (__pyx_v_kernel_size_ * __pyx_v_kernel_size_);
 3266:         # int [64] tmp_  = empty(64, numpy.int16, order='C')
+3267:         int *tmp_   = <int *> malloc(k_size * sizeof(int))
  __pyx_v_tmp_ = ((int *)malloc((__pyx_v_k_size * (sizeof(int)))));
 3268:         int *tmp
+3269:         int index = 0
  __pyx_v_index = 0;
 3270:         unsigned char *v
 3271: 
 3272: 
+3273:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3274:         for i in prange(0, w, schedule='static', num_threads=THREADS, chunksize=2048):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_tmp)            __pyx_t_12 = 0x800;
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_index) lastprivate(__pyx_v_j) lastprivate(__pyx_v_jj) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_tmp) schedule(static, __pyx_t_12) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_11; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_ii = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_index = ((int)0xbad0bad0);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_jj = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_kx = ((int)0xbad0bad0);
                            __pyx_v_ky = ((int)0xbad0bad0);
                            __pyx_v_tmp = ((int *)1);
+3275:             for j in range(0, h):
                            __pyx_t_13 = __pyx_v_h;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_14; __pyx_t_15+=1) {
                              __pyx_v_j = __pyx_t_15;
 3276: 
+3277:                 index = 0
                              __pyx_v_index = 0;
 3278: 
+3279:                 for kx in range(-k, k):
                              __pyx_t_16 = __pyx_v_k;
                              __pyx_t_17 = __pyx_t_16;
                              for (__pyx_t_18 = (-__pyx_v_k); __pyx_t_18 < __pyx_t_17; __pyx_t_18+=1) {
                                __pyx_v_kx = __pyx_t_18;
+3280:                     for ky in range(-k, k):
                                __pyx_t_19 = __pyx_v_k;
                                __pyx_t_20 = __pyx_t_19;
                                for (__pyx_t_21 = (-__pyx_v_k); __pyx_t_21 < __pyx_t_20; __pyx_t_21+=1) {
                                  __pyx_v_ky = __pyx_t_21;
 3281: 
+3282:                         ii = i + kx
                                  __pyx_v_ii = (__pyx_v_i + __pyx_v_kx);
+3283:                         jj = j + ky
                                  __pyx_v_jj = (__pyx_v_j + __pyx_v_ky);
 3284: 
+3285:                         if ii < 0:
                                  __pyx_t_22 = ((__pyx_v_ii < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L16;
                                  }
+3286:                             ii = 0
                                    __pyx_v_ii = 0;
+3287:                         elif ii > w:
                                  __pyx_t_22 = ((__pyx_v_ii > __pyx_v_w) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L16:;
+3288:                             ii = w
                                    __pyx_v_ii = __pyx_v_w;
 3289: 
+3290:                         if jj < 0:
                                  __pyx_t_22 = ((__pyx_v_jj < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L17;
                                  }
+3291:                             jj = 0
                                    __pyx_v_jj = 0;
+3292:                         elif jj > h:
                                  __pyx_t_22 = ((__pyx_v_jj > __pyx_v_h) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L17:;
+3293:                             jj = h
                                    __pyx_v_jj = __pyx_v_h;
 3294: 
+3295:                         tmp_[index]   = rgb_array_copy[ii, jj, 0]
                                  __pyx_t_23 = __pyx_v_ii;
                                  __pyx_t_24 = __pyx_v_jj;
                                  __pyx_t_25 = 0;
                                  (__pyx_v_tmp_[__pyx_v_index]) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_23 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_25)) )));
 3296: 
+3297:                         index = index + 1
                                  __pyx_v_index = (__pyx_v_index + 1);
                                }
                              }
 3298: 
+3299:                 tmp = quickSort(tmp_, 0, k_size)
                              __pyx_v_tmp = quickSort(__pyx_v_tmp_, 0, __pyx_v_k_size);
 3300: 
+3301:                 rgb_array_[i, j, 0] = tmp[k + 1]
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_23 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmp[(__pyx_v_k + 1)]);
+3302:                 rgb_array_[i, j, 1] = tmp[k + 1]
                              __pyx_t_23 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_25 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmp[(__pyx_v_k + 1)]);
+3303:                 rgb_array_[i, j, 2] = tmp[k + 1]
                              __pyx_t_25 = __pyx_v_i;
                              __pyx_t_24 = __pyx_v_j;
                              __pyx_t_23 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_tmp[(__pyx_v_k + 1)]);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3304: 
 3305: 
 3306: 
+3307: cdef float ONE_255 = <float>1.0 / <float>255.0
  __pyx_v_12PygameShader_6shader_ONE_255 = (((float)1.0) / ((float)255.0));
 3308: 
 3309: @cython.boundscheck(False)
 3310: @cython.wraparound(False)
 3311: @cython.nonecheck(False)
 3312: @cython.cdivision(True)
+3313: cdef inline void shader_color_reduction24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_color_reduction24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array, int __pyx_v_color_number) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_f;
  float __pyx_v_c1;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_color_reduction24_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 3314:         unsigned char [:, :, :] rgb_array, int color_number):
 3315:     """
 3316:     COLOR REDUCTION SHADER
 3317: 
 3318:     Decrease the amount of colors in the display or texture.
 3319:     The method of color reduction is very simple: every color of the original picture is replaced
 3320:     by an appropriate color from the limited palette that is accessible.
 3321: 
 3322:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3323:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array
 3324:      (library surfarray)
 3325: 
 3326:     e.g:
 3327:     color_reduction(surface, 8)
 3328: 
 3329:     :param rgb_array    : numpy.ndarray shape(w, h, 3) uint8 (unsigned char 0...255) containing the
 3330:     pygame display pixels format RGB
 3331:     :param color_number : integer; color number color_number^2
 3332:     :return             : void
 3333:     """
 3334: 
 3335: 
 3336:     cdef Py_ssize_t w, h
+3337:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3338: 
 3339:     # cdef float color_number = <float>pow(2, factor)
 3340: 
 3341:     cdef:
+3342:         int x=0, y=0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 3343:         unsigned char *r
 3344:         unsigned char *g
 3345:         unsigned char *b
+3346:         float f = <float> 255.0 / <float> color_number
  __pyx_v_f = (((float)255.0) / ((float)__pyx_v_color_number));
+3347:         float c1 = <float>color_number / <float>255.0
  __pyx_v_c1 = (((float)__pyx_v_color_number) / ((float)255.0));
 3348: 
+3349:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3350:         for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_x = ((int)0xbad0bad0);
+3351:             for x in range(0, w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_x = __pyx_t_7;
 3352: 
+3353:                 r = &rgb_array[x, y, 0]
                              __pyx_t_8 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+3354:                 g = &rgb_array[x, y, 1]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+3355:                 b = &rgb_array[x, y, 2]
                              __pyx_t_8 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
 3356: 
+3357:                 r[0] = <unsigned char>(<int>(<float>round_c(c1 * <float>r[0]) * f))
                              (__pyx_v_r[0]) = ((unsigned char)((int)(((float)round((__pyx_v_c1 * ((float)(__pyx_v_r[0]))))) * __pyx_v_f)));
+3358:                 g[0] = <unsigned char>(<int>(<float>round_c(c1 * <float>g[0]) * f))
                              (__pyx_v_g[0]) = ((unsigned char)((int)(((float)round((__pyx_v_c1 * ((float)(__pyx_v_g[0]))))) * __pyx_v_f)));
+3359:                 b[0] = <unsigned char>(<int>(<float>round_c(c1 * <float>b[0]) * f))
                              (__pyx_v_b[0]) = ((unsigned char)((int)(((float)round((__pyx_v_c1 * ((float)(__pyx_v_b[0]))))) * __pyx_v_f)));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3360: 
 3361: 
 3362: 
 3363: cdef:
+3364:     short [:, ::1] GY = numpy.array(
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_numpy); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 3364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __pyx_t_30 = __Pyx_PyObject_GetAttrStr(__pyx_t_33, __pyx_n_s_array_2); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 3364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
/* … */
  __pyx_t_2 = __Pyx_PyObject_CallOneArg(__pyx_t_30, __pyx_t_31); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
+3365:         ([-1, 0, 1],
  __pyx_t_33 = PyList_New(3); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 3365, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_33, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_33, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_33, 2, __pyx_int_1);
/* … */
  __pyx_t_31 = PyTuple_New(3); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 3365, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_GIVEREF(__pyx_t_33);
  PyTuple_SET_ITEM(__pyx_t_31, 0, __pyx_t_33);
  __Pyx_GIVEREF(__pyx_t_32);
  PyTuple_SET_ITEM(__pyx_t_31, 1, __pyx_t_32);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_31, 2, __pyx_t_2);
  __pyx_t_33 = 0;
  __pyx_t_32 = 0;
  __pyx_t_2 = 0;
+3366:          [-2, 0, 2],
  __pyx_t_32 = PyList_New(3); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 3366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_INCREF(__pyx_int_neg_2);
  __Pyx_GIVEREF(__pyx_int_neg_2);
  PyList_SET_ITEM(__pyx_t_32, 0, __pyx_int_neg_2);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_32, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_2);
  __Pyx_GIVEREF(__pyx_int_2);
  PyList_SET_ITEM(__pyx_t_32, 2, __pyx_int_2);
+3367:          [-1, 0, 1])).astype(dtype=int16, order='C')
  __pyx_t_2 = PyList_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_2, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_2, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_2, 2, __pyx_int_1);
/* … */
  __pyx_t_31 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_astype); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_30, __pyx_n_s_int16); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_dtype, __pyx_t_30) < 0) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 3367, __pyx_L1_error)
  __pyx_t_30 = __Pyx_PyObject_Call(__pyx_t_31, __pyx_empty_tuple, __pyx_t_2); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_35 = __Pyx_PyObject_to_MemoryviewSlice_d_dc_short(__pyx_t_30, PyBUF_WRITABLE); if (unlikely(!__pyx_t_35.memview)) __PYX_ERR(1, 3367, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_GY, 1);
  __pyx_v_12PygameShader_6shader_GY = __pyx_t_35;
  __pyx_t_35.memview = NULL;
  __pyx_t_35.data = NULL;
 3368: 
+3369:     short [:, ::1] GX = numpy.array(
  __Pyx_GetModuleGlobalName(__pyx_t_30, __pyx_n_s_numpy); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 3369, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_30, __pyx_n_s_array_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3369, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
/* … */
  __pyx_t_32 = __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_33); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 3369, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
+3370:         ([-1, -2, -1],
  __pyx_t_30 = PyList_New(3); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 3370, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_30, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_2);
  __Pyx_GIVEREF(__pyx_int_neg_2);
  PyList_SET_ITEM(__pyx_t_30, 1, __pyx_int_neg_2);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_30, 2, __pyx_int_neg_1);
/* … */
  __pyx_t_33 = PyTuple_New(3); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 3370, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_GIVEREF(__pyx_t_30);
  PyTuple_SET_ITEM(__pyx_t_33, 0, __pyx_t_30);
  __Pyx_GIVEREF(__pyx_t_31);
  PyTuple_SET_ITEM(__pyx_t_33, 1, __pyx_t_31);
  __Pyx_GIVEREF(__pyx_t_32);
  PyTuple_SET_ITEM(__pyx_t_33, 2, __pyx_t_32);
  __pyx_t_30 = 0;
  __pyx_t_31 = 0;
  __pyx_t_32 = 0;
+3371:          [0,   0,  0],
  __pyx_t_31 = PyList_New(3); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 3371, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_31, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_31, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_31, 2, __pyx_int_0);
+3372:          [1,   2,  1])).astype(dtype=int16, order='c')
  __pyx_t_32 = PyList_New(3); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_32, 0, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_2);
  __Pyx_GIVEREF(__pyx_int_2);
  PyList_SET_ITEM(__pyx_t_32, 1, __pyx_int_2);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_32, 2, __pyx_int_1);
/* … */
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_32, __pyx_n_s_astype); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __pyx_t_32 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_int16); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_32, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (PyDict_SetItem(__pyx_t_32, __pyx_n_s_order, __pyx_n_s_c_2) < 0) __PYX_ERR(1, 3372, __pyx_L1_error)
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_33, __pyx_empty_tuple, __pyx_t_32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __pyx_t_35 = __Pyx_PyObject_to_MemoryviewSlice_d_dc_short(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_35.memview)) __PYX_ERR(1, 3372, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_GX, 1);
  __pyx_v_12PygameShader_6shader_GX = __pyx_t_35;
  __pyx_t_35.memview = NULL;
  __pyx_t_35.data = NULL;
 3373: 
+3374:     unsigned short int KERNEL_HALF = 1
  __pyx_v_12PygameShader_6shader_KERNEL_HALF = 1;
 3375: 
 3376: 
 3377: @cython.boundscheck(False)
 3378: @cython.wraparound(False)
 3379: @cython.nonecheck(False)
 3380: @cython.cdivision(True)
+3381: cdef inline void shader_sobel24_inplace_c(unsigned char [:, :, :] rgb_array, float threshold=20.0):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_sobel24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array, struct __pyx_opt_args_12PygameShader_6shader_shader_sobel24_inplace_c *__pyx_optional_args) {
  float __pyx_v_threshold = ((float)20.0);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  Py_ssize_t __pyx_v_w_1;
  Py_ssize_t __pyx_v_h_1;
  int __pyx_v_kernel_offset_x;
  int __pyx_v_kernel_offset_y;
  __Pyx_memviewslice __pyx_v_source_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  Py_ssize_t __pyx_v_xx;
  Py_ssize_t __pyx_v_yy;
  float __pyx_v_r_gx;
  float __pyx_v_r_gy;
  unsigned char *__pyx_v_gray;
  unsigned char __pyx_v_m;
  float __pyx_v_magnitude;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_sobel24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold = __pyx_optional_args->threshold;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_sobel24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_source_array, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_sobel24_inplace_c {
  int __pyx_n;
  float threshold;
};
 3382:     """
 3383:     SHADER SOBEL (EDGE DETECTION)
 3384: 
 3385:     Transform the game display or a pygame surface into a sobel equivalent model
 3386:     (surface edge detection)
 3387: 
 3388:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3389:     please refer to pygame function pixels3d or array3d to convert an image into a 3d
 3390:     array (library surfarray)
 3391: 
 3392:     e.g:
 3393:     sobel(surface, 64)
 3394: 
 3395:     :param rgb_array    : numpy.ndarray shape (w, h, 3) containing RGB values
 3396:     :param threshold    : float; Threshold value (Default value = 20.0)
 3397:     :return             : void
 3398:     """
 3399: 
 3400:     cdef Py_ssize_t w, h
+3401:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3402: 
 3403:     cdef:
+3404:         Py_ssize_t w_1 = w - 1
  __pyx_v_w_1 = (__pyx_v_w - 1);
+3405:         Py_ssize_t h_1 = h - 1
  __pyx_v_h_1 = (__pyx_v_h - 1);
 3406:         int kernel_offset_x, kernel_offset_y
+3407:         unsigned char [:, :, :] source_array = numpy.array(rgb_array, copy=True)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3407, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3407, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_source_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 3408:         int x, y
 3409:         Py_ssize_t xx, yy
 3410:         float r_gx, r_gy
 3411:         unsigned char *gray
 3412:         unsigned char m
 3413:         float magnitude
 3414: 
+3415:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L4_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L5:;
      }
  }
 3416: 
+3417:         for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_gray) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_m) lastprivate(__pyx_v_magnitude) lastprivate(__pyx_v_r_gx) lastprivate(__pyx_v_r_gy) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_gray) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_m) lastprivate(__pyx_v_magnitude) lastprivate(__pyx_v_r_gx) lastprivate(__pyx_v_r_gy) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_gray = ((unsigned char *)1);
                            __pyx_v_kernel_offset_x = ((int)0xbad0bad0);
                            __pyx_v_kernel_offset_y = ((int)0xbad0bad0);
                            __pyx_v_m = ((unsigned char)'?');
                            __pyx_v_magnitude = ((float)__PYX_NAN());
                            __pyx_v_r_gx = ((float)__PYX_NAN());
                            __pyx_v_r_gy = ((float)__PYX_NAN());
                            __pyx_v_x = ((int)0xbad0bad0);
                            __pyx_v_xx = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_yy = ((Py_ssize_t)0xbad0bad0);
 3418: 
+3419:             for x in range(w):
                            __pyx_t_10 = __pyx_v_w;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_x = __pyx_t_12;
 3420: 
+3421:                 r_gx, r_gy = <float>0.0, <float>0.0
                              __pyx_t_13 = ((float)0.0);
                              __pyx_t_14 = ((float)0.0);
                              __pyx_v_r_gx = __pyx_t_13;
                              __pyx_v_r_gy = __pyx_t_14;
 3422: 
+3423:                 for kernel_offset_x in range(-KERNEL_HALF, KERNEL_HALF + 1):
                              __pyx_t_15 = (__pyx_v_12PygameShader_6shader_KERNEL_HALF + 1);
                              __pyx_t_16 = __pyx_t_15;
                              for (__pyx_t_17 = (-__pyx_v_12PygameShader_6shader_KERNEL_HALF); __pyx_t_17 < __pyx_t_16; __pyx_t_17+=1) {
                                __pyx_v_kernel_offset_x = __pyx_t_17;
 3424: 
+3425:                     for kernel_offset_y in range(-KERNEL_HALF, KERNEL_HALF + 1):
                                __pyx_t_18 = (__pyx_v_12PygameShader_6shader_KERNEL_HALF + 1);
                                __pyx_t_19 = __pyx_t_18;
                                for (__pyx_t_20 = (-__pyx_v_12PygameShader_6shader_KERNEL_HALF); __pyx_t_20 < __pyx_t_19; __pyx_t_20+=1) {
                                  __pyx_v_kernel_offset_y = __pyx_t_20;
 3426: 
+3427:                         xx = x + kernel_offset_x
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kernel_offset_x);
+3428:                         yy = y + kernel_offset_y
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_kernel_offset_y);
 3429: 
+3430:                         if xx > w_1:
                                  __pyx_t_21 = ((__pyx_v_xx > __pyx_v_w_1) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
+3431:                             xx = w_1
                                    __pyx_v_xx = __pyx_v_w_1;
+3432:                         if xx < 0:
                                  __pyx_t_21 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
+3433:                             xx = 0
                                    __pyx_v_xx = 0;
 3434: 
+3435:                         if yy > h_1:
                                  __pyx_t_21 = ((__pyx_v_yy > __pyx_v_h_1) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
+3436:                             yy = h_1
                                    __pyx_v_yy = __pyx_v_h_1;
+3437:                         if yy < 0:
                                  __pyx_t_21 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
+3438:                             yy = 0
                                    __pyx_v_yy = 0;
 3439: 
 3440:                         # grayscale image red = green = blue
+3441:                         gray = &source_array[xx, yy, 0]
                                  __pyx_t_22 = __pyx_v_xx;
                                  __pyx_t_23 = __pyx_v_yy;
                                  __pyx_t_24 = 0;
                                  __pyx_v_gray = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_22 * __pyx_v_source_array.strides[0]) ) + __pyx_t_23 * __pyx_v_source_array.strides[1]) ) + __pyx_t_24 * __pyx_v_source_array.strides[2]) ))));
 3442: 
+3443:                         if kernel_offset_x != 0:
                                  __pyx_t_21 = ((__pyx_v_kernel_offset_x != 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
 3444: 
+3445:                             r_gx = r_gx + <float> gray[0] * \
                                    __pyx_v_r_gx = (__pyx_v_r_gx + (((float)(__pyx_v_gray[0])) * ((float)(*((short *) ( /* dim=1 */ ((char *) (((short *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_GX.data + __pyx_t_24 * __pyx_v_12PygameShader_6shader_GX.strides[0]) )) + __pyx_t_23)) ))))));
+3446:                                    <float> GX[kernel_offset_x + KERNEL_HALF,
                                    if (unlikely(!__pyx_v_12PygameShader_6shader_GX.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("GX"); __PYX_ERR(1, 3446, __pyx_L8_error) }
/* … */
                                    __pyx_t_24 = (__pyx_v_kernel_offset_x + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
                                    __pyx_t_23 = (__pyx_v_kernel_offset_y + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
 3447:                                               kernel_offset_y + KERNEL_HALF]
 3448: 
+3449:                         if kernel_offset_y != 0:
                                  __pyx_t_21 = ((__pyx_v_kernel_offset_y != 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
                                }
                              }
 3450: 
+3451:                             r_gy = r_gy + <float> gray[0] * \
                                    __pyx_v_r_gy = (__pyx_v_r_gy + (((float)(__pyx_v_gray[0])) * ((float)(*((short *) ( /* dim=1 */ ((char *) (((short *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_GY.data + __pyx_t_23 * __pyx_v_12PygameShader_6shader_GY.strides[0]) )) + __pyx_t_24)) ))))));
+3452:                                    <float> GY[kernel_offset_x + KERNEL_HALF,
                                    if (unlikely(!__pyx_v_12PygameShader_6shader_GY.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("GY"); __PYX_ERR(1, 3452, __pyx_L8_error) }
/* … */
                                    __pyx_t_23 = (__pyx_v_kernel_offset_x + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
                                    __pyx_t_24 = (__pyx_v_kernel_offset_y + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
 3453:                                               kernel_offset_y + KERNEL_HALF]
 3454: 
+3455:                 magnitude = min(<float> sqrt(r_gx * r_gx + r_gy * r_gy), <float>255.0)
                              __pyx_t_14 = ((float)255.0);
                              __pyx_t_13 = ((float)sqrt(((__pyx_v_r_gx * __pyx_v_r_gx) + (__pyx_v_r_gy * __pyx_v_r_gy))));
                              if (((__pyx_t_14 < __pyx_t_13) != 0)) {
                                __pyx_t_25 = __pyx_t_14;
                              } else {
                                __pyx_t_25 = __pyx_t_13;
                              }
                              __pyx_v_magnitude = __pyx_t_25;
 3456: 
 3457:                 # if magnitude > 255:
 3458:                 #     magnitude = 255.0
 3459: 
+3460:                 m = <unsigned char> magnitude if magnitude > threshold else 0
                              if (((__pyx_v_magnitude > __pyx_v_threshold) != 0)) {
                                __pyx_t_26 = ((unsigned char)__pyx_v_magnitude);
                              } else {
                                __pyx_t_26 = 0;
                              }
                              __pyx_v_m = __pyx_t_26;
 3461: 
 3462:                 # update the pixel if the magnitude is above threshold else black pixel
+3463:                 rgb_array[x, y, 0] = m
                              __pyx_t_24 = __pyx_v_x;
                              __pyx_t_23 = __pyx_v_y;
                              __pyx_t_22 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_24 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_m;
+3464:                 rgb_array[x, y, 1] = m
                              __pyx_t_22 = __pyx_v_x;
                              __pyx_t_23 = __pyx_v_y;
                              __pyx_t_24 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_22 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_24 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_m;
+3465:                 rgb_array[x, y, 2] = m
                              __pyx_t_24 = __pyx_v_x;
                              __pyx_t_23 = __pyx_v_y;
                              __pyx_t_22 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_24 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array.strides[2]) )) = __pyx_v_m;
                            }
                            goto __pyx_L23;
                            __pyx_L8_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L22;
                            __pyx_L22:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates0)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_gray;
                                __pyx_parallel_temp1 = __pyx_v_kernel_offset_x;
                                __pyx_parallel_temp2 = __pyx_v_kernel_offset_y;
                                __pyx_parallel_temp3 = __pyx_v_m;
                                __pyx_parallel_temp4 = __pyx_v_magnitude;
                                __pyx_parallel_temp5 = __pyx_v_r_gx;
                                __pyx_parallel_temp6 = __pyx_v_r_gy;
                                __pyx_parallel_temp7 = __pyx_v_x;
                                __pyx_parallel_temp8 = __pyx_v_xx;
                                __pyx_parallel_temp9 = __pyx_v_y;
                                __pyx_parallel_temp10 = __pyx_v_yy;
                            }
                            __pyx_L23:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_gray = __pyx_parallel_temp0;
              __pyx_v_kernel_offset_x = __pyx_parallel_temp1;
              __pyx_v_kernel_offset_y = __pyx_parallel_temp2;
              __pyx_v_m = __pyx_parallel_temp3;
              __pyx_v_magnitude = __pyx_parallel_temp4;
              __pyx_v_r_gx = __pyx_parallel_temp5;
              __pyx_v_r_gy = __pyx_parallel_temp6;
              __pyx_v_x = __pyx_parallel_temp7;
              __pyx_v_xx = __pyx_parallel_temp8;
              __pyx_v_y = __pyx_parallel_temp9;
              __pyx_v_yy = __pyx_parallel_temp10;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L4_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3466: 
 3467: 
 3468: 
 3469: @cython.boundscheck(False)
 3470: @cython.wraparound(False)
 3471: @cython.nonecheck(False)
 3472: @cython.cdivision(True)
+3473: cdef unsigned char [:, :, ::1] scale_array24_c(
static __Pyx_memviewslice __pyx_f_12PygameShader_6shader_scale_array24_c(__Pyx_memviewslice __pyx_v_rgb_array, int __pyx_v_w2, int __pyx_v_h2) {
  Py_ssize_t __pyx_v_w1;
  Py_ssize_t __pyx_v_h1;
  CYTHON_UNUSED Py_ssize_t __pyx_v_s;
  CYTHON_UNUSED PyObject *__pyx_v_e = NULL;
  __Pyx_memviewslice __pyx_v_new_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_fx;
  float __pyx_v_fy;
  int __pyx_v_x;
  int __pyx_v_y;
  Py_ssize_t __pyx_v_xx;
  Py_ssize_t __pyx_v_yy;
  __Pyx_memviewslice __pyx_r = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("scale_array24_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_14);
  __PYX_XDEC_MEMVIEW(&__pyx_t_15, 1);
  __pyx_r.data = NULL;
  __pyx_r.memview = NULL;
  __Pyx_AddTraceback("PygameShader.shader.scale_array24_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  goto __pyx_L2;
  __pyx_L0:;
  if (unlikely(!__pyx_r.memview)) {
    PyErr_SetString(PyExc_TypeError, "Memoryview return value is not initialized");
  }
  __pyx_L2:;
  __Pyx_XDECREF(__pyx_v_e);
  __PYX_XDEC_MEMVIEW(&__pyx_v_new_array, 1);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 3474:         unsigned char [:, :, :]
 3475:         rgb_array,
 3476:         int w2,
 3477:         int h2
 3478: ):
 3479:     """
 3480:     ARRAY RE-SCALING ; ARRAY SHAPE (W, H, 3)
 3481: 
 3482:     This is an internal tool that cannot be access outside of this library (cpdef hook missing)
 3483:     Re-scale an array (rgb_array) of size (w, h, 3) into an equivalent array size (w2, h2, 3).
 3484:     This function is identical to a surface rescaling but uses the array instead
 3485: 
 3486:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3487:      please refer to pygame function pixels3d or array3d to convert an image into a 3d
 3488:       array (library surfarray)
 3489: 
 3490:     e.g:
 3491:     memview_array = scale_array24_c(my_array, 300, 300)
 3492: 
 3493:     :param rgb_array    : RGB numpy.ndarray, format (w, h, 3) numpy.uint8
 3494:     :param w2           : new width
 3495:     :param h2           : new height
 3496:     :return             : Return a MemoryViewSlice 3d numpy.ndarray format (w, h, 3) uint8
 3497:     """
+3498:     assert w2 > 0, "Argument w2 cannot be <=0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_w2 > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_w2_cannot_be_0);
      __PYX_ERR(1, 3498, __pyx_L1_error)
    }
  }
  #endif
+3499:     assert h2 > 0, "Argument h2 cannot be <=0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_h2 > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_h2_cannot_be_0);
      __PYX_ERR(1, 3499, __pyx_L1_error)
    }
  }
  #endif
 3500: 
 3501:     cdef Py_ssize_t w1, h1, s
 3502: 
+3503:     try:
  {
    /*try:*/ {
/* … */
    }
  }
+3504:         w1, h1, s = rgb_array.shape[:3]
      __pyx_t_4 = __pyx_v_rgb_array.shape;
      __pyx_t_5 = (__pyx_t_4[0]);
      __pyx_t_6 = (__pyx_t_4[1]);
      __pyx_t_7 = (__pyx_t_4[2]);
      __pyx_v_w1 = __pyx_t_5;
      __pyx_v_h1 = __pyx_t_6;
      __pyx_v_s = __pyx_t_7;
 3505: 
 3506:     except (ValueError, pygame.error) as e:
 3507:         raise ValueError('\nArray shape not understood.')
 3508: 
 3509:     cdef:
+3510:         unsigned char [:, :, ::1] new_array = numpy.zeros((w2, h2, 3), numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_n_s_numpy); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_n_s_zeros); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = __Pyx_PyInt_From_int(__pyx_v_w2); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_11 = __Pyx_PyInt_From_int(__pyx_v_h2); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_12 = PyTuple_New(3); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_GIVEREF(__pyx_t_9);
  PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_11);
  PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_11);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_int_3);
  __pyx_t_9 = 0;
  __pyx_t_11 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_n_s_numpy); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_n_s_uint8); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __pyx_t_11 = NULL;
  __pyx_t_13 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_10))) {
    __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_10);
    if (likely(__pyx_t_11)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_11);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_10, function);
      __pyx_t_13 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_11, __pyx_t_12, __pyx_t_9};
    __pyx_t_8 = __Pyx_PyFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_13, 2+__pyx_t_13); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3510, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_11, __pyx_t_12, __pyx_t_9};
    __pyx_t_8 = __Pyx_PyCFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_13, 2+__pyx_t_13); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3510, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  } else
  #endif
  {
    __pyx_t_14 = PyTuple_New(2+__pyx_t_13); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 3510, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    if (__pyx_t_11) {
      __Pyx_GIVEREF(__pyx_t_11); PyTuple_SET_ITEM(__pyx_t_14, 0, __pyx_t_11); __pyx_t_11 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_12);
    PyTuple_SET_ITEM(__pyx_t_14, 0+__pyx_t_13, __pyx_t_12);
    __Pyx_GIVEREF(__pyx_t_9);
    PyTuple_SET_ITEM(__pyx_t_14, 1+__pyx_t_13, __pyx_t_9);
    __pyx_t_12 = 0;
    __pyx_t_9 = 0;
    __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_t_14, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 3510, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  }
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_15 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_15.memview)) __PYX_ERR(1, 3510, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_new_array = __pyx_t_15;
  __pyx_t_15.memview = NULL;
  __pyx_t_15.data = NULL;
+3511:         float fx = <float>w1 / <float>w2
  __pyx_v_fx = (((float)__pyx_v_w1) / ((float)__pyx_v_w2));
+3512:         float fy = <float>h1 / <float>h2
  __pyx_v_fy = (((float)__pyx_v_h1) / ((float)__pyx_v_h2));
 3513:         int x, y
 3514:         Py_ssize_t xx, yy
+3515:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L11;
        }
        __pyx_L11:;
      }
  }
+3516:         for x in prange(w2, schedule='static', num_threads=THREADS):
        __pyx_t_13 = __pyx_v_w2;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_17 = (__pyx_t_13 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_17 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_13 = __pyx_v_w2;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_17 = (__pyx_t_13 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_17 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_16 = 0; __pyx_t_16 < __pyx_t_17; __pyx_t_16++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_16);
                            /* Initialize private variables to invalid values */
                            __pyx_v_xx = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_yy = ((Py_ssize_t)0xbad0bad0);
+3517:             xx = <int>(x * fx)
                            __pyx_v_xx = ((int)(__pyx_v_x * __pyx_v_fx));
+3518:             for y in range(h2):
                            __pyx_t_18 = __pyx_v_h2;
                            __pyx_t_19 = __pyx_t_18;
                            for (__pyx_t_20 = 0; __pyx_t_20 < __pyx_t_19; __pyx_t_20+=1) {
                              __pyx_v_y = __pyx_t_20;
+3519:                 yy = <int>(y * fy)
                              __pyx_v_yy = ((int)(__pyx_v_y * __pyx_v_fy));
+3520:                 new_array[x, y, 0] = rgb_array[xx, yy, 0]
                              __pyx_t_21 = __pyx_v_xx;
                              __pyx_t_22 = __pyx_v_yy;
                              __pyx_t_23 = 0;
                              __pyx_t_24 = __pyx_v_x;
                              __pyx_t_25 = __pyx_v_y;
                              __pyx_t_26 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_24 * __pyx_v_new_array.strides[0]) ) + __pyx_t_25 * __pyx_v_new_array.strides[1]) )) + __pyx_t_26)) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_21 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_22 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array.strides[2]) )));
+3521:                 new_array[x, y, 1] = rgb_array[xx, yy, 1]
                              __pyx_t_23 = __pyx_v_xx;
                              __pyx_t_22 = __pyx_v_yy;
                              __pyx_t_21 = 1;
                              __pyx_t_26 = __pyx_v_x;
                              __pyx_t_25 = __pyx_v_y;
                              __pyx_t_24 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_26 * __pyx_v_new_array.strides[0]) ) + __pyx_t_25 * __pyx_v_new_array.strides[1]) )) + __pyx_t_24)) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_23 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_22 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_21 * __pyx_v_rgb_array.strides[2]) )));
+3522:                 new_array[x, y, 2] = rgb_array[xx, yy, 2]
                              __pyx_t_21 = __pyx_v_xx;
                              __pyx_t_22 = __pyx_v_yy;
                              __pyx_t_23 = 2;
                              __pyx_t_24 = __pyx_v_x;
                              __pyx_t_25 = __pyx_v_y;
                              __pyx_t_26 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_24 * __pyx_v_new_array.strides[0]) ) + __pyx_t_25 * __pyx_v_new_array.strides[1]) )) + __pyx_t_26)) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_21 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_22 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3523: 
+3524:     return new_array
  __PYX_INC_MEMVIEW(&__pyx_v_new_array, 0);
  __pyx_r = __pyx_v_new_array;
  goto __pyx_L0;
 3525: 
 3526: 
 3527: @cython.boundscheck(False)
 3528: @cython.wraparound(False)
 3529: @cython.nonecheck(False)
 3530: @cython.cdivision(True)
+3531: cdef inline void shader_sobel24_fast_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_sobel24_fast_inplace_c(PyObject *__pyx_v_surface_, struct __pyx_opt_args_12PygameShader_6shader_shader_sobel24_fast_inplace_c *__pyx_optional_args) {
  int __pyx_v_threshold_ = ((int)20);
  unsigned short __pyx_v_factor_ = ((unsigned short)1);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  Py_ssize_t __pyx_v_w_1;
  Py_ssize_t __pyx_v_h_1;
  int __pyx_v_kernel_offset_x;
  int __pyx_v_kernel_offset_y;
  int __pyx_v_x;
  int __pyx_v_y;
  Py_ssize_t __pyx_v_xx;
  Py_ssize_t __pyx_v_yy;
  float __pyx_v_r_gx;
  float __pyx_v_r_gy;
  unsigned char *__pyx_v_gray;
  unsigned char __pyx_v_m;
  float __pyx_v_magnitude;
  __Pyx_memviewslice __pyx_v_source_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_rescale_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_new_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_new_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_sobel24_fast_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold_ = __pyx_optional_args->threshold_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_factor_ = __pyx_optional_args->factor_;
      }
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_13);
  __PYX_XDEC_MEMVIEW(&__pyx_t_31, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_sobel24_fast_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_source_array, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_rescale_array, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_new_array, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_new_, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_sobel24_fast_inplace_c {
  int __pyx_n;
  int threshold_;
  unsigned short factor_;
};
 3532:         surface_, int threshold_=20, unsigned short factor_=1):
 3533:     """
 3534:     SHADER FAST SOBEL (EDGE DETECTION)
 3535: 
 3536:     Transform the game display or a pygame surface into a sobel equivalent model
 3537:     (surface edge detection).This version is slightly fastest than shader_sobel24_inplace_c as
 3538:     it down-scale the array containing all the pixels and apply the sobel algorithm to a smaller
 3539:     sample. When the processing is done, the array is re-scale to its original dimensions.
 3540:     If this method is in theory faster than shader_sobel24_inplace_c, down-scaling and up-scaling
 3541:     an array does have a side effect of decreasing the overall image definition
 3542:     (jagged lines non-antialiasing)
 3543: 
 3544:     e.g:
 3545:     sobel_fast(surface, 64, factor_=1)
 3546: 
 3547:     :param surface_     :  pygame.Surface
 3548:     :param threshold_   : integer; threshold value for the sobel filter
 3549:     :param factor_      : unsigned short (default value =1). Define the
 3550:     reduction factor of an image. 1 divide by 2, 2 divide by 4 etc
 3551:     :return             : void
 3552:     """
 3553: 
 3554:     cdef:
 3555:         Py_ssize_t w, h, w_1, h_1
+3556:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3556, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3556, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 3556, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 3556, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 3556, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_6 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 3556, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 3556, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 3557: 
 3558:     cdef:
 3559:         int kernel_offset_x, kernel_offset_y
 3560:         int x, y
 3561:         Py_ssize_t xx, yy
 3562:         float r_gx, r_gy
 3563:         unsigned char *gray
 3564:         unsigned char m
 3565:         float magnitude
 3566: 
+3567:         unsigned char [:, :, :] source_array = pixels3d(surface_)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3567, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_source_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 3568:         unsigned char [:, :, :] rescale_array = \
+3569:             numpy.array(pixels3d(scale(surface_, (w >> factor_, h >> factor_))))
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_numpy); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_array_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_n_s_scale); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_11 = PyInt_FromSsize_t((__pyx_v_w >> __pyx_v_factor_)); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_12 = PyInt_FromSsize_t((__pyx_v_h >> __pyx_v_factor_)); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __pyx_t_13 = PyTuple_New(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_13);
  __Pyx_GIVEREF(__pyx_t_11);
  PyTuple_SET_ITEM(__pyx_t_13, 0, __pyx_t_11);
  __Pyx_GIVEREF(__pyx_t_12);
  PyTuple_SET_ITEM(__pyx_t_13, 1, __pyx_t_12);
  __pyx_t_11 = 0;
  __pyx_t_12 = 0;
  __pyx_t_12 = NULL;
  __pyx_t_14 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_10))) {
    __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_10);
    if (likely(__pyx_t_12)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_12);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_10, function);
      __pyx_t_14 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_12, __pyx_v_surface_, __pyx_t_13};
    __pyx_t_9 = __Pyx_PyFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_14, 2+__pyx_t_14); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3569, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_12, __pyx_v_surface_, __pyx_t_13};
    __pyx_t_9 = __Pyx_PyCFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_14, 2+__pyx_t_14); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3569, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
  } else
  #endif
  {
    __pyx_t_11 = PyTuple_New(2+__pyx_t_14); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 3569, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    if (__pyx_t_12) {
      __Pyx_GIVEREF(__pyx_t_12); PyTuple_SET_ITEM(__pyx_t_11, 0, __pyx_t_12); __pyx_t_12 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface_);
    __Pyx_GIVEREF(__pyx_v_surface_);
    PyTuple_SET_ITEM(__pyx_t_11, 0+__pyx_t_14, __pyx_v_surface_);
    __Pyx_GIVEREF(__pyx_t_13);
    PyTuple_SET_ITEM(__pyx_t_11, 1+__pyx_t_14, __pyx_t_13);
    __pyx_t_13 = 0;
    __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_t_11, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3569, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  }
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_10 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_10)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_10);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_3 = (__pyx_t_10) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_10, __pyx_t_9) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_t_3) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3569, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rescale_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+3570:         unsigned char [:, :, :] new_array = empty((w >> factor_, h >> factor_, 3), uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyInt_FromSsize_t((__pyx_v_w >> __pyx_v_factor_)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyInt_FromSsize_t((__pyx_v_h >> __pyx_v_factor_)); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_9 = PyTuple_New(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_4);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_9, 2, __pyx_int_3);
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = NULL;
  __pyx_t_14 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
      __pyx_t_14 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_9, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_14, 2+__pyx_t_14); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3570, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_9, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_14, 2+__pyx_t_14); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3570, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_10 = PyTuple_New(2+__pyx_t_14); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 3570, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_9);
    PyTuple_SET_ITEM(__pyx_t_10, 0+__pyx_t_14, __pyx_t_9);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_10, 1+__pyx_t_14, __pyx_t_4);
    __pyx_t_9 = 0;
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_10, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 3570, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3570, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_new_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 3571: 
+3572:     h = h >> factor_
  __pyx_v_h = (__pyx_v_h >> __pyx_v_factor_);
+3573:     w = w >> factor_
  __pyx_v_w = (__pyx_v_w >> __pyx_v_factor_);
+3574:     w_1 = w - 1
  __pyx_v_w_1 = (__pyx_v_w - 1);
+3575:     h_1 = h - 1
  __pyx_v_h_1 = (__pyx_v_h - 1);
 3576: 
+3577:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L6_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L7:;
      }
  }
 3578: 
+3579:         for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_7 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_15 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_15 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_gray) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_m) lastprivate(__pyx_v_magnitude) lastprivate(__pyx_v_r_gx) lastprivate(__pyx_v_r_gy) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_7 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_15 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_15 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_gray) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_m) lastprivate(__pyx_v_magnitude) lastprivate(__pyx_v_r_gx) lastprivate(__pyx_v_r_gy) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_15; __pyx_t_6++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_gray = ((unsigned char *)1);
                            __pyx_v_kernel_offset_x = ((int)0xbad0bad0);
                            __pyx_v_kernel_offset_y = ((int)0xbad0bad0);
                            __pyx_v_m = ((unsigned char)'?');
                            __pyx_v_magnitude = ((float)__PYX_NAN());
                            __pyx_v_r_gx = ((float)__PYX_NAN());
                            __pyx_v_r_gy = ((float)__PYX_NAN());
                            __pyx_v_x = ((int)0xbad0bad0);
                            __pyx_v_xx = ((Py_ssize_t)0xbad0bad0);
                            __pyx_v_yy = ((Py_ssize_t)0xbad0bad0);
 3580: 
+3581:             for x in range(w):
                            __pyx_t_16 = __pyx_v_w;
                            __pyx_t_17 = __pyx_t_16;
                            for (__pyx_t_14 = 0; __pyx_t_14 < __pyx_t_17; __pyx_t_14+=1) {
                              __pyx_v_x = __pyx_t_14;
 3582: 
+3583:                 r_gx, r_gy = <float>0.0, <float>0.0
                              __pyx_t_18 = ((float)0.0);
                              __pyx_t_19 = ((float)0.0);
                              __pyx_v_r_gx = __pyx_t_18;
                              __pyx_v_r_gy = __pyx_t_19;
 3584: 
+3585:                 for kernel_offset_y in range(-KERNEL_HALF, KERNEL_HALF + 1):
                              __pyx_t_20 = (__pyx_v_12PygameShader_6shader_KERNEL_HALF + 1);
                              __pyx_t_21 = __pyx_t_20;
                              for (__pyx_t_22 = (-__pyx_v_12PygameShader_6shader_KERNEL_HALF); __pyx_t_22 < __pyx_t_21; __pyx_t_22+=1) {
                                __pyx_v_kernel_offset_y = __pyx_t_22;
 3586: 
+3587:                     for kernel_offset_x in range(-KERNEL_HALF, KERNEL_HALF + 1):
                                __pyx_t_23 = (__pyx_v_12PygameShader_6shader_KERNEL_HALF + 1);
                                __pyx_t_24 = __pyx_t_23;
                                for (__pyx_t_25 = (-__pyx_v_12PygameShader_6shader_KERNEL_HALF); __pyx_t_25 < __pyx_t_24; __pyx_t_25+=1) {
                                  __pyx_v_kernel_offset_x = __pyx_t_25;
 3588: 
+3589:                         xx = x + kernel_offset_x
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kernel_offset_x);
+3590:                         yy = y + kernel_offset_y
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_kernel_offset_y);
 3591: 
+3592:                         if xx > w_1:
                                  __pyx_t_26 = ((__pyx_v_xx > __pyx_v_w_1) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
+3593:                             xx = w_1
                                    __pyx_v_xx = __pyx_v_w_1;
+3594:                         if xx < 0:
                                  __pyx_t_26 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
+3595:                             xx = 0
                                    __pyx_v_xx = 0;
 3596: 
+3597:                         if yy > h_1:
                                  __pyx_t_26 = ((__pyx_v_yy > __pyx_v_h_1) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
+3598:                             yy = h_1
                                    __pyx_v_yy = __pyx_v_h_1;
+3599:                         if yy < 0:
                                  __pyx_t_26 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
+3600:                             yy = 0
                                    __pyx_v_yy = 0;
 3601: 
 3602:                         # grayscale image red = green = blue
+3603:                         gray = &rescale_array[xx, yy, 0]
                                  __pyx_t_27 = __pyx_v_xx;
                                  __pyx_t_28 = __pyx_v_yy;
                                  __pyx_t_29 = 0;
                                  __pyx_v_gray = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rescale_array.data + __pyx_t_27 * __pyx_v_rescale_array.strides[0]) ) + __pyx_t_28 * __pyx_v_rescale_array.strides[1]) ) + __pyx_t_29 * __pyx_v_rescale_array.strides[2]) ))));
 3604: 
+3605:                         if kernel_offset_x != 0:
                                  __pyx_t_26 = ((__pyx_v_kernel_offset_x != 0) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
 3606: 
+3607:                             r_gx = r_gx + <float> gray[0] * \
                                    __pyx_v_r_gx = (__pyx_v_r_gx + (((float)(__pyx_v_gray[0])) * ((float)(*((short *) ( /* dim=1 */ ((char *) (((short *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_GX.data + __pyx_t_29 * __pyx_v_12PygameShader_6shader_GX.strides[0]) )) + __pyx_t_28)) ))))));
+3608:                                    <float> GX[kernel_offset_x + KERNEL_HALF,
                                    if (unlikely(!__pyx_v_12PygameShader_6shader_GX.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("GX"); __PYX_ERR(1, 3608, __pyx_L10_error) }
/* … */
                                    __pyx_t_29 = (__pyx_v_kernel_offset_x + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
                                    __pyx_t_28 = (__pyx_v_kernel_offset_y + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
 3609:                                               kernel_offset_y + KERNEL_HALF]
 3610: 
+3611:                         if kernel_offset_y != 0:
                                  __pyx_t_26 = ((__pyx_v_kernel_offset_y != 0) != 0);
                                  if (__pyx_t_26) {
/* … */
                                  }
                                }
                              }
 3612: 
+3613:                             r_gy = r_gy + <float> gray[0] * \
                                    __pyx_v_r_gy = (__pyx_v_r_gy + (((float)(__pyx_v_gray[0])) * ((float)(*((short *) ( /* dim=1 */ ((char *) (((short *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_GY.data + __pyx_t_28 * __pyx_v_12PygameShader_6shader_GY.strides[0]) )) + __pyx_t_29)) ))))));
+3614:                                    <float> GY[kernel_offset_x + KERNEL_HALF,
                                    if (unlikely(!__pyx_v_12PygameShader_6shader_GY.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("GY"); __PYX_ERR(1, 3614, __pyx_L10_error) }
/* … */
                                    __pyx_t_28 = (__pyx_v_kernel_offset_x + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
                                    __pyx_t_29 = (__pyx_v_kernel_offset_y + __pyx_v_12PygameShader_6shader_KERNEL_HALF);
 3615:                                               kernel_offset_y + KERNEL_HALF]
 3616: 
+3617:                 magnitude = <float> sqrt(r_gx * r_gx + r_gy * r_gy)
                              __pyx_v_magnitude = ((float)sqrt(((__pyx_v_r_gx * __pyx_v_r_gx) + (__pyx_v_r_gy * __pyx_v_r_gy))));
 3618: 
+3619:                 if magnitude > 255:
                              __pyx_t_26 = ((__pyx_v_magnitude > 255.0) != 0);
                              if (__pyx_t_26) {
/* … */
                              }
+3620:                     magnitude = <float>255.0
                                __pyx_v_magnitude = ((float)255.0);
 3621: 
+3622:                 m = <unsigned char> magnitude if magnitude > threshold_ else 0
                              if (((__pyx_v_magnitude > __pyx_v_threshold_) != 0)) {
                                __pyx_t_30 = ((unsigned char)__pyx_v_magnitude);
                              } else {
                                __pyx_t_30 = 0;
                              }
                              __pyx_v_m = __pyx_t_30;
 3623: 
 3624:                 # update the pixel if the magnitude is above threshold else black pixel
+3625:                 new_array[x, y, 0] = m
                              __pyx_t_29 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_27 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_29 * __pyx_v_new_array.strides[0]) ) + __pyx_t_28 * __pyx_v_new_array.strides[1]) ) + __pyx_t_27 * __pyx_v_new_array.strides[2]) )) = __pyx_v_m;
+3626:                 new_array[x, y, 1] = m
                              __pyx_t_27 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_29 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_27 * __pyx_v_new_array.strides[0]) ) + __pyx_t_28 * __pyx_v_new_array.strides[1]) ) + __pyx_t_29 * __pyx_v_new_array.strides[2]) )) = __pyx_v_m;
+3627:                 new_array[x, y, 2] = m
                              __pyx_t_29 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_27 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_29 * __pyx_v_new_array.strides[0]) ) + __pyx_t_28 * __pyx_v_new_array.strides[1]) ) + __pyx_t_27 * __pyx_v_new_array.strides[2]) )) = __pyx_v_m;
                            }
                            goto __pyx_L26;
                            __pyx_L10_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L25;
                            __pyx_L25:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates1)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_gray;
                                __pyx_parallel_temp1 = __pyx_v_kernel_offset_x;
                                __pyx_parallel_temp2 = __pyx_v_kernel_offset_y;
                                __pyx_parallel_temp3 = __pyx_v_m;
                                __pyx_parallel_temp4 = __pyx_v_magnitude;
                                __pyx_parallel_temp5 = __pyx_v_r_gx;
                                __pyx_parallel_temp6 = __pyx_v_r_gy;
                                __pyx_parallel_temp7 = __pyx_v_x;
                                __pyx_parallel_temp8 = __pyx_v_xx;
                                __pyx_parallel_temp9 = __pyx_v_y;
                                __pyx_parallel_temp10 = __pyx_v_yy;
                            }
                            __pyx_L26:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_gray = __pyx_parallel_temp0;
              __pyx_v_kernel_offset_x = __pyx_parallel_temp1;
              __pyx_v_kernel_offset_y = __pyx_parallel_temp2;
              __pyx_v_m = __pyx_parallel_temp3;
              __pyx_v_magnitude = __pyx_parallel_temp4;
              __pyx_v_r_gx = __pyx_parallel_temp5;
              __pyx_v_r_gy = __pyx_parallel_temp6;
              __pyx_v_x = __pyx_parallel_temp7;
              __pyx_v_xx = __pyx_parallel_temp8;
              __pyx_v_y = __pyx_parallel_temp9;
              __pyx_v_yy = __pyx_parallel_temp10;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L6_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3628: 
+3629:     w = w << factor_
  __pyx_v_w = (__pyx_v_w << __pyx_v_factor_);
+3630:     h = h << factor_
  __pyx_v_h = (__pyx_v_h << __pyx_v_factor_);
 3631: 
+3632:     cdef unsigned char [:, :, :] new_ = scale_array24_c(new_array, w, h)
  __pyx_t_31 = __pyx_f_12PygameShader_6shader_scale_array24_c(__pyx_v_new_array, __pyx_v_w, __pyx_v_h); if (unlikely(!__pyx_t_31.memview)) __PYX_ERR(1, 3632, __pyx_L1_error)
  __pyx_v_new_ = __pyx_t_31;
  __pyx_t_31.memview = NULL;
  __pyx_t_31.data = NULL;
 3633: 
+3634:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L29;
        }
        __pyx_L29:;
      }
  }
 3635: 
+3636:         for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_15 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_7 = (__pyx_t_15 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_7 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_15 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_7 = (__pyx_t_15 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_7 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_7; __pyx_t_6++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_x = ((int)0xbad0bad0);
+3637:             for x in range(w):
                            __pyx_t_16 = __pyx_v_w;
                            __pyx_t_17 = __pyx_t_16;
                            for (__pyx_t_14 = 0; __pyx_t_14 < __pyx_t_17; __pyx_t_14+=1) {
                              __pyx_v_x = __pyx_t_14;
 3638: 
+3639:                 source_array[x, y, 0] = new_[x, y, 0]
                              __pyx_t_27 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_29 = 0;
                              __pyx_t_32 = __pyx_v_x;
                              __pyx_t_33 = __pyx_v_y;
                              __pyx_t_34 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_32 * __pyx_v_source_array.strides[0]) ) + __pyx_t_33 * __pyx_v_source_array.strides[1]) ) + __pyx_t_34 * __pyx_v_source_array.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_.data + __pyx_t_27 * __pyx_v_new_.strides[0]) ) + __pyx_t_28 * __pyx_v_new_.strides[1]) ) + __pyx_t_29 * __pyx_v_new_.strides[2]) )));
+3640:                 source_array[x, y, 1] = new_[x, y, 1]
                              __pyx_t_29 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_27 = 1;
                              __pyx_t_34 = __pyx_v_x;
                              __pyx_t_33 = __pyx_v_y;
                              __pyx_t_32 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_34 * __pyx_v_source_array.strides[0]) ) + __pyx_t_33 * __pyx_v_source_array.strides[1]) ) + __pyx_t_32 * __pyx_v_source_array.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_.data + __pyx_t_29 * __pyx_v_new_.strides[0]) ) + __pyx_t_28 * __pyx_v_new_.strides[1]) ) + __pyx_t_27 * __pyx_v_new_.strides[2]) )));
+3641:                 source_array[x, y, 2] = new_[x, y, 2]
                              __pyx_t_27 = __pyx_v_x;
                              __pyx_t_28 = __pyx_v_y;
                              __pyx_t_29 = 2;
                              __pyx_t_32 = __pyx_v_x;
                              __pyx_t_33 = __pyx_v_y;
                              __pyx_t_34 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_32 * __pyx_v_source_array.strides[0]) ) + __pyx_t_33 * __pyx_v_source_array.strides[1]) ) + __pyx_t_34 * __pyx_v_source_array.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_.data + __pyx_t_27 * __pyx_v_new_.strides[0]) ) + __pyx_t_28 * __pyx_v_new_.strides[1]) ) + __pyx_t_29 * __pyx_v_new_.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3642: 
 3643: 
 3644: @cython.boundscheck(False)
 3645: @cython.wraparound(False)
 3646: @cython.nonecheck(False)
 3647: @cython.cdivision(True)
+3648: cdef inline void shader_invert_surface_24bit_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_invert_surface_24bit_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_invert_surface_24bit_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 3649:         unsigned char [:, :, :] rgb_array):
 3650: 
 3651:     """
 3652:     SHADER INVERT PIXELS
 3653: 
 3654:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3655:      please refer to pygame function pixels3d or array3d to convert an image into a 3d
 3656:      array (library surfarray)
 3657: 
 3658:     Invert all pixels of the display or a given texture
 3659:     e.g:
 3660:     invert(surface)
 3661: 
 3662:     :param rgb_array    : numpy.ndarray containing all the RGB color values. Array shape (w, h, 3)
 3663:     :return             : void
 3664:     """
 3665: 
 3666:     cdef Py_ssize_t w, h
+3667:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3668: 
 3669:     cdef:
+3670:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 3671:         unsigned char *r
 3672:         unsigned char *g
 3673:         unsigned char *b
 3674: 
+3675:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3676:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
+3677:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
+3678:                 r = &rgb_array[i, j, 0]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+3679:                 g = &rgb_array[i, j, 1]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+3680:                 b = &rgb_array[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+3681:                 r[0] = 255 - r[0]
                              (__pyx_v_r[0]) = (0xFF - (__pyx_v_r[0]));
+3682:                 g[0] = 255 - g[0]
                              (__pyx_v_g[0]) = (0xFF - (__pyx_v_g[0]));
+3683:                 b[0] = 255 - b[0]
                              (__pyx_v_b[0]) = (0xFF - (__pyx_v_b[0]));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3684: 
 3685: 
+3686: cdef float[5] GAUSS_KERNEL = [1.0/16.0, 4.0/16.0, 6.0/16.0, 4.0/16.0, 1.0/16.0]
  __pyx_t_36[0] = (1.0 / 16.0);
  __pyx_t_36[1] = (4.0 / 16.0);
  __pyx_t_36[2] = (6.0 / 16.0);
  __pyx_t_36[3] = (4.0 / 16.0);
  __pyx_t_36[4] = (1.0 / 16.0);
  memcpy(&(__pyx_v_12PygameShader_6shader_GAUSS_KERNEL[0]), __pyx_t_36, sizeof(__pyx_v_12PygameShader_6shader_GAUSS_KERNEL[0]) * (5));
 3687: 
 3688: @cython.boundscheck(False)
 3689: @cython.wraparound(False)
 3690: @cython.nonecheck(False)
 3691: @cython.cdivision(True)
+3692: cdef inline void shader_blur5x5_array24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_blur5x5_array24_inplace_c *__pyx_optional_args) {
  PyObject *__pyx_v_t = ((PyObject *)__pyx_int_1);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  short __pyx_v_kernel_half;
  __Pyx_memviewslice __pyx_v_convolve = { 0, 0, { 0 }, { 0 }, { 0 } };
  CYTHON_UNUSED __Pyx_memviewslice __pyx_v_convolved = { 0, 0, { 0 }, { 0 }, { 0 } };
  CYTHON_UNUSED Py_ssize_t __pyx_v_kernel_length;
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_xx;
  int __pyx_v_yy;
  float __pyx_v_r;
  float __pyx_v_g;
  float __pyx_v_b;
  char __pyx_v_kernel_offset;
  unsigned char __pyx_v_red;
  unsigned char __pyx_v_green;
  unsigned char __pyx_v_blue;
  float *__pyx_v_k;
  unsigned char *__pyx_v_c1;
  unsigned char *__pyx_v_c2;
  unsigned char *__pyx_v_c3;
  unsigned char *__pyx_v_c4;
  unsigned char *__pyx_v_c5;
  unsigned char *__pyx_v_c6;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_blur5x5_array24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 1) {
      __pyx_v_t = __pyx_optional_args->t;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_blur5x5_array24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_convolve, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_convolved, 1);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_blur5x5_array24_inplace_c {
  int __pyx_n;
  PyObject *mask;
  PyObject *t;
};
 3693:         unsigned char [:, :, :] rgb_array_, mask=None, t=1):
 3694:     """
 3695:     APPLY A GAUSSIAN BLUR EFFECT TO THE GAME DISPLAY OR TO A GIVEN TEXTURE (KERNEL 5x5)
 3696: 
 3697:     # Gaussian kernel 5x5
 3698:         # |1   4   6   4  1|
 3699:         # |4  16  24  16  4|
 3700:         # |6  24  36  24  6|  x 1/256
 3701:         # |4  16  24  16  4|
 3702:         # |1  4    6   4  1|
 3703:     This method is using convolution property and process the image in two passes,
 3704:     first the horizontal convolution and last the vertical convolution
 3705:     pixels convoluted outside image edges will be set to adjacent edge value
 3706: 
 3707:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3708:     please refer to pygame function pixels3d or array3d to convert an image into a 3d array (
 3709:     library surfarray)
 3710: 
 3711:     :param rgb_array_   : numpy.ndarray type (w, h, 3) uint8
 3712:     :param mask         : numpy.ndarray default None
 3713:     :param t            : integer; number of times
 3714:     :return             : Return 24-bit a numpy.ndarray type (w, h, 3) uint8
 3715:     """
 3716: 
 3717:     cdef Py_ssize_t w, h
+3718:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3719: 
 3720:     # kernel 5x5 separable
 3721:     cdef:
 3722: 
+3723:         short int kernel_half = 2
  __pyx_v_kernel_half = 2;
+3724:         unsigned char [:, :, ::1] convolve = numpy.empty((w, h, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_empty); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = PyTuple_New(3); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_6);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_7, 2, __pyx_int_3);
  __pyx_t_4 = 0;
  __pyx_t_6 = 0;
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_7);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_7);
  __pyx_t_7 = 0;
  __pyx_t_7 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_7, __pyx_n_s_dtype, __pyx_t_4) < 0) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_7); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3724, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_convolve = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+3725:         unsigned char [:, :, ::1] convolved = numpy.empty((w, h, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_empty); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_6);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_int_3);
  __pyx_t_4 = 0;
  __pyx_t_6 = 0;
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_5);
  __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_dtype, __pyx_t_4) < 0) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_6, __pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3725, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_convolved = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+3726:         Py_ssize_t kernel_length = len(GAUSS_KERNEL)
  __pyx_t_4 = __Pyx_carray_to_py_float(__pyx_v_12PygameShader_6shader_GAUSS_KERNEL, 5); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3726, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = PyObject_Length(__pyx_t_4); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-1))) __PYX_ERR(1, 3726, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_kernel_length = __pyx_t_3;
 3727:         int x, y, xx, yy
 3728:         float r, g, b, s
 3729:         char kernel_offset
 3730:         unsigned char red, green, blue
 3731:         float *k
 3732:         unsigned char *c1
 3733:         unsigned char *c2
 3734:         unsigned char *c3
 3735:         unsigned char *c4
 3736:         unsigned char *c5
 3737:         unsigned char *c6
 3738: 
+3739:     for r in range(t):
  __pyx_t_4 = __Pyx_PyObject_CallOneArg(__pyx_builtin_range, __pyx_v_t); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3739, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (likely(PyList_CheckExact(__pyx_t_4)) || PyTuple_CheckExact(__pyx_t_4)) {
    __pyx_t_5 = __pyx_t_4; __Pyx_INCREF(__pyx_t_5); __pyx_t_3 = 0;
    __pyx_t_9 = NULL;
  } else {
    __pyx_t_3 = -1; __pyx_t_5 = PyObject_GetIter(__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3739, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_9 = Py_TYPE(__pyx_t_5)->tp_iternext; if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 3739, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  for (;;) {
    if (likely(!__pyx_t_9)) {
      if (likely(PyList_CheckExact(__pyx_t_5))) {
        if (__pyx_t_3 >= PyList_GET_SIZE(__pyx_t_5)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_4 = PyList_GET_ITEM(__pyx_t_5, __pyx_t_3); __Pyx_INCREF(__pyx_t_4); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(1, 3739, __pyx_L1_error)
        #else
        __pyx_t_4 = PySequence_ITEM(__pyx_t_5, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3739, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        #endif
      } else {
        if (__pyx_t_3 >= PyTuple_GET_SIZE(__pyx_t_5)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_4 = PyTuple_GET_ITEM(__pyx_t_5, __pyx_t_3); __Pyx_INCREF(__pyx_t_4); __pyx_t_3++; if (unlikely(0 < 0)) __PYX_ERR(1, 3739, __pyx_L1_error)
        #else
        __pyx_t_4 = PySequence_ITEM(__pyx_t_5, __pyx_t_3); __pyx_t_3++; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3739, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        #endif
      }
    } else {
      __pyx_t_4 = __pyx_t_9(__pyx_t_5);
      if (unlikely(!__pyx_t_4)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();
          else __PYX_ERR(1, 3739, __pyx_L1_error)
        }
        break;
      }
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_10 = __pyx_PyFloat_AsFloat(__pyx_t_4); if (unlikely((__pyx_t_10 == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 3739, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_v_r = __pyx_t_10;
/* … */
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
+3740:         with nogil:
    {
        #ifdef WITH_THREAD
        PyThreadState *_save;
        Py_UNBLOCK_THREADS
        __Pyx_FastGIL_Remember();
        #endif
        /*try:*/ {
/* … */
        /*finally:*/ {
          /*normal exit:*/{
            #ifdef WITH_THREAD
            __Pyx_FastGIL_Forget();
            Py_BLOCK_THREADS
            #endif
            goto __pyx_L9;
          }
          __pyx_L9:;
        }
    }
 3741: 
 3742:             # horizontal convolution
+3743:             for y in prange(0, h, schedule='static', num_threads=THREADS):
          __pyx_t_2 = __pyx_v_h;
          if ((1 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_12 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
              if (__pyx_t_12 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_c4) lastprivate(__pyx_v_c5) lastprivate(__pyx_v_c6) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
          __pyx_t_2 = __pyx_v_h;
          if ((1 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_12 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
              if (__pyx_t_12 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_c4) lastprivate(__pyx_v_c5) lastprivate(__pyx_v_c6) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                      #endif /* _OPENMP */
                      for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_12; __pyx_t_11++){
                          {
                              __pyx_v_y = (int)(0 + 1 * __pyx_t_11);
                              /* Initialize private variables to invalid values */
                              __pyx_v_b = ((float)__PYX_NAN());
                              __pyx_v_blue = ((unsigned char)'?');
                              __pyx_v_c1 = ((unsigned char *)1);
                              __pyx_v_c2 = ((unsigned char *)1);
                              __pyx_v_c3 = ((unsigned char *)1);
                              __pyx_v_c4 = ((unsigned char *)1);
                              __pyx_v_c5 = ((unsigned char *)1);
                              __pyx_v_c6 = ((unsigned char *)1);
                              __pyx_v_g = ((float)__PYX_NAN());
                              __pyx_v_green = ((unsigned char)'?');
                              __pyx_v_k = ((float *)1);
                              __pyx_v_kernel_offset = ((char)'?');
                              __pyx_v_r = ((float)__PYX_NAN());
                              __pyx_v_red = ((unsigned char)'?');
                              __pyx_v_x = ((int)0xbad0bad0);
                              __pyx_v_xx = ((int)0xbad0bad0);
 3744: 
+3745:                 c1 = &rgb_array_[0, y, 0]
                              __pyx_t_13 = 0;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              __pyx_v_c1 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+3746:                 c2 = &rgb_array_[0, y, 1]
                              __pyx_t_15 = 0;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              __pyx_v_c2 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
+3747:                 c3 = &rgb_array_[0, y, 2]
                              __pyx_t_13 = 0;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              __pyx_v_c3 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+3748:                 c4 = &rgb_array_[w-1, y, 0]
                              __pyx_t_15 = (__pyx_v_w - 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 0;
                              __pyx_v_c4 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
+3749:                 c5 = &rgb_array_[w-1, y, 1]
                              __pyx_t_13 = (__pyx_v_w - 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              __pyx_v_c5 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+3750:                 c6 = &rgb_array_[w-1, y, 2]
                              __pyx_t_15 = (__pyx_v_w - 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 2;
                              __pyx_v_c6 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
 3751: 
+3752:                 for x in range(0, w):  # range [0..w-1]
                              __pyx_t_16 = __pyx_v_w;
                              __pyx_t_17 = __pyx_t_16;
                              for (__pyx_t_18 = 0; __pyx_t_18 < __pyx_t_17; __pyx_t_18+=1) {
                                __pyx_v_x = __pyx_t_18;
 3753: 
+3754:                     r, g, b = 0, 0, 0
                                __pyx_t_10 = 0.0;
                                __pyx_t_19 = 0.0;
                                __pyx_t_20 = 0.0;
                                __pyx_v_r = __pyx_t_10;
                                __pyx_v_g = __pyx_t_19;
                                __pyx_v_b = __pyx_t_20;
 3755: 
+3756:                     for kernel_offset in range(-kernel_half, kernel_half + 1):
                                __pyx_t_21 = (__pyx_v_kernel_half + 1);
                                __pyx_t_22 = __pyx_t_21;
                                for (__pyx_t_23 = (-__pyx_v_kernel_half); __pyx_t_23 < __pyx_t_22; __pyx_t_23+=1) {
                                  __pyx_v_kernel_offset = __pyx_t_23;
 3757: 
+3758:                         k = &GAUSS_KERNEL[kernel_offset + kernel_half]
                                  __pyx_v_k = (&(__pyx_v_12PygameShader_6shader_GAUSS_KERNEL[(__pyx_v_kernel_offset + __pyx_v_kernel_half)]));
 3759: 
+3760:                         xx = x + kernel_offset
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kernel_offset);
 3761: 
 3762:                         # check boundaries.
 3763:                         # Fetch the edge pixel for the convolution
+3764:                         if xx < 0:
                                  __pyx_t_24 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_24) {
/* … */
                                    goto __pyx_L18;
                                  }
+3765:                             red, green, blue = c1[0], c2[0], c3[0]
                                    __pyx_t_25 = (__pyx_v_c1[0]);
                                    __pyx_t_26 = (__pyx_v_c2[0]);
                                    __pyx_t_27 = (__pyx_v_c3[0]);
                                    __pyx_v_red = __pyx_t_25;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_27;
+3766:                         elif xx > (w - 1):
                                  __pyx_t_24 = ((__pyx_v_xx > (__pyx_v_w - 1)) != 0);
                                  if (__pyx_t_24) {
/* … */
                                    goto __pyx_L18;
                                  }
+3767:                             red, green, blue = c4[0], c5[0], c6[0]
                                    __pyx_t_27 = (__pyx_v_c4[0]);
                                    __pyx_t_26 = (__pyx_v_c5[0]);
                                    __pyx_t_25 = (__pyx_v_c6[0]);
                                    __pyx_v_red = __pyx_t_27;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_25;
 3768:                         else:
+3769:                             red, green, blue = rgb_array_[xx, y, 0],\
                                  /*else*/ {
                                    __pyx_t_13 = __pyx_v_xx;
                                    __pyx_t_14 = __pyx_v_y;
                                    __pyx_t_15 = 0;
                                    __pyx_t_25 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )));
+3770:                                 rgb_array_[xx, y, 1], rgb_array_[xx, y, 2]
                                    __pyx_t_15 = __pyx_v_xx;
                                    __pyx_t_14 = __pyx_v_y;
                                    __pyx_t_13 = 1;
                                    __pyx_t_26 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )));
                                    __pyx_t_13 = __pyx_v_xx;
                                    __pyx_t_14 = __pyx_v_y;
                                    __pyx_t_15 = 2;
                                    __pyx_t_27 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )));
                                    __pyx_v_red = __pyx_t_25;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_27;
+3771:                             if red + green + blue == 0:
                                    __pyx_t_24 = ((((__pyx_v_red + __pyx_v_green) + __pyx_v_blue) == 0) != 0);
                                    if (__pyx_t_24) {
/* … */
                                    }
                                  }
                                  __pyx_L18:;
+3772:                                 continue
                                      goto __pyx_L16_continue;
 3773: 
+3774:                         r = r + red * k[0]
                                  __pyx_v_r = (__pyx_v_r + (__pyx_v_red * (__pyx_v_k[0])));
+3775:                         g = g + green * k[0]
                                  __pyx_v_g = (__pyx_v_g + (__pyx_v_green * (__pyx_v_k[0])));
+3776:                         b = b + blue * k[0]
                                  __pyx_v_b = (__pyx_v_b + (__pyx_v_blue * (__pyx_v_k[0])));
                                  __pyx_L16_continue:;
                                }
 3777: 
+3778:                     convolve[x, y, 0] = <unsigned char>r
                                __pyx_t_15 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_13 = 0;
                                *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) )) = ((unsigned char)__pyx_v_r);
+3779:                     convolve[x, y, 1] = <unsigned char>g
                                __pyx_t_13 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_15 = 1;
                                *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) )) = ((unsigned char)__pyx_v_g);
+3780:                     convolve[x, y, 2] = <unsigned char>b
                                __pyx_t_15 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_13 = 2;
                                *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) )) = ((unsigned char)__pyx_v_b);
                              }
                          }
                      }
                  }
              }
          }
          #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
              #undef likely
              #undef unlikely
              #define likely(x)   __builtin_expect(!!(x), 1)
              #define unlikely(x) __builtin_expect(!!(x), 0)
          #endif
 3781: 
 3782:             # Vertical convolution
+3783:             for x in prange(0,  w, schedule='static', num_threads=THREADS):
          __pyx_t_12 = __pyx_v_w;
          if ((1 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_2 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
              if (__pyx_t_2 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_c4) lastprivate(__pyx_v_c5) lastprivate(__pyx_v_c6) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
          __pyx_t_12 = __pyx_v_w;
          if ((1 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_2 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
              if (__pyx_t_2 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_c4) lastprivate(__pyx_v_c5) lastprivate(__pyx_v_c6) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                      #endif /* _OPENMP */
                      for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_2; __pyx_t_11++){
                          {
                              __pyx_v_x = (int)(0 + 1 * __pyx_t_11);
                              /* Initialize private variables to invalid values */
                              __pyx_v_b = ((float)__PYX_NAN());
                              __pyx_v_blue = ((unsigned char)'?');
                              __pyx_v_c1 = ((unsigned char *)1);
                              __pyx_v_c2 = ((unsigned char *)1);
                              __pyx_v_c3 = ((unsigned char *)1);
                              __pyx_v_c4 = ((unsigned char *)1);
                              __pyx_v_c5 = ((unsigned char *)1);
                              __pyx_v_c6 = ((unsigned char *)1);
                              __pyx_v_g = ((float)__PYX_NAN());
                              __pyx_v_green = ((unsigned char)'?');
                              __pyx_v_k = ((float *)1);
                              __pyx_v_kernel_offset = ((char)'?');
                              __pyx_v_r = ((float)__PYX_NAN());
                              __pyx_v_red = ((unsigned char)'?');
                              __pyx_v_y = ((int)0xbad0bad0);
                              __pyx_v_yy = ((int)0xbad0bad0);
 3784: 
+3785:                 c1 = &convolve[x, 0, 0]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = 0;
                              __pyx_t_15 = 0;
                              __pyx_v_c1 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) ))));
+3786:                 c2 = &convolve[x, 0, 1]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = 0;
                              __pyx_t_13 = 1;
                              __pyx_v_c2 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) ))));
+3787:                 c3 = &convolve[x, 0, 2]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = 0;
                              __pyx_t_15 = 2;
                              __pyx_v_c3 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) ))));
+3788:                 c4 = &convolve[x, h-1, 0]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_h - 1);
                              __pyx_t_13 = 0;
                              __pyx_v_c4 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) ))));
+3789:                 c5 = &convolve[x, h-1, 1]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_h - 1);
                              __pyx_t_15 = 1;
                              __pyx_v_c5 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) ))));
+3790:                 c6 = &convolve[x, h-1, 2]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_h - 1);
                              __pyx_t_13 = 2;
                              __pyx_v_c6 = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) ))));
 3791: 
+3792:                 for y in range(0, h):
                              __pyx_t_16 = __pyx_v_h;
                              __pyx_t_17 = __pyx_t_16;
                              for (__pyx_t_18 = 0; __pyx_t_18 < __pyx_t_17; __pyx_t_18+=1) {
                                __pyx_v_y = __pyx_t_18;
+3793:                     r, g, b = 0, 0, 0
                                __pyx_t_20 = 0.0;
                                __pyx_t_19 = 0.0;
                                __pyx_t_10 = 0.0;
                                __pyx_v_r = __pyx_t_20;
                                __pyx_v_g = __pyx_t_19;
                                __pyx_v_b = __pyx_t_10;
 3794: 
+3795:                     for kernel_offset in range(-kernel_half, kernel_half + 1):
                                __pyx_t_21 = (__pyx_v_kernel_half + 1);
                                __pyx_t_22 = __pyx_t_21;
                                for (__pyx_t_23 = (-__pyx_v_kernel_half); __pyx_t_23 < __pyx_t_22; __pyx_t_23+=1) {
                                  __pyx_v_kernel_offset = __pyx_t_23;
 3796: 
+3797:                         k = &GAUSS_KERNEL[kernel_offset + kernel_half]
                                  __pyx_v_k = (&(__pyx_v_12PygameShader_6shader_GAUSS_KERNEL[(__pyx_v_kernel_offset + __pyx_v_kernel_half)]));
+3798:                         yy = y + kernel_offset
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_kernel_offset);
 3799: 
+3800:                         if yy < 0:
                                  __pyx_t_24 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_24) {
/* … */
                                    goto __pyx_L30;
                                  }
+3801:                             red, green, blue = c1[0], c2[0], c3[0]
                                    __pyx_t_27 = (__pyx_v_c1[0]);
                                    __pyx_t_26 = (__pyx_v_c2[0]);
                                    __pyx_t_25 = (__pyx_v_c3[0]);
                                    __pyx_v_red = __pyx_t_27;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_25;
+3802:                         elif yy > (h -1):
                                  __pyx_t_24 = ((__pyx_v_yy > (__pyx_v_h - 1)) != 0);
                                  if (__pyx_t_24) {
/* … */
                                    goto __pyx_L30;
                                  }
+3803:                             red, green, blue = c4[0], c5[0], c6[0]
                                    __pyx_t_25 = (__pyx_v_c4[0]);
                                    __pyx_t_26 = (__pyx_v_c5[0]);
                                    __pyx_t_27 = (__pyx_v_c6[0]);
                                    __pyx_v_red = __pyx_t_25;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_27;
 3804:                         else:
+3805:                             red, green, blue = convolve[x, yy, 0],\
                                  /*else*/ {
                                    __pyx_t_13 = __pyx_v_x;
                                    __pyx_t_14 = __pyx_v_yy;
                                    __pyx_t_15 = 0;
                                    __pyx_t_27 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) )));
+3806:                                 convolve[x, yy, 1], convolve[x, yy, 2]
                                    __pyx_t_15 = __pyx_v_x;
                                    __pyx_t_14 = __pyx_v_yy;
                                    __pyx_t_13 = 1;
                                    __pyx_t_26 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_15 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_13)) )));
                                    __pyx_t_13 = __pyx_v_x;
                                    __pyx_t_14 = __pyx_v_yy;
                                    __pyx_t_15 = 2;
                                    __pyx_t_25 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_convolve.data + __pyx_t_13 * __pyx_v_convolve.strides[0]) ) + __pyx_t_14 * __pyx_v_convolve.strides[1]) )) + __pyx_t_15)) )));
                                    __pyx_v_red = __pyx_t_27;
                                    __pyx_v_green = __pyx_t_26;
                                    __pyx_v_blue = __pyx_t_25;
+3807:                             if red + green + blue == 0:
                                    __pyx_t_24 = ((((__pyx_v_red + __pyx_v_green) + __pyx_v_blue) == 0) != 0);
                                    if (__pyx_t_24) {
/* … */
                                    }
                                  }
                                  __pyx_L30:;
+3808:                                 continue
                                      goto __pyx_L28_continue;
 3809: 
+3810:                         r = r + red * k[0]
                                  __pyx_v_r = (__pyx_v_r + (__pyx_v_red * (__pyx_v_k[0])));
+3811:                         g = g + green * k[0]
                                  __pyx_v_g = (__pyx_v_g + (__pyx_v_green * (__pyx_v_k[0])));
+3812:                         b = b + blue * k[0]
                                  __pyx_v_b = (__pyx_v_b + (__pyx_v_blue * (__pyx_v_k[0])));
                                  __pyx_L28_continue:;
                                }
 3813: 
+3814:                     rgb_array_[x, y, 0], rgb_array_[x, y, 1], rgb_array_[x, y, 2] = \
                                __pyx_t_15 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_13 = 0;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_25;
                                __pyx_t_13 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_15 = 1;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_26;
                                __pyx_t_15 = __pyx_v_x;
                                __pyx_t_14 = __pyx_v_y;
                                __pyx_t_13 = 2;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_27;
                              }
                          }
                      }
                  }
              }
          }
          #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
              #undef likely
              #undef unlikely
              #define likely(x)   __builtin_expect(!!(x), 1)
              #define unlikely(x) __builtin_expect(!!(x), 0)
          #endif
        }
+3815:                         <unsigned char>r, <unsigned char>g, <unsigned char>b
                                __pyx_t_25 = ((unsigned char)__pyx_v_r);
                                __pyx_t_26 = ((unsigned char)__pyx_v_g);
                                __pyx_t_27 = ((unsigned char)__pyx_v_b);
 3816: 
 3817: 
 3818: @cython.boundscheck(False)
 3819: @cython.wraparound(False)
 3820: @cython.nonecheck(False)
 3821: @cython.cdivision(True)
+3822: cdef inline void shader_wave24bit_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_wave24bit_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_rad, int __pyx_v_size) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_x_pos;
  int __pyx_v_y_pos;
  int __pyx_v_xx;
  int __pyx_v_yy;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_c1;
  int __pyx_v_w_1;
  int __pyx_v_h_1;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_wave24bit_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_wave24bit_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
  __Pyx_RefNannyFinishContext();
}
 3823:         unsigned char [:, :, :] rgb_array_,
 3824:         float rad,
 3825:         int size):
 3826:     """
 3827:     CREATE A WAVE EFFECT TO THE GAME DISPLAY OR TO A GIVEN SURFACE
 3828: 
 3829:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3830:      please refer to pygame function pixels3d or array3d to convert an image into a
 3831:      3d array (library surfarray)
 3832: 
 3833:     e.g:
 3834:     wave(surface, 8 * math.pi/180.0 + frame_number, 5)
 3835: 
 3836:     :param rgb_array_   : numpy.ndarray shape (w, h, 3) containing all the RGB values
 3837:     :param rad          : float; angle in rad to rotate over time
 3838:     :param size         : int; Number of sub-surfaces
 3839:     :return             : void
 3840:     """
 3841: 
 3842: 
 3843: 
 3844:     cdef Py_ssize_t w, h
+3845:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3846: 
 3847:     cdef:
+3848:         unsigned char [:, :, :] rgb = numpy.array(rgb_array_, copy=True)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3848, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3848, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 3849:         int x, y, x_pos, y_pos, xx, yy
+3850:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+3851:         float c1 = <float>1.0 / <float>(size * size)
  __pyx_v_c1 = (((float)1.0) / ((float)(__pyx_v_size * __pyx_v_size)));
+3852:         int w_1 = <int>w - 1
  __pyx_v_w_1 = (((int)__pyx_v_w) - 1);
+3853:         int h_1 = <int>h - 1
  __pyx_v_h_1 = (((int)__pyx_v_h) - 1);
 3854: 
+3855:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 3856: 
+3857:         for y in prange(0, h_1 - size, size, schedule='static', num_threads=THREADS):
        __pyx_t_9 = (__pyx_v_h_1 - __pyx_v_size);
        __pyx_t_10 = __pyx_v_size;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x_pos) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y_pos) lastprivate(__pyx_v_yy) schedule(static)        __pyx_t_10 = __pyx_v_size;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x_pos) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y_pos) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_12; __pyx_t_11++){
                        {
                            __pyx_v_y = (int)(0 + __pyx_t_10 * __pyx_t_11);
                            /* Initialize private variables to invalid values */
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
                            __pyx_v_x_pos = ((int)0xbad0bad0);
                            __pyx_v_xx = ((int)0xbad0bad0);
                            __pyx_v_y_pos = ((int)0xbad0bad0);
                            __pyx_v_yy = ((int)0xbad0bad0);
 3858: 
+3859:             y_pos = y + size + <int>(<float>sin(rad + <float>y * c1) * <float>size)
                            __pyx_v_y_pos = ((__pyx_v_y + __pyx_v_size) + ((int)(((float)sin((__pyx_v_rad + (((float)__pyx_v_y) * __pyx_v_c1)))) * ((float)__pyx_v_size))));
 3860: 
+3861:             for x in prange(0, w_1 - size, size, schedule='static', num_threads=THREADS):
                            __pyx_t_13 = (__pyx_v_w_1 - __pyx_v_size);
                            __pyx_t_14 = __pyx_v_size;
                            if ((__pyx_t_14 == 0)) abort();
                            {
                                __pyx_t_16 = (__pyx_t_13 - 0 + __pyx_t_14 - __pyx_t_14/abs(__pyx_t_14)) / __pyx_t_14;
                                if (__pyx_t_16 > 0)
                                {
                                    #if 0
                                    #pragma omp parallel
                                    #endif /* _OPENMP */
                                    {
                                        #if 0
                                        #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x_pos) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_yy) schedule(static)                            __pyx_t_14 = __pyx_v_size;
                            if ((__pyx_t_14 == 0)) abort();
                            {
                                __pyx_t_16 = (__pyx_t_13 - 0 + __pyx_t_14 - __pyx_t_14/abs(__pyx_t_14)) / __pyx_t_14;
                                if (__pyx_t_16 > 0)
                                {
                                    #if 0
                                    #pragma omp parallel
                                    #endif /* _OPENMP */
                                    {
                                        #if 0
                                        #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x_pos) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                                        #endif /* _OPENMP */
                                        for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_16; __pyx_t_15++){
                                            {
                                                __pyx_v_x = (int)(0 + __pyx_t_14 * __pyx_t_15);
                                                /* Initialize private variables to invalid values */
                                                __pyx_v_i = ((int)0xbad0bad0);
                                                __pyx_v_j = ((int)0xbad0bad0);
                                                __pyx_v_x_pos = ((int)0xbad0bad0);
                                                __pyx_v_xx = ((int)0xbad0bad0);
                                                __pyx_v_yy = ((int)0xbad0bad0);
 3862: 
+3863:                 x_pos = x + size + <int> (<float>sin(rad + <float> x * c1) * <float> size)
                                                __pyx_v_x_pos = ((__pyx_v_x + __pyx_v_size) + ((int)(((float)sin((__pyx_v_rad + (((float)__pyx_v_x) * __pyx_v_c1)))) * ((float)__pyx_v_size))));
 3864: 
+3865:                 for i in range(0, size + 1):
                                                __pyx_t_17 = (__pyx_v_size + 1);
                                                __pyx_t_18 = __pyx_t_17;
                                                for (__pyx_t_19 = 0; __pyx_t_19 < __pyx_t_18; __pyx_t_19+=1) {
                                                  __pyx_v_i = __pyx_t_19;
 3866: 
+3867:                     for j in range(0, size + 1):
                                                  __pyx_t_20 = (__pyx_v_size + 1);
                                                  __pyx_t_21 = __pyx_t_20;
                                                  for (__pyx_t_22 = 0; __pyx_t_22 < __pyx_t_21; __pyx_t_22+=1) {
                                                    __pyx_v_j = __pyx_t_22;
 3868: 
+3869:                         xx = x_pos + i
                                                    __pyx_v_xx = (__pyx_v_x_pos + __pyx_v_i);
+3870:                         yy = y_pos + j
                                                    __pyx_v_yy = (__pyx_v_y_pos + __pyx_v_j);
 3871: 
+3872:                         if xx > w_1:
                                                    __pyx_t_23 = ((__pyx_v_xx > __pyx_v_w_1) != 0);
                                                    if (__pyx_t_23) {
/* … */
                                                      goto __pyx_L18;
                                                    }
+3873:                             xx = w_1
                                                      __pyx_v_xx = __pyx_v_w_1;
+3874:                         elif xx < 0:
                                                    __pyx_t_23 = ((__pyx_v_xx < 0) != 0);
                                                    if (__pyx_t_23) {
/* … */
                                                    }
                                                    __pyx_L18:;
+3875:                             xx = 0
                                                      __pyx_v_xx = 0;
+3876:                         if yy > h_1:
                                                    __pyx_t_23 = ((__pyx_v_yy > __pyx_v_h_1) != 0);
                                                    if (__pyx_t_23) {
/* … */
                                                      goto __pyx_L19;
                                                    }
+3877:                             yy = h_1
                                                      __pyx_v_yy = __pyx_v_h_1;
+3878:                         elif yy < 0:
                                                    __pyx_t_23 = ((__pyx_v_yy < 0) != 0);
                                                    if (__pyx_t_23) {
/* … */
                                                    }
                                                    __pyx_L19:;
+3879:                             yy = 0
                                                      __pyx_v_yy = 0;
+3880:                         rgb_array_[xx, yy, 0] = rgb[x + i, y + j, 0]
                                                    __pyx_t_24 = (__pyx_v_x + __pyx_v_i);
                                                    __pyx_t_25 = (__pyx_v_y + __pyx_v_j);
                                                    __pyx_t_26 = 0;
                                                    __pyx_t_27 = __pyx_v_xx;
                                                    __pyx_t_28 = __pyx_v_yy;
                                                    __pyx_t_29 = 0;
                                                    *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_27 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_28 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_29 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_24 * __pyx_v_rgb.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb.strides[1]) ) + __pyx_t_26 * __pyx_v_rgb.strides[2]) )));
+3881:                         rgb_array_[xx, yy, 1] = rgb[x + i, y + j, 1]
                                                    __pyx_t_26 = (__pyx_v_x + __pyx_v_i);
                                                    __pyx_t_25 = (__pyx_v_y + __pyx_v_j);
                                                    __pyx_t_24 = 1;
                                                    __pyx_t_29 = __pyx_v_xx;
                                                    __pyx_t_28 = __pyx_v_yy;
                                                    __pyx_t_27 = 1;
                                                    *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_29 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_28 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_27 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_26 * __pyx_v_rgb.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb.strides[1]) ) + __pyx_t_24 * __pyx_v_rgb.strides[2]) )));
+3882:                         rgb_array_[xx, yy, 2] = rgb[x + i, y + j, 2]
                                                    __pyx_t_24 = (__pyx_v_x + __pyx_v_i);
                                                    __pyx_t_25 = (__pyx_v_y + __pyx_v_j);
                                                    __pyx_t_26 = 2;
                                                    __pyx_t_27 = __pyx_v_xx;
                                                    __pyx_t_28 = __pyx_v_yy;
                                                    __pyx_t_29 = 2;
                                                    *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_27 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_28 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_29 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_24 * __pyx_v_rgb.strides[0]) ) + __pyx_t_25 * __pyx_v_rgb.strides[1]) ) + __pyx_t_26 * __pyx_v_rgb.strides[2]) )));
                                                  }
                                                }
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 3883: 
 3884: 
 3885: 
 3886: 
 3887: @cython.boundscheck(False)
 3888: @cython.wraparound(False)
 3889: @cython.nonecheck(False)
 3890: @cython.cdivision(False)
+3891: cdef inline void shader_swirl24bit_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_swirl24bit_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_degrees) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_diffx;
  int __pyx_v_diffy;
  int __pyx_v_angle;
  float __pyx_v_columns;
  float __pyx_v_rows;
  float __pyx_v_r;
  float __pyx_v_di;
  float __pyx_v_dj;
  float __pyx_v_c1;
  float __pyx_v_c2;
  __Pyx_memviewslice __pyx_v_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_r_max;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_swirl24bit_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_swirl24bit_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
  __Pyx_RefNannyFinishContext();
}
 3892:         unsigned char [:, :, :] rgb_array_,
 3893:         float degrees
 3894: ):
 3895:     """
 3896:     SWIRL AN IMAGE (ANGLE APPROXIMATION METHOD)
 3897: 
 3898:     This algorithm uses a table of cos and sin.
 3899: 
 3900:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3901:      please refer to pygame function pixels3d or array3d to convert an image into a
 3902:      3d array (library surfarray)
 3903: 
 3904:     e.g:
 3905:     swirl(surface, frame_number / 1000.0)
 3906: 
 3907:     :param rgb_array_   : numpy.ndarray shape (w, h, 3) containing all the RGB color values
 3908:     :param degrees      : float; swirl angle in degrees
 3909:     :return             : void
 3910:     """
 3911: 
 3912:     cdef Py_ssize_t w, h
+3913:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3914: 
 3915:     cdef:
 3916:         int i, j, diffx, diffy, angle
 3917:         float columns, rows, r, di, dj, c1, c2
+3918:         unsigned char [:, :, ::1] rgb = numpy.array(rgb_array_, copy=True, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3918, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 3918, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3918, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 3919:         float r_max
 3920: 
 3921: 
+3922:     columns = <float>0.5 * (<float>w - <float>1.0)
  __pyx_v_columns = (((float)0.5) * (((float)__pyx_v_w) - ((float)1.0)));
+3923:     rows    = <float>0.5 * (<float>h - <float>1.0)
  __pyx_v_rows = (((float)0.5) * (((float)__pyx_v_h) - ((float)1.0)));
 3924: 
+3925:     r_max = <float>sqrt(columns * columns + rows * rows)
  __pyx_v_r_max = ((float)sqrt(((__pyx_v_columns * __pyx_v_columns) + (__pyx_v_rows * __pyx_v_rows))));
 3926: 
+3927:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L4_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L5:;
      }
  }
+3928:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_angle) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_di) lastprivate(__pyx_v_diffx) lastprivate(__pyx_v_diffy) lastprivate(__pyx_v_dj) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_angle) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_di) lastprivate(__pyx_v_diffx) lastprivate(__pyx_v_diffy) lastprivate(__pyx_v_dj) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_angle = ((int)0xbad0bad0);
                            __pyx_v_c1 = ((float)__PYX_NAN());
                            __pyx_v_c2 = ((float)__PYX_NAN());
                            __pyx_v_di = ((float)__PYX_NAN());
                            __pyx_v_diffx = ((int)0xbad0bad0);
                            __pyx_v_diffy = ((int)0xbad0bad0);
                            __pyx_v_dj = ((float)__PYX_NAN());
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((float)__PYX_NAN());
+3929:             for i in range(w):
                            __pyx_t_10 = __pyx_v_w;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_i = __pyx_t_12;
 3930: 
+3931:                 di = <float>i - columns
                              __pyx_v_di = (((float)__pyx_v_i) - __pyx_v_columns);
+3932:                 dj = <float>j - rows
                              __pyx_v_dj = (((float)__pyx_v_j) - __pyx_v_rows);
 3933: 
+3934:                 r = <float>sqrt(di * di + dj * dj) / <float>r_max
                              __pyx_t_13 = ((float)sqrt(((__pyx_v_di * __pyx_v_di) + (__pyx_v_dj * __pyx_v_dj))));
                              if (unlikely(((float)__pyx_v_r_max) == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "float division");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 3934, __pyx_L8_error)
                              }
                              __pyx_v_r = (__pyx_t_13 / ((float)__pyx_v_r_max));
+3935:                 angle = <int>(degrees * r % 360)
                              __pyx_v_angle = ((int)__Pyx_mod_float((__pyx_v_degrees * __pyx_v_r), 360.0));
 3936: 
+3937:                 c1 = COS_TABLE[angle]
                              __pyx_v_c1 = (__pyx_v_12PygameShader_6shader_COS_TABLE[__pyx_v_angle]);
+3938:                 c2 = SIN_TABLE[angle]
                              __pyx_v_c2 = (__pyx_v_12PygameShader_6shader_SIN_TABLE[__pyx_v_angle]);
+3939:                 diffx = <int>(di * c1 - dj * c2 + columns)
                              __pyx_v_diffx = ((int)(((__pyx_v_di * __pyx_v_c1) - (__pyx_v_dj * __pyx_v_c2)) + __pyx_v_columns));
+3940:                 diffy = <int>(di * c2 + dj * c1 + rows)
                              __pyx_v_diffy = ((int)(((__pyx_v_di * __pyx_v_c2) + (__pyx_v_dj * __pyx_v_c1)) + __pyx_v_rows));
 3941: 
+3942:                 if (diffx >-1) and (diffx < w) and \
                              __pyx_t_15 = ((__pyx_v_diffx > -1L) != 0);
                              if (__pyx_t_15) {
                              } else {
                                __pyx_t_14 = __pyx_t_15;
                                goto __pyx_L13_bool_binop_done;
                              }
                              __pyx_t_15 = ((__pyx_v_diffx < __pyx_v_w) != 0);
                              if (__pyx_t_15) {
                              } else {
                                __pyx_t_14 = __pyx_t_15;
                                goto __pyx_L13_bool_binop_done;
                              }
/* … */
                              if (__pyx_t_14) {
/* … */
                              }
                            }
                            goto __pyx_L18;
                            __pyx_L8_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L17;
                            __pyx_L17:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates2)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_angle;
                                __pyx_parallel_temp1 = __pyx_v_c1;
                                __pyx_parallel_temp2 = __pyx_v_c2;
                                __pyx_parallel_temp3 = __pyx_v_di;
                                __pyx_parallel_temp4 = __pyx_v_diffx;
                                __pyx_parallel_temp5 = __pyx_v_diffy;
                                __pyx_parallel_temp6 = __pyx_v_dj;
                                __pyx_parallel_temp7 = __pyx_v_i;
                                __pyx_parallel_temp8 = __pyx_v_j;
                                __pyx_parallel_temp9 = __pyx_v_r;
                            }
                            __pyx_L18:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_angle = __pyx_parallel_temp0;
              __pyx_v_c1 = __pyx_parallel_temp1;
              __pyx_v_c2 = __pyx_parallel_temp2;
              __pyx_v_di = __pyx_parallel_temp3;
              __pyx_v_diffx = __pyx_parallel_temp4;
              __pyx_v_diffy = __pyx_parallel_temp5;
              __pyx_v_dj = __pyx_parallel_temp6;
              __pyx_v_i = __pyx_parallel_temp7;
              __pyx_v_j = __pyx_parallel_temp8;
              __pyx_v_r = __pyx_parallel_temp9;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L4_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+3943:                    (diffy >-1) and (diffy < h):
                              __pyx_t_15 = ((__pyx_v_diffy > -1L) != 0);
                              if (__pyx_t_15) {
                              } else {
                                __pyx_t_14 = __pyx_t_15;
                                goto __pyx_L13_bool_binop_done;
                              }
                              __pyx_t_15 = ((__pyx_v_diffy < __pyx_v_h) != 0);
                              __pyx_t_14 = __pyx_t_15;
                              __pyx_L13_bool_binop_done:;
+3944:                     rgb_array_[i, j, 0], rgb_array_[i, j, 1],\
                                __pyx_t_18 = __pyx_v_i;
                                __pyx_t_17 = __pyx_v_j;
                                __pyx_t_16 = 0;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_18 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_19;
                                __pyx_t_16 = __pyx_v_i;
                                __pyx_t_17 = __pyx_v_j;
                                __pyx_t_18 = 1;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_20;
+3945:                         rgb_array_[i, j, 2] = rgb[diffx, diffy, 0], \
                                __pyx_t_16 = __pyx_v_diffx;
                                __pyx_t_17 = __pyx_v_diffy;
                                __pyx_t_18 = 0;
                                __pyx_t_19 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_16 * __pyx_v_rgb.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb.strides[1]) )) + __pyx_t_18)) )));
/* … */
                                __pyx_t_18 = __pyx_v_i;
                                __pyx_t_17 = __pyx_v_j;
                                __pyx_t_16 = 2;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_18 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_21;
+3946:                                               rgb[diffx, diffy, 1], rgb[diffx, diffy, 2]
                                __pyx_t_18 = __pyx_v_diffx;
                                __pyx_t_17 = __pyx_v_diffy;
                                __pyx_t_16 = 1;
                                __pyx_t_20 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_18 * __pyx_v_rgb.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb.strides[1]) )) + __pyx_t_16)) )));
                                __pyx_t_16 = __pyx_v_diffx;
                                __pyx_t_17 = __pyx_v_diffy;
                                __pyx_t_18 = 2;
                                __pyx_t_21 = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_16 * __pyx_v_rgb.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb.strides[1]) )) + __pyx_t_18)) )));
 3947: 
 3948: 
 3949: @cython.boundscheck(False)
 3950: @cython.wraparound(False)
 3951: @cython.nonecheck(False)
 3952: @cython.cdivision(True)
+3953: cdef inline void shader_swirl24bit_inplace_c1(unsigned char [:, :, :] rgb_array_, float degrees):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_swirl24bit_inplace_c1(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_degrees) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_diffx;
  int __pyx_v_diffy;
  float __pyx_v_columns;
  float __pyx_v_rows;
  float __pyx_v_r;
  float __pyx_v_di;
  float __pyx_v_dj;
  float __pyx_v_c1;
  float __pyx_v_c2;
  float __pyx_v_angle;
  __Pyx_memviewslice __pyx_v_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_rad;
  float __pyx_v_r_max;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_swirl24bit_inplace_c1", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_swirl24bit_inplace_c1", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
  __Pyx_RefNannyFinishContext();
}
 3954:     """
 3955:     SWIRL AN IMAGE WITHOUT ANGLE APPROXIMATION
 3956: 
 3957:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 3958:      please refer to pygame function pixels3d or array3d to convert an image into a 3d
 3959:      array (library surfarray)
 3960: 
 3961:     e.g:
 3962:     swirl(surface_, frame_number / 1000)
 3963: 
 3964:     :param rgb_array_   : numpy.ndarray shape (w, h, 3) containing all the RGB color values
 3965:     :param degrees      : float; swirl angle in degrees
 3966:     :return             : void
 3967:     """
 3968: 
 3969:     cdef Py_ssize_t w, h
+3970:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 3971: 
 3972:     cdef:
 3973:         int i, j, diffx, diffy
 3974:         float columns, rows, r, di, dj, c1, c2, angle
+3975:         unsigned char [:, :, :] rgb = numpy.array(rgb_array_, copy=True)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 3975, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 3975, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+3976:         float rad = degrees * DEG_TO_RAD
  __pyx_v_rad = (__pyx_v_degrees * __pyx_v_12PygameShader_6shader_DEG_TO_RAD);
 3977:         float r_max
 3978: 
 3979: 
+3980:     columns = <float>0.5 * (w - <float>1.0)
  __pyx_v_columns = (((float)0.5) * (__pyx_v_w - ((float)1.0)));
+3981:     rows    = <float>0.5 * (h - <float>1.0)
  __pyx_v_rows = (((float)0.5) * (__pyx_v_h - ((float)1.0)));
+3982:     r_max   = <float>sqrt(columns * columns + rows * rows)
  __pyx_v_r_max = ((float)sqrt(((__pyx_v_columns * __pyx_v_columns) + (__pyx_v_rows * __pyx_v_rows))));
+3983:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+3984:         for i in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_angle) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_di) lastprivate(__pyx_v_diffx) lastprivate(__pyx_v_diffy) lastprivate(__pyx_v_dj) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_angle) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_di) lastprivate(__pyx_v_diffx) lastprivate(__pyx_v_diffy) lastprivate(__pyx_v_dj) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_angle = ((float)__PYX_NAN());
                            __pyx_v_c1 = ((float)__PYX_NAN());
                            __pyx_v_c2 = ((float)__PYX_NAN());
                            __pyx_v_di = ((float)__PYX_NAN());
                            __pyx_v_diffx = ((int)0xbad0bad0);
                            __pyx_v_diffy = ((int)0xbad0bad0);
                            __pyx_v_dj = ((float)__PYX_NAN());
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_r = ((float)__PYX_NAN());
+3985:             for j in range(h):
                            __pyx_t_10 = __pyx_v_h;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_j = __pyx_t_12;
 3986: 
+3987:                 di = <float>i - columns
                              __pyx_v_di = (((float)__pyx_v_i) - __pyx_v_columns);
+3988:                 dj = <float>j - rows
                              __pyx_v_dj = (((float)__pyx_v_j) - __pyx_v_rows);
 3989: 
+3990:                 r = <float>sqrt(di * di + dj * dj)
                              __pyx_v_r = ((float)sqrt(((__pyx_v_di * __pyx_v_di) + (__pyx_v_dj * __pyx_v_dj))));
+3991:                 angle = <float>(rad * r/r_max)
                              __pyx_v_angle = ((float)((__pyx_v_rad * __pyx_v_r) / __pyx_v_r_max));
 3992: 
+3993:                 c1 = <float>cos(angle)
                              __pyx_v_c1 = ((float)cos(__pyx_v_angle));
+3994:                 c2 = <float>sin(angle)
                              __pyx_v_c2 = ((float)sin(__pyx_v_angle));
+3995:                 diffx = <int>(di * c1 - dj * c2 + columns)
                              __pyx_v_diffx = ((int)(((__pyx_v_di * __pyx_v_c1) - (__pyx_v_dj * __pyx_v_c2)) + __pyx_v_columns));
+3996:                 diffy = <int>(di * c2 + dj * c1 + rows)
                              __pyx_v_diffy = ((int)(((__pyx_v_di * __pyx_v_c2) + (__pyx_v_dj * __pyx_v_c1)) + __pyx_v_rows));
 3997: 
+3998:                 if (diffx >-1) and (diffx < w) and \
                              __pyx_t_14 = ((__pyx_v_diffx > -1L) != 0);
                              if (__pyx_t_14) {
                              } else {
                                __pyx_t_13 = __pyx_t_14;
                                goto __pyx_L13_bool_binop_done;
                              }
                              __pyx_t_14 = ((__pyx_v_diffx < __pyx_v_w) != 0);
                              if (__pyx_t_14) {
                              } else {
                                __pyx_t_13 = __pyx_t_14;
                                goto __pyx_L13_bool_binop_done;
                              }
/* … */
                              if (__pyx_t_13) {
/* … */
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+3999:                    (diffy >-1) and (diffy < h):
                              __pyx_t_14 = ((__pyx_v_diffy > -1L) != 0);
                              if (__pyx_t_14) {
                              } else {
                                __pyx_t_13 = __pyx_t_14;
                                goto __pyx_L13_bool_binop_done;
                              }
                              __pyx_t_14 = ((__pyx_v_diffy < __pyx_v_h) != 0);
                              __pyx_t_13 = __pyx_t_14;
                              __pyx_L13_bool_binop_done:;
+4000:                     rgb_array_[i, j, 0], rgb_array_[i, j, 1],\
                                __pyx_t_17 = __pyx_v_i;
                                __pyx_t_16 = __pyx_v_j;
                                __pyx_t_15 = 0;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_17 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_18;
                                __pyx_t_15 = __pyx_v_i;
                                __pyx_t_16 = __pyx_v_j;
                                __pyx_t_17 = 1;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_19;
+4001:                         rgb_array_[i, j, 2] = rgb[diffx, diffy, 0], \
                                __pyx_t_15 = __pyx_v_diffx;
                                __pyx_t_16 = __pyx_v_diffy;
                                __pyx_t_17 = 0;
                                __pyx_t_18 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_15 * __pyx_v_rgb.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb.strides[2]) )));
/* … */
                                __pyx_t_17 = __pyx_v_i;
                                __pyx_t_16 = __pyx_v_j;
                                __pyx_t_15 = 2;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_17 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_20;
+4002:                                               rgb[diffx, diffy, 1], rgb[diffx, diffy, 2]
                                __pyx_t_17 = __pyx_v_diffx;
                                __pyx_t_16 = __pyx_v_diffy;
                                __pyx_t_15 = 1;
                                __pyx_t_19 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_17 * __pyx_v_rgb.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb.strides[2]) )));
                                __pyx_t_15 = __pyx_v_diffx;
                                __pyx_t_16 = __pyx_v_diffy;
                                __pyx_t_17 = 2;
                                __pyx_t_20 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_15 * __pyx_v_rgb.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb.strides[2]) )));
 4003: 
 4004: 
 4005: 
 4006: 
 4007: @cython.boundscheck(False)
 4008: @cython.wraparound(False)
 4009: @cython.nonecheck(False)
 4010: @cython.cdivision(False)
+4011: cdef inline void shader_plasma24bit_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_plasma24bit_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, int __pyx_v_frame, struct __pyx_opt_args_12PygameShader_6shader_shader_plasma24bit_inplace_c *__pyx_optional_args) {
  float __pyx_v_hue_ = __pyx_k__19;
  float __pyx_v_sat_ = __pyx_k__20;
  float __pyx_v_value_ = __pyx_k__21;
  float __pyx_v_a_ = ((float)0.00392156862745098);
  float __pyx_v_b_ = ((float)0.08333333333333333);
  float __pyx_v_c_ = ((float)0.08333333333333333);
  CYTHON_UNUSED Py_ssize_t __pyx_v_width;
  Py_ssize_t __pyx_v_height;
  float __pyx_v_xx;
  float __pyx_v_yy;
  float __pyx_v_t;
  float __pyx_v_h;
  float __pyx_v_s;
  float __pyx_v_v;
  int __pyx_v_i;
  int __pyx_v_x;
  int __pyx_v_y;
  float __pyx_v_f;
  float __pyx_v_p;
  float __pyx_v_q;
  float __pyx_v_t_;
  float __pyx_v_hue;
  float __pyx_v_r;
  float __pyx_v_g;
  float __pyx_v_b;
  unsigned char *__pyx_v_rr;
  unsigned char *__pyx_v_gg;
  unsigned char *__pyx_v_bb;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_plasma24bit_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_hue_ = __pyx_optional_args->hue_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_sat_ = __pyx_optional_args->sat_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_value_ = __pyx_optional_args->value_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_a_ = __pyx_optional_args->a_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_b_ = __pyx_optional_args->b_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_c_ = __pyx_optional_args->c_;
              }
            }
          }
        }
      }
    }
  }
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_plasma24bit_inplace_c {
  int __pyx_n;
  float hue_;
  float sat_;
  float value_;
  float a_;
  float b_;
  float c_;
};
 4012:         unsigned char [:, :, :] rgb_array_,
 4013:         int frame,
+4014:         float hue_=1.0/6.0,
  if (unlikely(6.0 == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float division");
    __PYX_ERR(1, 4014, __pyx_L1_error)
  }
  __pyx_k__19 = (1.0 / 6.0);
+4015:         float sat_=1.0/6.0,
  if (unlikely(6.0 == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float division");
    __PYX_ERR(1, 4015, __pyx_L1_error)
  }
  __pyx_k__20 = (1.0 / 6.0);
+4016:         float value_=1.0/8.0,
  if (unlikely(8.0 == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float division");
    __PYX_ERR(1, 4016, __pyx_L1_error)
  }
  __pyx_k__21 = (1.0 / 8.0);
 4017:         float a_=ONE_255,
 4018:         float b_=ONE_TWELVE,
 4019:         float c_=ONE_TWELVE):
 4020:     """
 4021:     CREATE A BASIC PLASMA EFFECT ON THE TOP OF A PYGAME SURFACE
 4022: 
 4023:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4024:      please refer to pygame function pixels3d or array3d to convert an image into a
 4025:      3d array (library surfarray)
 4026: 
 4027:     e.g:
 4028:     plasma_config(surface, frame_number)
 4029: 
 4030:     :param a_           : float; default value 1.0/255.0 control the plasma equation
 4031:     :param b_           : float; default value 1.0/12.0 control the plasma equation
 4032:     :param c_           : float; default value 1.0/12.0 control the plasma equation
 4033:     :param value_       : float; default value 1.0/8.0 value factor
 4034:     :param sat_         : float; default value 1.0/6.0 saturation value
 4035:     :param hue_         : float; default value 1.0/6.0 hue value factor
 4036:     :param rgb_array_   : numpy.ndarray shape( w, h, 3) containing all the RGB color values
 4037:     :param frame        : integer; Variable that need to change over time
 4038:     :return             : void
 4039:     """
 4040: 
 4041:     cdef Py_ssize_t width, height
+4042:     width, height = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_width = __pyx_t_2;
  __pyx_v_height = __pyx_t_3;
 4043: 
 4044:     cdef:
 4045:         float xx, yy, t
 4046:         float h, s, v
+4047:         int i = 0, x, y
  __pyx_v_i = 0;
 4048:         float f, p, q, t_
 4049:         float hue, r, g, b
 4050:         unsigned char *rr
 4051:         unsigned char *gg
 4052:         unsigned char *bb
 4053: 
+4054:     t = <float>frame
  __pyx_v_t = ((float)__pyx_v_frame);
 4055: 
+4056:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4057:         for x in prange(width, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_f) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_h) lastprivate(__pyx_v_hue) lastprivate(__pyx_v_i) lastprivate(__pyx_v_p) lastprivate(__pyx_v_q) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_s) lastprivate(__pyx_v_t_) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_f) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_h) lastprivate(__pyx_v_hue) lastprivate(__pyx_v_i) lastprivate(__pyx_v_p) lastprivate(__pyx_v_q) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_s) lastprivate(__pyx_v_t_) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((float)__PYX_NAN());
                            __pyx_v_bb = ((unsigned char *)1);
                            __pyx_v_f = ((float)__PYX_NAN());
                            __pyx_v_g = ((float)__PYX_NAN());
                            __pyx_v_gg = ((unsigned char *)1);
                            __pyx_v_h = ((float)__PYX_NAN());
                            __pyx_v_hue = ((float)__PYX_NAN());
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_p = ((float)__PYX_NAN());
                            __pyx_v_q = ((float)__PYX_NAN());
                            __pyx_v_r = ((float)__PYX_NAN());
                            __pyx_v_rr = ((unsigned char *)1);
                            __pyx_v_s = ((float)__PYX_NAN());
                            __pyx_v_t_ = ((float)__PYX_NAN());
                            __pyx_v_v = ((float)__PYX_NAN());
                            __pyx_v_xx = ((float)__PYX_NAN());
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_yy = ((float)__PYX_NAN());
+4058:             for y in range(height):
                            __pyx_t_5 = __pyx_v_height;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_y = __pyx_t_7;
 4059: 
+4060:                 xx = <float>x * <float>0.5
                              __pyx_v_xx = (((float)__pyx_v_x) * ((float)0.5));
+4061:                 yy = <float>y * <float>0.5
                              __pyx_v_yy = (((float)__pyx_v_y) * ((float)0.5));
 4062: 
 4063:                 hue = <float>4.0 + <float>sin((xx * <float>0.5 + yy * <float>0.5) * a_) \
+4064:                       + <float>sin((xx * b_ + t) * c_)
                              __pyx_v_hue = ((((float)4.0) + ((float)sin((((__pyx_v_xx * ((float)0.5)) + (__pyx_v_yy * ((float)0.5))) * __pyx_v_a_)))) + ((float)sin((((__pyx_v_xx * __pyx_v_b_) + __pyx_v_t) * __pyx_v_c_))));
 4065: 
+4066:                 h, s, v = hue * hue_, hue * sat_, hue * value_
                              __pyx_t_8 = (__pyx_v_hue * __pyx_v_hue_);
                              __pyx_t_9 = (__pyx_v_hue * __pyx_v_sat_);
                              __pyx_t_10 = (__pyx_v_hue * __pyx_v_value_);
                              __pyx_v_h = __pyx_t_8;
                              __pyx_v_s = __pyx_t_9;
                              __pyx_v_v = __pyx_t_10;
 4067: 
+4068:                 i = <int>(h * <float>6.0)
                              __pyx_v_i = ((int)(__pyx_v_h * ((float)6.0)));
+4069:                 f = (h * <float>6.0) - i
                              __pyx_v_f = ((__pyx_v_h * ((float)6.0)) - __pyx_v_i);
+4070:                 p = v*(<float>1.0 - s)
                              __pyx_v_p = (__pyx_v_v * (((float)1.0) - __pyx_v_s));
+4071:                 q = v*(<float>1.0 - s * f)
                              __pyx_v_q = (__pyx_v_v * (((float)1.0) - (__pyx_v_s * __pyx_v_f)));
+4072:                 t_ = v*(<float>1.0 - s * (<float>1.0 - f))
                              __pyx_v_t_ = (__pyx_v_v * (((float)1.0) - (__pyx_v_s * (((float)1.0) - __pyx_v_f))));
+4073:                 i = i % 6
                              __pyx_v_i = __Pyx_mod_long(__pyx_v_i, 6);
 4074: 
+4075:                 if i == 0:
                              __pyx_t_11 = ((__pyx_v_i == 0) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4076:                     r, g, b =  v, t, p
                                __pyx_t_10 = __pyx_v_v;
                                __pyx_t_9 = __pyx_v_t;
                                __pyx_t_8 = __pyx_v_p;
                                __pyx_v_r = __pyx_t_10;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_8;
+4077:                 if i == 1:
                              __pyx_t_11 = ((__pyx_v_i == 1) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4078:                      r, g, b = q, v, p
                                __pyx_t_8 = __pyx_v_q;
                                __pyx_t_9 = __pyx_v_v;
                                __pyx_t_10 = __pyx_v_p;
                                __pyx_v_r = __pyx_t_8;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_10;
+4079:                 if i == 2:
                              __pyx_t_11 = ((__pyx_v_i == 2) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4080:                      r, g, b = p, v, t
                                __pyx_t_10 = __pyx_v_p;
                                __pyx_t_9 = __pyx_v_v;
                                __pyx_t_8 = __pyx_v_t;
                                __pyx_v_r = __pyx_t_10;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_8;
+4081:                 if i == 3:
                              __pyx_t_11 = ((__pyx_v_i == 3) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4082:                      r, g, b = p, q, v
                                __pyx_t_8 = __pyx_v_p;
                                __pyx_t_9 = __pyx_v_q;
                                __pyx_t_10 = __pyx_v_v;
                                __pyx_v_r = __pyx_t_8;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_10;
+4083:                 if i == 4:
                              __pyx_t_11 = ((__pyx_v_i == 4) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4084:                      r, g, b = t_, p, v
                                __pyx_t_10 = __pyx_v_t_;
                                __pyx_t_9 = __pyx_v_p;
                                __pyx_t_8 = __pyx_v_v;
                                __pyx_v_r = __pyx_t_10;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_8;
+4085:                 if i == 5:
                              __pyx_t_11 = ((__pyx_v_i == 5) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4086:                      r, g, b = v, p, q
                                __pyx_t_8 = __pyx_v_v;
                                __pyx_t_9 = __pyx_v_p;
                                __pyx_t_10 = __pyx_v_q;
                                __pyx_v_r = __pyx_t_8;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_10;
 4087: 
+4088:                 if s == 0.0:
                              __pyx_t_11 = ((__pyx_v_s == 0.0) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4089:                      r, g, b = v, v, v
                                __pyx_t_10 = __pyx_v_v;
                                __pyx_t_9 = __pyx_v_v;
                                __pyx_t_8 = __pyx_v_v;
                                __pyx_v_r = __pyx_t_10;
                                __pyx_v_g = __pyx_t_9;
                                __pyx_v_b = __pyx_t_8;
 4090: 
+4091:                 rr = &rgb_array_[x, y, 0]
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_13 = __pyx_v_y;
                              __pyx_t_14 = 0;
                              __pyx_v_rr = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) ))));
+4092:                 gg = &rgb_array_[x, y, 1]
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_13 = __pyx_v_y;
                              __pyx_t_12 = 1;
                              __pyx_v_gg = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))));
+4093:                 bb = &rgb_array_[x, y, 2]
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_13 = __pyx_v_y;
                              __pyx_t_14 = 2;
                              __pyx_v_bb = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) ))));
 4094: 
+4095:                 if rr[0] < 256:
                              __pyx_t_11 = (((__pyx_v_rr[0]) < 0x100) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4096:                     rr[0] = <unsigned char>(min(rr[0] + r * <float>128.0, <float>255.0))
                                __pyx_t_8 = ((float)255.0);
                                __pyx_t_9 = ((__pyx_v_rr[0]) + (__pyx_v_r * ((float)128.0)));
                                if (((__pyx_t_8 < __pyx_t_9) != 0)) {
                                  __pyx_t_10 = __pyx_t_8;
                                } else {
                                  __pyx_t_10 = __pyx_t_9;
                                }
                                (__pyx_v_rr[0]) = ((unsigned char)__pyx_t_10);
 4097: 
+4098:                 if gg[0] < 256:
                              __pyx_t_11 = (((__pyx_v_gg[0]) < 0x100) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
+4099:                     gg[0] = <unsigned char>(min(gg[0] + g * <float>128.0, <float>255.0))
                                __pyx_t_10 = ((float)255.0);
                                __pyx_t_8 = ((__pyx_v_gg[0]) + (__pyx_v_g * ((float)128.0)));
                                if (((__pyx_t_10 < __pyx_t_8) != 0)) {
                                  __pyx_t_9 = __pyx_t_10;
                                } else {
                                  __pyx_t_9 = __pyx_t_8;
                                }
                                (__pyx_v_gg[0]) = ((unsigned char)__pyx_t_9);
 4100: 
+4101:                 if bb[0] < 256:
                              __pyx_t_11 = (((__pyx_v_bb[0]) < 0x100) != 0);
                              if (__pyx_t_11) {
/* … */
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+4102:                     bb[0] = <unsigned char>(min(bb[0] + b * <float>128.0, <float>255.0))
                                __pyx_t_9 = ((float)255.0);
                                __pyx_t_10 = ((__pyx_v_bb[0]) + (__pyx_v_b * ((float)128.0)));
                                if (((__pyx_t_9 < __pyx_t_10) != 0)) {
                                  __pyx_t_8 = __pyx_t_9;
                                } else {
                                  __pyx_t_8 = __pyx_t_10;
                                }
                                (__pyx_v_bb[0]) = ((unsigned char)__pyx_t_8);
 4103: 
 4104: 
 4105: @cython.boundscheck(False)
 4106: @cython.wraparound(False)
 4107: @cython.nonecheck(False)
 4108: @cython.cdivision(True)
+4109: cdef inline void shader_plasma_c(surface_, float frame, unsigned int [::1] palette_):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_plasma_c(PyObject *__pyx_v_surface_, float __pyx_v_frame, __Pyx_memviewslice __pyx_v_palette_) {
  Py_ssize_t __pyx_v_width;
  Py_ssize_t __pyx_v_height;
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_ii;
  int __pyx_v_c;
  __Pyx_memviewslice __pyx_v_rgb_array_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned char *__pyx_v_rr;
  unsigned char *__pyx_v_gg;
  unsigned char *__pyx_v_bb;
  float __pyx_v_color_;
  float __pyx_v_w2;
  float __pyx_v_h2;
  Py_ssize_t __pyx_v_length;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_plasma_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_plasma_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_, 1);
  __Pyx_RefNannyFinishContext();
}
 4110: 
 4111:     """
 4112:     CREATE A PLASMA EFFECT INPLACE
 4113: 
 4114:     e.g:
 4115:     plasma(surface, frame_number)
 4116: 
 4117:     :param surface_: pygame Surface
 4118:     :param frame   : float; frame number
 4119:     :param palette_: color palette
 4120:     :return        : void
 4121:     """
 4122:     cdef Py_ssize_t width, height
+4123:     width, height = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 4123, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4123, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4123, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4123, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 4123, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 4123, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_6 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 4123, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 4123, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_width = __pyx_t_6;
  __pyx_v_height = __pyx_t_7;
 4124: 
 4125:     cdef:
 4126:         int x, y, ii,c
 4127: 
+4128:         unsigned char [:, :, :] rgb_array_ = pixels3d(surface_)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4128, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4128, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 4128, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rgb_array_ = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 4129: 
 4130:         unsigned char *rr
 4131:         unsigned char *gg
 4132:         unsigned char *bb
 4133:         float color_
+4134:         float w2 = <float>width * <float>HALF
  __pyx_v_w2 = (((float)__pyx_v_width) * ((float)0.5));
+4135:         float h2 = <float>height * <float>HALF
  __pyx_v_h2 = (((float)__pyx_v_height) * ((float)0.5));
+4136:         Py_ssize_t length = len(palette_)
  __pyx_t_9 = __Pyx_MemoryView_Len(__pyx_v_palette_); 
  __pyx_v_length = __pyx_t_9;
 4137: 
+4138:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L7:;
      }
  }
 4139: 
+4140:         for y in prange(height, schedule='static', num_threads=THREADS):
        __pyx_t_7 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_bb) lastprivate(__pyx_v_c) lastprivate(__pyx_v_color_) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_7 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_bb) lastprivate(__pyx_v_c) lastprivate(__pyx_v_color_) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_10; __pyx_t_6++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_bb = ((unsigned char *)1);
                            __pyx_v_c = ((int)0xbad0bad0);
                            __pyx_v_color_ = ((float)__PYX_NAN());
                            __pyx_v_gg = ((unsigned char *)1);
                            __pyx_v_ii = ((int)0xbad0bad0);
                            __pyx_v_rr = ((unsigned char *)1);
                            __pyx_v_x = ((int)0xbad0bad0);
+4141:             for x in range(width):
                            __pyx_t_11 = __pyx_v_width;
                            __pyx_t_12 = __pyx_t_11;
                            for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_12; __pyx_t_13+=1) {
                              __pyx_v_x = __pyx_t_13;
 4142: 
+4143:                 rr = &rgb_array_[x, y, 0]
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_16 = 0;
                              __pyx_v_rr = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) ))));
+4144:                 gg = &rgb_array_[x, y, 1]
                              __pyx_t_16 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_14 = 1;
                              __pyx_v_gg = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) ))));
+4145:                 bb = &rgb_array_[x, y, 2]
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_16 = 2;
                              __pyx_v_bb = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) ))));
 4146: 
 4147:                 color_ = <float>128.0 + (<float>128.0 * <float>sin(x * ONE_255 + frame)) \
 4148:                     + <float>128.0 + (<float>128.0 * <float>sin(frame * ONE_32 + y * ONE_64)) \
 4149:                     + <float>128.0 + (<float>128.0 * <float>sin(
 4150:                     sqrt((x - w2) * (x - w2) + (y - h2) * (y - h2)) * ONE_255)) \
+4151:                     + <float>128.0 + (<float>128.0 * <float>sin(
                              __pyx_v_color_ = (((((((((float)128.0) + (((float)128.0) * ((float)sin(((__pyx_v_x * 0.00392156862745098) + __pyx_v_frame))))) + ((float)128.0)) + (((float)128.0) * ((float)sin(((__pyx_v_frame * 0.03125) + (__pyx_v_y * 0.015625)))))) + ((float)128.0)) + (((float)128.0) * ((float)sin((sqrt((((__pyx_v_x - __pyx_v_w2) * (__pyx_v_x - __pyx_v_w2)) + ((__pyx_v_y - __pyx_v_h2) * (__pyx_v_y - __pyx_v_h2)))) * 0.00392156862745098))))) + ((float)128.0)) + (((float)128.0) * ((float)sin((((float)sqrt((((__pyx_v_x * __pyx_v_x) + (__pyx_v_y * __pyx_v_y)) + __pyx_v_frame))) * ((float)0.015625))))));
 4152:                     <float>sqrt(x * x + y * y + frame) * <float>ONE_64))
 4153: 
+4154:                 c = min(<int>(color_ / <float>8.0), <int>length)
                              __pyx_t_17 = ((int)__pyx_v_length);
                              __pyx_t_18 = ((int)(__pyx_v_color_ / ((float)8.0)));
                              if (((__pyx_t_17 < __pyx_t_18) != 0)) {
                                __pyx_t_19 = __pyx_t_17;
                              } else {
                                __pyx_t_19 = __pyx_t_18;
                              }
                              __pyx_v_c = __pyx_t_19;
 4155: 
+4156:                 ii = palette_[c]
                              __pyx_t_16 = __pyx_v_c;
                              __pyx_v_ii = (*((unsigned int *) ( /* dim=0 */ ((char *) (((unsigned int *) __pyx_v_palette_.data) + __pyx_t_16)) )));
 4157: 
+4158:                 rr[0] = (ii >> 16) & 255
                              (__pyx_v_rr[0]) = ((__pyx_v_ii >> 16) & 0xFF);
+4159:                 gg[0] = (ii >> 8) & 255
                              (__pyx_v_gg[0]) = ((__pyx_v_ii >> 8) & 0xFF);
+4160:                 bb[0] = ii & 255
                              (__pyx_v_bb[0]) = (__pyx_v_ii & 0xFF);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4161: 
 4162: 
 4163: @cython.boundscheck(False)
 4164: @cython.wraparound(False)
 4165: @cython.nonecheck(False)
 4166: @cython.cdivision(True)
+4167: cdef inline float [:, :, :, ::1] rgb_to_hsl_model_c():
static CYTHON_INLINE __Pyx_memviewslice __pyx_f_12PygameShader_6shader_rgb_to_hsl_model_c(void) {
  __Pyx_memviewslice __pyx_v_rgb_to_hsl = { 0, 0, { 0 }, { 0 }, { 0 } };
  struct hsl __pyx_v_hsl_;
  int __pyx_v_r;
  int __pyx_v_g;
  int __pyx_v_b;
  __Pyx_memviewslice __pyx_r = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_hsl_model_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
  __pyx_r.data = NULL;
  __pyx_r.memview = NULL;
  __Pyx_AddTraceback("PygameShader.shader.rgb_to_hsl_model_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  goto __pyx_L2;
  __pyx_L0:;
  if (unlikely(!__pyx_r.memview)) {
    PyErr_SetString(PyExc_TypeError, "Memoryview return value is not initialized");
  }
  __pyx_L2:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_to_hsl, 1);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 4168:     """
 4169:     CONVERT RGB INTO HSL MODEL
 4170: 
 4171:     The array can be used when the rgb to hsl is extensively used
 4172: 
 4173:     All the values will be stored into an array shape (r, g, b, 3) type float
 4174:     :return: Numpy.ndarray shape (r, g, b, 3) type float
 4175:     """
+4176:     cdef float [:, :, :, ::1] rgb_to_hsl = numpy.empty((256, 256, 256, 3), float32)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4176, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4176, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_float32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4176, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = NULL;
  __pyx_t_5 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_5 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_tuple__22, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4176, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_tuple__22, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4176, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_6 = PyTuple_New(2+__pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4176, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_INCREF(__pyx_tuple__22);
    __Pyx_GIVEREF(__pyx_tuple__22);
    PyTuple_SET_ITEM(__pyx_t_6, 0+__pyx_t_5, __pyx_tuple__22);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_6, 1+__pyx_t_5, __pyx_t_2);
    __pyx_t_2 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_6, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4176, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_float(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 4176, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rgb_to_hsl = __pyx_t_7;
  __pyx_t_7.memview = NULL;
  __pyx_t_7.data = NULL;
/* … */
  __pyx_tuple__22 = PyTuple_Pack(4, __pyx_int_256, __pyx_int_256, __pyx_int_256, __pyx_int_3); if (unlikely(!__pyx_tuple__22)) __PYX_ERR(1, 4176, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__22);
  __Pyx_GIVEREF(__pyx_tuple__22);
 4177:     cdef hsl hsl_
 4178:     cdef int r, g, b
+4179:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4180:         for r in prange(0, 256, schedule='static', num_threads=THREADS):
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x100 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) firstprivate(__pyx_v_r) lastprivate(__pyx_v_r) schedule(static)
/* … */
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x100 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) firstprivate(__pyx_v_r) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_9; __pyx_t_8++){
                        {
                            __pyx_v_r = (int)(0 + 1 * __pyx_t_8);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((int)0xbad0bad0);
                            __pyx_v_g = ((int)0xbad0bad0);
+4181:             for g in range(0, 256):
                            for (__pyx_t_5 = 0; __pyx_t_5 < 0x100; __pyx_t_5+=1) {
                              __pyx_v_g = __pyx_t_5;
+4182:                 for b in range(0, 256):
                              for (__pyx_t_10 = 0; __pyx_t_10 < 0x100; __pyx_t_10+=1) {
                                __pyx_v_b = __pyx_t_10;
+4183:                     hsl_ = struct_rgb_to_hsl(
                                __pyx_v_hsl_ = struct_rgb_to_hsl((__pyx_v_r * ((float)0.00392156862745098)), (__pyx_v_g * ((float)0.00392156862745098)), (__pyx_v_b * ((float)0.00392156862745098)));
 4184:                         r * <float>ONE_255, g * <float>ONE_255, b * <float>ONE_255)
+4185:                     rgb_to_hsl[r, g, b, 0] = min(<float>(hsl_.h * <float>255.0), <float>255.0)
                                __pyx_t_11 = ((float)255.0);
                                __pyx_t_12 = ((float)(__pyx_v_hsl_.h * ((float)255.0)));
                                if (((__pyx_t_11 < __pyx_t_12) != 0)) {
                                  __pyx_t_13 = __pyx_t_11;
                                } else {
                                  __pyx_t_13 = __pyx_t_12;
                                }
                                __pyx_t_14 = __pyx_v_r;
                                __pyx_t_15 = __pyx_v_g;
                                __pyx_t_16 = __pyx_v_b;
                                __pyx_t_17 = 0;
                                *((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl.data + __pyx_t_14 * __pyx_v_rgb_to_hsl.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_to_hsl.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_to_hsl.strides[2]) )) + __pyx_t_17)) )) = __pyx_t_13;
+4186:                     rgb_to_hsl[r, g, b, 1] = min(<float>(hsl_.s * <float>255.0), <float>255.0)
                                __pyx_t_13 = ((float)255.0);
                                __pyx_t_11 = ((float)(__pyx_v_hsl_.s * ((float)255.0)));
                                if (((__pyx_t_13 < __pyx_t_11) != 0)) {
                                  __pyx_t_12 = __pyx_t_13;
                                } else {
                                  __pyx_t_12 = __pyx_t_11;
                                }
                                __pyx_t_17 = __pyx_v_r;
                                __pyx_t_16 = __pyx_v_g;
                                __pyx_t_15 = __pyx_v_b;
                                __pyx_t_14 = 1;
                                *((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl.data + __pyx_t_17 * __pyx_v_rgb_to_hsl.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_to_hsl.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_to_hsl.strides[2]) )) + __pyx_t_14)) )) = __pyx_t_12;
+4187:                     rgb_to_hsl[r, g, b, 2] = min(<float>(hsl_.l * <float>255.0), <float>255.0)
                                __pyx_t_12 = ((float)255.0);
                                __pyx_t_13 = ((float)(__pyx_v_hsl_.l * ((float)255.0)));
                                if (((__pyx_t_12 < __pyx_t_13) != 0)) {
                                  __pyx_t_11 = __pyx_t_12;
                                } else {
                                  __pyx_t_11 = __pyx_t_13;
                                }
                                __pyx_t_14 = __pyx_v_r;
                                __pyx_t_15 = __pyx_v_g;
                                __pyx_t_16 = __pyx_v_b;
                                __pyx_t_17 = 2;
                                *((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl.data + __pyx_t_14 * __pyx_v_rgb_to_hsl.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_to_hsl.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_to_hsl.strides[2]) )) + __pyx_t_17)) )) = __pyx_t_11;
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4188: 
+4189:     return asarray(rgb_to_hsl, dtype=float32)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_asarray); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_rgb_to_hsl, 4, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_3);
  __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_float32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_6, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_float(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 4189, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_7;
  __pyx_t_7.memview = NULL;
  __pyx_t_7.data = NULL;
  goto __pyx_L0;
 4190: 
 4191: 
 4192: 
 4193: @cython.boundscheck(False)
 4194: @cython.wraparound(False)
 4195: @cython.nonecheck(False)
 4196: @cython.cdivision(True)
+4197: cdef inline unsigned char [:, :, :, ::1] hsl_to_rgb_model_c():
static CYTHON_INLINE __Pyx_memviewslice __pyx_f_12PygameShader_6shader_hsl_to_rgb_model_c(void) {
  __Pyx_memviewslice __pyx_v_hsl_to_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  struct rgb __pyx_v_rgb_;
  int __pyx_v_h;
  int __pyx_v_s;
  int __pyx_v_l;
  __Pyx_memviewslice __pyx_r = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("hsl_to_rgb_model_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
  __pyx_r.data = NULL;
  __pyx_r.memview = NULL;
  __Pyx_AddTraceback("PygameShader.shader.hsl_to_rgb_model_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  goto __pyx_L2;
  __pyx_L0:;
  if (unlikely(!__pyx_r.memview)) {
    PyErr_SetString(PyExc_TypeError, "Memoryview return value is not initialized");
  }
  __pyx_L2:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_hsl_to_rgb, 1);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 4198:     """
 4199:     CONVERT HSL INTO RGB MODEL
 4200: 
 4201:     The array can be used when the hsl to rgb is extensively used
 4202: 
 4203:     All the values will be stored into an array shape (r, g, b, 3) type float
 4204:     :return: Numpy.ndarray shape (r, g, b, 3) type float
 4205:     """
+4206:     cdef unsigned char [:, :, :, ::1] hsl_to_rgb = numpy.empty((256, 256, 256, 3), uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4206, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4206, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4206, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = NULL;
  __pyx_t_5 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_5 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_tuple__22, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4206, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_tuple__22, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4206, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_6 = PyTuple_New(2+__pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4206, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_INCREF(__pyx_tuple__22);
    __Pyx_GIVEREF(__pyx_tuple__22);
    PyTuple_SET_ITEM(__pyx_t_6, 0+__pyx_t_5, __pyx_tuple__22);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_6, 1+__pyx_t_5, __pyx_t_2);
    __pyx_t_2 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_6, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4206, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 4206, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_hsl_to_rgb = __pyx_t_7;
  __pyx_t_7.memview = NULL;
  __pyx_t_7.data = NULL;
 4207:     cdef rgb rgb_
 4208:     cdef int r, g, b
 4209:     cdef int h, s, l
 4210: 
+4211:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4212:         for h in prange(0, 256, schedule='static', num_threads=THREADS):
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x100 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_h) lastprivate(__pyx_v_h) lastprivate(__pyx_v_l) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static)
/* … */
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x100 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_h) lastprivate(__pyx_v_h) lastprivate(__pyx_v_l) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_9; __pyx_t_8++){
                        {
                            __pyx_v_h = (int)(0 + 1 * __pyx_t_8);
                            /* Initialize private variables to invalid values */
                            __pyx_v_l = ((int)0xbad0bad0);
                            __pyx_v_s = ((int)0xbad0bad0);
+4213:             for s in range(0, 256):
                            /* "PygameShader/shader.pyx":4213
 *     with nogil:
 *         for h in prange(0, 256, schedule='static', num_threads=THREADS):
 *             for s in range(0, 256):             # <<<<<<<<<<<<<<
 *                 for l in range(0, 256):
 *                     rgb_ = struct_hsl_to_rgb(h * <float>ONE_255, s *
 */
                            for (__pyx_t_5 = 0; __pyx_t_5 < 0x100; __pyx_t_5+=1) {
                              __pyx_v_s = __pyx_t_5;
+4214:                 for l in range(0, 256):
                              for (__pyx_t_10 = 0; __pyx_t_10 < 0x100; __pyx_t_10+=1) {
                                __pyx_v_l = __pyx_t_10;
+4215:                     rgb_ = struct_hsl_to_rgb(h * <float>ONE_255, s *
                                __pyx_v_rgb_ = struct_hsl_to_rgb((__pyx_v_h * ((float)0.00392156862745098)), (__pyx_v_s * ((float)0.00392156862745098)), (__pyx_v_l * ((float)0.00392156862745098)));
 4216:                                              <float>ONE_255, l * <float>ONE_255)
+4217:                     hsl_to_rgb[h, s, l, 0] =\
                                __pyx_t_14 = __pyx_v_h;
                                __pyx_t_15 = __pyx_v_s;
                                __pyx_t_16 = __pyx_v_l;
                                __pyx_t_17 = 0;
                                *((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_to_rgb.data + __pyx_t_14 * __pyx_v_hsl_to_rgb.strides[0]) ) + __pyx_t_15 * __pyx_v_hsl_to_rgb.strides[1]) ) + __pyx_t_16 * __pyx_v_hsl_to_rgb.strides[2]) )) + __pyx_t_17)) )) = __pyx_t_13;
+4218:                         min(<unsigned char> (rgb_.r * <float>255.0), <unsigned char>255)
                                __pyx_t_11 = ((unsigned char)0xFF);
                                __pyx_t_12 = ((unsigned char)(__pyx_v_rgb_.r * ((float)255.0)));
                                if (((__pyx_t_11 < __pyx_t_12) != 0)) {
                                  __pyx_t_13 = __pyx_t_11;
                                } else {
                                  __pyx_t_13 = __pyx_t_12;
                                }
+4219:                     hsl_to_rgb[h, s, l, 1] = \
                                __pyx_t_17 = __pyx_v_h;
                                __pyx_t_16 = __pyx_v_s;
                                __pyx_t_15 = __pyx_v_l;
                                __pyx_t_14 = 1;
                                *((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_to_rgb.data + __pyx_t_17 * __pyx_v_hsl_to_rgb.strides[0]) ) + __pyx_t_16 * __pyx_v_hsl_to_rgb.strides[1]) ) + __pyx_t_15 * __pyx_v_hsl_to_rgb.strides[2]) )) + __pyx_t_14)) )) = __pyx_t_12;
+4220:                         min(<unsigned char> (rgb_.g * <float>255.0), <unsigned char>255)
                                __pyx_t_13 = ((unsigned char)0xFF);
                                __pyx_t_11 = ((unsigned char)(__pyx_v_rgb_.g * ((float)255.0)));
                                if (((__pyx_t_13 < __pyx_t_11) != 0)) {
                                  __pyx_t_12 = __pyx_t_13;
                                } else {
                                  __pyx_t_12 = __pyx_t_11;
                                }
+4221:                     hsl_to_rgb[h, s, l, 2] = \
                                __pyx_t_14 = __pyx_v_h;
                                __pyx_t_15 = __pyx_v_s;
                                __pyx_t_16 = __pyx_v_l;
                                __pyx_t_17 = 2;
                                *((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_to_rgb.data + __pyx_t_14 * __pyx_v_hsl_to_rgb.strides[0]) ) + __pyx_t_15 * __pyx_v_hsl_to_rgb.strides[1]) ) + __pyx_t_16 * __pyx_v_hsl_to_rgb.strides[2]) )) + __pyx_t_17)) )) = __pyx_t_11;
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+4222:                         min(<unsigned char> (rgb_.b * <float>255.0), <unsigned char>255)
                                __pyx_t_12 = ((unsigned char)0xFF);
                                __pyx_t_13 = ((unsigned char)(__pyx_v_rgb_.b * ((float)255.0)));
                                if (((__pyx_t_12 < __pyx_t_13) != 0)) {
                                  __pyx_t_11 = __pyx_t_12;
                                } else {
                                  __pyx_t_11 = __pyx_t_13;
                                }
 4223: 
+4224:     return asarray(hsl_to_rgb, dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_asarray); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_hsl_to_rgb, 4, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_3);
  __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_6, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_d_d_d_dc_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 4224, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_7;
  __pyx_t_7.memview = NULL;
  __pyx_t_7.data = NULL;
  goto __pyx_L0;
 4225: 
 4226: @cython.boundscheck(False)
 4227: @cython.wraparound(False)
 4228: @cython.nonecheck(False)
 4229: @cython.cdivision(True)
+4230: cdef inline void shader_hsl_surface24bit_inplace_c(unsigned char [:, :, :] rgb_array, float shift_):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_hsl_surface24bit_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array, float __pyx_v_shift_) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  struct hsl __pyx_v_hsl_;
  struct rgb __pyx_v_rgb_;
  float __pyx_v_h_;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_hsl_surface24bit_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 4231: 
 4232:     """
 4233:     ROTATE THE HUE OF THE GAME DISPLAY OR GIVEN TEXTURE
 4234: 
 4235:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4236:     please refer to pygame function pixels3d or array3d to convert an image into a
 4237:     3d array (library surfarray)
 4238: 
 4239:     e.g:
 4240:     hsl(surface, 0.2)
 4241: 
 4242:     :param rgb_array    : numpy.ndarray of shape(w, h, 3) of unsigned char, rgb values
 4243:     :param shift_       : float; Hue value in range [-1.0 ... 1.0]
 4244:     :return             : void
 4245:     """
 4246: 
 4247:     cdef Py_ssize_t w, h
+4248:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 4249: 
 4250:     cdef:
+4251:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4252:         hsl hsl_
 4253:         rgb rgb_
 4254:         float h_
 4255:         unsigned char *r
 4256:         unsigned char *g
 4257:         unsigned char *b
 4258: 
 4259: 
+4260:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4261:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h_) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h_) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_h_ = ((float)__PYX_NAN());
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
+4262:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
+4263:                 r = &rgb_array[i, j, 0]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+4264:                 g = &rgb_array[i, j, 1]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+4265:                 b = &rgb_array[i, j, 2]
                              /* "PygameShader/shader.pyx":4265
 *                 r = &rgb_array[i, j, 0]
 *                 g = &rgb_array[i, j, 1]
 *                 b = &rgb_array[i, j, 2]             # <<<<<<<<<<<<<<
 *                 hsl_ = struct_rgb_to_hsl(
 *                     r[0] * <float>ONE_255, g[0] *
 */
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+4266:                 hsl_ = struct_rgb_to_hsl(
                              __pyx_v_hsl_ = struct_rgb_to_hsl(((__pyx_v_r[0]) * ((float)0.00392156862745098)), ((__pyx_v_g[0]) * ((float)0.00392156862745098)), ((__pyx_v_b[0]) * ((float)0.00392156862745098)));
 4267:                     r[0] * <float>ONE_255, g[0] *
 4268:                     <float>ONE_255, b[0] * <float>ONE_255)
 4269: 
 4270:                 #h_ = min((hsl_.h + shift_), 1.0)
 4271:                 #h_ = max(h_, 0.0)
+4272:                 h_ = hsl_.h + shift_
                              __pyx_v_h_ = (__pyx_v_hsl_.h + __pyx_v_shift_);
+4273:                 rgb_ = struct_hsl_to_rgb(h_, hsl_.s, hsl_.l)
                              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_h_, __pyx_v_hsl_.s, __pyx_v_hsl_.l);
 4274: 
+4275:                 r[0] = <unsigned char>(rgb_.r * <float>255.0)
                              (__pyx_v_r[0]) = ((unsigned char)(__pyx_v_rgb_.r * ((float)255.0)));
+4276:                 g[0] = <unsigned char>(rgb_.g * <float>255.0)
                              (__pyx_v_g[0]) = ((unsigned char)(__pyx_v_rgb_.g * ((float)255.0)));
+4277:                 b[0] = <unsigned char>(rgb_.b * <float>255.0)
                              (__pyx_v_b[0]) = ((unsigned char)(__pyx_v_rgb_.b * ((float)255.0)));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4278: 
 4279: 
 4280: 
 4281: @cython.boundscheck(False)
 4282: @cython.wraparound(False)
 4283: @cython.nonecheck(False)
 4284: @cython.cdivision(True)
+4285: cdef inline void shader_hsl_surface24bit_fast_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_hsl_surface24bit_fast_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_hsl_model_, __Pyx_memviewslice __pyx_v_rgb_model_) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_h_;
  unsigned char __pyx_v_h__;
  unsigned char __pyx_v_s__;
  unsigned char __pyx_v_l__;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_hsl_surface24bit_fast_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 4286:         unsigned char [:, :, :] rgb_array,
 4287:         float shift_,
 4288:         float [:, :, :, ::1] hsl_model_,
 4289:         unsigned char [:, :, :, ::1] rgb_model_):
 4290: 
 4291:     """
 4292:     ROTATE THE HUE OF AN IMAGE USING STORED HSL TO RGB AND RGB TO HSL VALUES
 4293: 
 4294:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4295:     please refer to pygame function pixels3d or array3d to convert an image into a
 4296:     3d array (library surfarray)
 4297: 
 4298:     e.g:
 4299:     hsl(surface, 0.2, hsl_model, rgb_model)
 4300: 
 4301:     :param rgb_array    : numpy.ndarray of shape(w, h, 3) of unsigned char, rgb values
 4302:     :param shift_       : float; Hue value in range [-1.0 ... 1.0]
 4303:     :param hsl_model_   : numpy.ndarray shape (r, g, b, 3) of hsl values r, g & b
 4304:     in range [0 ... 255]
 4305:     :param rgb_model_   : numpy.ndarray shape (h, s, l, 3) of hsl values h, s & l
 4306:     in range [0.0 ... 1.0]
 4307:     :return: void
 4308:     """
 4309: 
 4310: 
 4311: 
 4312:     cdef Py_ssize_t w, h
+4313:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 4314: 
 4315:     cdef:
+4316:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4317: 
 4318:         float h_
 4319:         unsigned char h__, s__, l__
 4320: 
 4321:         unsigned char *r
 4322:         unsigned char *g
 4323:         unsigned char *b
 4324: 
 4325: 
+4326:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4327:         for j in prange(h, schedule='dynamic', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h_) lastprivate(__pyx_v_h__) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l__) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s__) schedule(dynamic)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h_) lastprivate(__pyx_v_h__) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l__) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s__) schedule(dynamic) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_h_ = ((float)__PYX_NAN());
                            __pyx_v_h__ = ((unsigned char)'?');
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_l__ = ((unsigned char)'?');
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_s__ = ((unsigned char)'?');
+4328:             for i in range(w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
 4329: 
+4330:                 r = &rgb_array[i, j, 0]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+4331:                 g = &rgb_array[i, j, 1]
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+4332:                 b = &rgb_array[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
 4333: 
+4334:                 h_ = hsl_model_[r[0], g[0], b[0], 0]
                              __pyx_t_11 = (__pyx_v_r[0]);
                              __pyx_t_12 = (__pyx_v_g[0]);
                              __pyx_t_13 = (__pyx_v_b[0]);
                              __pyx_t_10 = 0;
                              __pyx_v_h_ = (*((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_model_.data + __pyx_t_11 * __pyx_v_hsl_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_hsl_model_.strides[1]) ) + __pyx_t_13 * __pyx_v_hsl_model_.strides[2]) )) + __pyx_t_10)) )));
 4335: 
+4336:                 h__ = <unsigned char> (<float>min((h_ * ONE_255 + shift_), <float>1.0) * \
                              __pyx_t_14 = ((float)1.0);
                              __pyx_t_15 = ((__pyx_v_h_ * 0.00392156862745098) + __pyx_v_shift_);
                              if (((__pyx_t_14 < __pyx_t_15) != 0)) {
                                __pyx_t_16 = __pyx_t_14;
                              } else {
                                __pyx_t_16 = __pyx_t_15;
                              }
/* … */
                              __pyx_v_h__ = ((unsigned char)(((float)__pyx_t_16) * ((float)255.0)));
 4337:                     <float>255.0)
 4338: 
+4339:                 s__ = <unsigned char> hsl_model_[r[0], g[0], b[0], 1]
                              __pyx_t_13 = (__pyx_v_r[0]);
                              __pyx_t_12 = (__pyx_v_g[0]);
                              __pyx_t_11 = (__pyx_v_b[0]);
                              __pyx_t_10 = 1;
                              __pyx_v_s__ = ((unsigned char)(*((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_model_.data + __pyx_t_13 * __pyx_v_hsl_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_hsl_model_.strides[1]) ) + __pyx_t_11 * __pyx_v_hsl_model_.strides[2]) )) + __pyx_t_10)) ))));
+4340:                 l__ = <unsigned char> hsl_model_[r[0], g[0], b[0], 2]
                              __pyx_t_11 = (__pyx_v_r[0]);
                              __pyx_t_12 = (__pyx_v_g[0]);
                              __pyx_t_13 = (__pyx_v_b[0]);
                              __pyx_t_10 = 2;
                              __pyx_v_l__ = ((unsigned char)(*((float *) ( /* dim=3 */ ((char *) (((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_hsl_model_.data + __pyx_t_11 * __pyx_v_hsl_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_hsl_model_.strides[1]) ) + __pyx_t_13 * __pyx_v_hsl_model_.strides[2]) )) + __pyx_t_10)) ))));
 4341: 
+4342:                 r[0] = (&rgb_model_[h__, s__, l__, 0])[0]
                              __pyx_t_13 = __pyx_v_h__;
                              __pyx_t_12 = __pyx_v_s__;
                              __pyx_t_11 = __pyx_v_l__;
                              __pyx_t_10 = 0;
                              (__pyx_v_r[0]) = ((&(*((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_model_.data + __pyx_t_13 * __pyx_v_rgb_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_rgb_model_.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_model_.strides[2]) )) + __pyx_t_10)) ))))[0]);
+4343:                 g[0] = (&rgb_model_[h__, s__, l__, 1])[0]
                              __pyx_t_11 = __pyx_v_h__;
                              __pyx_t_12 = __pyx_v_s__;
                              __pyx_t_13 = __pyx_v_l__;
                              __pyx_t_10 = 1;
                              (__pyx_v_g[0]) = ((&(*((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_model_.data + __pyx_t_11 * __pyx_v_rgb_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_rgb_model_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_model_.strides[2]) )) + __pyx_t_10)) ))))[0]);
+4344:                 b[0] = (&rgb_model_[h__, s__, l__, 2])[0]
                              __pyx_t_13 = __pyx_v_h__;
                              __pyx_t_12 = __pyx_v_s__;
                              __pyx_t_11 = __pyx_v_l__;
                              __pyx_t_10 = 2;
                              (__pyx_v_b[0]) = ((&(*((unsigned char *) ( /* dim=3 */ ((char *) (((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_model_.data + __pyx_t_13 * __pyx_v_rgb_model_.strides[0]) ) + __pyx_t_12 * __pyx_v_rgb_model_.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_model_.strides[2]) )) + __pyx_t_10)) ))))[0]);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4345: 
 4346: 
 4347: 
 4348: @cython.boundscheck(False)
 4349: @cython.wraparound(False)
 4350: @cython.nonecheck(False)
 4351: @cython.cdivision(True)
+4352: cdef inline void shader_brightness24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_brightness24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_inplace_c *__pyx_optional_args) {
  float __pyx_v_shift_ = ((float)0.0);
  Py_ssize_t __pyx_v_width;
  CYTHON_UNUSED Py_ssize_t __pyx_v_height;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_l;
  struct hsl __pyx_v_hsl_;
  struct rgb __pyx_v_rgb_;
  CYTHON_UNUSED int __pyx_v_exclude_color;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_brightness24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_shift_ = __pyx_optional_args->shift_;
    }
  }
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_inplace_c {
  int __pyx_n;
  float shift_;
};
 4353:         unsigned char [:, :, :] rgb_array_, float shift_=0):
 4354:     """
 4355:     SHADER BRIGHTNESS
 4356: 
 4357:     This shader control the pygame display brightness level
 4358:     It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb
 4359: 
 4360:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4361:     please refer to pygame function pixels3d or array3d to convert an image into
 4362:     a 3d array (library surfarray)
 4363: 
 4364:     e.g:
 4365:     brightness(surface, 0.2)
 4366: 
 4367:     :param rgb_array_: numpy ndarray shape (w, h, 3) containing RGB pixels values
 4368:     :param shift_    : float; values in range [-1.0 ... 1.0], 0 no change,
 4369:     -1 lowest brightness, +1 highest brightness
 4370:     :return          : void
 4371:     """
 4372: 
 4373:     cdef Py_ssize_t width, height
+4374:     width, height = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_width = __pyx_t_2;
  __pyx_v_height = __pyx_t_3;
 4375: 
 4376:     cdef:
+4377:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4378:         unsigned char *r
 4379:         unsigned char *g
 4380:         unsigned char *b
 4381:         float l, h, s
 4382:         hsl hsl_
 4383:         rgb rgb_
 4384:         float high, low, high_
 4385:         unsigned char exclude_r, exclude_g, exclude_b
+4386:         bint exclude_color = False
  __pyx_v_exclude_color = 0;
 4387: 
+4388:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4389:         for j in prange(height, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_l = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char *)1);
+4390:             for i in range(width):
                            __pyx_t_5 = __pyx_v_width;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
 4391: 
+4392:                 r, g, b = &rgb_array_[i, j, 0], &rgb_array_[i, j, 1], &rgb_array_[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_t_11 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_8 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_12 = __pyx_v_i;
                              __pyx_t_13 = __pyx_v_j;
                              __pyx_t_14 = 1;
                              __pyx_t_15 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 2;
                              __pyx_t_19 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_v_r = __pyx_t_11;
                              __pyx_v_g = __pyx_t_15;
                              __pyx_v_b = __pyx_t_19;
 4393: 
+4394:                 hsl_ = struct_rgb_to_hsl(
                              __pyx_v_hsl_ = struct_rgb_to_hsl(((__pyx_v_r[0]) * ((float)0.00392156862745098)), ((__pyx_v_g[0]) * ((float)0.00392156862745098)), ((__pyx_v_b[0]) * ((float)0.00392156862745098)));
 4395:                     r[0] * <float>ONE_255, g[0] *
 4396:                     <float>ONE_255, b[0] * <float>ONE_255)
 4397: 
+4398:                 l = min((hsl_.l + shift_), <float>1.0)
                              __pyx_t_20 = ((float)1.0);
                              __pyx_t_21 = (__pyx_v_hsl_.l + __pyx_v_shift_);
                              if (((__pyx_t_20 < __pyx_t_21) != 0)) {
                                __pyx_t_22 = __pyx_t_20;
                              } else {
                                __pyx_t_22 = __pyx_t_21;
                              }
                              __pyx_v_l = __pyx_t_22;
+4399:                 l = max(l, <float>0.0)
                              __pyx_t_22 = ((float)0.0);
                              __pyx_t_20 = __pyx_v_l;
                              if (((__pyx_t_22 > __pyx_t_20) != 0)) {
                                __pyx_t_21 = __pyx_t_22;
                              } else {
                                __pyx_t_21 = __pyx_t_20;
                              }
                              __pyx_v_l = __pyx_t_21;
 4400: 
+4401:                 rgb_ = struct_hsl_to_rgb(hsl_.h, hsl_.s, l)
                              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_hsl_.h, __pyx_v_hsl_.s, __pyx_v_l);
 4402: 
+4403:                 r[0] = <unsigned char> (rgb_.r * 255.0)
                              (__pyx_v_r[0]) = ((unsigned char)(__pyx_v_rgb_.r * 255.0));
+4404:                 g[0] = <unsigned char> (rgb_.g * 255.0)
                              (__pyx_v_g[0]) = ((unsigned char)(__pyx_v_rgb_.g * 255.0));
+4405:                 b[0] = <unsigned char> (rgb_.b * 255.0)
                              (__pyx_v_b[0]) = ((unsigned char)(__pyx_v_rgb_.b * 255.0));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4406: 
 4407: 
 4408: 
 4409: @cython.boundscheck(False)
 4410: @cython.wraparound(False)
 4411: @cython.nonecheck(False)
 4412: @cython.cdivision(True)
+4413: cdef inline void shader_brightness24_exclude_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_brightness24_exclude_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_exclude_inplace_c *__pyx_optional_args) {
  float __pyx_v_shift_ = ((float)0.0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_brightness24_exclude_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_exclude_inplace_c {
  int __pyx_n;
  float shift_;
  PyObject *color_;
};
+4414:         unsigned char [:, :, :] rgb_array_, float shift_=0.0, color_=(0, 0, 0)):
  PyObject *__pyx_v_color_ = ((PyObject *)__pyx_tuple__9);
  Py_ssize_t __pyx_v_width;
  Py_ssize_t __pyx_v_height;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_r;
  unsigned char __pyx_v_g;
  unsigned char __pyx_v_b;
  float __pyx_v_l;
  struct hsl __pyx_v_hsl_;
  struct rgb __pyx_v_rgb_;
  unsigned char __pyx_v_rr;
  unsigned char __pyx_v_gg;
  unsigned char __pyx_v_bb;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_brightness24_exclude_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_shift_ = __pyx_optional_args->shift_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_color_ = __pyx_optional_args->color_;
      }
    }
  }
 4415:     """
 4416:     SHADER BRIGHTNESS (EXCLUDE A SPECIFIC COLOR FROM THE PROCESS, DEFAULT BLACK COLOR)
 4417: 
 4418:     This shader control the pygame display brightness level
 4419:     It uses two external functions coded in C, struct_rgb_to_hsl & struct_hsl_to_rgb
 4420: 
 4421:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4422:      please refer to pygame function pixels3d or array3d to convert an image into a
 4423:      3d array (library surfarray)
 4424: 
 4425:     e.g:
 4426:     brightness_exclude(surface, 0.2)
 4427: 
 4428:     :param rgb_array_: numpy ndarray shape (w, h, 3) containing RGB pixels values
 4429:     :param shift_    : float; values in range [-1.0 ... 1.0], 0 no change,
 4430:     -1 lowest brightness, +1 highest brightness
 4431:     :param color_    : tuple; Color to exclude from the brightness process
 4432:     :return          : void
 4433:     """
 4434: 
 4435:     cdef Py_ssize_t width, height
+4436:     width, height = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_width = __pyx_t_2;
  __pyx_v_height = __pyx_t_3;
 4437: 
 4438:     cdef:
+4439:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4440:         unsigned char r
 4441:         unsigned char g
 4442:         unsigned char b
 4443:         float l, h, s
 4444:         hsl hsl_
 4445:         rgb rgb_
 4446:         float high, low, high_
+4447:         unsigned char rr=color_[0], gg=color_[1], bb=color_[2]
  __pyx_t_4 = __Pyx_GetItemInt(__pyx_v_color_, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyInt_As_unsigned_char(__pyx_t_4); if (unlikely((__pyx_t_5 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rr = __pyx_t_5;
  __pyx_t_4 = __Pyx_GetItemInt(__pyx_v_color_, 1, long, 1, __Pyx_PyInt_From_long, 0, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyInt_As_unsigned_char(__pyx_t_4); if (unlikely((__pyx_t_5 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_gg = __pyx_t_5;
  __pyx_t_4 = __Pyx_GetItemInt(__pyx_v_color_, 2, long, 1, __Pyx_PyInt_From_long, 0, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyInt_As_unsigned_char(__pyx_t_4); if (unlikely((__pyx_t_5 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 4447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_bb = __pyx_t_5;
 4448: 
+4449:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4450:         for j in range(height): #, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_height;
        __pyx_t_2 = __pyx_t_3;
        for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_2; __pyx_t_6+=1) {
          __pyx_v_j = __pyx_t_6;
+4451:             for i in range(width):
          __pyx_t_7 = __pyx_v_width;
          __pyx_t_8 = __pyx_t_7;
          for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) {
            __pyx_v_i = __pyx_t_9;
 4452: 
+4453:                 r, g, b = rgb_array_[i, j, 0], rgb_array_[i, j, 1], rgb_array_[i, j, 2]
            __pyx_t_10 = __pyx_v_i;
            __pyx_t_11 = __pyx_v_j;
            __pyx_t_12 = 0;
            __pyx_t_5 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
            __pyx_t_12 = __pyx_v_i;
            __pyx_t_11 = __pyx_v_j;
            __pyx_t_10 = 1;
            __pyx_t_13 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )));
            __pyx_t_10 = __pyx_v_i;
            __pyx_t_11 = __pyx_v_j;
            __pyx_t_12 = 2;
            __pyx_t_14 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
            __pyx_v_r = __pyx_t_5;
            __pyx_v_g = __pyx_t_13;
            __pyx_v_b = __pyx_t_14;
 4454: 
+4455:                 if not ((r==rr) and (g==gg) and (b==bb)):
            __pyx_t_16 = ((__pyx_v_r == __pyx_v_rr) != 0);
            if (__pyx_t_16) {
            } else {
              __pyx_t_15 = __pyx_t_16;
              goto __pyx_L11_bool_binop_done;
            }
            __pyx_t_16 = ((__pyx_v_g == __pyx_v_gg) != 0);
            if (__pyx_t_16) {
            } else {
              __pyx_t_15 = __pyx_t_16;
              goto __pyx_L11_bool_binop_done;
            }
            __pyx_t_16 = ((__pyx_v_b == __pyx_v_bb) != 0);
            __pyx_t_15 = __pyx_t_16;
            __pyx_L11_bool_binop_done:;
            __pyx_t_16 = ((!__pyx_t_15) != 0);
            if (__pyx_t_16) {
/* … */
            }
          }
        }
      }
 4456: 
+4457:                     hsl_ = struct_rgb_to_hsl(
              __pyx_v_hsl_ = struct_rgb_to_hsl((__pyx_v_r * ((float)0.00392156862745098)), (__pyx_v_g * ((float)0.00392156862745098)), (__pyx_v_b * ((float)0.00392156862745098)));
 4458:                         r * <float>ONE_255, g * <float>ONE_255, b * <float>ONE_255)
 4459: 
+4460:                     l = min((hsl_.l + shift_), <float>1.0)
              __pyx_t_17 = ((float)1.0);
              __pyx_t_18 = (__pyx_v_hsl_.l + __pyx_v_shift_);
              if (((__pyx_t_17 < __pyx_t_18) != 0)) {
                __pyx_t_19 = __pyx_t_17;
              } else {
                __pyx_t_19 = __pyx_t_18;
              }
              __pyx_v_l = __pyx_t_19;
+4461:                     l = max(l, <float>0.0)
              __pyx_t_19 = ((float)0.0);
              __pyx_t_17 = __pyx_v_l;
              if (((__pyx_t_19 > __pyx_t_17) != 0)) {
                __pyx_t_18 = __pyx_t_19;
              } else {
                __pyx_t_18 = __pyx_t_17;
              }
              __pyx_v_l = __pyx_t_18;
 4462: 
+4463:                     rgb_ = struct_hsl_to_rgb(hsl_.h, hsl_.s, l)
              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_hsl_.h, __pyx_v_hsl_.s, __pyx_v_l);
 4464: 
+4465:                     rgb_array_[i, j, 0] = <unsigned char> (rgb_.r * 255.0)
              __pyx_t_12 = __pyx_v_i;
              __pyx_t_11 = __pyx_v_j;
              __pyx_t_10 = 0;
              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.r * 255.0));
+4466:                     rgb_array_[i, j, 1] = <unsigned char> (rgb_.g * 255.0)
              __pyx_t_10 = __pyx_v_i;
              __pyx_t_11 = __pyx_v_j;
              __pyx_t_12 = 1;
              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.g * 255.0));
+4467:                     rgb_array_[i, j, 2] = <unsigned char> (rgb_.b * 255.0)
              __pyx_t_12 = __pyx_v_i;
              __pyx_t_11 = __pyx_v_j;
              __pyx_t_10 = 2;
              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.b * 255.0));
 4468: 
 4469: 
 4470: 
 4471: @cython.boundscheck(False)
 4472: @cython.wraparound(False)
 4473: @cython.nonecheck(False)
 4474: @cython.cdivision(True)
+4475: cdef inline void shader_brightness24_bpf_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_brightness24_bpf_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_bpf_c *__pyx_optional_args) {
  float __pyx_v_shift_ = ((float)0.0);
  unsigned char __pyx_v_bpf_treshold_ = ((unsigned char)64);
  Py_ssize_t __pyx_v_width;
  CYTHON_UNUSED Py_ssize_t __pyx_v_height;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char __pyx_v_r;
  unsigned char __pyx_v_g;
  unsigned char __pyx_v_b;
  float __pyx_v_l;
  struct hsl __pyx_v_hsl_;
  struct rgb __pyx_v_rgb_;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_brightness24_bpf_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_shift_ = __pyx_optional_args->shift_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_bpf_treshold_ = __pyx_optional_args->bpf_treshold_;
      }
    }
  }
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_brightness24_bpf_c {
  int __pyx_n;
  float shift_;
  unsigned char bpf_treshold_;
};
 4476:         unsigned char [:, :, :] rgb_array_,
 4477:         float shift_=0.0,
 4478:         unsigned char bpf_treshold_=64):
 4479:     """
 4480:     
 4481:     :param rgb_array_: numpy ndarray shape (w, h, 3) containing RGB pixels values
 4482:     :param shift_    : float; values in range [-1.0 ... 1.0], 0 no change,
 4483:     -1 lowest brightness, +1 highest brightness
 4484:     :param bpf_treshold_ : integer; Bright pass filter threshold value 
 4485:     :return          : void
 4486:     """
 4487: 
 4488: 
 4489:     cdef Py_ssize_t width, height
+4490:     width, height = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_width = __pyx_t_2;
  __pyx_v_height = __pyx_t_3;
 4491: 
 4492:     cdef:
+4493:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4494:         unsigned char r
 4495:         unsigned char g
 4496:         unsigned char b
 4497:         float l, h, s
 4498:         hsl hsl_
 4499:         rgb rgb_
 4500:         float high, low, high_
 4501: 
 4502: 
+4503:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4504:         for j in prange(height, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char)'?');
                            __pyx_v_g = ((unsigned char)'?');
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_l = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char)'?');
+4505:             for i in range(width):
                            __pyx_t_5 = __pyx_v_width;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_i = __pyx_t_7;
 4506: 
+4507:                 r, g, b = rgb_array_[i, j, 0], rgb_array_[i, j, 1], rgb_array_[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_t_11 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_8 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )));
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 1;
                              __pyx_t_12 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array_.strides[2]) )));
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 2;
                              __pyx_t_13 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_8 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )));
                              __pyx_v_r = __pyx_t_11;
                              __pyx_v_g = __pyx_t_12;
                              __pyx_v_b = __pyx_t_13;
 4508: 
+4509:                 if r + g + b < bpf_treshold_:
                              __pyx_t_14 = ((((__pyx_v_r + __pyx_v_g) + __pyx_v_b) < __pyx_v_bpf_treshold_) != 0);
                              if (__pyx_t_14) {
/* … */
                              }
+4510:                     continue
                                goto __pyx_L10_continue;
 4511: 
+4512:                 hsl_ = struct_rgb_to_hsl(
                              __pyx_v_hsl_ = struct_rgb_to_hsl((__pyx_v_r * ((float)0.00392156862745098)), (__pyx_v_g * ((float)0.00392156862745098)), (__pyx_v_b * ((float)0.00392156862745098)));
 4513:                     r * <float>ONE_255, g * <float>ONE_255, b * <float>ONE_255)
 4514: 
+4515:                 l = min((hsl_.l + shift_), <float>1.0)
                              __pyx_t_15 = ((float)1.0);
                              __pyx_t_16 = (__pyx_v_hsl_.l + __pyx_v_shift_);
                              if (((__pyx_t_15 < __pyx_t_16) != 0)) {
                                __pyx_t_17 = __pyx_t_15;
                              } else {
                                __pyx_t_17 = __pyx_t_16;
                              }
                              __pyx_v_l = __pyx_t_17;
+4516:                 l = max(l, <float>0.0)
                              __pyx_t_17 = ((float)0.0);
                              __pyx_t_15 = __pyx_v_l;
                              if (((__pyx_t_17 > __pyx_t_15) != 0)) {
                                __pyx_t_16 = __pyx_t_17;
                              } else {
                                __pyx_t_16 = __pyx_t_15;
                              }
                              __pyx_v_l = __pyx_t_16;
 4517: 
+4518:                 rgb_ = struct_hsl_to_rgb(hsl_.h, hsl_.s, l)
                              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_hsl_.h, __pyx_v_hsl_.s, __pyx_v_l);
 4519: 
+4520:                 rgb_array_[i, j, 0] = <unsigned char> (rgb_.r * 255.0 )
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.r * 255.0));
+4521:                 rgb_array_[i, j, 1] = <unsigned char> (rgb_.g * 255.0 )
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_8 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.g * 255.0));
+4522:                 rgb_array_[i, j, 2] = <unsigned char> (rgb_.b * 255.0 )
                              __pyx_t_10 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_8 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)(__pyx_v_rgb_.b * 255.0));
                              __pyx_L10_continue:;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4523: 
 4524: 
 4525: 
 4526: @cython.boundscheck(False)
 4527: @cython.wraparound(False)
 4528: @cython.nonecheck(False)
 4529: @cython.cdivision(True)
+4530: cdef inline void shader_brightness_24_inplace1_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_brightness_24_inplace1_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_shift_, __Pyx_memviewslice __pyx_v_rgb_to_hsl_model) {
  CYTHON_UNUSED Py_ssize_t __pyx_v_width;
  Py_ssize_t __pyx_v_height;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_l;
  float __pyx_v_h;
  float __pyx_v_s;
  struct rgb __pyx_v_rgb_;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_brightness_24_inplace1_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 4531:         unsigned char [:, :, :] rgb_array_, float shift_, float [:, :, :, :] rgb_to_hsl_model):
 4532:     """
 4533:     SHADER BRIGHTNESS USING STORED RGB TO HSL VALUES (SLOWEST VERSION)
 4534: 
 4535:     This method is fetching all the HSL values from an array instead
 4536:     In theory this method should be faster than the direct calculation therefore the size of the
 4537:     array degrade the performance somehow.
 4538: 
 4539:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4540:     please refer to pygame function pixels3d or array3d to convert an image into a
 4541:     3d array (library surfarray)
 4542: 
 4543:     e.g:
 4544:     brightness_model(surface, 0.2 rgb_to_hsl_model)
 4545: 
 4546:     :param rgb_array_      : numpy.ndarray containing RGB values array shapes (w, h, 3) uint8
 4547:     :param shift_          : float; value in range[-1.0 ... 1.0]
 4548:     :param rgb_to_hsl_model: Array shape (r, g, b, 3) containing all pre-calculated HSL values
 4549:     :return                : void
 4550:     """
 4551: 
 4552:     cdef Py_ssize_t width, height
+4553:     width, height = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_width = __pyx_t_2;
  __pyx_v_height = __pyx_t_3;
 4554: 
 4555:     cdef:
+4556:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4557:         unsigned char *r
 4558:         unsigned char *g
 4559:         unsigned char *b
 4560:         float l, h, s
 4561: 
 4562:         rgb rgb_
 4563:         float high, low, high_
 4564: 
+4565:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 4566: 
+4567:         for i in prange(width, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_h) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_l) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_h = ((float)__PYX_NAN());
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_l = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_s = ((float)__PYX_NAN());
+4568:             for j in range(height):
                            __pyx_t_5 = __pyx_v_height;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_j = __pyx_t_7;
 4569: 
+4570:                 r, g, b = &rgb_array_[i, j, 0], &rgb_array_[i, j, 1], &rgb_array_[i, j, 2]
                              __pyx_t_8 = __pyx_v_i;
                              __pyx_t_9 = __pyx_v_j;
                              __pyx_t_10 = 0;
                              __pyx_t_11 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_8 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_12 = __pyx_v_i;
                              __pyx_t_13 = __pyx_v_j;
                              __pyx_t_14 = 1;
                              __pyx_t_15 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 2;
                              __pyx_t_19 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_v_r = __pyx_t_11;
                              __pyx_v_g = __pyx_t_15;
                              __pyx_v_b = __pyx_t_19;
 4571: 
+4572:                 h = rgb_to_hsl_model[r[0], g[0], b[0], 0]
                              __pyx_t_20 = (__pyx_v_r[0]);
                              __pyx_t_21 = (__pyx_v_g[0]);
                              __pyx_t_22 = (__pyx_v_b[0]);
                              __pyx_t_18 = 0;
                              __pyx_v_h = (*((float *) ( /* dim=3 */ (( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl_model.data + __pyx_t_20 * __pyx_v_rgb_to_hsl_model.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_to_hsl_model.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_to_hsl_model.strides[2]) ) + __pyx_t_18 * __pyx_v_rgb_to_hsl_model.strides[3]) )));
+4573:                 s = rgb_to_hsl_model[r[0], g[0], b[0], 1]
                              __pyx_t_22 = (__pyx_v_r[0]);
                              __pyx_t_21 = (__pyx_v_g[0]);
                              __pyx_t_20 = (__pyx_v_b[0]);
                              __pyx_t_18 = 1;
                              __pyx_v_s = (*((float *) ( /* dim=3 */ (( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl_model.data + __pyx_t_22 * __pyx_v_rgb_to_hsl_model.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_to_hsl_model.strides[1]) ) + __pyx_t_20 * __pyx_v_rgb_to_hsl_model.strides[2]) ) + __pyx_t_18 * __pyx_v_rgb_to_hsl_model.strides[3]) )));
+4574:                 l = rgb_to_hsl_model[r[0], g[0], b[0], 2]
                              __pyx_t_20 = (__pyx_v_r[0]);
                              __pyx_t_21 = (__pyx_v_g[0]);
                              __pyx_t_22 = (__pyx_v_b[0]);
                              __pyx_t_18 = 2;
                              __pyx_v_l = (*((float *) ( /* dim=3 */ (( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_to_hsl_model.data + __pyx_t_20 * __pyx_v_rgb_to_hsl_model.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_to_hsl_model.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_to_hsl_model.strides[2]) ) + __pyx_t_18 * __pyx_v_rgb_to_hsl_model.strides[3]) )));
 4575: 
+4576:                 l = min((l + shift_), <float>1.0)
                              __pyx_t_23 = ((float)1.0);
                              __pyx_t_24 = (__pyx_v_l + __pyx_v_shift_);
                              if (((__pyx_t_23 < __pyx_t_24) != 0)) {
                                __pyx_t_25 = __pyx_t_23;
                              } else {
                                __pyx_t_25 = __pyx_t_24;
                              }
                              __pyx_v_l = __pyx_t_25;
+4577:                 l = max(l, <float>0.0)
                              __pyx_t_25 = ((float)0.0);
                              __pyx_t_23 = __pyx_v_l;
                              if (((__pyx_t_25 > __pyx_t_23) != 0)) {
                                __pyx_t_24 = __pyx_t_25;
                              } else {
                                __pyx_t_24 = __pyx_t_23;
                              }
                              __pyx_v_l = __pyx_t_24;
 4578: 
+4579:                 rgb_ = struct_hsl_to_rgb(h, s, l)
                              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_h, __pyx_v_s, __pyx_v_l);
+4580:                 r[0] = <unsigned char> (rgb_.r * <float>255.0)
                              (__pyx_v_r[0]) = ((unsigned char)(__pyx_v_rgb_.r * ((float)255.0)));
+4581:                 g[0] = <unsigned char> (rgb_.g * <float>255.0)
                              (__pyx_v_g[0]) = ((unsigned char)(__pyx_v_rgb_.g * ((float)255.0)));
+4582:                 b[0] = <unsigned char> (rgb_.b * <float>255.0)
                              (__pyx_v_b[0]) = ((unsigned char)(__pyx_v_rgb_.b * ((float)255.0)));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4583: 
 4584: 
 4585: 
 4586: 
 4587: @cython.boundscheck(False)
 4588: @cython.wraparound(False)
 4589: @cython.nonecheck(False)
 4590: @cython.cdivision(True)
+4591: cdef inline void shader_saturation_array24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_saturation_array24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_shift_) {
  Py_ssize_t __pyx_v_width;
  CYTHON_UNUSED Py_ssize_t __pyx_v_height;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_s;
  struct hsl __pyx_v_hsl_;
  struct rgb __pyx_v_rgb_;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_saturation_array24_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_WriteUnraisable("PygameShader.shader.shader_saturation_array24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
 4592:         unsigned char [:, :, :] rgb_array_, float shift_):
 4593:     """
 4594:     SHADER SATURATION
 4595: 
 4596:     This shader control the saturation level of the pygame display or surface/texture
 4597: 
 4598:     The Array (rgb_array) must be a numpy array shape (w, h, 3)
 4599:     containing RGB pixels, please refer to pygame
 4600:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 4601: 
 4602:     e.g:
 4603:     saturation(surface, 0.2)
 4604: 
 4605:     :param rgb_array_: numpy.ndarray shape (w, h, 3) containing RGB values uint8
 4606:     :param shift_    : float; value in range[-1.0...1.0], control the saturation level
 4607:     :return          : void
 4608:     """
 4609: 
+4610:     assert -1.0 <= shift_ <= 1.0, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (-1.0 <= __pyx_v_shift_);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_shift_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_shift_must_be_in_range);
      __PYX_ERR(1, 4610, __pyx_L1_error)
    }
  }
  #endif
 4611:         "Argument shift must be in range[-1.0 ... 1.0]"
 4612: 
 4613:     cdef Py_ssize_t width, height
+4614:     width, height = rgb_array_.shape[:2]
  __pyx_t_2 = __pyx_v_rgb_array_.shape;
  __pyx_t_3 = (__pyx_t_2[0]);
  __pyx_t_4 = (__pyx_t_2[1]);
  __pyx_v_width = __pyx_t_3;
  __pyx_v_height = __pyx_t_4;
 4615: 
 4616:     cdef:
+4617:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4618:         unsigned char *r
 4619:         unsigned char *g
 4620:         unsigned char *b
 4621:         float s
 4622:         hsl hsl_
 4623:         rgb rgb_
 4624: 
 4625: 
+4626:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4627:         for j in prange(height, schedule='static', num_threads=THREADS):
        __pyx_t_4 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static)
/* … */
        __pyx_t_4 = __pyx_v_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_hsl_) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_5; __pyx_t_3++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_3);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_s = ((float)__PYX_NAN());
+4628:             for i in range(width):
                            __pyx_t_6 = __pyx_v_width;
                            __pyx_t_7 = __pyx_t_6;
                            for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) {
                              __pyx_v_i = __pyx_t_8;
+4629:                 r, g, b = &rgb_array_[i, j, 0], &rgb_array_[i, j, 1], &rgb_array_[i, j, 2]
                              __pyx_t_9 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_11 = 0;
                              __pyx_t_12 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_9 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_13 = __pyx_v_i;
                              __pyx_t_14 = __pyx_v_j;
                              __pyx_t_15 = 1;
                              __pyx_t_16 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_t_17 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_19 = 2;
                              __pyx_t_20 = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_17 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_19 * __pyx_v_rgb_array_.strides[2]) ))));
                              __pyx_v_r = __pyx_t_12;
                              __pyx_v_g = __pyx_t_16;
                              __pyx_v_b = __pyx_t_20;
+4630:                 hsl_ = struct_rgb_to_hsl(<float>r[0] * <float>ONE_255,
                              __pyx_v_hsl_ = struct_rgb_to_hsl((((float)(__pyx_v_r[0])) * ((float)0.00392156862745098)), (((float)(__pyx_v_g[0])) * ((float)0.00392156862745098)), (((float)(__pyx_v_b[0])) * ((float)0.00392156862745098)));
 4631:                                          <float>g[0] * <float>ONE_255,
 4632:                                          <float>b[0] * <float>ONE_255)
 4633: 
+4634:                 s = min((hsl_.s + shift_), <float>0.5)
                              __pyx_t_21 = ((float)0.5);
                              __pyx_t_22 = (__pyx_v_hsl_.s + __pyx_v_shift_);
                              if (((__pyx_t_21 < __pyx_t_22) != 0)) {
                                __pyx_t_23 = __pyx_t_21;
                              } else {
                                __pyx_t_23 = __pyx_t_22;
                              }
                              __pyx_v_s = __pyx_t_23;
+4635:                 s = max(s, <float>0.0)
                              __pyx_t_23 = ((float)0.0);
                              __pyx_t_21 = __pyx_v_s;
                              if (((__pyx_t_23 > __pyx_t_21) != 0)) {
                                __pyx_t_22 = __pyx_t_23;
                              } else {
                                __pyx_t_22 = __pyx_t_21;
                              }
                              __pyx_v_s = __pyx_t_22;
+4636:                 rgb_ = struct_hsl_to_rgb(hsl_.h, s, hsl_.l)
                              __pyx_v_rgb_ = struct_hsl_to_rgb(__pyx_v_hsl_.h, __pyx_v_s, __pyx_v_hsl_.l);
+4637:                 r[0] = <unsigned char>(rgb_.r * <float>255.0)
                              (__pyx_v_r[0]) = ((unsigned char)(__pyx_v_rgb_.r * ((float)255.0)));
+4638:                 g[0] = <unsigned char>(rgb_.g * <float>255.0)
                              (__pyx_v_g[0]) = ((unsigned char)(__pyx_v_rgb_.g * ((float)255.0)));
+4639:                 b[0] = <unsigned char>(rgb_.b * <float>255.0)
                              (__pyx_v_b[0]) = ((unsigned char)(__pyx_v_rgb_.b * ((float)255.0)));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4640: 
 4641: 
 4642: 
 4643: 
 4644: 
 4645: @cython.boundscheck(False)
 4646: @cython.wraparound(False)
 4647: @cython.nonecheck(False)
 4648: @cython.cdivision(True)
 4649: # e.g
 4650: # heatwave_vertical(
 4651: #         surface_, numpy.full((w, h), 255, dtype=numpy.uint8),
 4652: #         b*random.uniform(55.0, 100), 0, sigma_=random.uniform(0.4, 1), mu_=b*2)
+4653: cdef inline void shader_heatwave24_vertical_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_heatwave24_vertical_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, CYTHON_UNUSED __Pyx_memviewslice __pyx_v_mask, float __pyx_v_amplitude_, float __pyx_v_center_, float __pyx_v_sigma_, float __pyx_v_mu_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_yy;
  int __pyx_v_h_1;
  __Pyx_memviewslice __pyx_v_f_gauss = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_heatwave24_vertical_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_heatwave24_vertical_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_f_gauss, 1);
  __Pyx_RefNannyFinishContext();
}
 4654:         unsigned char [:, :, :] rgb_array_,
 4655:         unsigned char [:, :] mask,
 4656:         float amplitude_,
 4657:         float center_,
 4658:         float sigma_,
 4659:         float mu_):
 4660:     """
 4661:     APPLY A GAUSSIAN TRANSFORMATION TO AN ARRAY
 4662: 
 4663:     This effect can be use for simulate air turbulence or heat flow/convection
 4664: 
 4665:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels, please refer to pygame
 4666:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 4667: 
 4668: 
 4669:     :param rgb_array_: numpy.ndarray shape (width, height, 3) uint8 containing RGB pixels
 4670:     :param mask      : numpy.ndarray shape (x, y) uint8, (values 255 or 0).
 4671:     Apply transformation to the original array
 4672:     if the value @(x, y) is 255 else remain unchanged.
 4673:     :param amplitude_: Control the maximum of the gaussian equation.
 4674:     No transformation if factor_ equal zero
 4675:     :param center_   : Control the center of the gaussian equation (if center_ equal zero,
 4676:      the Gauss equation is centered
 4677:     at x=0 and maximum is 0.4 with amplitude_ = 1.0)
 4678:     :param sigma_    : float; sigma value of the gauss equation
 4679:     :param mu_       : float; mu value of the gauss equation
 4680:     :return          : void
 4681:     """
 4682:     # TODO MASK
 4683: 
 4684:     cdef Py_ssize_t w, h
+4685:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 4686: 
 4687:     cdef:
+4688:         unsigned char [:, :, :] rgb_array_copy = numpy.array(rgb_array_, copy=False)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_False) < 0) __PYX_ERR(1, 4688, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 4688, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+4689:         int x = 0, y = 0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 4690:         int yy
+4691:         int h_1 = <int>h - 1
  __pyx_v_h_1 = (((int)__pyx_v_h) - 1);
 4692:         unsigned char *r
+4693:         float [::1] f_gauss = linspace(-4, 4, w, dtype=float32)
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_linspace); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_INCREF(__pyx_int_neg_4);
  __Pyx_GIVEREF(__pyx_int_neg_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_int_neg_4);
  __Pyx_INCREF(__pyx_int_4);
  __Pyx_GIVEREF(__pyx_int_4);
  PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_int_4);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 2, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_float32); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_dc_float(__pyx_t_5, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 4693, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_f_gauss = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 4694: 
 4695: 
+4696:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 4697: 
+4698:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_10; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_yy = ((int)0xbad0bad0);
 4699: 
+4700:             for y in range(h):
                            __pyx_t_11 = __pyx_v_h;
                            __pyx_t_12 = __pyx_t_11;
                            for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_12; __pyx_t_13+=1) {
                              __pyx_v_y = __pyx_t_13;
 4701: 
+4702:                 yy =<int>(gauss(f_gauss[x], center_, sigma_, mu_) * amplitude_ + y)
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_16.__pyx_n = 2;
                              __pyx_t_16.sigma = __pyx_v_sigma_;
                              __pyx_t_16.mu = __pyx_v_mu_;
                              __pyx_t_15 = __pyx_f_12PygameShader_6shader_gauss((*((float *) ( /* dim=0 */ ((char *) (((float *) __pyx_v_f_gauss.data) + __pyx_t_14)) ))), __pyx_v_center_, &__pyx_t_16); 
                              __pyx_v_yy = ((int)((__pyx_t_15 * __pyx_v_amplitude_) + __pyx_v_y));
 4703: 
 4704:                 # printf("\n %i ", yy)
+4705:                 if yy > h_1:
                              __pyx_t_17 = ((__pyx_v_yy > __pyx_v_h_1) != 0);
                              if (__pyx_t_17) {
/* … */
                              }
+4706:                     yy = h_1
                                __pyx_v_yy = __pyx_v_h_1;
 4707: 
+4708:                 if yy < 0:
                              __pyx_t_17 = ((__pyx_v_yy < 0) != 0);
                              if (__pyx_t_17) {
/* … */
                              }
+4709:                     yy = 0
                                __pyx_v_yy = 0;
 4710: 
+4711:                 rgb_array_[x, y, 0] = rgb_array_copy[x, yy, 0]
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_18 = __pyx_v_yy;
                              __pyx_t_19 = 0;
                              __pyx_t_20 = __pyx_v_x;
                              __pyx_t_21 = __pyx_v_y;
                              __pyx_t_22 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_20 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_18 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_19 * __pyx_v_rgb_array_copy.strides[2]) )));
+4712:                 rgb_array_[x, y, 1] = rgb_array_copy[x, yy, 1]
                              __pyx_t_19 = __pyx_v_x;
                              __pyx_t_18 = __pyx_v_yy;
                              __pyx_t_14 = 1;
                              __pyx_t_22 = __pyx_v_x;
                              __pyx_t_21 = __pyx_v_y;
                              __pyx_t_20 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_22 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_20 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_19 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_18 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[2]) )));
+4713:                 rgb_array_[x, y, 2] = rgb_array_copy[x, yy, 2]
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_18 = __pyx_v_yy;
                              __pyx_t_19 = 2;
                              __pyx_t_20 = __pyx_v_x;
                              __pyx_t_21 = __pyx_v_y;
                              __pyx_t_22 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_20 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_21 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_18 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_19 * __pyx_v_rgb_array_copy.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4714: 
 4715: 
 4716: 
 4717: 
 4718: @cython.boundscheck(False)
 4719: @cython.wraparound(False)
 4720: @cython.nonecheck(False)
 4721: @cython.cdivision(False)
 4722: # e.g horizontal_glitch(surface, 0.5, 0.08, frame % 20)
+4723: cdef inline void shader_horizontal_glitch24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_horizontal_glitch24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_rad1_, float __pyx_v_frequency_, float __pyx_v_amplitude_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_rad;
  float __pyx_v_angle;
  float __pyx_v_angle1;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_ii;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_horizontal_glitch24_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_horizontal_glitch24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_RefNannyFinishContext();
}
 4724:         unsigned char [:, :, :] rgb_array_,
 4725:         float rad1_,
 4726:         float frequency_,
 4727:         float amplitude_):
 4728: 
 4729:     """
 4730:     SHADER GLITCH EFFECT
 4731: 
 4732:     Deform the pygame display to create a glitch appearance
 4733: 
 4734:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4735:     please refer to pygame function pixels3d or array3d to convert an image into a
 4736:     3d array (library surfarray)
 4737: 
 4738:     :param rgb_array_: numpy.ndarray shape (w, h, 3) uint8 containing RGB pixels
 4739:     :param rad1_     : float; Angle in radians, this value control the angle variation over the time
 4740:     :param frequency_:  float; signal frequency, factor that amplify the angle variation
 4741:     :param amplitude_: float; cos amplitude value
 4742:     :return:
 4743:     """
 4744:     cdef Py_ssize_t w, h
+4745:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 4746: 
 4747:     cdef:
+4748:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+4749:         float rad = <float>(3.14/180.0)
  __pyx_v_rad = ((float)(3.14 / 180.0));
+4750:         float angle = 0
  __pyx_v_angle = 0.0;
+4751:         float angle1 = 0
  __pyx_v_angle1 = 0.0;
+4752:         unsigned char [:, :, :] rgb_array_copy = numpy.array(rgb_array_, copy=True)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 4752, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 4752, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+4753:         int ii=0
  __pyx_v_ii = 0;
 4754: 
+4755:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L4_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L5:;
      }
  }
 4756: 
+4757:         for j in range(h):
        __pyx_t_3 = __pyx_v_h;
        __pyx_t_2 = __pyx_t_3;
        for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_2; __pyx_t_9+=1) {
          __pyx_v_j = __pyx_t_9;
 4758: 
+4759:             for i in range(w):
          __pyx_t_10 = __pyx_v_w;
          __pyx_t_11 = __pyx_t_10;
          for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
            __pyx_v_i = __pyx_t_12;
 4760: 
+4761:                 ii = (i + <int>(<float>cos(angle) * amplitude_))
            __pyx_v_ii = (__pyx_v_i + ((int)(((float)cos(__pyx_v_angle)) * __pyx_v_amplitude_)));
+4762:                 if ii > <int>w - 1:
            __pyx_t_13 = ((__pyx_v_ii > (((int)__pyx_v_w) - 1)) != 0);
            if (__pyx_t_13) {
/* … */
            }
+4763:                     ii = <int>w - 1
              __pyx_v_ii = (((int)__pyx_v_w) - 1);
+4764:                 if ii < 0:
            __pyx_t_13 = ((__pyx_v_ii < 0) != 0);
            if (__pyx_t_13) {
/* … */
            }
+4765:                     ii = 0
              __pyx_v_ii = 0;
 4766: 
+4767:                 rgb_array_[i, j, 0],\
            __pyx_t_16 = __pyx_v_i;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_14 = 0;
            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_17;
+4768:                 rgb_array_[i, j, 1],\
            __pyx_t_14 = __pyx_v_i;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_16 = 1;
            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_18;
+4769:                 rgb_array_[i, j, 2] = rgb_array_copy[ii, j, 0],\
            __pyx_t_14 = __pyx_v_ii;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_16 = 0;
            __pyx_t_17 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[2]) )));
/* … */
            __pyx_t_16 = __pyx_v_i;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_14 = 2;
            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_t_19;
          }
+4770:                     rgb_array_copy[ii, j, 1], rgb_array_copy[ii, j, 2]
            __pyx_t_16 = __pyx_v_ii;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_14 = 1;
            __pyx_t_18 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[2]) )));
            __pyx_t_14 = __pyx_v_ii;
            __pyx_t_15 = __pyx_v_j;
            __pyx_t_16 = 2;
            __pyx_t_19 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[2]) )));
 4771: 
+4772:             angle1 = angle1 + frequency_ * rad
          __pyx_v_angle1 = (__pyx_v_angle1 + (__pyx_v_frequency_ * __pyx_v_rad));
+4773:             angle = angle + (rad1_ * rad + rand() % angle1 - rand() % angle1)
          __pyx_t_12 = rand();
          if (unlikely(__pyx_v_angle1 == 0)) {
            #ifdef WITH_THREAD
            PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
            #endif
            PyErr_SetString(PyExc_ZeroDivisionError, "float divmod()");
            #ifdef WITH_THREAD
            __Pyx_PyGILState_Release(__pyx_gilstate_save);
            #endif
            __PYX_ERR(1, 4773, __pyx_L4_error)
          }
          __pyx_t_20 = rand();
          if (unlikely(__pyx_v_angle1 == 0)) {
            #ifdef WITH_THREAD
            PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
            #endif
            PyErr_SetString(PyExc_ZeroDivisionError, "float divmod()");
            #ifdef WITH_THREAD
            __Pyx_PyGILState_Release(__pyx_gilstate_save);
            #endif
            __PYX_ERR(1, 4773, __pyx_L4_error)
          }
          __pyx_v_angle = (__pyx_v_angle + (((__pyx_v_rad1_ * __pyx_v_rad) + __Pyx_mod_float(__pyx_t_12, __pyx_v_angle1)) - __Pyx_mod_float(__pyx_t_20, __pyx_v_angle1)));
        }
      }
 4774: 
 4775: 
 4776: 
 4777: 
 4778: @cython.boundscheck(False)
 4779: @cython.wraparound(False)
 4780: @cython.nonecheck(False)
 4781: @cython.cdivision(True)
+4782: cdef inline void shader_bpf24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_bpf24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, struct __pyx_opt_args_12PygameShader_6shader_shader_bpf24_inplace_c *__pyx_optional_args) {
  int __pyx_v_threshold = ((int)0x80);
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_lum;
  float __pyx_v_c;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_bpf24_inplace_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold = __pyx_optional_args->threshold;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_WriteUnraisable("PygameShader.shader.shader_bpf24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_bpf24_inplace_c {
  int __pyx_n;
  int threshold;
  int transpose;
};
 4783:         unsigned char [:, :, :] rgb_array_, int threshold = 128, bint transpose=False):
 4784:     """
 4785:     SHADER BRIGHT PASS FILTER (INPLACE)
 4786: 
 4787:     Conserve only the brightest pixels in an array
 4788: 
 4789:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4790:      please refer to pygame function pixels3d or array3d to convert an image into a
 4791:      3d array (library surfarray)
 4792: 
 4793:     :param rgb_array_: numpy.ndarray shape (w, h, 3) uint8 containing RGB pixels
 4794:     :param threshold : integer; Bright pass threshold default 128
 4795:     :param transpose : bool; True| False transpose the final array
 4796:     :return          :  void
 4797:     """
 4798: 
+4799:     assert 0 <= threshold <= 255, "Argument threshold must be in range [0 ... 255]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (0 <= __pyx_v_threshold);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_threshold <= 0xFF);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_threshold_must_be_in_ra);
      __PYX_ERR(1, 4799, __pyx_L1_error)
    }
  }
  #endif
 4800: 
 4801:     cdef:
 4802:         Py_ssize_t w, h
+4803:     w, h = rgb_array_.shape[:2]
  __pyx_t_2 = __pyx_v_rgb_array_.shape;
  __pyx_t_3 = (__pyx_t_2[0]);
  __pyx_t_4 = (__pyx_t_2[1]);
  __pyx_v_w = __pyx_t_3;
  __pyx_v_h = __pyx_t_4;
 4804: 
 4805:     cdef:
+4806:         int i = 0, j = 0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4807:         float lum, c
 4808:         unsigned char *r
 4809:         unsigned char *g
 4810:         unsigned char *b
 4811: 
+4812:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4813:         for j in prange(0, h, schedule='static', num_threads=THREADS):
        __pyx_t_4 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_lum) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_4 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_lum) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_5; __pyx_t_3++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_3);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_c = ((float)__PYX_NAN());
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_lum = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char *)1);
+4814:             for i in range(0, w):
                            __pyx_t_6 = __pyx_v_w;
                            __pyx_t_7 = __pyx_t_6;
                            for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) {
                              __pyx_v_i = __pyx_t_8;
 4815: 
 4816:                 # ITU-R BT.601 luma coefficients
+4817:                 r = &rgb_array_[i, j, 0]
                              __pyx_t_9 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_11 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_9 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[2]) ))));
+4818:                 g = &rgb_array_[i, j, 1]
                              __pyx_t_11 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_9 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_11 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_9 * __pyx_v_rgb_array_.strides[2]) ))));
+4819:                 b = &rgb_array_[i, j, 2]
                              __pyx_t_9 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_11 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_9 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[2]) ))));
 4820: 
+4821:                 lum = r[0] * <float>0.299 + g[0] * <float>0.587 + b[0] * <float>0.114
                              __pyx_v_lum = ((((__pyx_v_r[0]) * ((float)0.299)) + ((__pyx_v_g[0]) * ((float)0.587))) + ((__pyx_v_b[0]) * ((float)0.114)));
 4822: 
+4823:                 if lum > threshold:
                              __pyx_t_1 = ((__pyx_v_lum > __pyx_v_threshold) != 0);
                              if (__pyx_t_1) {
/* … */
                                goto __pyx_L12;
                              }
+4824:                     c = (lum - threshold) / lum
                                __pyx_v_c = ((__pyx_v_lum - __pyx_v_threshold) / __pyx_v_lum);
+4825:                     r[0] = <unsigned char>(r[0] * c)
                                (__pyx_v_r[0]) = ((unsigned char)((__pyx_v_r[0]) * __pyx_v_c));
+4826:                     g[0] = <unsigned char>(g[0] * c)
                                (__pyx_v_g[0]) = ((unsigned char)((__pyx_v_g[0]) * __pyx_v_c));
+4827:                     b[0] = <unsigned char>(b[0] * c)
                                (__pyx_v_b[0]) = ((unsigned char)((__pyx_v_b[0]) * __pyx_v_c));
 4828:                 else:
+4829:                     r[0], g[0], b[0] = 0, 0, 0
                              /*else*/ {
                                __pyx_t_12 = 0;
                                __pyx_t_13 = 0;
                                __pyx_t_14 = 0;
                                (__pyx_v_r[0]) = __pyx_t_12;
                                (__pyx_v_g[0]) = __pyx_t_13;
                                (__pyx_v_b[0]) = __pyx_t_14;
                              }
                              __pyx_L12:;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 4830: 
 4831: 
 4832: 
 4833: @cython.boundscheck(False)
 4834: @cython.wraparound(False)
 4835: @cython.nonecheck(False)
 4836: @cython.cdivision(True)
+4837: cdef inline bpf24_c(
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_bpf24_c(__Pyx_memviewslice __pyx_v_input_array_, struct __pyx_opt_args_12PygameShader_6shader_bpf24_c *__pyx_optional_args) {
  int __pyx_v_threshold = ((int)0x80);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_lum;
  float __pyx_v_c;
  __Pyx_memviewslice __pyx_v_output_array_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bpf24_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_threshold = __pyx_optional_args->threshold;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_11);
  __PYX_XDEC_MEMVIEW(&__pyx_t_12, 1);
  __Pyx_AddTraceback("PygameShader.shader.bpf24_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_output_array_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+4838:         unsigned char [:, :, :] input_array_,
struct __pyx_opt_args_12PygameShader_6shader_bpf24_c {
  int __pyx_n;
  int threshold;
  int transpose;
};
 4839:         int threshold = 128,
 4840:         bint transpose=False):
 4841:     """
 4842:     SHADER BRIGHT PASS FILTER
 4843: 
 4844:     Conserve only the brightest pixels in an array
 4845: 
 4846:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 4847:     please refer to pygame function pixels3d or array3d to convert an image into a
 4848:     3d array (library surfarray)
 4849: 
 4850:     :param input_array_: numpy.ndarray shape (w, h, 3) uint8 containing RGB pixels
 4851:     :param threshold   : float Bright pass threshold default 128
 4852:     :param transpose   : bool; True| False transpose the final array
 4853:     :return            :  Return the modified array shape (w, h, 3) uint8
 4854:     """
+4855:     assert 0 <= threshold <= 255, "Argument threshold must be in range [0 ... 255]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (0 <= __pyx_v_threshold);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_threshold <= 0xFF);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_threshold_must_be_in_ra);
      __PYX_ERR(1, 4855, __pyx_L1_error)
    }
  }
  #endif
 4856: 
 4857:     cdef:
 4858:         Py_ssize_t w, h
+4859:     w, h = input_array_.shape[:2]
  __pyx_t_2 = __pyx_v_input_array_.shape;
  __pyx_t_3 = (__pyx_t_2[0]);
  __pyx_t_4 = (__pyx_t_2[1]);
  __pyx_v_w = __pyx_t_3;
  __pyx_v_h = __pyx_t_4;
 4860: 
 4861:     cdef:
+4862:         int i = 0, j = 0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
 4863:         float lum, c
+4864:         unsigned char [:, :, :] output_array_ = numpy.zeros((h, w, 3), uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_numpy); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_zeros); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_8 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = PyTuple_New(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_8);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_9, 2, __pyx_int_3);
  __pyx_t_6 = 0;
  __pyx_t_8 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_uint8); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_6 = NULL;
  __pyx_t_10 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_7))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_7);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_7, function);
      __pyx_t_10 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_9, __pyx_t_8};
    __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_10, 2+__pyx_t_10); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4864, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_9, __pyx_t_8};
    __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_10, 2+__pyx_t_10); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4864, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  } else
  #endif
  {
    __pyx_t_11 = PyTuple_New(2+__pyx_t_10); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 4864, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    if (__pyx_t_6) {
      __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_11, 0, __pyx_t_6); __pyx_t_6 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_9);
    PyTuple_SET_ITEM(__pyx_t_11, 0+__pyx_t_10, __pyx_t_9);
    __Pyx_GIVEREF(__pyx_t_8);
    PyTuple_SET_ITEM(__pyx_t_11, 1+__pyx_t_10, __pyx_t_8);
    __pyx_t_9 = 0;
    __pyx_t_8 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_11, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4864, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  }
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_12 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_5, PyBUF_WRITABLE); if (unlikely(!__pyx_t_12.memview)) __PYX_ERR(1, 4864, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_output_array_ = __pyx_t_12;
  __pyx_t_12.memview = NULL;
  __pyx_t_12.data = NULL;
 4865:         unsigned char *r
 4866:         unsigned char *g
 4867:         unsigned char *b
 4868: 
+4869:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+4870:         for j in prange(0, h, schedule='static', num_threads=THREADS):
        __pyx_t_4 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_13 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_13 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_lum) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_4 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_13 = (__pyx_t_4 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_13 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_lum) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_13; __pyx_t_3++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_3);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_c = ((float)__PYX_NAN());
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_lum = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char *)1);
+4871:             for i in range(0, w):
                            __pyx_t_14 = __pyx_v_w;
                            __pyx_t_15 = __pyx_t_14;
                            for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_15; __pyx_t_10+=1) {
                              __pyx_v_i = __pyx_t_10;
 4872: 
 4873:                 # ITU-R BT.601 luma coefficients
+4874:                 r = &input_array_[i, j, 0]
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_input_array_.data + __pyx_t_16 * __pyx_v_input_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_input_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_input_array_.strides[2]) ))));
+4875:                 g = &input_array_[i, j, 1]
                              __pyx_t_18 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_16 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_input_array_.data + __pyx_t_18 * __pyx_v_input_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_input_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_input_array_.strides[2]) ))));
+4876:                 b = &input_array_[i, j, 2]
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_input_array_.data + __pyx_t_16 * __pyx_v_input_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_input_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_input_array_.strides[2]) ))));
 4877: 
+4878:                 lum = r[0] * <float>0.299 + g[0] * <float>0.587 + b[0] * <float>0.114
                              __pyx_v_lum = ((((__pyx_v_r[0]) * ((float)0.299)) + ((__pyx_v_g[0]) * ((float)0.587))) + ((__pyx_v_b[0]) * ((float)0.114)));
 4879: 
+4880:                 if lum > threshold:
                              __pyx_t_1 = ((__pyx_v_lum > __pyx_v_threshold) != 0);
                              if (__pyx_t_1) {
/* … */
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+4881:                     c = (lum - threshold) / lum
                                __pyx_v_c = ((__pyx_v_lum - __pyx_v_threshold) / __pyx_v_lum);
+4882:                     output_array_[j, i, 0] = <unsigned char>(r[0] * c)
                                __pyx_t_18 = __pyx_v_j;
                                __pyx_t_17 = __pyx_v_i;
                                __pyx_t_16 = 0;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_output_array_.data + __pyx_t_18 * __pyx_v_output_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_output_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_output_array_.strides[2]) )) = ((unsigned char)((__pyx_v_r[0]) * __pyx_v_c));
+4883:                     output_array_[j, i, 1] = <unsigned char>(g[0] * c)
                                __pyx_t_16 = __pyx_v_j;
                                __pyx_t_17 = __pyx_v_i;
                                __pyx_t_18 = 1;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_output_array_.data + __pyx_t_16 * __pyx_v_output_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_output_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_output_array_.strides[2]) )) = ((unsigned char)((__pyx_v_g[0]) * __pyx_v_c));
+4884:                     output_array_[j, i, 2] = <unsigned char>(b[0] * c)
                                __pyx_t_18 = __pyx_v_j;
                                __pyx_t_17 = __pyx_v_i;
                                __pyx_t_16 = 2;
                                *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_output_array_.data + __pyx_t_18 * __pyx_v_output_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_output_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_output_array_.strides[2]) )) = ((unsigned char)((__pyx_v_b[0]) * __pyx_v_c));
 4885: 
+4886:     return pygame.image.frombuffer(output_array_, (w, h), 'RGB')
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_pygame); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_n_s_image); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __pyx_t_11 = __pyx_memoryview_fromslice(__pyx_v_output_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_8 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 4886, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_9);
  PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_9);
  __pyx_t_8 = 0;
  __pyx_t_9 = 0;
  __pyx_t_9 = NULL;
  __pyx_t_10 = 0;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_7))) {
    __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_7);
    if (likely(__pyx_t_9)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_9);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_7, function);
      __pyx_t_10 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[4] = {__pyx_t_9, __pyx_t_11, __pyx_t_6, __pyx_n_s_RGB};
    __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_10, 3+__pyx_t_10); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4886, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[4] = {__pyx_t_9, __pyx_t_11, __pyx_t_6, __pyx_n_s_RGB};
    __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_10, 3+__pyx_t_10); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4886, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  } else
  #endif
  {
    __pyx_t_8 = PyTuple_New(3+__pyx_t_10); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 4886, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    if (__pyx_t_9) {
      __Pyx_GIVEREF(__pyx_t_9); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_9); __pyx_t_9 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_11);
    PyTuple_SET_ITEM(__pyx_t_8, 0+__pyx_t_10, __pyx_t_11);
    __Pyx_GIVEREF(__pyx_t_6);
    PyTuple_SET_ITEM(__pyx_t_8, 1+__pyx_t_10, __pyx_t_6);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_8, 2+__pyx_t_10, __pyx_n_s_RGB);
    __pyx_t_11 = 0;
    __pyx_t_6 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_8, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4886, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  }
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_r = __pyx_t_5;
  __pyx_t_5 = 0;
  goto __pyx_L0;
 4887: 
 4888: 
 4889: 
 4890: @cython.boundscheck(False)
 4891: @cython.wraparound(False)
 4892: @cython.nonecheck(False)
 4893: @cython.cdivision(True)
+4894: cdef inline void shader_bloom_effect_array24_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_bloom_effect_array24_c(PyObject *__pyx_v_surface_, int __pyx_v_threshold_, struct __pyx_opt_args_12PygameShader_6shader_shader_bloom_effect_array24_c *__pyx_optional_args) {
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_bloom_effect_array24_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_surface_cp);
  __Pyx_XDECREF(__pyx_v_s2);
  __Pyx_XDECREF(__pyx_v_s2_array);
  __Pyx_XDECREF(__pyx_v_b2_blurred);
  __Pyx_XDECREF(__pyx_v_s4);
  __Pyx_XDECREF(__pyx_v_s4_array);
  __Pyx_XDECREF(__pyx_v_b4_blurred);
  __Pyx_XDECREF(__pyx_v_s8);
  __Pyx_XDECREF(__pyx_v_s8_array);
  __Pyx_XDECREF(__pyx_v_b8_blurred);
  __Pyx_XDECREF(__pyx_v_s16);
  __Pyx_XDECREF(__pyx_v_s16_array);
  __Pyx_XDECREF(__pyx_v_b16_blurred);
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_shader_bloom_effect_array24_c {
  int __pyx_n;
  int fast_;
};
 4895:         surface_,
 4896:         int threshold_,
+4897:         bint fast_ = False):
  int __pyx_v_fast_ = ((int)0);
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  CYTHON_UNUSED int __pyx_v_bit_size;
  int __pyx_v_w2;
  int __pyx_v_h2;
  int __pyx_v_w4;
  int __pyx_v_h4;
  int __pyx_v_w8;
  int __pyx_v_h8;
  int __pyx_v_w16;
  int __pyx_v_h16;
  int __pyx_v_x2;
  int __pyx_v_x4;
  int __pyx_v_x8;
  int __pyx_v_x16;
  PyObject *__pyx_v_surface_cp = NULL;
  PyObject *__pyx_v_s2 = NULL;
  PyObject *__pyx_v_s2_array = NULL;
  PyObject *__pyx_v_b2_blurred = NULL;
  PyObject *__pyx_v_s4 = NULL;
  PyObject *__pyx_v_s4_array = NULL;
  PyObject *__pyx_v_b4_blurred = NULL;
  PyObject *__pyx_v_s8 = NULL;
  PyObject *__pyx_v_s8_array = NULL;
  PyObject *__pyx_v_b8_blurred = NULL;
  PyObject *__pyx_v_s16 = NULL;
  PyObject *__pyx_v_s16_array = NULL;
  PyObject *__pyx_v_b16_blurred = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_bloom_effect_array24_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_fast_ = __pyx_optional_args->fast_;
    }
  }
 4898:     """
 4899:     CREATE A BLOOM EFFECT
 4900: 
 4901:     * Surface must be a pygame Surface 24-32 bit format
 4902: 
 4903:     :param surface_     : pygame.Surface; Game display or texture
 4904:     :param threshold_   : integer; Threshold value uint8 in range [0 ... 255].
 4905:     The threshold value is used by a bright
 4906:      pass filter to determine the bright pixels above the given threshold.
 4907:       Below 128 the bloom effect will be more
 4908:      noticeable and above 128 a bit less.
 4909:     :param fast_        : bool; True | False; If True the bloom effect will be approximated
 4910:     and only the x16 subsurface
 4911:     will be processed to maximize the overall processing time, default is False).
 4912:     :return             : void
 4913:     """
 4914: 
+4915:     assert 0 <= threshold_ <= 255, "Argument threshold must be in range [0 ... 255]"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (0 <= __pyx_v_threshold_);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_threshold_ <= 0xFF);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_threshold_must_be_in_ra);
      __PYX_ERR(1, 4915, __pyx_L1_error)
    }
  }
  #endif
 4916: 
 4917:     cdef:
 4918:         Py_ssize_t  w, h
 4919:         int bit_size
 4920:         int w2, h2, w4, h4, w8, h8, w16, h16
+4921:         bint x2, x4, x8, x16 = False
  __pyx_v_x16 = 0;
 4922: 
+4923:     w, h = surface_.get_size()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4923, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4923, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_2))) || (PyList_CheckExact(__pyx_t_2))) {
    PyObject* sequence = __pyx_t_2;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 4923, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_3 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_4);
    #else
    __pyx_t_3 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4923, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4923, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    #endif
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_5 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4923, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_6 = Py_TYPE(__pyx_t_5)->tp_iternext;
    index = 0; __pyx_t_3 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    index = 1; __pyx_t_4 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_4)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_6(__pyx_t_5), 2) < 0) __PYX_ERR(1, 4923, __pyx_L1_error)
    __pyx_t_6 = NULL;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_6 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 4923, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 4923, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyIndex_AsSsize_t(__pyx_t_4); if (unlikely((__pyx_t_8 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 4923, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_w = __pyx_t_7;
  __pyx_v_h = __pyx_t_8;
+4924:     bit_size = surface_.get_bitsize()
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bitsize); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4924, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_2 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4924, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_9 = __Pyx_PyInt_As_int(__pyx_t_2); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 4924, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_bit_size = __pyx_t_9;
 4925: 
+4926:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L7:;
      }
  }
+4927:         w2, h2   = <int>w >> 1, <int>h >> 1
        __pyx_t_10 = (((int)__pyx_v_w) >> 1);
        __pyx_t_11 = (((int)__pyx_v_h) >> 1);
        __pyx_v_w2 = __pyx_t_10;
        __pyx_v_h2 = __pyx_t_11;
+4928:         w4, h4   = w2 >> 1, h2 >> 1
        __pyx_t_11 = (__pyx_v_w2 >> 1);
        __pyx_t_10 = (__pyx_v_h2 >> 1);
        __pyx_v_w4 = __pyx_t_11;
        __pyx_v_h4 = __pyx_t_10;
+4929:         w8, h8   = w4 >> 1, h4 >> 1
        __pyx_t_10 = (__pyx_v_w4 >> 1);
        __pyx_t_11 = (__pyx_v_h4 >> 1);
        __pyx_v_w8 = __pyx_t_10;
        __pyx_v_h8 = __pyx_t_11;
+4930:         w16, h16 = w8 >> 1, h8 >> 1
        __pyx_t_11 = (__pyx_v_w8 >> 1);
        __pyx_t_10 = (__pyx_v_h8 >> 1);
        __pyx_v_w16 = __pyx_t_11;
        __pyx_v_h16 = __pyx_t_10;
      }
 4931: 
+4932:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L10;
        }
        __pyx_L10:;
      }
  }
+4933:         if w2 > 0 and h2 > 0:
        __pyx_t_12 = ((__pyx_v_w2 > 0) != 0);
        if (__pyx_t_12) {
        } else {
          __pyx_t_1 = __pyx_t_12;
          goto __pyx_L12_bool_binop_done;
        }
        __pyx_t_12 = ((__pyx_v_h2 > 0) != 0);
        __pyx_t_1 = __pyx_t_12;
        __pyx_L12_bool_binop_done:;
        if (__pyx_t_1) {
/* … */
          goto __pyx_L11;
        }
+4934:             x2 = True
          __pyx_v_x2 = 1;
 4935:         else:
+4936:             x2 = False
        /*else*/ {
          __pyx_v_x2 = 0;
        }
        __pyx_L11:;
 4937: 
+4938:         if w4 > 0 and h4 > 0:
        __pyx_t_12 = ((__pyx_v_w4 > 0) != 0);
        if (__pyx_t_12) {
        } else {
          __pyx_t_1 = __pyx_t_12;
          goto __pyx_L15_bool_binop_done;
        }
        __pyx_t_12 = ((__pyx_v_h4 > 0) != 0);
        __pyx_t_1 = __pyx_t_12;
        __pyx_L15_bool_binop_done:;
        if (__pyx_t_1) {
/* … */
          goto __pyx_L14;
        }
+4939:             x4 = True
          __pyx_v_x4 = 1;
 4940:         else:
+4941:             x4 = False
        /*else*/ {
          __pyx_v_x4 = 0;
        }
        __pyx_L14:;
 4942: 
+4943:         if w8 > 0 and h8 > 0:
        __pyx_t_12 = ((__pyx_v_w8 > 0) != 0);
        if (__pyx_t_12) {
        } else {
          __pyx_t_1 = __pyx_t_12;
          goto __pyx_L18_bool_binop_done;
        }
        __pyx_t_12 = ((__pyx_v_h8 > 0) != 0);
        __pyx_t_1 = __pyx_t_12;
        __pyx_L18_bool_binop_done:;
        if (__pyx_t_1) {
/* … */
          goto __pyx_L17;
        }
+4944:             x8 = True
          __pyx_v_x8 = 1;
 4945:         else:
+4946:             x8 = False
        /*else*/ {
          __pyx_v_x8 = 0;
        }
        __pyx_L17:;
 4947: 
+4948:         if w16 > 0 and h16 > 0:
        __pyx_t_12 = ((__pyx_v_w16 > 0) != 0);
        if (__pyx_t_12) {
        } else {
          __pyx_t_1 = __pyx_t_12;
          goto __pyx_L21_bool_binop_done;
        }
        __pyx_t_12 = ((__pyx_v_h16 > 0) != 0);
        __pyx_t_1 = __pyx_t_12;
        __pyx_L21_bool_binop_done:;
        if (__pyx_t_1) {
/* … */
          goto __pyx_L20;
        }
+4949:             x16 = True
          __pyx_v_x16 = 1;
 4950:         else:
+4951:             x16 = False
        /*else*/ {
          __pyx_v_x16 = 0;
        }
        __pyx_L20:;
      }
 4952: 
 4953:     # SUBSURFACE DOWNSCALE CANNOT
 4954:     # BE PERFORMED AND WILL RAISE AN EXCEPTION
+4955:     if not x2:
  __pyx_t_1 = ((!(__pyx_v_x2 != 0)) != 0);
  if (__pyx_t_1) {
/* … */
  }
+4956:         return
    goto __pyx_L0;
 4957: 
+4958:     if fast_:
  __pyx_t_1 = (__pyx_v_fast_ != 0);
  if (__pyx_t_1) {
/* … */
  }
+4959:         x2, x4, x8 = False, False, False
    __pyx_t_1 = 0;
    __pyx_t_12 = 0;
    __pyx_t_13 = 0;
    __pyx_v_x2 = __pyx_t_1;
    __pyx_v_x4 = __pyx_t_12;
    __pyx_v_x8 = __pyx_t_13;
 4960: 
+4961:     surface_cp = bpf24_c(pixels3d(surface_), threshold=threshold_)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4961, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_2 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_3, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4961, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_14 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_14.memview)) __PYX_ERR(1, 4961, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_15.__pyx_n = 1;
  __pyx_t_15.threshold = __pyx_v_threshold_;
  __pyx_t_2 = __pyx_f_12PygameShader_6shader_bpf24_c(__pyx_t_14, &__pyx_t_15); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4961, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
  __pyx_t_14.memview = NULL;
  __pyx_t_14.data = NULL;
  __pyx_v_surface_cp = __pyx_t_2;
  __pyx_t_2 = 0;
 4962: 
 4963: 
 4964:     # FIRST SUBSURFACE DOWNSCALE x2
 4965:     # THIS IS THE MOST EXPENSIVE IN TERM OF PROCESSING TIME
+4966:     if x2:
  __pyx_t_13 = (__pyx_v_x2 != 0);
  if (__pyx_t_13) {
/* … */
  }
+4967:         s2 = scale(surface_cp, (w2, h2))
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_scale); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4967, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_w2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4967, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4967, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4967, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_t_5);
    __pyx_t_3 = 0;
    __pyx_t_5 = 0;
    __pyx_t_5 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_4);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_4, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_4)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_16};
      __pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4967, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_16};
      __pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4967, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    } else
    #endif
    {
      __pyx_t_3 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4967, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (__pyx_t_5) {
        __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_5); __pyx_t_5 = NULL;
      }
      __Pyx_INCREF(__pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_v_surface_cp);
      PyTuple_SET_ITEM(__pyx_t_3, 0+__pyx_t_9, __pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_t_16);
      PyTuple_SET_ITEM(__pyx_t_3, 1+__pyx_t_9, __pyx_t_16);
      __pyx_t_16 = 0;
      __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4967, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    }
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_v_s2 = __pyx_t_2;
    __pyx_t_2 = 0;
+4968:         s2_array = numpy.array(s2.get_view('3'), dtype=numpy.uint8)
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_array_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_s2, __pyx_n_s_get_view); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_16 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_3);
      if (likely(__pyx_t_16)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
        __Pyx_INCREF(__pyx_t_16);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_3, function);
      }
    }
    __pyx_t_2 = (__pyx_t_16) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_16, __pyx_kp_s_3) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_kp_s_3);
    __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
    __pyx_t_2 = 0;
    __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_numpy); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4968, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_s2_array = __pyx_t_5;
    __pyx_t_5 = 0;
+4969:         shader_blur5x5_array24_inplace_c(s2_array)
    __pyx_t_14 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_s2_array, PyBUF_WRITABLE); if (unlikely(!__pyx_t_14.memview)) __PYX_ERR(1, 4969, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_14, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
    __pyx_t_14.memview = NULL;
    __pyx_t_14.data = NULL;
 4970:         # b2_blurred = frombuffer(numpy.array(s2_array.transpose(1, 0, 2),
 4971:         # order='C', copy=False), (w2, h2), 'RGB')
+4972:         b2_blurred = make_surface(s2_array)
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4972, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
      if (likely(__pyx_t_3)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_3);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_2, function);
      }
    }
    __pyx_t_5 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_3, __pyx_v_s2_array) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v_s2_array);
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4972, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_b2_blurred = __pyx_t_5;
    __pyx_t_5 = 0;
+4973:         s2 = smoothscale(b2_blurred, (w, h))
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4973, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4973, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4973, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4973, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_t_4);
    __pyx_t_3 = 0;
    __pyx_t_4 = 0;
    __pyx_t_4 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_2, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_2)) {
      PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_b2_blurred, __pyx_t_16};
      __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4973, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
      PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_b2_blurred, __pyx_t_16};
      __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4973, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    } else
    #endif
    {
      __pyx_t_3 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4973, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      if (__pyx_t_4) {
        __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4); __pyx_t_4 = NULL;
      }
      __Pyx_INCREF(__pyx_v_b2_blurred);
      __Pyx_GIVEREF(__pyx_v_b2_blurred);
      PyTuple_SET_ITEM(__pyx_t_3, 0+__pyx_t_9, __pyx_v_b2_blurred);
      __Pyx_GIVEREF(__pyx_t_16);
      PyTuple_SET_ITEM(__pyx_t_3, 1+__pyx_t_9, __pyx_t_16);
      __pyx_t_16 = 0;
      __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_3, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4973, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    }
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF_SET(__pyx_v_s2, __pyx_t_5);
    __pyx_t_5 = 0;
+4974:         surface_.blit(s2, (0, 0), special_flags=BLEND_RGB_ADD)
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_v_s2);
    __Pyx_GIVEREF(__pyx_v_s2);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_s2);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_tuple__12);
    __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_special_flags, __pyx_t_16) < 0) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_t_16 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_2, __pyx_t_3); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
 4975: 
 4976:     # SECOND SUBSURFACE DOWNSCALE x4
 4977:     # THIS IS THE SECOND MOST EXPENSIVE IN TERM OF PROCESSING TIME
+4978:     if x4:
  __pyx_t_13 = (__pyx_v_x4 != 0);
  if (__pyx_t_13) {
/* … */
  }
+4979:         s4 = scale(surface_cp, (w4, h4))
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_scale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4979, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4979, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4979, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4979, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_5);
    __pyx_t_2 = 0;
    __pyx_t_5 = 0;
    __pyx_t_5 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_3, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_3)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_4};
      __pyx_t_16 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4979, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_16);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_4};
      __pyx_t_16 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4979, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_16);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    } else
    #endif
    {
      __pyx_t_2 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4979, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      if (__pyx_t_5) {
        __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_5); __pyx_t_5 = NULL;
      }
      __Pyx_INCREF(__pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_v_surface_cp);
      PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_9, __pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_t_4);
      PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_9, __pyx_t_4);
      __pyx_t_4 = 0;
      __pyx_t_16 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, NULL); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4979, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_16);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    }
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_s4 = __pyx_t_16;
    __pyx_t_16 = 0;
+4980:         s4_array = numpy.array(s4.get_view('3'), dtype=numpy.uint8)
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_numpy); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_16, __pyx_n_s_array_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_s4, __pyx_n_s_get_view); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_4 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_2, function);
      }
    }
    __pyx_t_16 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_kp_s_3) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_kp_s_3);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_16);
    __pyx_t_16 = 0;
    __pyx_t_16 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (PyDict_SetItem(__pyx_t_16, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, __pyx_t_16); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_v_s4_array = __pyx_t_5;
    __pyx_t_5 = 0;
+4981:         shader_blur5x5_array24_inplace_c(s4_array)
    __pyx_t_14 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_s4_array, PyBUF_WRITABLE); if (unlikely(!__pyx_t_14.memview)) __PYX_ERR(1, 4981, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_14, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
    __pyx_t_14.memview = NULL;
    __pyx_t_14.data = NULL;
 4982:         # b4_blurred = frombuffer(numpy.array(s4_array.transpose(1, 0, 2),
 4983:         # order='C', copy=False), (w4, h4), 'RGB')
+4984:         b4_blurred = make_surface(s4_array)
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4984, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_2 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_16))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_16);
      if (likely(__pyx_t_2)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
        __Pyx_INCREF(__pyx_t_2);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_16, function);
      }
    }
    __pyx_t_5 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_16, __pyx_t_2, __pyx_v_s4_array) : __Pyx_PyObject_CallOneArg(__pyx_t_16, __pyx_v_s4_array);
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4984, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_v_b4_blurred = __pyx_t_5;
    __pyx_t_5 = 0;
+4985:         s4 = smoothscale(b4_blurred, (w, h))
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4985, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
    __pyx_t_2 = 0;
    __pyx_t_3 = 0;
    __pyx_t_3 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_16))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_16);
      if (likely(__pyx_t_3)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
        __Pyx_INCREF(__pyx_t_3);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_16, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_16)) {
      PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_b4_blurred, __pyx_t_4};
      __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_16, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4985, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_16)) {
      PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_v_b4_blurred, __pyx_t_4};
      __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_16, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4985, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    } else
    #endif
    {
      __pyx_t_2 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4985, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      if (__pyx_t_3) {
        __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3); __pyx_t_3 = NULL;
      }
      __Pyx_INCREF(__pyx_v_b4_blurred);
      __Pyx_GIVEREF(__pyx_v_b4_blurred);
      PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_9, __pyx_v_b4_blurred);
      __Pyx_GIVEREF(__pyx_t_4);
      PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_9, __pyx_t_4);
      __pyx_t_4 = 0;
      __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_16, __pyx_t_2, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4985, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    }
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_DECREF_SET(__pyx_v_s4, __pyx_t_5);
    __pyx_t_5 = 0;
+4986:         surface_.blit(s4, (0, 0), special_flags=BLEND_RGB_ADD)
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_INCREF(__pyx_v_s4);
    __Pyx_GIVEREF(__pyx_v_s4);
    PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_v_s4);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_tuple__12);
    __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_special_flags, __pyx_t_4) < 0) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_16, __pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4986, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
 4987: 
 4988:     # THIRD SUBSURFACE DOWNSCALE x8
+4989:     if x8:
  __pyx_t_13 = (__pyx_v_x8 != 0);
  if (__pyx_t_13) {
/* … */
  }
+4990:         s8 = scale(surface_cp, (w8, h8))
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_scale); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4990, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_16 = __Pyx_PyInt_From_int(__pyx_v_w8); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4990, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4990, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4990, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_16);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_5);
    __pyx_t_16 = 0;
    __pyx_t_5 = 0;
    __pyx_t_5 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_2, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_2)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_3};
      __pyx_t_4 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4990, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_3};
      __pyx_t_4 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4990, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else
    #endif
    {
      __pyx_t_16 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4990, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_16);
      if (__pyx_t_5) {
        __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_5); __pyx_t_5 = NULL;
      }
      __Pyx_INCREF(__pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_v_surface_cp);
      PyTuple_SET_ITEM(__pyx_t_16, 0+__pyx_t_9, __pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_t_3);
      PyTuple_SET_ITEM(__pyx_t_16, 1+__pyx_t_9, __pyx_t_3);
      __pyx_t_3 = 0;
      __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_16, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4990, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    }
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_s8 = __pyx_t_4;
    __pyx_t_4 = 0;
+4991:         s8_array = numpy.array(s8.get_view('3'), dtype=numpy.uint8)
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_v_s8, __pyx_n_s_get_view); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_3 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_16))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_16);
      if (likely(__pyx_t_3)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
        __Pyx_INCREF(__pyx_t_3);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_16, function);
      }
    }
    __pyx_t_4 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_16, __pyx_t_3, __pyx_kp_s_3) : __Pyx_PyObject_CallOneArg(__pyx_t_16, __pyx_kp_s_3);
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_t_16 = PyTuple_New(1); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_4);
    __pyx_t_4 = 0;
    __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_numpy); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_16, __pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_v_s8_array = __pyx_t_5;
    __pyx_t_5 = 0;
+4992:         shader_blur5x5_array24_inplace_c(s8_array)
    __pyx_t_14 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_s8_array, PyBUF_WRITABLE); if (unlikely(!__pyx_t_14.memview)) __PYX_ERR(1, 4992, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_14, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
    __pyx_t_14.memview = NULL;
    __pyx_t_14.data = NULL;
 4993:         # b8_blurred = frombuffer(numpy.array(s8_array.transpose(1, 0, 2),
 4994:         # order='C', copy=False), (w8, h8), 'RGB')
+4995:         b8_blurred = make_surface(s8_array)
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4995, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_16 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_4);
      if (likely(__pyx_t_16)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
        __Pyx_INCREF(__pyx_t_16);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_4, function);
      }
    }
    __pyx_t_5 = (__pyx_t_16) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_16, __pyx_v_s8_array) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_v_s8_array);
    __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4995, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_v_b8_blurred = __pyx_t_5;
    __pyx_t_5 = 0;
+4996:         s8 = smoothscale(b8_blurred, (w, h))
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4996, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_16 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4996, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 4996, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4996, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_16);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2);
    __pyx_t_16 = 0;
    __pyx_t_2 = 0;
    __pyx_t_2 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
      if (likely(__pyx_t_2)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
        __Pyx_INCREF(__pyx_t_2);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_4, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_4)) {
      PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_v_b8_blurred, __pyx_t_3};
      __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4996, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
      PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_v_b8_blurred, __pyx_t_3};
      __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4996, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else
    #endif
    {
      __pyx_t_16 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4996, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_16);
      if (__pyx_t_2) {
        __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_2); __pyx_t_2 = NULL;
      }
      __Pyx_INCREF(__pyx_v_b8_blurred);
      __Pyx_GIVEREF(__pyx_v_b8_blurred);
      PyTuple_SET_ITEM(__pyx_t_16, 0+__pyx_t_9, __pyx_v_b8_blurred);
      __Pyx_GIVEREF(__pyx_t_3);
      PyTuple_SET_ITEM(__pyx_t_16, 1+__pyx_t_9, __pyx_t_3);
      __pyx_t_3 = 0;
      __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_16, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4996, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    }
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF_SET(__pyx_v_s8, __pyx_t_5);
    __pyx_t_5 = 0;
+4997:         surface_.blit(s8, (0, 0), special_flags=BLEND_RGB_ADD)
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_INCREF(__pyx_v_s8);
    __Pyx_GIVEREF(__pyx_v_s8);
    PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_s8);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_tuple__12);
    __pyx_t_16 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    if (PyDict_SetItem(__pyx_t_16, __pyx_n_s_special_flags, __pyx_t_3) < 0) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_4, __pyx_t_16); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 4997, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
 4998: 
 4999:     # FOURTH SUBSURFACE DOWNSCALE x16
 5000:     # LESS SIGNIFICANT IN TERMS OF RENDERING AND PROCESSING TIME
+5001:     if x16:
  __pyx_t_13 = (__pyx_v_x16 != 0);
  if (__pyx_t_13) {
/* … */
  }
+5002:         s16 = scale(surface_cp, (w16, h16))
    __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_scale); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5002, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_w16); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5002, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h16); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5002, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5002, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_5);
    __pyx_t_4 = 0;
    __pyx_t_5 = 0;
    __pyx_t_5 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_16))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_16);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_16, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_16)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_2};
      __pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_16, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5002, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_16)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_surface_cp, __pyx_t_2};
      __pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_16, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5002, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    } else
    #endif
    {
      __pyx_t_4 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5002, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__pyx_t_5) {
        __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_5); __pyx_t_5 = NULL;
      }
      __Pyx_INCREF(__pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_v_surface_cp);
      PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_9, __pyx_v_surface_cp);
      __Pyx_GIVEREF(__pyx_t_2);
      PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_9, __pyx_t_2);
      __pyx_t_2 = 0;
      __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_16, __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5002, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __pyx_v_s16 = __pyx_t_3;
    __pyx_t_3 = 0;
+5003:         s16_array = numpy.array(s16.get_view('3'), dtype=numpy.uint8)
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_numpy); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_array_2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_s16, __pyx_n_s_get_view); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_2 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
      if (likely(__pyx_t_2)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
        __Pyx_INCREF(__pyx_t_2);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_4, function);
      }
    }
    __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_2, __pyx_kp_s_3) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_kp_s_3);
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5003, __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_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_16, __pyx_t_4, __pyx_t_3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5003, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_s16_array = __pyx_t_5;
    __pyx_t_5 = 0;
+5004:         shader_blur5x5_array24_inplace_c(s16_array)
    __pyx_t_14 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_s16_array, PyBUF_WRITABLE); if (unlikely(!__pyx_t_14.memview)) __PYX_ERR(1, 5004, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_14, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_14, 1);
    __pyx_t_14.memview = NULL;
    __pyx_t_14.data = NULL;
 5005:         # b16_blurred = frombuffer(numpy.array(s16_array.transpose(1, 0, 2),
 5006:         # order='C', copy=False), (w16, h16), 'RGB')
+5007:         b16_blurred = make_surface(s16_array)
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5007, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_3, function);
      }
    }
    __pyx_t_5 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_4, __pyx_v_s16_array) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_s16_array);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5007, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_b16_blurred = __pyx_t_5;
    __pyx_t_5 = 0;
+5008:         s16 = smoothscale(b16_blurred, (w, h))
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5008, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5008, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_16 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5008, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5008, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_16);
    __pyx_t_4 = 0;
    __pyx_t_16 = 0;
    __pyx_t_16 = NULL;
    __pyx_t_9 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_3);
      if (likely(__pyx_t_16)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
        __Pyx_INCREF(__pyx_t_16);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_3, function);
        __pyx_t_9 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_3)) {
      PyObject *__pyx_temp[3] = {__pyx_t_16, __pyx_v_b16_blurred, __pyx_t_2};
      __pyx_t_5 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5008, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
      PyObject *__pyx_temp[3] = {__pyx_t_16, __pyx_v_b16_blurred, __pyx_t_2};
      __pyx_t_5 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5008, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    } else
    #endif
    {
      __pyx_t_4 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5008, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__pyx_t_16) {
        __Pyx_GIVEREF(__pyx_t_16); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_16); __pyx_t_16 = NULL;
      }
      __Pyx_INCREF(__pyx_v_b16_blurred);
      __Pyx_GIVEREF(__pyx_v_b16_blurred);
      PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_9, __pyx_v_b16_blurred);
      __Pyx_GIVEREF(__pyx_t_2);
      PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_9, __pyx_t_2);
      __pyx_t_2 = 0;
      __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5008, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF_SET(__pyx_v_s16, __pyx_t_5);
    __pyx_t_5 = 0;
+5009:         surface_.blit(s16, (0, 0), special_flags=BLEND_RGB_ADD)
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_INCREF(__pyx_v_s16);
    __Pyx_GIVEREF(__pyx_v_s16);
    PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_s16);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_tuple__12);
    __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_special_flags, __pyx_t_2) < 0) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5009, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 5010: 
 5011: 
 5012:     # if mask_ is not None:
 5013:     #     # Multiply mask surface pixels with mask values.
 5014:     #     # RGB pixels = 0 when mask value = 0.0, otherwise
 5015:     #     # modify RGB amplitude
 5016:     #     surface_cp = filtering24_c(surface_cp, mask_)
 5017: 
 5018: 
+5019: cdef unsigned int [:, :, ::1] IMAGE_FISHEYE_MODEL = numpy.zeros((800, 1024, 2), uint32)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_33 = PyTuple_New(2); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_INCREF(__pyx_tuple__58);
  __Pyx_GIVEREF(__pyx_tuple__58);
  PyTuple_SET_ITEM(__pyx_t_33, 0, __pyx_tuple__58);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_33, 1, __pyx_t_2);
  __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_32, __pyx_t_33, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __pyx_t_37 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_int(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_37.memview)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_IMAGE_FISHEYE_MODEL, 1);
  __pyx_v_12PygameShader_6shader_IMAGE_FISHEYE_MODEL = __pyx_t_37;
  __pyx_t_37.memview = NULL;
  __pyx_t_37.data = NULL;
/* … */
  __pyx_tuple__58 = PyTuple_Pack(3, __pyx_int_800, __pyx_int_1024, __pyx_int_2); if (unlikely(!__pyx_tuple__58)) __PYX_ERR(1, 5019, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__58);
  __Pyx_GIVEREF(__pyx_tuple__58);
 5020: 
 5021: @cython.boundscheck(False)
 5022: @cython.wraparound(False)
 5023: @cython.nonecheck(False)
 5024: @cython.cdivision(True)
+5025: cdef inline shader_fisheye24_footprint_c(Py_ssize_t w, Py_ssize_t h):
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_shader_fisheye24_footprint_c(Py_ssize_t __pyx_v_w, Py_ssize_t __pyx_v_h) {
  __Pyx_memviewslice __pyx_v_image_fisheye_model = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_y;
  int __pyx_v_x;
  CYTHON_UNUSED int __pyx_v_v;
  float __pyx_v_ny;
  float __pyx_v_ny2;
  float __pyx_v_nx;
  float __pyx_v_nx2;
  float __pyx_v_r;
  float __pyx_v_theta;
  float __pyx_v_nxn;
  float __pyx_v_nyn;
  float __pyx_v_nr;
  int __pyx_v_x2;
  int __pyx_v_y2;
  CYTHON_UNUSED float __pyx_v_s;
  float __pyx_v_c1;
  float __pyx_v_c2;
  float __pyx_v_w2;
  float __pyx_v_h2;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_fisheye24_footprint_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_AddTraceback("PygameShader.shader.shader_fisheye24_footprint_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_image_fisheye_model, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5026: 
 5027:     """
 5028:     CREATE A FISHEYE MODEL TO HOLD THE PIXEL COORDINATES OF A SURFACE/ GAME DISPLAY
 5029: 
 5030:     * The surface and the model must have the same dimensions.
 5031: 
 5032:     Store the fisheye model into an external array image_fisheye_model shape (width, height, 2)
 5033: 
 5034:     IMAGE_FISHEYE_MODEL contains the fisheye transformation coordinate (x2 & y2) that reference
 5035:     the final image pixel position (fisheye model)
 5036:     This method has to be call once before the main loop in order to calculate
 5037:     the projected position for each pixels.
 5038: 
 5039:     :param w    : integer; width of the model
 5040:     :param h    : integer; height of the model
 5041:     :return     : Return a numpy.ndarray type (w, h, 2) representing the fisheye model (coordinates
 5042:     of all surface pixels passing through the fisheye lens model)
 5043:     """
 5044: 
+5045:     assert w > 0, "Argument w must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_w > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_w_must_be_0);
      __PYX_ERR(1, 5045, __pyx_L1_error)
    }
  }
  #endif
+5046:     assert h > 0, "Argument h must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_h > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_h_must_be_0);
      __PYX_ERR(1, 5046, __pyx_L1_error)
    }
  }
  #endif
 5047: 
 5048:     cdef:
+5049:         unsigned int [:, :, :] image_fisheye_model = numpy.zeros((w, h, 2), numpy.uint)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_4);
  __Pyx_INCREF(__pyx_int_2);
  __Pyx_GIVEREF(__pyx_int_2);
  PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_int_2);
  __pyx_t_2 = 0;
  __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_uint); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_t_5, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5049, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_t_5, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5049, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_7 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_6, __pyx_t_5);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_6, __pyx_t_2);
    __pyx_t_5 = 0;
    __pyx_t_2 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_7, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_int(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5049, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_image_fisheye_model = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+5050:         int y=0, x=0, v
  __pyx_v_y = 0;
  __pyx_v_x = 0;
 5051:         float ny, ny2, nx, nx2, r, theta, nxn, nyn, nr
 5052:         int x2, y2
+5053:         float s = <float>w * <float>h
  __pyx_v_s = (((float)__pyx_v_w) * ((float)__pyx_v_h));
+5054:         float c1 = <float>2.0 / <float>h
  __pyx_v_c1 = (((float)2.0) / ((float)__pyx_v_h));
+5055:         float c2 = <float>2.0 / <float>w
  __pyx_v_c2 = (((float)2.0) / ((float)__pyx_v_w));
+5056:         float w2 = <float>w * <float>0.5
  __pyx_v_w2 = (((float)__pyx_v_w) * ((float)0.5));
+5057:         float h2 = <float>h * <float>0.5
  __pyx_v_h2 = (((float)__pyx_v_h) * ((float)0.5));
 5058: 
+5059:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+5060:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_9 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_nr) lastprivate(__pyx_v_nx) lastprivate(__pyx_v_nx2) lastprivate(__pyx_v_nxn) lastprivate(__pyx_v_ny) lastprivate(__pyx_v_ny2) lastprivate(__pyx_v_nyn) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static)
/* … */
        __pyx_t_9 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_nr) lastprivate(__pyx_v_nx) lastprivate(__pyx_v_nx2) lastprivate(__pyx_v_nxn) lastprivate(__pyx_v_ny) lastprivate(__pyx_v_ny2) lastprivate(__pyx_v_nyn) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_11; __pyx_t_10++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_10);
                            /* Initialize private variables to invalid values */
                            __pyx_v_nr = ((float)__PYX_NAN());
                            __pyx_v_nx = ((float)__PYX_NAN());
                            __pyx_v_nx2 = ((float)__PYX_NAN());
                            __pyx_v_nxn = ((float)__PYX_NAN());
                            __pyx_v_ny = ((float)__PYX_NAN());
                            __pyx_v_ny2 = ((float)__PYX_NAN());
                            __pyx_v_nyn = ((float)__PYX_NAN());
                            __pyx_v_r = ((float)__PYX_NAN());
                            __pyx_v_theta = ((float)__PYX_NAN());
                            __pyx_v_v = ((int)0xbad0bad0);
                            __pyx_v_x2 = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_y2 = ((int)0xbad0bad0);
+5061:             nx = x * c2 - <float>1.0
                            __pyx_v_nx = ((__pyx_v_x * __pyx_v_c2) - ((float)1.0));
+5062:             nx2 = nx * nx
                            __pyx_v_nx2 = (__pyx_v_nx * __pyx_v_nx);
+5063:             for y in range(h):
                            __pyx_t_12 = __pyx_v_h;
                            __pyx_t_13 = __pyx_t_12;
                            for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_13; __pyx_t_6+=1) {
                              __pyx_v_y = __pyx_t_6;
+5064:                 ny = <float>y * c1 - <float>1.0
                              __pyx_v_ny = ((((float)__pyx_v_y) * __pyx_v_c1) - ((float)1.0));
+5065:                 ny2 = ny * ny
                              __pyx_v_ny2 = (__pyx_v_ny * __pyx_v_ny);
+5066:                 r = <float>sqrt(nx2 + ny2)
                              __pyx_v_r = ((float)sqrt((__pyx_v_nx2 + __pyx_v_ny2)));
+5067:                 if 0.0 <= r <= 1.0:
                              __pyx_t_14 = (0.0 <= __pyx_v_r);
                              if (__pyx_t_14) {
                                __pyx_t_14 = (__pyx_v_r <= 1.0);
                              }
                              __pyx_t_15 = (__pyx_t_14 != 0);
                              if (__pyx_t_15) {
/* … */
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+5068:                     nr = (r + <float>1.0 - <float>sqrt(1.0 - (nx2 + ny2))) * <float>0.5
                                __pyx_v_nr = (((__pyx_v_r + ((float)1.0)) - ((float)sqrt((1.0 - (__pyx_v_nx2 + __pyx_v_ny2))))) * ((float)0.5));
+5069:                     if nr <= 1.0:
                                __pyx_t_15 = ((__pyx_v_nr <= 1.0) != 0);
                                if (__pyx_t_15) {
/* … */
                                }
+5070:                         theta = <float>atan2(ny, nx)
                                  __pyx_v_theta = ((float)atan2(__pyx_v_ny, __pyx_v_nx));
+5071:                         nxn = nr * <float>cos(theta)
                                  __pyx_v_nxn = (__pyx_v_nr * ((float)cos(__pyx_v_theta)));
+5072:                         nyn = nr * <float>sin(theta)
                                  __pyx_v_nyn = (__pyx_v_nr * ((float)sin(__pyx_v_theta)));
+5073:                         x2 = <int>(nxn * w2 + w2)
                                  __pyx_v_x2 = ((int)((__pyx_v_nxn * __pyx_v_w2) + __pyx_v_w2));
+5074:                         y2 = <int>(nyn * h2 + h2)
                                  __pyx_v_y2 = ((int)((__pyx_v_nyn * __pyx_v_h2) + __pyx_v_h2));
+5075:                         v = <int>(y2 * w + x2)
                                  __pyx_v_v = ((int)((__pyx_v_y2 * __pyx_v_w) + __pyx_v_x2));
+5076:                         image_fisheye_model[x, y, 0] = x2
                                  __pyx_t_16 = __pyx_v_x;
                                  __pyx_t_17 = __pyx_v_y;
                                  __pyx_t_18 = 0;
                                  *((unsigned int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_image_fisheye_model.data + __pyx_t_16 * __pyx_v_image_fisheye_model.strides[0]) ) + __pyx_t_17 * __pyx_v_image_fisheye_model.strides[1]) ) + __pyx_t_18 * __pyx_v_image_fisheye_model.strides[2]) )) = __pyx_v_x2;
+5077:                         image_fisheye_model[x, y, 1] = y2
                                  __pyx_t_18 = __pyx_v_x;
                                  __pyx_t_17 = __pyx_v_y;
                                  __pyx_t_16 = 1;
                                  *((unsigned int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_image_fisheye_model.data + __pyx_t_18 * __pyx_v_image_fisheye_model.strides[0]) ) + __pyx_t_17 * __pyx_v_image_fisheye_model.strides[1]) ) + __pyx_t_16 * __pyx_v_image_fisheye_model.strides[2]) )) = __pyx_v_y2;
 5078: 
+5079:     return asarray(ascontiguousarray(image_fisheye_model))
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_asarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_ascontiguousarray); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = __pyx_memoryview_fromslice(__pyx_v_image_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_7 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_t_5) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_5);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_t_7) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_7);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 5080: 
 5081: @cython.boundscheck(False)
 5082: @cython.wraparound(False)
 5083: @cython.nonecheck(False)
 5084: @cython.cdivision(True)
+5085: cdef inline void shader_fisheye24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_fisheye24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, __Pyx_memviewslice __pyx_v_fisheye_model) {
  CYTHON_UNUSED Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned int *__pyx_v_x2;
  unsigned int *__pyx_v_y2;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_fisheye24_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_fisheye24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_RefNannyFinishContext();
}
 5086:         unsigned char [:, :, :] rgb_array_, unsigned int [:, :, :] fisheye_model):
 5087:     """
 5088:     THIS SHADER CAN BE USE TO DISPLAY THE GAME THROUGH A LENS EFFECT
 5089: 
 5090:     Display a fisheye effect in real time given a numpy ndarray referencing the
 5091:     pixels RGB of a Pygame.Surface. In order to accomplish a real time
 5092:     calculation, this algorithm is using a pre-calculated transformation stored
 5093:     in the array fisheye_model.
 5094:     The function shader_fisheye24_footprint_c has to be called prior
 5095:     shader_fisheye24_inplace_c in order to store the transformation values.
 5096: 
 5097:     This shader can be applied directly to the pygame display
 5098: 
 5099:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 5100:      please refer to pygame
 5101:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 5102: 
 5103:     :param rgb_array_       : numpy.ndarray shape (width, height, 3) containing RGB pixels
 5104:     :param fisheye_model    : numpy.ndarray shape (width, height, 2) int32, fisheye model
 5105:     containing the pixels
 5106:     coordinates after the fisheye transformation
 5107:     :return                 : void
 5108:     """
 5109: 
 5110:     cdef:
 5111:         Py_ssize_t w, h
+5112:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 5113: 
 5114:     cdef:
 5115:         int x, y
+5116:         unsigned char [:, :, :] rgb_array_copy = numpy.array(rgb_array_, copy=False, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_False) < 0) __PYX_ERR(1, 5116, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5116, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5116, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 5117:         unsigned int *x2
 5118:         unsigned int *y2
 5119: 
+5120:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+5121:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_x2 = ((unsigned int *)1);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_y2 = ((unsigned int *)1);
+5122:             for y in range(h):
                            __pyx_t_10 = __pyx_v_h;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_y = __pyx_t_12;
+5123:                 x2 = &fisheye_model[x, y, 0]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              __pyx_v_x2 = (&(*((unsigned int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_fisheye_model.data + __pyx_t_13 * __pyx_v_fisheye_model.strides[0]) ) + __pyx_t_14 * __pyx_v_fisheye_model.strides[1]) ) + __pyx_t_15 * __pyx_v_fisheye_model.strides[2]) ))));
+5124:                 y2 = &fisheye_model[x, y, 1]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              __pyx_v_y2 = (&(*((unsigned int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_fisheye_model.data + __pyx_t_15 * __pyx_v_fisheye_model.strides[0]) ) + __pyx_t_14 * __pyx_v_fisheye_model.strides[1]) ) + __pyx_t_13 * __pyx_v_fisheye_model.strides[2]) ))));
 5125: 
+5126:                 rgb_array_[x, y, 0] = rgb_array_copy[x2[0], y2[0], 0]
                              __pyx_t_16 = (__pyx_v_x2[0]);
                              __pyx_t_17 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 0;
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_18 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[2]) )));
+5127:                 rgb_array_[x, y, 1] = rgb_array_copy[x2[0], y2[0], 1]
                              __pyx_t_17 = (__pyx_v_x2[0]);
                              __pyx_t_16 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 1;
                              __pyx_t_18 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_14 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_18 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[2]) )));
+5128:                 rgb_array_[x, y, 2] = rgb_array_copy[x2[0], y2[0], 2]
                              __pyx_t_16 = (__pyx_v_x2[0]);
                              __pyx_t_17 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 2;
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_18 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5129: 
 5130: 
 5131: 
 5132: @cython.boundscheck(False)
 5133: @cython.wraparound(False)
 5134: @cython.nonecheck(False)
 5135: @cython.cdivision(True)
+5136: cdef inline tuple shader_rain_footprint_inplace_c(Py_ssize_t w, Py_ssize_t h):
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_shader_rain_footprint_inplace_c(Py_ssize_t __pyx_v_w, Py_ssize_t __pyx_v_h) {
  __Pyx_memviewslice __pyx_v_rain_fisheye_model = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_y;
  int __pyx_v_x;
  CYTHON_UNUSED int __pyx_v_v;
  float __pyx_v_ny;
  float __pyx_v_ny2;
  float __pyx_v_nx;
  float __pyx_v_nx2;
  float __pyx_v_r;
  float __pyx_v_theta;
  float __pyx_v_nxn;
  float __pyx_v_nyn;
  float __pyx_v_nr;
  int __pyx_v_x2;
  int __pyx_v_y2;
  CYTHON_UNUSED float __pyx_v_s;
  float __pyx_v_c1;
  float __pyx_v_c2;
  float __pyx_v_w2;
  float __pyx_v_h2;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rain_footprint_inplace_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_AddTraceback("PygameShader.shader.shader_rain_footprint_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rain_fisheye_model, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5137:     """
 5138:     CREATE A FISH EYE LENS DEFORMATION MAP/TEXTURE
 5139: 
 5140:     * This function create a texture and its equivalent numpy.ndarray containing the coordinates
 5141:       for each pixels after deformation.
 5142:     * This method must be called once outside of your game main loop
 5143:     * The model can be re-use to display your video game animation without being re-calculated for
 5144:       each frame. This method allow a high fps rate
 5145: 
 5146:     :param w    : integer; Width of the fish eye effect
 5147:     :param h    : integer; height of the fish eye effect
 5148:     :return     : Pygame Surface representing the fish-eye effect and the equivalent numpy.ndarray
 5149:     """
+5150:     assert w > 0, "Argument w must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_w > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_w_must_be_0);
      __PYX_ERR(1, 5150, __pyx_L1_error)
    }
  }
  #endif
+5151:     assert h > 0, "Argument h must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_h > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_h_must_be_0);
      __PYX_ERR(1, 5151, __pyx_L1_error)
    }
  }
  #endif
 5152: 
 5153:     cdef:
+5154:         unsigned int [:, :, ::1] rain_fisheye_model = numpy.zeros((w, h, 3), numpy.uint)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_4);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_int_3);
  __pyx_t_2 = 0;
  __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_uint); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_t_5, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5154, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_t_5, __pyx_t_2};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5154, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_7 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_6, __pyx_t_5);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_6, __pyx_t_2);
    __pyx_t_5 = 0;
    __pyx_t_2 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_7, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_int(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5154, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rain_fisheye_model = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+5155:         int y=0, x=0, v
  __pyx_v_y = 0;
  __pyx_v_x = 0;
 5156:         float ny, ny2, nx, nx2, r, theta, nxn, nyn, nr
 5157:         int x2, y2
+5158:         float s = <float>w * <float>h
  __pyx_v_s = (((float)__pyx_v_w) * ((float)__pyx_v_h));
+5159:         float c1 = <float>2.0 / <float>h
  __pyx_v_c1 = (((float)2.0) / ((float)__pyx_v_h));
+5160:         float c2 = <float>2.0 / <float>w
  __pyx_v_c2 = (((float)2.0) / ((float)__pyx_v_w));
+5161:         float w2 = <float>w * <float>0.5
  __pyx_v_w2 = (((float)__pyx_v_w) * ((float)0.5));
+5162:         float h2 = <float>h * <float>0.5
  __pyx_v_h2 = (((float)__pyx_v_h) * ((float)0.5));
 5163: 
+5164:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+5165:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_9 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_nr) lastprivate(__pyx_v_nx) lastprivate(__pyx_v_nx2) lastprivate(__pyx_v_nxn) lastprivate(__pyx_v_ny) lastprivate(__pyx_v_ny2) lastprivate(__pyx_v_nyn) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static)
/* … */
        __pyx_t_9 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_nr) lastprivate(__pyx_v_nx) lastprivate(__pyx_v_nx2) lastprivate(__pyx_v_nxn) lastprivate(__pyx_v_ny) lastprivate(__pyx_v_ny2) lastprivate(__pyx_v_nyn) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) lastprivate(__pyx_v_v) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_11; __pyx_t_10++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_10);
                            /* Initialize private variables to invalid values */
                            __pyx_v_nr = ((float)__PYX_NAN());
                            __pyx_v_nx = ((float)__PYX_NAN());
                            __pyx_v_nx2 = ((float)__PYX_NAN());
                            __pyx_v_nxn = ((float)__PYX_NAN());
                            __pyx_v_ny = ((float)__PYX_NAN());
                            __pyx_v_ny2 = ((float)__PYX_NAN());
                            __pyx_v_nyn = ((float)__PYX_NAN());
                            __pyx_v_r = ((float)__PYX_NAN());
                            __pyx_v_theta = ((float)__PYX_NAN());
                            __pyx_v_v = ((int)0xbad0bad0);
                            __pyx_v_x2 = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_y2 = ((int)0xbad0bad0);
+5166:             nx = x * c2 - <float>1.0
                            __pyx_v_nx = ((__pyx_v_x * __pyx_v_c2) - ((float)1.0));
+5167:             nx2 = nx * nx
                            __pyx_v_nx2 = (__pyx_v_nx * __pyx_v_nx);
+5168:             for y in range(h):
                            __pyx_t_12 = __pyx_v_h;
                            __pyx_t_13 = __pyx_t_12;
                            for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_13; __pyx_t_6+=1) {
                              __pyx_v_y = __pyx_t_6;
+5169:                 ny = y * c1 - <float>1.0
                              __pyx_v_ny = ((__pyx_v_y * __pyx_v_c1) - ((float)1.0));
+5170:                 ny2 = ny * ny
                              __pyx_v_ny2 = (__pyx_v_ny * __pyx_v_ny);
+5171:                 r = <float>sqrt(nx2 + ny2)
                              __pyx_v_r = ((float)sqrt((__pyx_v_nx2 + __pyx_v_ny2)));
+5172:                 if 0.0 <= r <= 1.0:
                              __pyx_t_14 = (0.0 <= __pyx_v_r);
                              if (__pyx_t_14) {
                                __pyx_t_14 = (__pyx_v_r <= 1.0);
                              }
                              __pyx_t_15 = (__pyx_t_14 != 0);
                              if (__pyx_t_15) {
/* … */
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+5173:                     nr = (r + <float>1.0 - <float>sqrt(1.0 - (nx2 + ny2))) * <float>0.45
                                __pyx_v_nr = (((__pyx_v_r + ((float)1.0)) - ((float)sqrt((1.0 - (__pyx_v_nx2 + __pyx_v_ny2))))) * ((float)0.45));
+5174:                     if nr <= 1.0:
                                __pyx_t_15 = ((__pyx_v_nr <= 1.0) != 0);
                                if (__pyx_t_15) {
/* … */
                                }
+5175:                         theta = <float>atan2(ny, nx)
                                  __pyx_v_theta = ((float)atan2(__pyx_v_ny, __pyx_v_nx));
+5176:                         nxn = nr * <float>cos(theta)
                                  __pyx_v_nxn = (__pyx_v_nr * ((float)cos(__pyx_v_theta)));
+5177:                         nyn = nr * <float>sin(theta)
                                  __pyx_v_nyn = (__pyx_v_nr * ((float)sin(__pyx_v_theta)));
+5178:                         x2 = <int>(nxn * w2 + w2)
                                  __pyx_v_x2 = ((int)((__pyx_v_nxn * __pyx_v_w2) + __pyx_v_w2));
+5179:                         y2 = <int>(nyn * h2 + h2)
                                  __pyx_v_y2 = ((int)((__pyx_v_nyn * __pyx_v_h2) + __pyx_v_h2));
+5180:                         v = <int>(y2 * w + x2)
                                  __pyx_v_v = ((int)((__pyx_v_y2 * __pyx_v_w) + __pyx_v_x2));
+5181:                         rain_fisheye_model[x, y, 0] = x2
                                  __pyx_t_16 = __pyx_v_x;
                                  __pyx_t_17 = __pyx_v_y;
                                  __pyx_t_18 = 0;
                                  *((unsigned int *) ( /* dim=2 */ ((char *) (((unsigned int *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rain_fisheye_model.data + __pyx_t_16 * __pyx_v_rain_fisheye_model.strides[0]) ) + __pyx_t_17 * __pyx_v_rain_fisheye_model.strides[1]) )) + __pyx_t_18)) )) = __pyx_v_x2;
+5182:                         rain_fisheye_model[x, y, 1] = y2
                                  __pyx_t_18 = __pyx_v_x;
                                  __pyx_t_17 = __pyx_v_y;
                                  __pyx_t_16 = 1;
                                  *((unsigned int *) ( /* dim=2 */ ((char *) (((unsigned int *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rain_fisheye_model.data + __pyx_t_18 * __pyx_v_rain_fisheye_model.strides[0]) ) + __pyx_t_17 * __pyx_v_rain_fisheye_model.strides[1]) )) + __pyx_t_16)) )) = __pyx_v_y2;
+5183:                         rain_fisheye_model[x, y, 2] = 0
                                  __pyx_t_16 = __pyx_v_x;
                                  __pyx_t_17 = __pyx_v_y;
                                  __pyx_t_18 = 2;
                                  *((unsigned int *) ( /* dim=2 */ ((char *) (((unsigned int *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rain_fisheye_model.data + __pyx_t_16 * __pyx_v_rain_fisheye_model.strides[0]) ) + __pyx_t_17 * __pyx_v_rain_fisheye_model.strides[1]) )) + __pyx_t_18)) )) = 0;
 5184: 
+5185:     return make_surface(asarray(rain_fisheye_model)), asarray(rain_fisheye_model)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_asarray); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = __pyx_memoryview_fromslice(__pyx_v_rain_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_7 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_t_5) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_5);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_2, __pyx_t_7) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_7);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_asarray); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_rain_fisheye_model, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_7))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_7);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_7, function);
    }
  }
  __pyx_t_3 = (__pyx_t_5) ? __Pyx_PyObject_Call2Args(__pyx_t_7, __pyx_t_5, __pyx_t_2) : __Pyx_PyObject_CallOneArg(__pyx_t_7, __pyx_t_2);
  __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5185, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_3);
  __pyx_t_1 = 0;
  __pyx_t_3 = 0;
  __pyx_r = ((PyObject*)__pyx_t_7);
  __pyx_t_7 = 0;
  goto __pyx_L0;
 5186: 
 5187: 
 5188: @cython.boundscheck(False)
 5189: @cython.wraparound(False)
 5190: @cython.nonecheck(False)
 5191: @cython.cdivision(True)
+5192: cdef inline void shader_rain_fisheye24_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_rain_fisheye24_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, __Pyx_memviewslice __pyx_v_rain_fisheye_model) {
  CYTHON_UNUSED Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned int *__pyx_v_x2;
  unsigned int *__pyx_v_y2;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rain_fisheye24_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_rain_fisheye24_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_RefNannyFinishContext();
}
 5193:         unsigned char [:, :, :] rgb_array_,
 5194:         unsigned int [:, :, ::1] rain_fisheye_model
 5195: ):
 5196:     """
 5197:     THIS SHADER CAN BE USED TO SIMULATE RAIN DROPLET OR BUBBLE DISPLAYED ON THE TOP OF
 5198:     THE SCREEN SURFACE.
 5199: 
 5200:     Both array rgb_array_ and rain_fisheye_model must have the same size
 5201: 
 5202:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 5203:     please refer to pygame
 5204:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 5205: 
 5206:     1) Always call the method shader_rain_footprint_inplace_c before the main loop.
 5207:        The transformation model doesn't have to be calculated every frames.
 5208:        The above method will generate a pygame texture (24bit) containing the location
 5209:        of each pixels after deformation. It does also return a numpy.ndarray equivalent
 5210:        pixel format that can be used instead of the surface if needed.
 5211: 
 5212:     It uses a fish eye lens deformation to reproduce the deformed background image onto
 5213:     the final image. The operation apply inplace and the surface referenced by the rgb_array_
 5214:     will be modified directly.
 5215:     The fish-eye lens deformation will recreate you game scene into the rain droplet or bubble
 5216:     and create the illusion of animation inside the bubble.
 5217: 
 5218:     * This shader cannot be applied directly to the pygame display as the array passed to the
 5219:     function is a scaled format of the pygame.display (copy not referencing directly the
 5220:     surface pixels)
 5221: 
 5222:     * This algorithm use a pre-calculated fish-eye lens deformation model to boost the overall
 5223:     fps performances, the texture pixel is then transformed with the model without any intensive
 5224:     math calculation.
 5225: 
 5226:     :param rgb_array_           : numpy.ndarray type (w, h, 3) uint8 (unsigned char 0...255)
 5227:     Array referencing a
 5228:     pygame surface (compatible with 24bit format only RGB model)
 5229:     :param rain_fisheye_model   : numpy.ndarray type (w, h, 3) unsigned int containing the
 5230:     the coordinate for each pixels
 5231:     :return                     : void
 5232:     """
 5233: 
 5234:     cdef:
 5235:         Py_ssize_t w, h
+5236:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 5237: 
 5238:     cdef:
 5239:         int x, y
+5240:         unsigned char [:, :, ::1] rgb_array_copy = numpy.array(rgb_array_, copy=True, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 5240, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5240, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5240, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 5241:         unsigned int *x2
 5242:         unsigned int *y2
 5243: 
+5244:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+5245:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_y) lastprivate(__pyx_v_y2) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_x2 = ((unsigned int *)1);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_y2 = ((unsigned int *)1);
+5246:             for y in range(h):
                            __pyx_t_10 = __pyx_v_h;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_y = __pyx_t_12;
+5247:                 x2 = &rain_fisheye_model[x, y, 0]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              __pyx_v_x2 = (&(*((unsigned int *) ( /* dim=2 */ ((char *) (((unsigned int *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rain_fisheye_model.data + __pyx_t_13 * __pyx_v_rain_fisheye_model.strides[0]) ) + __pyx_t_14 * __pyx_v_rain_fisheye_model.strides[1]) )) + __pyx_t_15)) ))));
+5248:                 y2 = &rain_fisheye_model[x, y, 1]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              __pyx_v_y2 = (&(*((unsigned int *) ( /* dim=2 */ ((char *) (((unsigned int *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rain_fisheye_model.data + __pyx_t_15 * __pyx_v_rain_fisheye_model.strides[0]) ) + __pyx_t_14 * __pyx_v_rain_fisheye_model.strides[1]) )) + __pyx_t_13)) ))));
 5249: 
+5250:                 rgb_array_[x, y, 0] = rgb_array_copy[x2[0], y2[0], 0]
                              __pyx_t_16 = (__pyx_v_x2[0]);
                              __pyx_t_17 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 0;
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_18 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_13)) )));
+5251:                 rgb_array_[x, y, 1] = rgb_array_copy[x2[0], y2[0], 1]
                              __pyx_t_17 = (__pyx_v_x2[0]);
                              __pyx_t_16 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 1;
                              __pyx_t_18 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_14 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_18 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_13)) )));
+5252:                 rgb_array_[x, y, 2] = rgb_array_copy[x2[0], y2[0], 2]
                              __pyx_t_16 = (__pyx_v_x2[0]);
                              __pyx_t_17 = (__pyx_v_y2[0]);
                              __pyx_t_13 = 2;
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_15 = __pyx_v_y;
                              __pyx_t_18 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_18 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_16 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_copy.strides[1]) )) + __pyx_t_13)) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5253: 
 5254: 
 5255: 
 5256: 
 5257: 
 5258: @cython.boundscheck(False)
 5259: @cython.wraparound(False)
 5260: @cython.nonecheck(False)
 5261: @cython.cdivision(True)
+5262: cdef inline void shader_tv_scanline_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_tv_scanline_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, int __pyx_v_frame_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_j;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  int __pyx_v_frame_2;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_tv_scanline_inplace_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 5263:         unsigned char [:, :, :] rgb_array_,
 5264:         int frame_):
 5265:     """
 5266:     SHADER CREATING A TV SCANLINE EFFECT ON PYGAME SURFACE
 5267: 
 5268:     The space between each scanline can by adjusted with the frame_ value.
 5269:     The scanline intensity/colors is lower that the original pixel value 
 5270:     
 5271:     * This shader can be apply directly to the pygame display as long as rgb_array_ array reference
 5272:     directly the screen pixels
 5273: 
 5274:     The Array (rgb_array) must be a numpy array shape (w, h, 3) containing RGB pixels,
 5275:     please refer to pygame
 5276:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 5277: 
 5278:     :param rgb_array_   : numpy.ndarray shape (w, h, 3) containing RGB pixels
 5279:     :param frame_       : integer; Frame numbre (linear value)
 5280:     :return             : void
 5281:     """
 5282: 
 5283: 
 5284:     cdef:
 5285:         Py_ssize_t w, h
+5286:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 5287: 
 5288:     cdef:
 5289:         int x, y, j
 5290:         unsigned char *r
 5291:         unsigned char *g
 5292:         unsigned char *b
+5293:         int frame_2 = frame_ >> 1
  __pyx_v_frame_2 = (__pyx_v_frame_ >> 1);
 5294: 
+5295:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+5296:         for y in prange(0, h, frame_, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        __pyx_t_4 = __pyx_v_frame_;
        if ((__pyx_t_4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 0 + __pyx_t_4 - __pyx_t_4/abs(__pyx_t_4)) / __pyx_t_4;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)        __pyx_t_4 = __pyx_v_frame_;
        if ((__pyx_t_4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 0 + __pyx_t_4 - __pyx_t_4/abs(__pyx_t_4)) / __pyx_t_4;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_5; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + __pyx_t_4 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_x = ((int)0xbad0bad0);
+5297:             for x in range(w):
                            __pyx_t_6 = __pyx_v_w;
                            __pyx_t_7 = __pyx_t_6;
                            for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) {
                              __pyx_v_x = __pyx_t_8;
+5298:                 for j in range(frame_2):
                              __pyx_t_9 = __pyx_v_frame_2;
                              __pyx_t_10 = __pyx_t_9;
                              for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_10; __pyx_t_11+=1) {
                                __pyx_v_j = __pyx_t_11;
+5299:                     if y + j < h - 1:
                                __pyx_t_12 = (((__pyx_v_y + __pyx_v_j) < (__pyx_v_h - 1)) != 0);
                                if (__pyx_t_12) {
/* … */
                                  goto __pyx_L14;
                                }
+5300:                         r = &rgb_array_[x, y + j, 0]
                                  __pyx_t_13 = __pyx_v_x;
                                  __pyx_t_14 = (__pyx_v_y + __pyx_v_j);
                                  __pyx_t_15 = 0;
                                  __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+5301:                         g = &rgb_array_[x, y + j, 1]
                                  __pyx_t_15 = __pyx_v_x;
                                  __pyx_t_14 = (__pyx_v_y + __pyx_v_j);
                                  __pyx_t_13 = 1;
                                  __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
+5302:                         b = &rgb_array_[x, y + j, 2]
                                  __pyx_t_13 = __pyx_v_x;
                                  __pyx_t_14 = (__pyx_v_y + __pyx_v_j);
                                  __pyx_t_15 = 2;
                                  __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
 5303:                     else:
+5304:                         r = &rgb_array_[x, y, 0]
                                /*else*/ {
                                  __pyx_t_15 = __pyx_v_x;
                                  __pyx_t_14 = __pyx_v_y;
                                  __pyx_t_13 = 0;
                                  __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
+5305:                         g = &rgb_array_[x, y, 1]
                                  __pyx_t_13 = __pyx_v_x;
                                  __pyx_t_14 = __pyx_v_y;
                                  __pyx_t_15 = 1;
                                  __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+5306:                         b = &rgb_array_[x, y, 2]
                                  __pyx_t_15 = __pyx_v_x;
                                  __pyx_t_14 = __pyx_v_y;
                                  __pyx_t_13 = 2;
                                  __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) ))));
                                }
                                __pyx_L14:;
+5307:                     r[0] = <unsigned char> (r[0] * <float>0.65)
                                (__pyx_v_r[0]) = ((unsigned char)((__pyx_v_r[0]) * ((float)0.65)));
+5308:                     g[0] = <unsigned char> (g[0] * <float>0.65)
                                (__pyx_v_g[0]) = ((unsigned char)((__pyx_v_g[0]) * ((float)0.65)));
+5309:                     b[0] = <unsigned char> (b[0] * <float>0.65)
                                (__pyx_v_b[0]) = ((unsigned char)((__pyx_v_b[0]) * ((float)0.65)));
                              }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5310: 
 5311: 
 5312: @cython.binding(False)
 5313: @cython.boundscheck(False)
 5314: @cython.wraparound(False)
 5315: @cython.nonecheck(False)
 5316: @cython.cdivision(True)
+5317: cdef inline void shader_rgb_split_inplace_c(object surface_, int offset_):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_rgb_split_inplace_c(PyObject *__pyx_v_surface_, int __pyx_v_offset_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_z;
  __Pyx_memviewslice __pyx_v_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_red = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_green = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_blue = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rgb_split_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_8);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_XDECREF(__pyx_t_15);
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_rgb_split_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_red, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_green, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_blue, 1);
  __Pyx_RefNannyFinishContext();
}
 5318:     """
 5319:     THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)
 5320:     The transformation apply inplace
 5321: 
 5322:     The original surface will be used and used for the subsurface blit operation.
 5323:     Each channels will be blit sequentially in the following order RGB
 5324:     Note that channel green and blue will be blit with an additional flag BLEND_RGB_ADD, to mix
 5325:     the channel with the lower layers.
 5326: 
 5327:     * FPS BOOST
 5328:     In order to boost the fps frame rate the original surface to process can be downscale x2
 5329:     and rescale after processing.
 5330: 
 5331:     * This shader can be apply directly to the pygame display by passing the screen equ
 5332:     surface to the
 5333:     method. This is true if the surface passed to the method is not a screen copy or a
 5334:     modified/altered
 5335:     surface (e.g downscale / upscale surface)
 5336: 
 5337:     :param surface_ : pygame Surface to process (24bit format)
 5338:     :param offset_  : integer; offset to add to each channels RGB
 5339:     :return         : void
 5340:     """
 5341:     cdef:
 5342:         Py_ssize_t w, h
+5343:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5343, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5343, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 5343, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 5343, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 5343, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_6 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5343, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5343, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 5344: 
 5345:     cdef:
 5346:         int i, j
+5347:         int z = <int>h * <int>w * 3
  __pyx_v_z = ((((int)__pyx_v_h) * ((int)__pyx_v_w)) * 3);
+5348:         unsigned char [:] rgb   = numpy.frombuffer(surface_.get_buffer(), dtype=numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1);
  __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_dtype, __pyx_t_8) < 0) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5348, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_rgb = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5349:         unsigned char [:] red   = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2);
  __pyx_t_8 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5349, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5349, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_red = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5350:         unsigned char [:] green = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_uint8); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
  __pyx_t_8 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5350, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_1, __pyx_t_3); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5350, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_green = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5351:         unsigned char [:] blue  = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_uint8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_1);
  __pyx_t_8 = 0;
  __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5351, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5351, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_blue = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 5352: 
 5353: 
+5354:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L7:;
      }
  }
 5355: 
+5356:         for i in prange(0, w * h * 4, 4,  schedule='static', num_threads=THREADS, chunksize=8):
        __pyx_t_7 = ((__pyx_v_w * __pyx_v_h) * 4);
        if ((4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 4 - 4/abs(4)) / 4;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j)            __pyx_t_11 = 8;
/* … */
        __pyx_t_7 = ((__pyx_v_w * __pyx_v_h) * 4);
        if ((4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 4 - 4/abs(4)) / 4;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static, __pyx_t_11) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_10; __pyx_t_6++){
                        {
                            __pyx_v_i = (int)(0 + 4 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_j = ((int)0xbad0bad0);
+5357:             j = (i >> 2) * 3
                            __pyx_v_j = ((__pyx_v_i >> 2) * 3);
+5358:             red[j]     = rgb[i + 2]
                            __pyx_t_12 = (__pyx_v_i + 2);
                            __pyx_t_13 = __pyx_v_j;
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_red.data + __pyx_t_13 * __pyx_v_red.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
+5359:             green[j+1] = rgb[i + 1]
                            __pyx_t_12 = (__pyx_v_i + 1);
                            __pyx_t_13 = (__pyx_v_j + 1);
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_green.data + __pyx_t_13 * __pyx_v_green.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
+5360:             blue[j+2]  = rgb[i    ]
                            __pyx_t_12 = __pyx_v_i;
                            __pyx_t_13 = (__pyx_v_j + 2);
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_blue.data + __pyx_t_13 * __pyx_v_blue.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5361: 
+5362:     del rgb
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
+5363:     surface_.blit(fromstring(bytes(red), (w, h), 'RGB'), (0, 0))
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_red, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_14 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_4); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_15 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_15)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_15);
  __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5363, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_15);
  PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_t_15);
  __pyx_t_4 = 0;
  __pyx_t_15 = 0;
  __pyx_t_15 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_15 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_15)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_15);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[4] = {__pyx_t_15, __pyx_t_14, __pyx_t_16, __pyx_n_s_RGB};
    __pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0;
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[4] = {__pyx_t_15, __pyx_t_14, __pyx_t_16, __pyx_n_s_RGB};
    __pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0;
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_15) {
      __Pyx_GIVEREF(__pyx_t_15); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_15); __pyx_t_15 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_14);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_11, __pyx_t_14);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_11, __pyx_t_16);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_4, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_14 = 0;
    __pyx_t_16 = 0;
    __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_4, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_2, __pyx_tuple__12};
    __pyx_t_8 = __Pyx_PyFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 2+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_2, __pyx_tuple__12};
    __pyx_t_8 = __Pyx_PyCFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 2+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(2+__pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_11, __pyx_t_2);
    __Pyx_INCREF(__pyx_tuple__12);
    __Pyx_GIVEREF(__pyx_tuple__12);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_11, __pyx_tuple__12);
    __pyx_t_2 = 0;
    __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_4, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
+5364:     surface_.blit(fromstring(bytes(green), (w, h), 'RGB'), (offset_, offset_),
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_green, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_16 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __pyx_t_14 = PyTuple_New(2); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_14, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_16);
  PyTuple_SET_ITEM(__pyx_t_14, 1, __pyx_t_16);
  __pyx_t_2 = 0;
  __pyx_t_16 = 0;
  __pyx_t_16 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_16)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_16);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[4] = {__pyx_t_16, __pyx_t_3, __pyx_t_14, __pyx_n_s_RGB};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5364, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[4] = {__pyx_t_16, __pyx_t_3, __pyx_t_14, __pyx_n_s_RGB};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5364, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  {
    __pyx_t_2 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__pyx_t_16) {
      __Pyx_GIVEREF(__pyx_t_16); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_16); __pyx_t_16 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_11, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_14);
    PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_11, __pyx_t_14);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_2, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_3 = 0;
    __pyx_t_14 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_14 = PyTuple_New(2); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_14, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_14, 1, __pyx_t_2);
  __pyx_t_4 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_14);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_14);
  __pyx_t_1 = 0;
  __pyx_t_14 = 0;
/* … */
  __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_8, __pyx_t_2, __pyx_t_14); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5364, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+5365:                   special_flags=BLEND_RGB_ADD)
  __pyx_t_14 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5365, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5365, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_t_14, __pyx_n_s_special_flags, __pyx_t_1) < 0) __PYX_ERR(1, 5365, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+5366:     surface_.blit(fromstring(bytes(blue), (w, h), 'RGB'), (offset_ << 1, offset_ << 1),
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_8 = __pyx_memoryview_fromslice(__pyx_v_blue, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_4 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_t_3);
  __pyx_t_8 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_t_4, __pyx_t_16, __pyx_n_s_RGB};
    __pyx_t_14 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5366, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_14);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_t_4, __pyx_t_16, __pyx_n_s_RGB};
    __pyx_t_14 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5366, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_14);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  } else
  #endif
  {
    __pyx_t_8 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5366, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_8, 0+__pyx_t_11, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_16);
    PyTuple_SET_ITEM(__pyx_t_8, 1+__pyx_t_11, __pyx_t_16);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_8, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_4 = 0;
    __pyx_t_16 = 0;
    __pyx_t_14 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_8, NULL); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5366, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyInt_From_long((__pyx_v_offset_ << 1)); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_8 = __Pyx_PyInt_From_long((__pyx_v_offset_ << 1)); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_16 = PyTuple_New(2); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_16, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_16, 1, __pyx_t_8);
  __pyx_t_2 = 0;
  __pyx_t_8 = 0;
  __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_14);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_16);
  PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_16);
  __pyx_t_14 = 0;
  __pyx_t_16 = 0;
/* … */
  __pyx_t_14 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_8, __pyx_t_16); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5366, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
+5367:                   special_flags=BLEND_RGB_ADD)
  __pyx_t_16 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5367, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  if (PyDict_SetItem(__pyx_t_16, __pyx_n_s_special_flags, __pyx_t_14) < 0) __PYX_ERR(1, 5367, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
 5368: 
 5369: 
 5370: 
 5371: @cython.binding(False)
 5372: @cython.boundscheck(False)
 5373: @cython.wraparound(False)
 5374: @cython.nonecheck(False)
 5375: @cython.cdivision(True)
+5376: cdef shader_rgb_split_c(object surface_, int offset_):
static PyObject *__pyx_f_12PygameShader_6shader_shader_rgb_split_c(PyObject *__pyx_v_surface_, int __pyx_v_offset_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_i;
  int __pyx_v_j;
  int __pyx_v_z;
  __Pyx_memviewslice __pyx_v_rgb = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_red = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_green = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_blue = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_v_new_surface = NULL;
  PyObject *__pyx_v_red_ = NULL;
  PyObject *__pyx_v_green_ = NULL;
  PyObject *__pyx_v_blue_ = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_rgb_split_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_8);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_AddTraceback("PygameShader.shader.shader_rgb_split_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_red, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_green, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_blue, 1);
  __Pyx_XDECREF(__pyx_v_new_surface);
  __Pyx_XDECREF(__pyx_v_red_);
  __Pyx_XDECREF(__pyx_v_green_);
  __Pyx_XDECREF(__pyx_v_blue_);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5377:     """
 5378:     THIS SHADER CREATE AN RGB SPLIT EFFECT (SUPERPOSED CHANNEL R, G, B WITH GIVEN OFFSET)
 5379: 
 5380:     The final image has a different width and height since the offset value is removed to keep only 
 5381:     the overlapping R, G, B channels 
 5382:     Setting the Offset_ to zero will have no effect to the original image.
 5383: 
 5384:     :param surface_ : pygame Surface to process (24bit format)
 5385:     :param offset_  : integer; offset to add to each channels RGB
 5386:     :return         : void
 5387:     """
 5388: 
 5389:     cdef:
 5390:         Py_ssize_t w, h
+5391:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5391, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5391, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 5391, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 5391, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 5391, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_6 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5391, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyIndex_AsSsize_t(__pyx_t_3); if (unlikely((__pyx_t_7 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5391, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 5392: 
 5393:     cdef:
 5394:         int i, j
+5395:         int z = <int>h * <int>w * 3
  __pyx_v_z = ((((int)__pyx_v_h) * ((int)__pyx_v_w)) * 3);
+5396:         unsigned char [:] rgb   = numpy.frombuffer(surface_.get_buffer(), dtype=numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1);
  __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_uint8); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_dtype, __pyx_t_8) < 0) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5396, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_rgb = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5397:         unsigned char [:] red   = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_2);
  __pyx_t_8 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5397, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5397, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_red = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5398:         unsigned char [:] green = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_uint8); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
  __pyx_t_8 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5398, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_1, __pyx_t_3); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5398, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_green = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
+5399:         unsigned char [:] blue  = numpy.zeros(z, uint8, order='C')
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_numpy); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_n_s_zeros); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_z); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_uint8); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_8);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_1);
  __pyx_t_8 = 0;
  __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 5399, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_ds_unsigned_char(__pyx_t_8, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5399, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_blue = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 5400: 
 5401:     # Create a new surface (sizes - offset)
+5402:     new_surface = Surface((w-offset_, h-offset_))
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_Surface); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = PyInt_FromSsize_t((__pyx_v_w - __pyx_v_offset_)); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyInt_FromSsize_t((__pyx_v_h - __pyx_v_offset_)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_8 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_3, __pyx_t_4) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_4);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5402, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_new_surface = __pyx_t_8;
  __pyx_t_8 = 0;
+5403:     new_surface.convert()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_new_surface, __pyx_n_s_convert); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5403, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_8 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5403, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
 5404: 
+5405:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L7:;
      }
  }
 5406: 
+5407:         for i in prange(0, w * h * 4, 4,  schedule='static', num_threads=THREADS, chunksize=8):
        __pyx_t_7 = ((__pyx_v_w * __pyx_v_h) * 4);
        if ((4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 4 - 4/abs(4)) / 4;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j)            __pyx_t_11 = 8;
/* … */
        __pyx_t_7 = ((__pyx_v_w * __pyx_v_h) * 4);
        if ((4 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_7 - 0 + 4 - 4/abs(4)) / 4;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static, __pyx_t_11) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_10; __pyx_t_6++){
                        {
                            __pyx_v_i = (int)(0 + 4 * __pyx_t_6);
                            /* Initialize private variables to invalid values */
                            __pyx_v_j = ((int)0xbad0bad0);
+5408:             j = (i >> 2) * 3
                            __pyx_v_j = ((__pyx_v_i >> 2) * 3);
+5409:             red[j]     = rgb[i + 2]
                            __pyx_t_12 = (__pyx_v_i + 2);
                            __pyx_t_13 = __pyx_v_j;
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_red.data + __pyx_t_13 * __pyx_v_red.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
+5410:             green[j+1] = rgb[i + 1]
                            __pyx_t_12 = (__pyx_v_i + 1);
                            __pyx_t_13 = (__pyx_v_j + 1);
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_green.data + __pyx_t_13 * __pyx_v_green.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
+5411:             blue[j+2]  = rgb[i    ]
                            __pyx_t_12 = __pyx_v_i;
                            __pyx_t_13 = (__pyx_v_j + 2);
                            *((unsigned char *) ( /* dim=0 */ (__pyx_v_blue.data + __pyx_t_13 * __pyx_v_blue.strides[0]) )) = (*((unsigned char *) ( /* dim=0 */ (__pyx_v_rgb.data + __pyx_t_12 * __pyx_v_rgb.strides[0]) )));
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5412: 
+5413:     del rgb
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb, 1);
 5414: 
+5415:     red_ = fromstring(bytes(red), (w, h), 'RGB')
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_red, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_14 = PyTuple_New(2); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5415, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_14, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_14, 1, __pyx_t_2);
  __pyx_t_4 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_2, __pyx_t_3, __pyx_t_14, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5415, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_2, __pyx_t_3, __pyx_t_14, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyCFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5415, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5415, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_2) {
      __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2); __pyx_t_2 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_11, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_14);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_11, __pyx_t_14);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_4, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_3 = 0;
    __pyx_t_14 = 0;
    __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_4, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5415, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_red_ = __pyx_t_8;
  __pyx_t_8 = 0;
+5416:     green_ = fromstring(bytes(green), (w, h), 'RGB')
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_green, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_14 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_4); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_3);
  __pyx_t_4 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_t_14, __pyx_t_2, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5416, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_3, __pyx_t_14, __pyx_t_2, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyCFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5416, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5416, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_14);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_11, __pyx_t_14);
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_11, __pyx_t_2);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_4, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_14 = 0;
    __pyx_t_2 = 0;
    __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_4, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5416, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_green_ = __pyx_t_8;
  __pyx_t_8 = 0;
+5417:     blue_ = fromstring(bytes(blue), (w, h), 'RGB')
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_fromstring); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_blue, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyBytes_Type)), __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_14 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_14);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_14);
  __pyx_t_4 = 0;
  __pyx_t_14 = 0;
  __pyx_t_14 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_14 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_14)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_14);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_14, __pyx_t_2, __pyx_t_3, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5417, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_1)) {
    PyObject *__pyx_temp[4] = {__pyx_t_14, __pyx_t_2, __pyx_t_3, __pyx_n_s_RGB};
    __pyx_t_8 = __Pyx_PyCFunction_FastCall(__pyx_t_1, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5417, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5417, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_14) {
      __Pyx_GIVEREF(__pyx_t_14); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_14); __pyx_t_14 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_11, __pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_11, __pyx_t_3);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_4, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_2 = 0;
    __pyx_t_3 = 0;
    __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_4, NULL); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5417, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_blue_ = __pyx_t_8;
  __pyx_t_8 = 0;
 5418: 
+5419:     new_surface.blit(red_, (-offset_, -offset_), special_flags=BLEND_RGB_ADD)
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_new_surface, __pyx_n_s_blit); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_1 = __Pyx_PyInt_From_int((-__pyx_v_offset_)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyInt_From_int((-__pyx_v_offset_)); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_4);
  __pyx_t_1 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_INCREF(__pyx_v_red_);
  __Pyx_GIVEREF(__pyx_v_red_);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_red_);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
  __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_special_flags, __pyx_t_1) < 0) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_8, __pyx_t_4, __pyx_t_3); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5419, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+5420:     new_surface.blit(green_, (0, 0), special_flags=BLEND_RGB_ADD)
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_new_surface, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_v_green_);
  __Pyx_GIVEREF(__pyx_v_green_);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_green_);
  __Pyx_INCREF(__pyx_tuple__12);
  __Pyx_GIVEREF(__pyx_tuple__12);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_tuple__12);
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_special_flags, __pyx_t_8) < 0) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_8 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5420, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
+5421:     new_surface.blit(blue_, (offset_, offset_), special_flags=BLEND_RGB_ADD)
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_new_surface, __pyx_n_s_blit); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_offset_); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_3);
  __pyx_t_4 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_v_blue_);
  __Pyx_GIVEREF(__pyx_v_blue_);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_blue_);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_1);
  __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_BLEND_RGB_ADD); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_special_flags, __pyx_t_4) < 0) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_8, __pyx_t_3, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5421, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
+5422:     return new_surface
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_new_surface);
  __pyx_r = __pyx_v_new_surface;
  goto __pyx_L0;
 5423: 
 5424: 
+5425: cpdef inline void putmask_c(
static PyObject *__pyx_pw_12PygameShader_6shader_137putmask_c(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_putmask_c(__Pyx_memviewslice __pyx_v_array_, CYTHON_UNUSED Py_ssize_t __pyx_v_rows_, Py_ssize_t __pyx_v_cols_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_putmask_c *__pyx_optional_args) {
  int __pyx_v_i;
  int __pyx_v_j;
  int *__pyx_v_r;
  int *__pyx_v_g;
  int *__pyx_v_b;
  if (__pyx_optional_args) {
  }
/* … */
  /* function exit code */
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_137putmask_c(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_136putmask_c[] = "\n    EQUIVALENT METHOD TO numpy.putmask BUT MUCH FASTER FOR OPERATION WITH OPERAND < V_\n\n    * Cython cpdef function, this function can be called directly and do not require a\n      hook function.\n\n    numpy.putmask(array_, array_<0, 0) --> putmask_c(array_, w, h, 0)\n\n    :param array_   : numpy.ndarray shape (w, h, 3) of integer\n    :param rows_    : integer;\n    :param cols_    : integer;\n    :param v_       : Value for filter < v_\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_137putmask_c(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  __Pyx_memviewslice __pyx_v_array_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  Py_ssize_t __pyx_v_rows_;
  Py_ssize_t __pyx_v_cols_;
  int __pyx_v_v_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("putmask_c (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_array,&__pyx_n_s_rows,&__pyx_n_s_cols,&__pyx_n_s_v,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_array)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rows)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("putmask_c", 0, 3, 4, 1); __PYX_ERR(1, 5425, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_cols)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("putmask_c", 0, 3, 4, 2); __PYX_ERR(1, 5425, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_v);
          if (value) { values[3] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "putmask_c") < 0)) __PYX_ERR(1, 5425, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_array_ = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_int(values[0], PyBUF_WRITABLE); if (unlikely(!__pyx_v_array_.memview)) __PYX_ERR(1, 5426, __pyx_L3_error)
    __pyx_v_rows_ = __Pyx_PyIndex_AsSsize_t(values[1]); if (unlikely((__pyx_v_rows_ == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5426, __pyx_L3_error)
    __pyx_v_cols_ = __Pyx_PyIndex_AsSsize_t(values[2]); if (unlikely((__pyx_v_cols_ == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5426, __pyx_L3_error)
    if (values[3]) {
      __pyx_v_v_ = __Pyx_PyInt_As_int(values[3]); if (unlikely((__pyx_v_v_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5426, __pyx_L3_error)
    } else {
      __pyx_v_v_ = ((int)0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("putmask_c", 0, 3, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5425, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.putmask_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_136putmask_c(__pyx_self, __pyx_v_array_, __pyx_v_rows_, __pyx_v_cols_, __pyx_v_v_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_136putmask_c(CYTHON_UNUSED PyObject *__pyx_self, __Pyx_memviewslice __pyx_v_array_, Py_ssize_t __pyx_v_rows_, Py_ssize_t __pyx_v_cols_, int __pyx_v_v_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("putmask_c", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_array_.memview)) { __Pyx_RaiseUnboundLocalError("array_"); __PYX_ERR(1, 5425, __pyx_L1_error) }
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.v_ = __pyx_v_v_;
  __pyx_f_12PygameShader_6shader_putmask_c(__pyx_v_array_, __pyx_v_rows_, __pyx_v_cols_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5425, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.putmask_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_array_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_putmask_c {
  int __pyx_n;
  int v_;
};
 5426:         int [:, :, :] array_, Py_ssize_t rows_, Py_ssize_t cols_, int v_=0)nogil:
 5427:     """
 5428:     EQUIVALENT METHOD TO numpy.putmask BUT MUCH FASTER FOR OPERATION WITH OPERAND < V_
 5429: 
 5430:     * Cython cpdef function, this function can be called directly and do not require a
 5431:       hook function.
 5432: 
 5433:     numpy.putmask(array_, array_<0, 0) --> putmask_c(array_, w, h, 0)
 5434: 
 5435:     :param array_   : numpy.ndarray shape (w, h, 3) of integer
 5436:     :param rows_    : integer;
 5437:     :param cols_    : integer;
 5438:     :param v_       : Value for filter < v_
 5439:     :return         : void
 5440:     """
 5441:     cdef:
 5442:         int i, j
 5443:         int *r
 5444:         int *g
 5445:         int *b
 5446: 
+5447:     for i in prange(0, rows_, schedule='static', num_threads=THREADS):
  __pyx_t_1 = __pyx_v_rows_;
  if ((1 == 0)) abort();
  {
      #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
          #undef likely
          #undef unlikely
          #define likely(x)   (x)
          #define unlikely(x) (x)
      #endif
      __pyx_t_3 = (__pyx_t_1 - 0 + 1 - 1/abs(1)) / 1;
      if (__pyx_t_3 > 0)
      {
          #ifdef _OPENMP
          #pragma omp parallel
          #endif /* _OPENMP */
          {
              #ifdef _OPENMP
              #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static)
/* … */
  __pyx_t_1 = __pyx_v_rows_;
  if ((1 == 0)) abort();
  {
      #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
          #undef likely
          #undef unlikely
          #define likely(x)   (x)
          #define unlikely(x) (x)
      #endif
      __pyx_t_3 = (__pyx_t_1 - 0 + 1 - 1/abs(1)) / 1;
      if (__pyx_t_3 > 0)
      {
          #ifdef _OPENMP
          #pragma omp parallel
          #endif /* _OPENMP */
          {
              #ifdef _OPENMP
              #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
              #endif /* _OPENMP */
              for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_3; __pyx_t_2++){
                  {
                      __pyx_v_i = (int)(0 + 1 * __pyx_t_2);
                      /* Initialize private variables to invalid values */
                      __pyx_v_b = ((int *)1);
                      __pyx_v_g = ((int *)1);
                      __pyx_v_j = ((int)0xbad0bad0);
                      __pyx_v_r = ((int *)1);
+5448:         for j in range(0, cols_):
                      __pyx_t_4 = __pyx_v_cols_;
                      __pyx_t_5 = __pyx_t_4;
                      for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) {
                        __pyx_v_j = __pyx_t_6;
+5449:             r = &array_[i, j, 0]
                        __pyx_t_7 = __pyx_v_i;
                        __pyx_t_8 = __pyx_v_j;
                        __pyx_t_9 = 0;
                        __pyx_v_r = (&(*((int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array_.data + __pyx_t_7 * __pyx_v_array_.strides[0]) ) + __pyx_t_8 * __pyx_v_array_.strides[1]) ) + __pyx_t_9 * __pyx_v_array_.strides[2]) ))));
+5450:             g = &array_[i, j, 1]
                        __pyx_t_9 = __pyx_v_i;
                        __pyx_t_8 = __pyx_v_j;
                        __pyx_t_7 = 1;
                        __pyx_v_g = (&(*((int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array_.data + __pyx_t_9 * __pyx_v_array_.strides[0]) ) + __pyx_t_8 * __pyx_v_array_.strides[1]) ) + __pyx_t_7 * __pyx_v_array_.strides[2]) ))));
+5451:             b = &array_[i, j, 2]
                        __pyx_t_7 = __pyx_v_i;
                        __pyx_t_8 = __pyx_v_j;
                        __pyx_t_9 = 2;
                        __pyx_v_b = (&(*((int *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array_.data + __pyx_t_7 * __pyx_v_array_.strides[0]) ) + __pyx_t_8 * __pyx_v_array_.strides[1]) ) + __pyx_t_9 * __pyx_v_array_.strides[2]) ))));
+5452:             if r[0] < 0:
                        __pyx_t_10 = (((__pyx_v_r[0]) < 0) != 0);
                        if (__pyx_t_10) {
/* … */
                        }
                      }
                  }
              }
          }
      }
  }
  #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
      #undef likely
      #undef unlikely
      #define likely(x)   __builtin_expect(!!(x), 1)
      #define unlikely(x) __builtin_expect(!!(x), 0)
  #endif
+5453:                 r[0] = 0
                          (__pyx_v_r[0]) = 0;
+5454:                 g[0] = 0
                          (__pyx_v_g[0]) = 0;
+5455:                 b[0] = 0
                          (__pyx_v_b[0]) = 0;
 5456: 
 5457:             # if r[0] > 255:
 5458:             #     r[0] = 255
 5459:             # if g[0] > 255:
 5460:             #     g[0] = 255
 5461:             # if b[0] > 255:
 5462:             #     b[0] = 255
 5463: 
 5464: 
 5465: 
 5466: @cython.binding(False)
 5467: @cython.boundscheck(False)
 5468: @cython.wraparound(False)
 5469: @cython.nonecheck(False)
 5470: @cython.cdivision(True)
+5471: cdef inline tuple shader_ripple_c(
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_shader_ripple_c(CYTHON_UNUSED Py_ssize_t __pyx_v_rows_, CYTHON_UNUSED Py_ssize_t __pyx_v_cols_, __Pyx_memviewslice __pyx_v_previous, __Pyx_memviewslice __pyx_v_current, __Pyx_memviewslice __pyx_v_array) {
  int __pyx_v_i;
  int __pyx_v_j;
  float __pyx_v_data;
  float *__pyx_v_c;
  float *__pyx_v_d;
  unsigned char *__pyx_v_e;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_ripple_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_XDECREF(__pyx_t_17);
  __Pyx_XDECREF(__pyx_t_18);
  __Pyx_XDECREF(__pyx_t_19);
  __Pyx_AddTraceback("PygameShader.shader.shader_ripple_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5472:        Py_ssize_t rows_, Py_ssize_t cols_,
 5473:        float [:, ::1] previous,
 5474:        float [:, ::1] current,
 5475:        unsigned char [:, :, ::1] array,
 5476:        ):
 5477:     """
 5478:     THIS SHADER CREATE A WATER EFFECT ON A PYGAME SURFACE
 5479:     This version does not include any background deformation to keep a reasonable fps rate
 5480: 
 5481:     * GLOBAL VARIABLE CONSIDERATION
 5482:     Set 3 arrays as global numpy arrays (not in the main loop, these arrays does not have
 5483:     to be created every frames).
 5484: 
 5485:     current = numpy.zeros((width, height), dtype=numpy.float32)
 5486:     previous = numpy.zeros((width, height), dtype=numpy.float32)
 5487:     array = numpy.full((width, height, 3), 0, numpy.uint8)
 5488: 
 5489:     * ADD A WATER DROP
 5490:     To add a water drop to the display just add an integer value to the array previous such as
 5491:     previous[random.randint(0, width - 1), random.randint(0, height - 1)] = 1024
 5492:     with width and height matching the size of the array (width, height = previous.get_size())
 5493: 
 5494:     * PROCESSING TIME
 5495:     Then update the transformation. The function below will start the blurring process
 5496:     (flattening the
 5497:     values across the array to absorb the drop energy ; 1024 in the example above.
 5498:     Finally the arrays are swapped : current become previous and previous become current
 5499:     Note that:
 5500:     1) w & h must match the array size
 5501:     2) previous & current & array must be identical sizes otherwise an error will be thrown
 5502: 
 5503:     previous, current, array = shader_ripple_c(w, h, previous, current, array)
 5504: 
 5505:     * CREATING THE SURFACE
 5506:     The array is then transformed into a numpy.ndarray of type uint8 (unsigned char 0..255)
 5507:     The pygame make_surface method will convert the array type (w, h, 3) into a surface that can
 5508:     be blit to the active display.
 5509:     surf = make_surface(asarray(array, dtype=uint8))
 5510: 
 5511:     * BLIT
 5512: 
 5513:     The newly surface containing the drops can then be added to the current background or
 5514:     display (blit process).
 5515:     Both surface should have the same size for a more realistic effect
 5516:     The special_flag here is BLEND_RGBA_ADD but can be set to a different value to achieve the
 5517:     special effect needed (BLEND_RGB_MULT, BLEND_RGB_SUB) etc.
 5518:     Refer to blending modes to understand the math operation behind the flags
 5519: 
 5520:     surface_.blit(surf, (0, 0), special_flags=pygame.BLEND_RGBA_ADD)
 5521: 
 5522:     * BOOSTING THE FPS
 5523:     In order to boost the processing time, I downscale the surface prior processing and
 5524:     upscale it x2 when
 5525:     the process is done, this method provide an additional overall performance.
 5526: 
 5527:     * NOTE this shader cannot be apply to the screen directly (screen referencing
 5528:     pygame.display.get_surface()),
 5529: 
 5530: 
 5531:     :param rows_        : integer; Array width
 5532:     :param cols_        : integer; Array height
 5533:     :param previous     : numpy.ndarray type (w, h) type float; array use for the transformation
 5534:     :param current      : numpy.ndarray type (w, h) type float; array use for the transformation
 5535:     :param array        : numpy.ndarray type (w, h, 3) type unsigned char
 5536:     :return             : Return a tuple containing 3 arrays
 5537:     """
 5538: 
 5539:     cdef:
 5540:         int i, j, a, b
 5541:         float data
 5542:         float *c
 5543:         float *d
 5544:         unsigned char *e
 5545:         float r
 5546: 
+5547:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 5548: 
+5549:         for i in prange(1, rows_ - 1, schedule='static', num_threads=THREADS):
        __pyx_t_1 = (__pyx_v_rows_ - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_3 = (__pyx_t_1 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_3 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c) lastprivate(__pyx_v_d) lastprivate(__pyx_v_data) lastprivate(__pyx_v_e) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static)
/* … */
        __pyx_t_1 = (__pyx_v_rows_ - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_3 = (__pyx_t_1 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_3 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c) lastprivate(__pyx_v_d) lastprivate(__pyx_v_data) lastprivate(__pyx_v_e) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_3; __pyx_t_2++){
                        {
                            __pyx_v_i = (int)(1 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_c = ((float *)1);
                            __pyx_v_d = ((float *)1);
                            __pyx_v_data = ((float)__PYX_NAN());
                            __pyx_v_e = ((unsigned char *)1);
                            __pyx_v_j = ((int)0xbad0bad0);
+5550:             for j in prange(1, cols_ - 1, schedule='static', num_threads=THREADS):
                            __pyx_t_4 = (__pyx_v_cols_ - 1);
                            if ((1 == 0)) abort();
                            {
                                __pyx_t_6 = (__pyx_t_4 - 1 + 1 - 1/abs(1)) / 1;
                                if (__pyx_t_6 > 0)
                                {
                                    #if 0
                                    #pragma omp parallel
                                    #endif /* _OPENMP */
                                    {
                                        #if 0
                                        #pragma omp for lastprivate(__pyx_v_c) lastprivate(__pyx_v_d) lastprivate(__pyx_v_data) lastprivate(__pyx_v_e) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) schedule(static)
/* … */
                            __pyx_t_4 = (__pyx_v_cols_ - 1);
                            if ((1 == 0)) abort();
                            {
                                __pyx_t_6 = (__pyx_t_4 - 1 + 1 - 1/abs(1)) / 1;
                                if (__pyx_t_6 > 0)
                                {
                                    #if 0
                                    #pragma omp parallel
                                    #endif /* _OPENMP */
                                    {
                                        #if 0
                                        #pragma omp for lastprivate(__pyx_v_c) lastprivate(__pyx_v_d) lastprivate(__pyx_v_data) lastprivate(__pyx_v_e) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                                        #endif /* _OPENMP */
                                        for (__pyx_t_5 = 0; __pyx_t_5 < __pyx_t_6; __pyx_t_5++){
                                            {
                                                __pyx_v_j = (int)(1 + 1 * __pyx_t_5);
                                                /* Initialize private variables to invalid values */
                                                __pyx_v_c = ((float *)1);
                                                __pyx_v_d = ((float *)1);
                                                __pyx_v_data = ((float)__PYX_NAN());
                                                __pyx_v_e = ((unsigned char *)1);
 5551: 
 5552:                 # data = <int>(previous[i + 1, j] + previous[i - 1, j] +
 5553:                 #         previous[i, j - 1] + previous[i, j + 1])  >> 1
 5554: 
+5555:                 data = (previous[i + 1, j] + previous[i - 1, j] +
                                                __pyx_t_7 = (__pyx_v_i + 1);
                                                __pyx_t_8 = __pyx_v_j;
                                                __pyx_t_9 = (__pyx_v_i - 1);
                                                __pyx_t_10 = __pyx_v_j;
+5556:                               previous[i, j - 1] + previous[i, j + 1]) * <float>0.5
                                                __pyx_t_11 = __pyx_v_i;
                                                __pyx_t_12 = (__pyx_v_j - 1);
/* … */
                                                __pyx_t_13 = __pyx_v_i;
                                                __pyx_t_14 = (__pyx_v_j + 1);
/* … */
                                                __pyx_v_data = (((((*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_previous.data + __pyx_t_7 * __pyx_v_previous.strides[0]) )) + __pyx_t_8)) ))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_previous.data + __pyx_t_9 * __pyx_v_previous.strides[0]) )) + __pyx_t_10)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_previous.data + __pyx_t_11 * __pyx_v_previous.strides[0]) )) + __pyx_t_12)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_previous.data + __pyx_t_13 * __pyx_v_previous.strides[0]) )) + __pyx_t_14)) )))) * ((float)0.5));
+5557:                 c = &current[i, j]
                                                __pyx_t_14 = __pyx_v_i;
                                                __pyx_t_13 = __pyx_v_j;
                                                __pyx_v_c = (&(*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_current.data + __pyx_t_14 * __pyx_v_current.strides[0]) )) + __pyx_t_13)) ))));
+5558:                 data = data - <float>c[0]
                                                __pyx_v_data = (__pyx_v_data - ((float)(__pyx_v_c[0])));
+5559:                 data = data - (data * <float>0.011)
                                                __pyx_v_data = (__pyx_v_data - (__pyx_v_data * ((float)0.011)));
+5560:                 c[0] = data
                                                (__pyx_v_c[0]) = __pyx_v_data;
+5561:                 d = &previous[i,j]
                                                __pyx_t_13 = __pyx_v_i;
                                                __pyx_t_14 = __pyx_v_j;
                                                __pyx_v_d = (&(*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_previous.data + __pyx_t_13 * __pyx_v_previous.strides[0]) )) + __pyx_t_14)) ))));
+5562:                 e = &array[i, j, 0]
                                                __pyx_t_14 = __pyx_v_i;
                                                __pyx_t_13 = __pyx_v_j;
                                                __pyx_t_12 = 0;
                                                __pyx_v_e = (&(*((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array.data + __pyx_t_14 * __pyx_v_array.strides[0]) ) + __pyx_t_13 * __pyx_v_array.strides[1]) )) + __pyx_t_12)) ))));
+5563:                 e[0] = <unsigned char> d[0] if d[0] > 0 else 0
                                                if ((((__pyx_v_d[0]) > 0.0) != 0)) {
                                                  __pyx_t_15 = ((unsigned char)(__pyx_v_d[0]));
                                                } else {
                                                  __pyx_t_15 = 0;
                                                }
                                                (__pyx_v_e[0]) = __pyx_t_15;
+5564:                 array[i, j, 1] = e[0]
                                                __pyx_t_12 = __pyx_v_i;
                                                __pyx_t_13 = __pyx_v_j;
                                                __pyx_t_14 = 1;
                                                *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array.data + __pyx_t_12 * __pyx_v_array.strides[0]) ) + __pyx_t_13 * __pyx_v_array.strides[1]) )) + __pyx_t_14)) )) = (__pyx_v_e[0]);
+5565:                 array[i, j, 2] = e[0]
                                                __pyx_t_14 = __pyx_v_i;
                                                __pyx_t_13 = __pyx_v_j;
                                                __pyx_t_12 = 2;
                                                *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_array.data + __pyx_t_14 * __pyx_v_array.strides[0]) ) + __pyx_t_13 * __pyx_v_array.strides[1]) )) + __pyx_t_12)) )) = (__pyx_v_e[0]);
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5566: 
+5567:     return current, previous, array
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_16 = __pyx_memoryview_fromslice(__pyx_v_current, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 5567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __pyx_t_17 = __pyx_memoryview_fromslice(__pyx_v_previous, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 5567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_17);
  __pyx_t_18 = __pyx_memoryview_fromslice(__pyx_v_array, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_18)) __PYX_ERR(1, 5567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_18);
  __pyx_t_19 = PyTuple_New(3); if (unlikely(!__pyx_t_19)) __PYX_ERR(1, 5567, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_19);
  __Pyx_GIVEREF(__pyx_t_16);
  PyTuple_SET_ITEM(__pyx_t_19, 0, __pyx_t_16);
  __Pyx_GIVEREF(__pyx_t_17);
  PyTuple_SET_ITEM(__pyx_t_19, 1, __pyx_t_17);
  __Pyx_GIVEREF(__pyx_t_18);
  PyTuple_SET_ITEM(__pyx_t_19, 2, __pyx_t_18);
  __pyx_t_16 = 0;
  __pyx_t_17 = 0;
  __pyx_t_18 = 0;
  __pyx_r = ((PyObject*)__pyx_t_19);
  __pyx_t_19 = 0;
  goto __pyx_L0;
 5568: 
 5569: 
 5570: 
 5571: @cython.binding(False)
 5572: @cython.boundscheck(False)
 5573: @cython.wraparound(False)
 5574: @cython.nonecheck(False)
 5575: @cython.cdivision(False)
+5576: cpdef tunnel_modeling32(Py_ssize_t screen_width, Py_ssize_t screen_height):
static PyObject *__pyx_pw_12PygameShader_6shader_139tunnel_modeling32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_tunnel_modeling32(Py_ssize_t __pyx_v_screen_width, Py_ssize_t __pyx_v_screen_height, CYTHON_UNUSED int __pyx_skip_dispatch) {
  __Pyx_memviewslice __pyx_v_distances = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_angles = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_shades = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_v_surface = NULL;
  int __pyx_v_s_width;
  int __pyx_v_s_height;
  __Pyx_memviewslice __pyx_v_scr_data = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_i;
  double __pyx_v_sqy;
  double __pyx_v_sqx;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_modeling32", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_9, 1);
  __Pyx_AddTraceback("PygameShader.shader.tunnel_modeling32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_distances, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_angles, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_shades, 1);
  __Pyx_XDECREF(__pyx_v_surface);
  __PYX_XDEC_MEMVIEW(&__pyx_v_scr_data, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_139tunnel_modeling32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_138tunnel_modeling32[] = "\n    THIS METHOD CREATE A TUNNEL MODEL\n\n    * This method must be called before rendering the tunnel in order to create\n      all the necessary buffers that will be called during the rendering of the tunnel effect.\n      tunnel_modeling32 must be call once only before the main loop of your game.\n\n    * Cython cpdef function, this function can be called directly and do not require a\n      hook function.\n\n    * The default tunnel texture is internally loaded (the texture is 256x256 pixels 24-bit)\n      check the line :\n      surface = pygame.image.load(\"Assets\\Graphics\\Background\\space1.jpg\").convert()\n\n    * This algorithm uses a 256x256 texture but reshape it to 512x512 pixels for a\n    better effect definition\n\n    :param screen_width     : integer; Game display size (width in pixels)\n    :param screen_height    : integer; Game display size (height in pixels)\n    :return                 : return a tuple containing the following (distances, angles,\n    shades, scr_data)\n    distances is a numpy.ndarray buffer containing float values representing the distance\n    of each pixels\n    angles is a numpy.ndarray buffer containing float values representing the angle of each pixels\n    shades is a numpy.ndarray buffer containing float values representing the shade of each pixels\n    scr_data is a numpy.ndarray buffer containing uint8 values representing the BGR (not RGB)\n    values of each pixels\n\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_139tunnel_modeling32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  Py_ssize_t __pyx_v_screen_width;
  Py_ssize_t __pyx_v_screen_height;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_modeling32 (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_screen_width,&__pyx_n_s_screen_height,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_width)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_height)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_modeling32", 1, 2, 2, 1); __PYX_ERR(1, 5576, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "tunnel_modeling32") < 0)) __PYX_ERR(1, 5576, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
    }
    __pyx_v_screen_width = __Pyx_PyIndex_AsSsize_t(values[0]); if (unlikely((__pyx_v_screen_width == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5576, __pyx_L3_error)
    __pyx_v_screen_height = __Pyx_PyIndex_AsSsize_t(values[1]); if (unlikely((__pyx_v_screen_height == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5576, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("tunnel_modeling32", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5576, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.tunnel_modeling32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_138tunnel_modeling32(__pyx_self, __pyx_v_screen_width, __pyx_v_screen_height);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_138tunnel_modeling32(CYTHON_UNUSED PyObject *__pyx_self, Py_ssize_t __pyx_v_screen_width, Py_ssize_t __pyx_v_screen_height) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_modeling32", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_tunnel_modeling32(__pyx_v_screen_width, __pyx_v_screen_height, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5576, __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("PygameShader.shader.tunnel_modeling32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5577:     """
 5578:     THIS METHOD CREATE A TUNNEL MODEL
 5579: 
 5580:     * This method must be called before rendering the tunnel in order to create
 5581:       all the necessary buffers that will be called during the rendering of the tunnel effect.
 5582:       tunnel_modeling32 must be call once only before the main loop of your game.
 5583: 
 5584:     * Cython cpdef function, this function can be called directly and do not require a
 5585:       hook function.
 5586: 
 5587:     * The default tunnel texture is internally loaded (the texture is 256x256 pixels 24-bit)
 5588:       check the line :
 5589:       surface = pygame.image.load("Assets\\Graphics\\Background\\space1.jpg").convert()
 5590: 
 5591:     * This algorithm uses a 256x256 texture but reshape it to 512x512 pixels for a
 5592:     better effect definition
 5593: 
 5594:     :param screen_width     : integer; Game display size (width in pixels)
 5595:     :param screen_height    : integer; Game display size (height in pixels)
 5596:     :return                 : return a tuple containing the following (distances, angles,
 5597:     shades, scr_data)
 5598:     distances is a numpy.ndarray buffer containing float values representing the distance
 5599:     of each pixels
 5600:     angles is a numpy.ndarray buffer containing float values representing the angle of each pixels
 5601:     shades is a numpy.ndarray buffer containing float values representing the shade of each pixels
 5602:     scr_data is a numpy.ndarray buffer containing uint8 values representing the BGR (not RGB)
 5603:     values of each pixels
 5604: 
 5605:     """
 5606: 
+5607:     assert screen_width > 0, "Argument screen_width must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_width > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_width_must_be_0);
      __PYX_ERR(1, 5607, __pyx_L1_error)
    }
  }
  #endif
+5608:     assert screen_height > 0, "Argument screen_height must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_height > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_height_must_be_0);
      __PYX_ERR(1, 5608, __pyx_L1_error)
    }
  }
  #endif
 5609: 
+5610:     cdef int [:] distances = numpy.empty((screen_width * screen_height * 4), int32)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyInt_FromSsize_t(((__pyx_v_screen_width * __pyx_v_screen_height) * 4)); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_int32); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_2, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5610, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_2, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5610, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_7 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5610, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (__pyx_t_5) {
      __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_5); __pyx_t_5 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_6, __pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_6, __pyx_t_4);
    __pyx_t_2 = 0;
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_7, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5610, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_int(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5610, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_distances = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+5611:     cdef int [:] angles    = numpy.empty((screen_width * screen_height * 4), int32)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_numpy); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5611, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_empty); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5611, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = PyInt_FromSsize_t(((__pyx_v_screen_width * __pyx_v_screen_height) * 4)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5611, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_int32); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5611, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_7))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_7);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_7, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_t_3, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5611, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_7)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_t_3, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_7, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5611, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_5 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5611, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (__pyx_t_2) {
      __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_2); __pyx_t_2 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_6, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_6, __pyx_t_4);
    __pyx_t_3 = 0;
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_7, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5611, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  }
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_int(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5611, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_angles = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+5612:     cdef int [:] shades    = numpy.empty((screen_width * screen_height * 4), int32)
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_numpy); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_n_s_empty); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = PyInt_FromSsize_t(((__pyx_v_screen_width * __pyx_v_screen_height) * 4)); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_int32); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_7, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5612, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_3, __pyx_t_7, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5612, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_2 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5612, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__pyx_t_3) {
      __Pyx_GIVEREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_3); __pyx_t_3 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_6, __pyx_t_7);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_6, __pyx_t_4);
    __pyx_t_7 = 0;
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5612, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_ds_int(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5612, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_shades = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 5613: 
+5614:     surface = pygame.image.load("../Assets/space1.jpg").convert()
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_pygame); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_image); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_load); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_5 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_kp_s_Assets_space1_jpg) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_kp_s_Assets_space1_jpg);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_convert); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5614, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_surface = __pyx_t_1;
  __pyx_t_1 = 0;
 5615: 
+5616:     cdef int s_width  = 512
  __pyx_v_s_width = 0x200;
+5617:     cdef int s_height = 512
  __pyx_v_s_height = 0x200;
+5618:     surface = smoothscale(surface, (s_width, s_height))
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_s_width); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_s_height); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_t_4);
  __pyx_t_5 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface, __pyx_t_7};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5618, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_2)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface, __pyx_t_7};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_2, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5618, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  {
    __pyx_t_5 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5618, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface);
    __Pyx_GIVEREF(__pyx_v_surface);
    PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_6, __pyx_v_surface);
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_6, __pyx_t_7);
    __pyx_t_7 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_5, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5618, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF_SET(__pyx_v_surface, __pyx_t_1);
  __pyx_t_1 = 0;
+5619:     cdef unsigned char [::1] scr_data = surface.get_buffer()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5619, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5619, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_9 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_9.memview)) __PYX_ERR(1, 5619, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_scr_data = __pyx_t_9;
  __pyx_t_9.memview = NULL;
  __pyx_t_9.data = NULL;
 5620: 
+5621:     cdef  int x, y, i = 0
  __pyx_v_i = 0;
 5622: 
 5623: 
+5624:     for y in range(0, screen_height * 2):
  __pyx_t_10 = (__pyx_v_screen_height * 2);
  __pyx_t_11 = __pyx_t_10;
  for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_11; __pyx_t_6+=1) {
    __pyx_v_y = __pyx_t_6;
+5625:         sqy = pow(y - screen_height, 2)
    __pyx_v_sqy = pow((__pyx_v_y - __pyx_v_screen_height), 2.0);
+5626:         for x in range(0, screen_width * 2):
    __pyx_t_12 = (__pyx_v_screen_width * 2);
    __pyx_t_13 = __pyx_t_12;
    for (__pyx_t_14 = 0; __pyx_t_14 < __pyx_t_13; __pyx_t_14+=1) {
      __pyx_v_x = __pyx_t_14;
+5627:             sqx = pow(x - screen_width, 2)
      __pyx_v_sqx = pow((__pyx_v_x - __pyx_v_screen_width), 2.0);
+5628:             if (sqx + sqy) == 0:
      __pyx_t_15 = (((__pyx_v_sqx + __pyx_v_sqy) == 0.0) != 0);
      if (__pyx_t_15) {
/* … */
        goto __pyx_L7;
      }
+5629:                 distances[i] = 1
        __pyx_t_16 = __pyx_v_i;
        *((int *) ( /* dim=0 */ (__pyx_v_distances.data + __pyx_t_16 * __pyx_v_distances.strides[0]) )) = 1;
 5630:             else:
+5631:                 distances[i] = <int>(floor(
        __pyx_t_19 = ((int)floor((__pyx_t_17 / __pyx_t_18)));
/* … */
        __pyx_t_16 = __pyx_v_i;
        *((int *) ( /* dim=0 */ (__pyx_v_distances.data + __pyx_t_16 * __pyx_v_distances.strides[0]) )) = __Pyx_mod_int(__pyx_t_19, __pyx_v_s_height);
      }
      __pyx_L7:;
+5632:                     32 * <float>s_height / <float>sqrt(sqx + sqy))) % s_height
      /*else*/ {
/* … */
        __pyx_t_17 = (32.0 * ((float)__pyx_v_s_height));
/* … */
        __pyx_t_18 = ((float)sqrt((__pyx_v_sqx + __pyx_v_sqy)));
        if (unlikely(__pyx_t_18 == 0)) {
          PyErr_SetString(PyExc_ZeroDivisionError, "float division");
          __PYX_ERR(1, 5632, __pyx_L1_error)
        }
/* … */
        if (unlikely(__pyx_v_s_height == 0)) {
          PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
          __PYX_ERR(1, 5632, __pyx_L1_error)
        }
+5633:             angles[i]    = <int>round_c(<float>s_width * atan2(y - screen_height,
      __pyx_t_20 = (((float)__pyx_v_s_width) * atan2((__pyx_v_y - __pyx_v_screen_height), (__pyx_v_x - __pyx_v_screen_width)));
/* … */
      __pyx_t_16 = __pyx_v_i;
      *((int *) ( /* dim=0 */ (__pyx_v_angles.data + __pyx_t_16 * __pyx_v_angles.strides[0]) )) = ((int)round((__pyx_t_20 / ((float)__pyx_v_12PygameShader_6shader_M_PI))));
+5634:                                                              x - screen_width) / (<float>M_PI))
      if (unlikely(((float)__pyx_v_12PygameShader_6shader_M_PI) == 0)) {
        PyErr_SetString(PyExc_ZeroDivisionError, "float division");
        __PYX_ERR(1, 5634, __pyx_L1_error)
      }
+5635:             shades[i]    = <int>min(sqrt(sqx + sqy)*10, 255)
      __pyx_t_21 = 0xFF;
      __pyx_t_20 = (sqrt((__pyx_v_sqx + __pyx_v_sqy)) * 10.0);
      if (((__pyx_t_21 < __pyx_t_20) != 0)) {
        __pyx_t_22 = __pyx_t_21;
      } else {
        __pyx_t_22 = __pyx_t_20;
      }
      __pyx_t_16 = __pyx_v_i;
      *((int *) ( /* dim=0 */ (__pyx_v_shades.data + __pyx_t_16 * __pyx_v_shades.strides[0]) )) = ((int)__pyx_t_22);
+5636:             i = i + 1
      __pyx_v_i = (__pyx_v_i + 1);
    }
  }
 5637: 
+5638:     return distances, angles, shades, scr_data
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_distances, 1, (PyObject *(*)(char *)) __pyx_memview_get_int, (int (*)(char *, PyObject *)) __pyx_memview_set_int, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5638, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_angles, 1, (PyObject *(*)(char *)) __pyx_memview_get_int, (int (*)(char *, PyObject *)) __pyx_memview_set_int, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5638, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5 = __pyx_memoryview_fromslice(__pyx_v_shades, 1, (PyObject *(*)(char *)) __pyx_memview_get_int, (int (*)(char *, PyObject *)) __pyx_memview_set_int, 0);; if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5638, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_7 = __pyx_memoryview_fromslice(__pyx_v_scr_data, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 5638, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_4 = PyTuple_New(4); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5638, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_7);
  PyTuple_SET_ITEM(__pyx_t_4, 3, __pyx_t_7);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_5 = 0;
  __pyx_t_7 = 0;
  __pyx_r = __pyx_t_4;
  __pyx_t_4 = 0;
  goto __pyx_L0;
 5639: 
 5640: 
 5641: 
 5642: 
 5643: @cython.binding(False)
 5644: @cython.boundscheck(False)
 5645: @cython.wraparound(False)
 5646: @cython.nonecheck(False)
 5647: @cython.cdivision(True)
+5648: cpdef tunnel_render32(
static PyObject *__pyx_pw_12PygameShader_6shader_141tunnel_render32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_tunnel_render32(int __pyx_v_t, Py_ssize_t __pyx_v_screen_width, Py_ssize_t __pyx_v_screen_height, int __pyx_v_screen_w2, int __pyx_v_screen_h2, __Pyx_memviewslice __pyx_v_distances, __Pyx_memviewslice __pyx_v_angles, __Pyx_memviewslice __pyx_v_shades, __Pyx_memviewslice __pyx_v_scr_data, __Pyx_memviewslice __pyx_v_dest_array, CYTHON_UNUSED int __pyx_skip_dispatch) {
  int __pyx_v_s_width;
  int __pyx_v_s_height;
  float __pyx_v_timer;
  int __pyx_v_shiftx;
  int __pyx_v_shifty;
  int __pyx_v_centerx;
  int __pyx_v_centery;
  int __pyx_v_stride;
  int __pyx_v_dest_ofs;
  int __pyx_v_src_ofs;
  int __pyx_v_u;
  int __pyx_v_v;
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_pix_ofs;
  int __pyx_v_shade;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_render32", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_AddTraceback("PygameShader.shader.tunnel_render32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_141tunnel_render32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_140tunnel_render32[] = "\n    TUNNEL EFFECT RENDERING METHOD\n\n    * Always call the method tunnel_modeling32 outside of your game main loop\n    before calling this method (from\n      the main loop)\n\n    * Return a pygame surface containing the tunnel rendering effect, the image\n    is 32 bit (with per-pixel information)\n\n    * Cython cpdef function, this function can be called directly and do not\n    require a hook function.\n\n    * The parameter t must change overtime\n\n    :param t            : integer; linear value (frame number)\n    :param screen_width : integer; Game display size (width in pixels)\n    :param screen_height: integer; Game display size (height in pixels)\n    :param screen_w2    : integer; Game display width / 2.0\n    :param screen_h2    : integer; game display height / 2.0\n    :param distances    : numpy.ndarray buffer containing float values\n    representing the distance of each pixels\n    :param angles       : numpy.ndarray buffer containing float values\n    representing the angle of each pixels\n    :param shades       : numpy.ndarray buffer containing float values\n    representing the shade of each pixels\n    :param scr_data     : numpy.ndarray buffer containing float values\n    representing the BGR values  of each pixels\n    :param dest_array   : numpy.ndarray buffer containing float values\n    representing the RGB values of each pixels\n    :return             : Return a pygame.Surface (w, h) 32 bit with per-pixel information\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_141tunnel_render32(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_t;
  Py_ssize_t __pyx_v_screen_width;
  Py_ssize_t __pyx_v_screen_height;
  int __pyx_v_screen_w2;
  int __pyx_v_screen_h2;
  __Pyx_memviewslice __pyx_v_distances = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_angles = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_shades = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_scr_data = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_dest_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_render32 (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_t_2,&__pyx_n_s_screen_width,&__pyx_n_s_screen_height,&__pyx_n_s_screen_w2,&__pyx_n_s_screen_h2,&__pyx_n_s_distances,&__pyx_n_s_angles,&__pyx_n_s_shades,&__pyx_n_s_scr_data,&__pyx_n_s_dest_array,0};
    PyObject* values[10] = {0,0,0,0,0,0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case 10: values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
        CYTHON_FALLTHROUGH;
        case  9: values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
        CYTHON_FALLTHROUGH;
        case  8: values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
        CYTHON_FALLTHROUGH;
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_t_2)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_width)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 1); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_height)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 2); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_w2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 3); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (likely((values[4] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_screen_h2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 4); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (likely((values[5] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_distances)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 5); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (likely((values[6] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_angles)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 6); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  7:
        if (likely((values[7] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_shades)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 7); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  8:
        if (likely((values[8] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_scr_data)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 8); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  9:
        if (likely((values[9] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_dest_array)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, 9); __PYX_ERR(1, 5648, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "tunnel_render32") < 0)) __PYX_ERR(1, 5648, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 10) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
      values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
      values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
      values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
      values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
      values[7] = PyTuple_GET_ITEM(__pyx_args, 7);
      values[8] = PyTuple_GET_ITEM(__pyx_args, 8);
      values[9] = PyTuple_GET_ITEM(__pyx_args, 9);
    }
    __pyx_v_t = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_t == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5649, __pyx_L3_error)
    __pyx_v_screen_width = __Pyx_PyIndex_AsSsize_t(values[1]); if (unlikely((__pyx_v_screen_width == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5650, __pyx_L3_error)
    __pyx_v_screen_height = __Pyx_PyIndex_AsSsize_t(values[2]); if (unlikely((__pyx_v_screen_height == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 5651, __pyx_L3_error)
    __pyx_v_screen_w2 = __Pyx_PyInt_As_int(values[3]); if (unlikely((__pyx_v_screen_w2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5652, __pyx_L3_error)
    __pyx_v_screen_h2 = __Pyx_PyInt_As_int(values[4]); if (unlikely((__pyx_v_screen_h2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5653, __pyx_L3_error)
    __pyx_v_distances = __Pyx_PyObject_to_MemoryviewSlice_dc_int(values[5], PyBUF_WRITABLE); if (unlikely(!__pyx_v_distances.memview)) __PYX_ERR(1, 5654, __pyx_L3_error)
    __pyx_v_angles = __Pyx_PyObject_to_MemoryviewSlice_dc_int(values[6], PyBUF_WRITABLE); if (unlikely(!__pyx_v_angles.memview)) __PYX_ERR(1, 5655, __pyx_L3_error)
    __pyx_v_shades = __Pyx_PyObject_to_MemoryviewSlice_dc_int(values[7], PyBUF_WRITABLE); if (unlikely(!__pyx_v_shades.memview)) __PYX_ERR(1, 5656, __pyx_L3_error)
    __pyx_v_scr_data = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(values[8], PyBUF_WRITABLE); if (unlikely(!__pyx_v_scr_data.memview)) __PYX_ERR(1, 5657, __pyx_L3_error)
    __pyx_v_dest_array = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(values[9], PyBUF_WRITABLE); if (unlikely(!__pyx_v_dest_array.memview)) __PYX_ERR(1, 5658, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("tunnel_render32", 1, 10, 10, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5648, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.tunnel_render32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_140tunnel_render32(__pyx_self, __pyx_v_t, __pyx_v_screen_width, __pyx_v_screen_height, __pyx_v_screen_w2, __pyx_v_screen_h2, __pyx_v_distances, __pyx_v_angles, __pyx_v_shades, __pyx_v_scr_data, __pyx_v_dest_array);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_140tunnel_render32(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_t, Py_ssize_t __pyx_v_screen_width, Py_ssize_t __pyx_v_screen_height, int __pyx_v_screen_w2, int __pyx_v_screen_h2, __Pyx_memviewslice __pyx_v_distances, __Pyx_memviewslice __pyx_v_angles, __Pyx_memviewslice __pyx_v_shades, __Pyx_memviewslice __pyx_v_scr_data, __Pyx_memviewslice __pyx_v_dest_array) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("tunnel_render32", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_distances.memview)) { __Pyx_RaiseUnboundLocalError("distances"); __PYX_ERR(1, 5648, __pyx_L1_error) }
  if (unlikely(!__pyx_v_angles.memview)) { __Pyx_RaiseUnboundLocalError("angles"); __PYX_ERR(1, 5648, __pyx_L1_error) }
  if (unlikely(!__pyx_v_shades.memview)) { __Pyx_RaiseUnboundLocalError("shades"); __PYX_ERR(1, 5648, __pyx_L1_error) }
  if (unlikely(!__pyx_v_scr_data.memview)) { __Pyx_RaiseUnboundLocalError("scr_data"); __PYX_ERR(1, 5648, __pyx_L1_error) }
  if (unlikely(!__pyx_v_dest_array.memview)) { __Pyx_RaiseUnboundLocalError("dest_array"); __PYX_ERR(1, 5648, __pyx_L1_error) }
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_tunnel_render32(__pyx_v_t, __pyx_v_screen_width, __pyx_v_screen_height, __pyx_v_screen_w2, __pyx_v_screen_h2, __pyx_v_distances, __pyx_v_angles, __pyx_v_shades, __pyx_v_scr_data, __pyx_v_dest_array, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5648, __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("PygameShader.shader.tunnel_render32", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_distances, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_angles, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_shades, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_scr_data, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_dest_array, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 5649:         int t,
 5650:         Py_ssize_t screen_width,
 5651:         Py_ssize_t screen_height,
 5652:         int screen_w2,
 5653:         int screen_h2,
 5654:         int [::1] distances,
 5655:         int [::1] angles,
 5656:         int [::1] shades,
 5657:         unsigned char [::1] scr_data,
 5658:         unsigned char [::1] dest_array):
 5659: 
 5660:     """
 5661:     TUNNEL EFFECT RENDERING METHOD
 5662: 
 5663:     * Always call the method tunnel_modeling32 outside of your game main loop
 5664:     before calling this method (from
 5665:       the main loop)
 5666: 
 5667:     * Return a pygame surface containing the tunnel rendering effect, the image
 5668:     is 32 bit (with per-pixel information)
 5669: 
 5670:     * Cython cpdef function, this function can be called directly and do not
 5671:     require a hook function.
 5672: 
 5673:     * The parameter t must change overtime
 5674: 
 5675:     :param t            : integer; linear value (frame number)
 5676:     :param screen_width : integer; Game display size (width in pixels)
 5677:     :param screen_height: integer; Game display size (height in pixels)
 5678:     :param screen_w2    : integer; Game display width / 2.0
 5679:     :param screen_h2    : integer; game display height / 2.0
 5680:     :param distances    : numpy.ndarray buffer containing float values
 5681:     representing the distance of each pixels
 5682:     :param angles       : numpy.ndarray buffer containing float values
 5683:     representing the angle of each pixels
 5684:     :param shades       : numpy.ndarray buffer containing float values
 5685:     representing the shade of each pixels
 5686:     :param scr_data     : numpy.ndarray buffer containing float values
 5687:     representing the BGR values  of each pixels
 5688:     :param dest_array   : numpy.ndarray buffer containing float values
 5689:     representing the RGB values of each pixels
 5690:     :return             : Return a pygame.Surface (w, h) 32 bit with per-pixel information
 5691:     """
 5692: 
+5693:     assert screen_width > 0, "Argument screen_width must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_width > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_width_must_be_0);
      __PYX_ERR(1, 5693, __pyx_L1_error)
    }
  }
  #endif
+5694:     assert screen_height > 0, "Argument screen_height must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_height > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_height_must_be_0);
      __PYX_ERR(1, 5694, __pyx_L1_error)
    }
  }
  #endif
+5695:     assert screen_w2 > 0, "Argument screen_w2 must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_w2 > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_w2_must_be_0);
      __PYX_ERR(1, 5695, __pyx_L1_error)
    }
  }
  #endif
+5696:     assert screen_h2 > 0, "Argument screen_h2 must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_screen_h2 > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_screen_h2_must_be_0);
      __PYX_ERR(1, 5696, __pyx_L1_error)
    }
  }
  #endif
 5697: 
 5698:     cdef:
+5699:         int s_width  = 512
  __pyx_v_s_width = 0x200;
+5700:         int s_height = 512
  __pyx_v_s_height = 0x200;
+5701:         float timer = t * <float>1e-3
  __pyx_v_timer = (__pyx_v_t * ((float)1e-3));
+5702:         int shiftx  = <int>floor(s_width * timer)
  __pyx_v_shiftx = ((int)floor((__pyx_v_s_width * __pyx_v_timer)));
+5703:         int shifty  = <int>floor(s_height * <float>0.25 * timer)
  __pyx_v_shifty = ((int)floor(((__pyx_v_s_height * ((float)0.25)) * __pyx_v_timer)));
+5704:         int centerx = <int>(screen_w2 +
  __pyx_v_centerx = ((int)(__pyx_v_screen_w2 + ((float)floor(((__pyx_v_screen_w2 >> 1) * ((float)sin((__pyx_v_timer * ((float)0.25)))))))));
 5705:                             <float>floor((screen_w2 >> 1) * <float>sin(timer * <float>0.25)))
+5706:         int centery = <int>(screen_h2 + <float>floor(
  __pyx_v_centery = ((int)(__pyx_v_screen_h2 + ((float)floor(((__pyx_v_screen_h2 >> 1) * ((float)sin((__pyx_v_timer * ((float)0.5)))))))));
 5707:             (screen_h2 >> 1) * <float>sin(timer * <float>0.5)))
+5708:         int stride  = <int>screen_width * 2
  __pyx_v_stride = (((int)__pyx_v_screen_width) * 2);
+5709:         int dest_ofs = 0
  __pyx_v_dest_ofs = 0;
 5710:         int src_ofs
 5711:         int u, v, x, y
 5712:         int pix_ofs, shade
 5713: 
 5714:     # with nogil:
 5715:     #     for y in range(0,  screen_height):
 5716:     #         srcOfs = y * stride + centerx + centery * stride
 5717:     #         for x in range(0, screen_width):
 5718:     #             u = (distances[srcOfs] + shiftx) & 0xff
 5719:     #             v = (angles[srcOfs] + shifty) & 0xff
 5720:     #             while v < 0:
 5721:     #               v = v + s_height
 5722:     #
 5723:     #             shade = <int>(shades[srcOfs] * ONE_255)
 5724:     #
 5725:     #             pixOfs = (u + (v << 9)) << 3
 5726:     #             dest_array[dest_ofs    ] = scr_data[pixOfs + 2] * shade
 5727:     #             dest_array[dest_ofs + 1] = scr_data[pixOfs + 1] * shade
 5728:     #             dest_array[dest_ofs + 2] = scr_data[pixOfs + 0] * shade
 5729:     #             dest_array[dest_ofs + 3] = 255 # scr_data[pixOfs + 4] * shade
 5730:     #
 5731:     #             dest_ofs = dest_ofs + 4
 5732:     #             srcOfs  = srcOfs + 1
 5733:     #
 5734:     # return pygame.image.frombuffer(dest_array, (screen_width, screen_height), "RGBA")
 5735: 
+5736:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 5737: 
+5738:         for y in prange(0, screen_height, schedule='static', num_threads=4):
        __pyx_t_1 = __pyx_v_screen_height;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_3 = (__pyx_t_1 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_3 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_dest_ofs) lastprivate(__pyx_v_pix_ofs) lastprivate(__pyx_v_shade) lastprivate(__pyx_v_src_ofs) lastprivate(__pyx_v_u) lastprivate(__pyx_v_v) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(4)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_3; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_dest_ofs = ((int)0xbad0bad0);
                            __pyx_v_pix_ofs = ((int)0xbad0bad0);
                            __pyx_v_shade = ((int)0xbad0bad0);
                            __pyx_v_src_ofs = ((int)0xbad0bad0);
                            __pyx_v_u = ((int)0xbad0bad0);
                            __pyx_v_v = ((int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
 5739: 
+5740:             for x in range(0, screen_width):
                            __pyx_t_4 = __pyx_v_screen_width;
                            __pyx_t_5 = __pyx_t_4;
                            for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) {
                              __pyx_v_x = __pyx_t_6;
 5741: 
+5742:                 src_ofs = y * stride + centerx + centery * stride + x
                              __pyx_v_src_ofs = ((((__pyx_v_y * __pyx_v_stride) + __pyx_v_centerx) + (__pyx_v_centery * __pyx_v_stride)) + __pyx_v_x);
+5743:                 dest_ofs = (y * screen_height + x) << 2
                              __pyx_v_dest_ofs = (((__pyx_v_y * __pyx_v_screen_height) + __pyx_v_x) << 2);
 5744: 
+5745:                 u = (distances[src_ofs] + shiftx) & 0xff
                              __pyx_t_7 = __pyx_v_src_ofs;
                              __pyx_v_u = (((*((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_distances.data) + __pyx_t_7)) ))) + __pyx_v_shiftx) & 0xff);
+5746:                 v = (angles[src_ofs] + shifty) & 0xff
                              __pyx_t_7 = __pyx_v_src_ofs;
                              __pyx_v_v = (((*((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_angles.data) + __pyx_t_7)) ))) + __pyx_v_shifty) & 0xff);
 5747: 
+5748:                 shade = <int> (shades[src_ofs] * ONE_255)
                              __pyx_t_7 = __pyx_v_src_ofs;
                              __pyx_v_shade = ((int)((*((int *) ( /* dim=0 */ ((char *) (((int *) __pyx_v_shades.data) + __pyx_t_7)) ))) * 0.00392156862745098));
 5749: 
+5750:                 pix_ofs = (u + (v << 9)) << 3
                              __pyx_v_pix_ofs = ((__pyx_v_u + (__pyx_v_v << 9)) << 3);
 5751: 
+5752:                 dest_array[dest_ofs] = scr_data[pix_ofs + 2] * shade
                              __pyx_t_7 = (__pyx_v_pix_ofs + 2);
                              __pyx_t_8 = __pyx_v_dest_ofs;
                              *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_dest_array.data) + __pyx_t_8)) )) = ((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_scr_data.data) + __pyx_t_7)) ))) * __pyx_v_shade);
+5753:                 dest_array[dest_ofs + 1] = scr_data[pix_ofs + 1] * shade
                              __pyx_t_7 = (__pyx_v_pix_ofs + 1);
                              __pyx_t_8 = (__pyx_v_dest_ofs + 1);
                              *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_dest_array.data) + __pyx_t_8)) )) = ((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_scr_data.data) + __pyx_t_7)) ))) * __pyx_v_shade);
+5754:                 dest_array[dest_ofs + 2] = scr_data[pix_ofs + 0] * shade
                              __pyx_t_7 = (__pyx_v_pix_ofs + 0);
                              __pyx_t_8 = (__pyx_v_dest_ofs + 2);
                              *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_dest_array.data) + __pyx_t_8)) )) = ((*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_scr_data.data) + __pyx_t_7)) ))) * __pyx_v_shade);
+5755:                 dest_array[dest_ofs + 3] = 255
                              __pyx_t_7 = (__pyx_v_dest_ofs + 3);
                              *((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_dest_array.data) + __pyx_t_7)) )) = 0xFF;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 5756: 
+5757:     return pygame.image.frombuffer(dest_array, (screen_width, screen_height), "RGBA")
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_n_s_pygame); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_n_s_image); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __pyx_t_11 = __pyx_memoryview_fromslice(__pyx_v_dest_array, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_12 = PyInt_FromSsize_t(__pyx_v_screen_width); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __pyx_t_13 = PyInt_FromSsize_t(__pyx_v_screen_height); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_13);
  __pyx_t_14 = PyTuple_New(2); if (unlikely(!__pyx_t_14)) __PYX_ERR(1, 5757, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  __Pyx_GIVEREF(__pyx_t_12);
  PyTuple_SET_ITEM(__pyx_t_14, 0, __pyx_t_12);
  __Pyx_GIVEREF(__pyx_t_13);
  PyTuple_SET_ITEM(__pyx_t_14, 1, __pyx_t_13);
  __pyx_t_12 = 0;
  __pyx_t_13 = 0;
  __pyx_t_13 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_10))) {
    __pyx_t_13 = PyMethod_GET_SELF(__pyx_t_10);
    if (likely(__pyx_t_13)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_13);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_10, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[4] = {__pyx_t_13, __pyx_t_11, __pyx_t_14, __pyx_n_s_RGBA};
    __pyx_t_9 = __Pyx_PyFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_6, 3+__pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 5757, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[4] = {__pyx_t_13, __pyx_t_11, __pyx_t_14, __pyx_n_s_RGBA};
    __pyx_t_9 = __Pyx_PyCFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_6, 3+__pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 5757, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
  } else
  #endif
  {
    __pyx_t_12 = PyTuple_New(3+__pyx_t_6); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 5757, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    if (__pyx_t_13) {
      __Pyx_GIVEREF(__pyx_t_13); PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_13); __pyx_t_13 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_11);
    PyTuple_SET_ITEM(__pyx_t_12, 0+__pyx_t_6, __pyx_t_11);
    __Pyx_GIVEREF(__pyx_t_14);
    PyTuple_SET_ITEM(__pyx_t_12, 1+__pyx_t_6, __pyx_t_14);
    __Pyx_INCREF(__pyx_n_s_RGBA);
    __Pyx_GIVEREF(__pyx_n_s_RGBA);
    PyTuple_SET_ITEM(__pyx_t_12, 2+__pyx_t_6, __pyx_n_s_RGBA);
    __pyx_t_11 = 0;
    __pyx_t_14 = 0;
    __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_t_12, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 5757, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
  }
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_r = __pyx_t_9;
  __pyx_t_9 = 0;
  goto __pyx_L0;
 5758: 
 5759: 
 5760: 
 5761: 
 5762: # @cython.binding(True)
 5763: # @cython.boundscheck(True)
 5764: # @cython.wraparound(True)
 5765: # @cython.nonecheck(True)
 5766: # @cython.cdivision(False)
 5767: # cpdef tunnel_modeling24(int screen_width, int screen_height):
 5768: #
 5769: #     cdef int [:] distances = numpy.empty((screen_width * screen_height * 3), int32)
 5770: #     cdef int [:] angles    = numpy.empty((screen_width * screen_height * 3), int32)
 5771: #     cdef int [:] shades    = numpy.empty((screen_width * screen_height * 3), int32)
 5772: #
 5773: #     surface = pygame.image.load("Assets\\Graphics\\Background\\space1.jpg").convert()
 5774: #
 5775: #     cdef int s_width  = 512
 5776: #     cdef int s_height = 512
 5777: #     surface = pygame.transform.smoothscale(surface, (s_width, s_height))
 5778: #     cdef unsigned char [:] scr_data = numpy.frombuffer(
 5779: #     pygame.image.tostring(surface, 'RGB'), uint8).copy()
 5780: #
 5781: #     cdef  int x, y, i = 0
 5782: #
 5783: #     for y in range(0, screen_height * 2):
 5784: #         sqy = pow(y - screen_height, 2)
 5785: #         for x in range(0, screen_width * 2):
 5786: #             sqx = pow(x - screen_width, 2)
 5787: #
 5788: #             i /= 4
 5789: #             i *= 3
 5790: #             if (sqx + sqy) == 0:
 5791: #                 distances[i] = 1
 5792: #             else:
 5793: #                 distances[i] = <int>(
 5794: #                 floor(32 * <float>s_height / <float>sqrt(sqx + sqy))) % s_height
 5795: #             angles[i]    = <int>round(
 5796: #             <float>s_width * atan2(y - screen_height, x - screen_width) / M_PI)
 5797: #             shades[i]    = <int>min(sqrt(sqx + sqy)*10, 255)
 5798: #             i = i + 1
 5799: #
 5800: #     return distances, angles, shades, scr_data
 5801: #
 5802: 
 5803: # @cython.binding(True)
 5804: # @cython.boundscheck(True)
 5805: # @cython.wraparound(True)
 5806: # @cython.nonecheck(True)
 5807: # @cython.cdivision(True)
 5808: # cpdef tunnel_render24(int t,
 5809: #                     int screen_width,
 5810: #                     int screen_height,
 5811: #                     int screen_w2,
 5812: #                     int screen_h2,
 5813: #                     int [:] distances,
 5814: #                     int [:] angles,
 5815: #                     int [:] shades,
 5816: #                     unsigned char [:] scr_data,
 5817: #                     unsigned char [:] dest_array):
 5818: #     cdef:
 5819: #         int s_width  = 512
 5820: #         int s_height = 512
 5821: #         float timer = t * 1e-3
 5822: #         int shiftx  = <int>floor(s_width * timer)
 5823: #         int shifty  = <int>floor(s_height * 0.25 * timer)
 5824: #         int centerx = <int>(screen_w2 + floor((screen_w2 >> 1) * sin(timer * 0.25)))
 5825: #         int centery = <int>(screen_h2 + floor((screen_h2 >> 1) * sin(timer * 0.5)))
 5826: #         int stride  = screen_width * 2
 5827: #         int destOfs = 0
 5828: #         int srcOfs
 5829: #         int u, v, x, y
 5830: #         int pixOfs, shade
 5831: #
 5832: #
 5833: #     with nogil:
 5834: #
 5835: #         for y in prange(0,  screen_height,  schedule='static', num_threads=THREADS):
 5836: #             for x in range(0, screen_width):
 5837: #
 5838: #
 5839: #                 srcOfs = (y * stride * 3 + centerx + centery * stride + x * 3)
 5840: #
 5841: #                 destOfs = (y * screen_height*3 + x * 3)
 5842: #
 5843: #
 5844: #                 u = (distances[srcOfs] + shiftx) & 0xff
 5845: #                 v = (angles[srcOfs] + shifty) & 0xff
 5846: #
 5847: #
 5848: #                 #shade = <int>(shades[srcOfs] * ONE_255)
 5849: #
 5850: #                 pixOfs = (u + (v << 9)) << 1
 5851: #
 5852: #                 dest_array[destOfs    ] = scr_data[pixOfs + 2] #* shade
 5853: #                 dest_array[destOfs + 1] = scr_data[pixOfs + 1] #* shade
 5854: #                 dest_array[destOfs + 2] = scr_data[pixOfs + 0] #* shade
 5855: #
 5856: #
 5857: #     return pygame.image.frombuffer(dest_array, (screen_width, screen_height), "RGB")
 5858: 
 5859: 
 5860: 
 5861: 
 5862: 
 5863: @cython.binding(False)
 5864: @cython.boundscheck(False)
 5865: @cython.wraparound(False)
 5866: @cython.nonecheck(False)
 5867: @cython.cdivision(True)
+5868: cpdef tuple heat_map(int wavelength, float gamma=1.0):
static PyObject *__pyx_pw_12PygameShader_6shader_143heat_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_heat_map(int __pyx_v_wavelength, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_heat_map *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  struct rgb_color_int __pyx_v_rgb_c;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heat_map", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("PygameShader.shader.heat_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_143heat_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_142heat_map[] = "\n    RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    This function return a tuple (R,G,B) corresponding to the\n    color wavelength (wavelength_to_rgb is an External C\n    routine with pre-defined wavelength such as :\n    Color   Wavelength(nm) Frequency(THz)\n    Red     620-750        484-400\n    Orange  590-620        508-484\n    Yellow  570-590        526-508\n    Green   495-570        606-526\n    Blue    450-495        668-606\n    Violet  380-450        789-668\n    e.g If the routine is called with a wavelength of 620, the returned color\n    will be a red gradient\n\n    :param wavelength   : integer; Wavelength\n    :param gamma        : float; Gamma value\n    :return             : tuple RGB values (0 ... 255)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_143heat_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_wavelength;
  float __pyx_v_gamma;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heat_map (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_wavelength,&__pyx_n_s_gamma,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_wavelength)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_gamma);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "heat_map") < 0)) __PYX_ERR(1, 5868, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_wavelength = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_wavelength == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5868, __pyx_L3_error)
    if (values[1]) {
      __pyx_v_gamma = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_gamma == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 5868, __pyx_L3_error)
    } else {
      __pyx_v_gamma = ((float)1.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("heat_map", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5868, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.heat_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_142heat_map(__pyx_self, __pyx_v_wavelength, __pyx_v_gamma);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_142heat_map(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_wavelength, float __pyx_v_gamma) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heat_map", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_heat_map(__pyx_v_wavelength, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5868, __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("PygameShader.shader.heat_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_heat_map {
  int __pyx_n;
  float gamma;
};
 5869:     """
 5870:     RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH
 5871: 
 5872:     Cython cpdef function, this function can be called directly and do not require a
 5873:     hook function.
 5874: 
 5875:     This function return a tuple (R,G,B) corresponding to the
 5876:     color wavelength (wavelength_to_rgb is an External C
 5877:     routine with pre-defined wavelength such as :
 5878:     Color   Wavelength(nm) Frequency(THz)
 5879:     Red     620-750        484-400
 5880:     Orange  590-620        508-484
 5881:     Yellow  570-590        526-508
 5882:     Green   495-570        606-526
 5883:     Blue    450-495        668-606
 5884:     Violet  380-450        789-668
 5885:     e.g If the routine is called with a wavelength of 620, the returned color
 5886:     will be a red gradient
 5887: 
 5888:     :param wavelength   : integer; Wavelength
 5889:     :param gamma        : float; Gamma value
 5890:     :return             : tuple RGB values (0 ... 255)
 5891:     """
 5892:     cdef  rgb_color_int rgb_c
+5893:     rgb_c = wavelength_to_rgb(wavelength, gamma)
  __pyx_v_rgb_c = wavelength_to_rgb(__pyx_v_wavelength, __pyx_v_gamma);
+5894:     return rgb_c.r, rgb_c.g, rgb_c.b
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.r); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5894, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.g); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5894, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.b); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5894, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5894, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_3);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_r = ((PyObject*)__pyx_t_4);
  __pyx_t_4 = 0;
  goto __pyx_L0;
 5895: 
 5896: @cython.binding(False)
 5897: @cython.boundscheck(False)
 5898: @cython.wraparound(False)
 5899: @cython.nonecheck(False)
 5900: @cython.cdivision(True)
+5901: cpdef tuple custom_map(int wavelength, int [:] color_array_, float gamma=1.0):
static PyObject *__pyx_pw_12PygameShader_6shader_145custom_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_custom_map(int __pyx_v_wavelength, __Pyx_memviewslice __pyx_v_color_array_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_custom_map *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  struct rgb_color_int __pyx_v_rgb_c;
  int *__pyx_v_p;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("custom_map", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("PygameShader.shader.custom_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_145custom_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_144custom_map[] = "\n    RETURN AN RGB COLOR VALUE MATCHING A CUSTOM WAVELENGTH\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    This function return a tuple (R,G,B) corresponding to the\n    color wavelength define in color_array_\n    (wavelength_to_rgb_custom is an External C\n    routine with customize wavelength and allow the user to defined\n    a customize palette according to an input value)\n\n    example for a Fire palette\n    arr = numpy.array(\n        [0, 1,       # violet is not used\n         0, 1,       # blue is not used\n         0, 1,       # green is not used\n         2, 619,     # yellow, return a yellow gradient for values [2...619]\n         620, 650,   # orange return a orange gradient for values [620 ... 650]\n         651, 660    # red return a red gradient for values [651 ... 660]\n         ], numpy.int)\n\n\n    :param wavelength   : integer; Wavelength\n    :param gamma        : float; Gamma value\n    :param color_array_ : numpy array containing the min and max of each color (red,\n    orange, yellow, green, blue, violet)\n    :return             : tuple RGB values (0 ... 255)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_145custom_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_wavelength;
  __Pyx_memviewslice __pyx_v_color_array_ = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_gamma;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("custom_map (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_wavelength,&__pyx_n_s_color_array,&__pyx_n_s_gamma,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_wavelength)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_color_array)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("custom_map", 0, 2, 3, 1); __PYX_ERR(1, 5901, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_gamma);
          if (value) { values[2] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "custom_map") < 0)) __PYX_ERR(1, 5901, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_wavelength = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_wavelength == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5901, __pyx_L3_error)
    __pyx_v_color_array_ = __Pyx_PyObject_to_MemoryviewSlice_ds_int(values[1], PyBUF_WRITABLE); if (unlikely(!__pyx_v_color_array_.memview)) __PYX_ERR(1, 5901, __pyx_L3_error)
    if (values[2]) {
      __pyx_v_gamma = __pyx_PyFloat_AsFloat(values[2]); if (unlikely((__pyx_v_gamma == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 5901, __pyx_L3_error)
    } else {
      __pyx_v_gamma = ((float)1.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("custom_map", 0, 2, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5901, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.custom_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_144custom_map(__pyx_self, __pyx_v_wavelength, __pyx_v_color_array_, __pyx_v_gamma);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_144custom_map(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_wavelength, __Pyx_memviewslice __pyx_v_color_array_, float __pyx_v_gamma) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("custom_map", 0);
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_color_array_.memview)) { __Pyx_RaiseUnboundLocalError("color_array_"); __PYX_ERR(1, 5901, __pyx_L1_error) }
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_custom_map(__pyx_v_wavelength, __pyx_v_color_array_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5901, __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("PygameShader.shader.custom_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_color_array_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_custom_map {
  int __pyx_n;
  float gamma;
};
 5902:     """
 5903:     RETURN AN RGB COLOR VALUE MATCHING A CUSTOM WAVELENGTH
 5904: 
 5905:     Cython cpdef function, this function can be called directly and do not require a
 5906:     hook function.
 5907: 
 5908:     This function return a tuple (R,G,B) corresponding to the
 5909:     color wavelength define in color_array_
 5910:     (wavelength_to_rgb_custom is an External C
 5911:     routine with customize wavelength and allow the user to defined
 5912:     a customize palette according to an input value)
 5913: 
 5914:     example for a Fire palette
 5915:     arr = numpy.array(
 5916:         [0, 1,       # violet is not used
 5917:          0, 1,       # blue is not used
 5918:          0, 1,       # green is not used
 5919:          2, 619,     # yellow, return a yellow gradient for values [2...619]
 5920:          620, 650,   # orange return a orange gradient for values [620 ... 650]
 5921:          651, 660    # red return a red gradient for values [651 ... 660]
 5922:          ], numpy.int)
 5923: 
 5924: 
 5925:     :param wavelength   : integer; Wavelength
 5926:     :param gamma        : float; Gamma value
 5927:     :param color_array_ : numpy array containing the min and max of each color (red,
 5928:     orange, yellow, green, blue, violet)
 5929:     :return             : tuple RGB values (0 ... 255)
 5930:     """
 5931:     cdef  rgb_color_int rgb_c
 5932:     cdef int *p
+5933:     p = &color_array_[0]
  __pyx_t_1 = 0;
  __pyx_v_p = (&(*((int *) ( /* dim=0 */ (__pyx_v_color_array_.data + __pyx_t_1 * __pyx_v_color_array_.strides[0]) ))));
+5934:     rgb_c = wavelength_to_rgb_custom(wavelength, p, gamma)
  __pyx_v_rgb_c = wavelength_to_rgb_custom(__pyx_v_wavelength, __pyx_v_p, __pyx_v_gamma);
+5935:     return rgb_c.r, rgb_c.g, rgb_c.b
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.r); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5935, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.g); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5935, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.b); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5935, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5935, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_t_4);
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __pyx_r = ((PyObject*)__pyx_t_5);
  __pyx_t_5 = 0;
  goto __pyx_L0;
 5936: 
 5937: 
 5938: 
 5939: 
+5940: cdef int i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+5941: HEATMAP = [heat_map(i, 1.0) for i in range(380, 750)]
  __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5941, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  for (__pyx_t_7 = 0x17C; __pyx_t_7 < 0x2EE; __pyx_t_7+=1) {
    __pyx_v_12PygameShader_6shader_i = __pyx_t_7;
    __pyx_t_38.__pyx_n = 1;
    __pyx_t_38.gamma = 1.0;
    __pyx_t_33 = __pyx_f_12PygameShader_6shader_heat_map(__pyx_v_12PygameShader_6shader_i, 0, &__pyx_t_38); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 5941, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_33);
    if (unlikely(__Pyx_ListComp_Append(__pyx_t_2, (PyObject*)__pyx_t_33))) __PYX_ERR(1, 5941, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  }
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_HEATMAP, __pyx_t_2) < 0) __PYX_ERR(1, 5941, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 5942: 
+5943: cdef float f_map = (<float>750.0 - <float>380.0 -<float>1.0) / (<float>255.0 * <float>3.0)
  __pyx_v_12PygameShader_6shader_f_map = (((((float)750.0) - ((float)380.0)) - ((float)1.0)) / (((float)255.0) * ((float)3.0)));
 5944: 
+5945: cdef unsigned char[:, ::1] heatmap_array = numpy.zeros((750 - 380, 3), numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_tuple__59);
  __Pyx_GIVEREF(__pyx_tuple__59);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_tuple__59);
  __Pyx_GIVEREF(__pyx_t_32);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_32);
  __pyx_t_32 = 0;
  __pyx_t_32 = __Pyx_PyObject_Call(__pyx_t_33, __pyx_t_2, NULL); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_39 = __Pyx_PyObject_to_MemoryviewSlice_d_dc_unsigned_char(__pyx_t_32, PyBUF_WRITABLE); if (unlikely(!__pyx_t_39.memview)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_heatmap_array, 1);
  __pyx_v_12PygameShader_6shader_heatmap_array = __pyx_t_39;
  __pyx_t_39.memview = NULL;
  __pyx_t_39.data = NULL;
/* … */
  __pyx_tuple__59 = PyTuple_Pack(2, __pyx_int_370, __pyx_int_3); if (unlikely(!__pyx_tuple__59)) __PYX_ERR(1, 5945, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__59);
  __Pyx_GIVEREF(__pyx_tuple__59);
 5946: cdef tuple t
+5947: i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+5948: for t in HEATMAP:
  __Pyx_GetModuleGlobalName(__pyx_t_32, __pyx_n_s_HEATMAP); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5948, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  if (likely(PyList_CheckExact(__pyx_t_32)) || PyTuple_CheckExact(__pyx_t_32)) {
    __pyx_t_2 = __pyx_t_32; __Pyx_INCREF(__pyx_t_2); __pyx_t_40 = 0;
    __pyx_t_41 = NULL;
  } else {
    __pyx_t_40 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5948, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_41 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_41)) __PYX_ERR(1, 5948, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  for (;;) {
    if (likely(!__pyx_t_41)) {
      if (likely(PyList_CheckExact(__pyx_t_2))) {
        if (__pyx_t_40 >= PyList_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_32 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_32); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 5948, __pyx_L1_error)
        #else
        __pyx_t_32 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5948, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_32);
        #endif
      } else {
        if (__pyx_t_40 >= PyTuple_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_32 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_32); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 5948, __pyx_L1_error)
        #else
        __pyx_t_32 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 5948, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_32);
        #endif
      }
    } else {
      __pyx_t_32 = __pyx_t_41(__pyx_t_2);
      if (unlikely(!__pyx_t_32)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();
          else __PYX_ERR(1, 5948, __pyx_L1_error)
        }
        break;
      }
      __Pyx_GOTREF(__pyx_t_32);
    }
    if (!(likely(PyTuple_CheckExact(__pyx_t_32))||((__pyx_t_32) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_t_32)->tp_name), 0))) __PYX_ERR(1, 5948, __pyx_L1_error)
    __Pyx_XGOTREF(__pyx_v_12PygameShader_6shader_t);
    __Pyx_DECREF_SET(__pyx_v_12PygameShader_6shader_t, ((PyObject*)__pyx_t_32));
    __Pyx_GIVEREF(__pyx_t_32);
    __pyx_t_32 = 0;
/* … */
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+5949:     heatmap_array[i, 0] = t[0]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 5949, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 0)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 5949, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundLocalError("heatmap_array"); __PYX_ERR(1, 5949, __pyx_L1_error) }
    __pyx_t_43 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_44 = 0;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_43 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_44)) )) = __pyx_t_42;
+5950:     heatmap_array[i, 1] = t[1]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 5950, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 1)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 5950, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundLocalError("heatmap_array"); __PYX_ERR(1, 5950, __pyx_L1_error) }
    __pyx_t_44 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_43 = 1;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_44 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_43)) )) = __pyx_t_42;
+5951:     heatmap_array[i, 2] = t[2]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 5951, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 2)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 5951, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundLocalError("heatmap_array"); __PYX_ERR(1, 5951, __pyx_L1_error) }
    __pyx_t_43 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_44 = 2;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_43 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_44)) )) = __pyx_t_42;
+5952:     i += 1
    __pyx_v_12PygameShader_6shader_i = (__pyx_v_12PygameShader_6shader_i + 1);
 5953: 
 5954: 
 5955: 
 5956: @cython.binding(False)
 5957: @cython.boundscheck(False)
 5958: @cython.wraparound(False)
 5959: @cython.nonecheck(False)
 5960: @cython.cdivision(True)
+5961: cpdef inline void heatmap_convert(object surface_, bint rgb_=True):
static PyObject *__pyx_pw_12PygameShader_6shader_147heatmap_convert(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_heatmap_convert(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_heatmap_convert *__pyx_optional_args) {
  int __pyx_v_rgb_ = ((int)1);
  CYTHON_UNUSED unsigned int __pyx_v_w;
  CYTHON_UNUSED unsigned int __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned int __pyx_v_s;
  int __pyx_v_i;
  CYTHON_UNUSED int __pyx_v_size;
  unsigned int __pyx_v_index;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  CYTHON_UNUSED short __pyx_v_bitsize;
  CYTHON_UNUSED short __pyx_v_bytesize;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap_convert", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_rgb_ = __pyx_optional_args->rgb_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.heatmap_convert", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array, 1);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_147heatmap_convert(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_146heatmap_convert[] = "\n    TRANSFORM AN IMAGE INTO A HEATMAP EQUIVALENT\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param surface_ : pygame.Surface\n    :param rgb_     : boolean; True transformed the image into a RGB heatmap model of False (BGR)\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_147heatmap_convert(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_rgb_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap_convert (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_rgb,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_rgb);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "heatmap_convert") < 0)) __PYX_ERR(1, 5961, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    if (values[1]) {
      __pyx_v_rgb_ = __Pyx_PyObject_IsTrue(values[1]); if (unlikely((__pyx_v_rgb_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5961, __pyx_L3_error)
    } else {
      __pyx_v_rgb_ = ((int)1);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("heatmap_convert", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 5961, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.heatmap_convert", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_146heatmap_convert(__pyx_self, __pyx_v_surface_, __pyx_v_rgb_);

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_146heatmap_convert(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_rgb_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("heatmap_convert", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1.__pyx_n = 1;
  __pyx_t_1.rgb_ = __pyx_v_rgb_;
  __pyx_f_12PygameShader_6shader_heatmap_convert(__pyx_v_surface_, 0, &__pyx_t_1); 
  __pyx_t_2 = __Pyx_void_to_None(NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5961, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("PygameShader.shader.heatmap_convert", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_heatmap_convert {
  int __pyx_n;
  int rgb_;
};
 5962:     """
 5963:     TRANSFORM AN IMAGE INTO A HEATMAP EQUIVALENT
 5964: 
 5965:     Cython cpdef function, this function can be called directly and do not require a
 5966:     hook function.
 5967: 
 5968:     :param surface_ : pygame.Surface
 5969:     :param rgb_     : boolean; True transformed the image into a RGB heatmap model of False (BGR)
 5970:     :return         : void
 5971:     """
 5972: 
 5973:     cdef:
 5974:         unsigned int w, h
+5975:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5975, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 5975, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5975, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5975, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5975, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 5975, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 5975, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyInt_As_unsigned_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5975, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_unsigned_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5975, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 5976: 
 5977:     cdef:
+5978:         unsigned char [::1] rgb_array  = surface_.get_buffer()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5978, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5978, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 5978, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rgb_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 5979:         unsigned int s
 5980:         int i
+5981:         int size = rgb_array.size
  __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_rgb_array, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5981, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5981, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 5981, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_size = __pyx_t_9;
+5982:         unsigned int index = 0
  __pyx_v_index = 0;
 5983:         unsigned char *r
 5984:         unsigned char *g
 5985:         unsigned char *b
+5986:         short int bitsize = surface_.get_bitsize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bitsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5986, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5986, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 5986, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bitsize = __pyx_t_10;
+5987:         short int bytesize = surface_.get_bytesize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bytesize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5987, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5987, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 5987, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bytesize = __pyx_t_10;
 5988: 
+5989:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L6_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L7:;
      }
  }
 5990:         # RGB
+5991:         if rgb_:
        __pyx_t_11 = (__pyx_v_rgb_ != 0);
        if (__pyx_t_11) {
/* … */
          goto __pyx_L8;
        }
+5992:             for i in prange(0, size, bytesize, schedule='static', num_threads=THREADS):
          __pyx_t_9 = __pyx_v_size;
          __pyx_t_10 = __pyx_v_bytesize;
          if ((__pyx_t_10 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_13 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
              if (__pyx_t_13 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static)          __pyx_t_10 = __pyx_v_bytesize;
          if ((__pyx_t_10 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_13 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
              if (__pyx_t_13 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                      #endif /* _OPENMP */
                      for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_13; __pyx_t_12++){
                          {
                              __pyx_v_i = (int)(0 + __pyx_t_10 * __pyx_t_12);
                              /* Initialize private variables to invalid values */
                              __pyx_v_b = ((unsigned char *)1);
                              __pyx_v_g = ((unsigned char *)1);
                              __pyx_v_index = ((unsigned int)0xbad0bad0);
                              __pyx_v_r = ((unsigned char *)1);
                              __pyx_v_s = ((unsigned int)0xbad0bad0);
 5993: 
+5994:                 r = &rgb_array[i]
                              __pyx_t_14 = __pyx_v_i;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
+5995:                 g = &rgb_array[i + 1]
                              __pyx_t_14 = (__pyx_v_i + 1);
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
+5996:                 b = &rgb_array[i + 2]
                              __pyx_t_14 = (__pyx_v_i + 2);
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
 5997: 
+5998:                 s = r[0] + g[0] + b[0]
                              __pyx_v_s = (((__pyx_v_r[0]) + (__pyx_v_g[0])) + (__pyx_v_b[0]));
+5999:                 index = <int>(s * f_map)
                              __pyx_v_index = ((int)(__pyx_v_s * __pyx_v_12PygameShader_6shader_f_map));
 6000: 
+6001:                 r[0] = <unsigned char>heatmap_array[index, 0]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6001, __pyx_L11_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 0;
                              (__pyx_v_r[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
+6002:                 g[0] = <unsigned char>heatmap_array[index, 1]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6002, __pyx_L11_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 1;
                              (__pyx_v_g[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
+6003:                 b[0] = <unsigned char>heatmap_array[index, 2]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6003, __pyx_L11_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 2;
                              (__pyx_v_b[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
                              goto __pyx_L14;
                              __pyx_L11_error:;
                              {
                                  #ifdef WITH_THREAD
                                  PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                  #endif
                                  #ifdef _OPENMP
                                  #pragma omp flush(__pyx_parallel_exc_type)
                                  #endif /* _OPENMP */
                                  if (!__pyx_parallel_exc_type) {
                                    __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                    __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                    __Pyx_GOTREF(__pyx_parallel_exc_type);
                                  }
                                  #ifdef WITH_THREAD
                                  __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                  #endif
                              }
                              __pyx_parallel_why = 4;
                              goto __pyx_L13;
                              __pyx_L13:;
                              #ifdef _OPENMP
                              #pragma omp critical(__pyx_parallel_lastprivates3)
                              #endif /* _OPENMP */
                              {
                                  __pyx_parallel_temp0 = __pyx_v_b;
                                  __pyx_parallel_temp1 = __pyx_v_g;
                                  __pyx_parallel_temp2 = __pyx_v_i;
                                  __pyx_parallel_temp3 = __pyx_v_index;
                                  __pyx_parallel_temp4 = __pyx_v_r;
                                  __pyx_parallel_temp5 = __pyx_v_s;
                              }
                              __pyx_L14:;
                              #ifdef _OPENMP
                              #pragma omp flush(__pyx_parallel_why)
                              #endif /* _OPENMP */
                          }
                      }
                      #ifdef _OPENMP
                      Py_END_ALLOW_THREADS
                      #else
{
#ifdef WITH_THREAD
                      PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                      #endif
                      #endif /* _OPENMP */
                      /* Clean up any temporaries */
                      #ifdef WITH_THREAD
                      __Pyx_PyGILState_Release(__pyx_gilstate_save);
                      #endif
                      #ifndef _OPENMP
}
#endif /* _OPENMP */
                  }
              }
              if (__pyx_parallel_exc_type) {
                /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
                __pyx_parallel_why = 4;
              }
              if (__pyx_parallel_why) {
                __pyx_v_b = __pyx_parallel_temp0;
                __pyx_v_g = __pyx_parallel_temp1;
                __pyx_v_i = __pyx_parallel_temp2;
                __pyx_v_index = __pyx_parallel_temp3;
                __pyx_v_r = __pyx_parallel_temp4;
                __pyx_v_s = __pyx_parallel_temp5;
                switch (__pyx_parallel_why) {
                      case 4:
                  {
                      #ifdef WITH_THREAD
                      PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                      #endif
                      __Pyx_GIVEREF(__pyx_parallel_exc_type);
                      __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                      __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                      #ifdef WITH_THREAD
                      __Pyx_PyGILState_Release(__pyx_gilstate_save);
                      #endif
                  }
                  goto __pyx_L6_error;
                }
              }
          }
          #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
              #undef likely
              #undef unlikely
              #define likely(x)   __builtin_expect(!!(x), 1)
              #define unlikely(x) __builtin_expect(!!(x), 0)
          #endif
 6004:         # BGR
 6005:         else:
+6006:             for i in prange(0, size, bytesize, schedule='static', num_threads=THREADS):
        /*else*/ {
          __pyx_t_9 = __pyx_v_size;
          __pyx_t_10 = __pyx_v_bytesize;
          if ((__pyx_t_10 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
              if (__pyx_t_12 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static)          __pyx_t_10 = __pyx_v_bytesize;
          if ((__pyx_t_10 == 0)) abort();
          {
              #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                  #undef likely
                  #undef unlikely
                  #define likely(x)   (x)
                  #define unlikely(x) (x)
              #endif
              __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
              if (__pyx_t_12 > 0)
              {
                  #ifdef _OPENMP
                  #pragma omp parallel
                  #endif /* _OPENMP */
                  {
                      #ifdef _OPENMP
                      #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                      #endif /* _OPENMP */
                      for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_12; __pyx_t_13++){
                          {
                              __pyx_v_i = (int)(0 + __pyx_t_10 * __pyx_t_13);
                              /* Initialize private variables to invalid values */
                              __pyx_v_b = ((unsigned char *)1);
                              __pyx_v_g = ((unsigned char *)1);
                              __pyx_v_index = ((unsigned int)0xbad0bad0);
                              __pyx_v_r = ((unsigned char *)1);
                              __pyx_v_s = ((unsigned int)0xbad0bad0);
 6007: 
+6008:                 r = &rgb_array[i]
                              __pyx_t_14 = __pyx_v_i;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
+6009:                 g = &rgb_array[i + 1]
                              __pyx_t_14 = (__pyx_v_i + 1);
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
+6010:                 b = &rgb_array[i + 2]
                              __pyx_t_14 = (__pyx_v_i + 2);
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_14)) ))));
 6011: 
+6012:                 s = r[0] + g[0] + b[0]
                              __pyx_v_s = (((__pyx_v_r[0]) + (__pyx_v_g[0])) + (__pyx_v_b[0]));
+6013:                 index = <int>(s * f_map)
                              __pyx_v_index = ((int)(__pyx_v_s * __pyx_v_12PygameShader_6shader_f_map));
 6014: 
+6015:                 r[0] = <unsigned char>heatmap_array[index, 2]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6015, __pyx_L17_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 2;
                              (__pyx_v_r[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
+6016:                 g[0] = <unsigned char>heatmap_array[index, 1]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6016, __pyx_L17_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 1;
                              (__pyx_v_g[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
+6017:                 b[0] = <unsigned char>heatmap_array[index, 0]
                              if (unlikely(!__pyx_v_12PygameShader_6shader_heatmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("heatmap_array"); __PYX_ERR(1, 6017, __pyx_L17_error) }
                              __pyx_t_15 = __pyx_v_index;
                              __pyx_t_14 = 0;
                              (__pyx_v_b[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_heatmap_array.data + __pyx_t_15 * __pyx_v_12PygameShader_6shader_heatmap_array.strides[0]) )) + __pyx_t_14)) ))));
                              goto __pyx_L20;
                              __pyx_L17_error:;
                              {
                                  #ifdef WITH_THREAD
                                  PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                  #endif
                                  #ifdef _OPENMP
                                  #pragma omp flush(__pyx_parallel_exc_type)
                                  #endif /* _OPENMP */
                                  if (!__pyx_parallel_exc_type) {
                                    __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                    __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                    __Pyx_GOTREF(__pyx_parallel_exc_type);
                                  }
                                  #ifdef WITH_THREAD
                                  __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                  #endif
                              }
                              __pyx_parallel_why = 4;
                              goto __pyx_L19;
                              __pyx_L19:;
                              #ifdef _OPENMP
                              #pragma omp critical(__pyx_parallel_lastprivates4)
                              #endif /* _OPENMP */
                              {
                                  __pyx_parallel_temp0 = __pyx_v_b;
                                  __pyx_parallel_temp1 = __pyx_v_g;
                                  __pyx_parallel_temp2 = __pyx_v_i;
                                  __pyx_parallel_temp3 = __pyx_v_index;
                                  __pyx_parallel_temp4 = __pyx_v_r;
                                  __pyx_parallel_temp5 = __pyx_v_s;
                              }
                              __pyx_L20:;
                              #ifdef _OPENMP
                              #pragma omp flush(__pyx_parallel_why)
                              #endif /* _OPENMP */
                          }
                      }
                      #ifdef _OPENMP
                      Py_END_ALLOW_THREADS
                      #else
{
#ifdef WITH_THREAD
                      PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                      #endif
                      #endif /* _OPENMP */
                      /* Clean up any temporaries */
                      #ifdef WITH_THREAD
                      __Pyx_PyGILState_Release(__pyx_gilstate_save);
                      #endif
                      #ifndef _OPENMP
}
#endif /* _OPENMP */
                  }
              }
              if (__pyx_parallel_exc_type) {
                /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
                __pyx_parallel_why = 4;
              }
              if (__pyx_parallel_why) {
                __pyx_v_b = __pyx_parallel_temp0;
                __pyx_v_g = __pyx_parallel_temp1;
                __pyx_v_i = __pyx_parallel_temp2;
                __pyx_v_index = __pyx_parallel_temp3;
                __pyx_v_r = __pyx_parallel_temp4;
                __pyx_v_s = __pyx_parallel_temp5;
                switch (__pyx_parallel_why) {
                      case 4:
                  {
                      #ifdef WITH_THREAD
                      PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                      #endif
                      __Pyx_GIVEREF(__pyx_parallel_exc_type);
                      __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                      __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                      #ifdef WITH_THREAD
                      __Pyx_PyGILState_Release(__pyx_gilstate_save);
                      #endif
                  }
                  goto __pyx_L6_error;
                }
              }
          }
          #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
              #undef likely
              #undef unlikely
              #define likely(x)   __builtin_expect(!!(x), 1)
              #define unlikely(x) __builtin_expect(!!(x), 0)
          #endif
        }
        __pyx_L8:;
      }
 6018: 
 6019: 
 6020: 
 6021: @cython.binding(False)
 6022: @cython.boundscheck(False)
 6023: @cython.wraparound(False)
 6024: @cython.nonecheck(False)
 6025: @cython.cdivision(True)
+6026: cpdef tuple blue_map(int wavelength, float gamma=1.0):
static PyObject *__pyx_pw_12PygameShader_6shader_149blue_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_blue_map(int __pyx_v_wavelength, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_blue_map *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  struct rgb_color_int __pyx_v_rgb_c;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blue_map", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("PygameShader.shader.blue_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_149blue_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_148blue_map[] = "\n    RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param wavelength   : integer; Wavelength\n    :param gamma        : float; Gamma value\n    :return             : tuple RGB values (0 ... 255)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_149blue_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_wavelength;
  float __pyx_v_gamma;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blue_map (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_wavelength,&__pyx_n_s_gamma,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_wavelength)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_gamma);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "blue_map") < 0)) __PYX_ERR(1, 6026, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_wavelength = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_wavelength == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6026, __pyx_L3_error)
    if (values[1]) {
      __pyx_v_gamma = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_gamma == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 6026, __pyx_L3_error)
    } else {
      __pyx_v_gamma = ((float)1.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("blue_map", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 6026, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.blue_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_148blue_map(__pyx_self, __pyx_v_wavelength, __pyx_v_gamma);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_148blue_map(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_wavelength, float __pyx_v_gamma) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blue_map", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_blue_map(__pyx_v_wavelength, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6026, __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("PygameShader.shader.blue_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_blue_map {
  int __pyx_n;
  float gamma;
};
 6027:     """
 6028:     RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH
 6029: 
 6030:     Cython cpdef function, this function can be called directly and do not require a
 6031:     hook function.
 6032: 
 6033:     :param wavelength   : integer; Wavelength
 6034:     :param gamma        : float; Gamma value
 6035:     :return             : tuple RGB values (0 ... 255)
 6036:     """
 6037:     cdef  rgb_color_int rgb_c
+6038:     rgb_c = wavelength_to_rgb(wavelength, gamma)
  __pyx_v_rgb_c = wavelength_to_rgb(__pyx_v_wavelength, __pyx_v_gamma);
+6039:     return rgb_c.r, rgb_c.g, rgb_c.b
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.r); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6039, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.g); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6039, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.b); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6039, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6039, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_3);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_r = ((PyObject*)__pyx_t_4);
  __pyx_t_4 = 0;
  goto __pyx_L0;
 6040: 
+6041: i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+6042: BLUEMAP = [ blue_map(i, 1.0) for i in range(450, 495) ]
  __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6042, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  for (__pyx_t_7 = 0x1C2; __pyx_t_7 < 0x1EF; __pyx_t_7+=1) {
    __pyx_v_12PygameShader_6shader_i = __pyx_t_7;
    __pyx_t_45.__pyx_n = 1;
    __pyx_t_45.gamma = 1.0;
    __pyx_t_32 = __pyx_f_12PygameShader_6shader_blue_map(__pyx_v_12PygameShader_6shader_i, 0, &__pyx_t_45); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6042, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_32);
    if (unlikely(__Pyx_ListComp_Append(__pyx_t_2, (PyObject*)__pyx_t_32))) __PYX_ERR(1, 6042, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  }
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_BLUEMAP, __pyx_t_2) < 0) __PYX_ERR(1, 6042, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 6043: 
+6044: cdef float f_bluemap = (<float>495.0 - <float>450.0 - <float>1.0) / (<float>255.0 * <float>3.0)
  __pyx_v_12PygameShader_6shader_f_bluemap = (((((float)495.0) - ((float)450.0)) - ((float)1.0)) / (((float)255.0) * ((float)3.0)));
 6045: 
+6046: cdef unsigned char[:, ::1] bluemap_array = numpy.zeros((495 - 450, 3), numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_tuple__60);
  __Pyx_GIVEREF(__pyx_tuple__60);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_tuple__60);
  __Pyx_GIVEREF(__pyx_t_33);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_33);
  __pyx_t_33 = 0;
  __pyx_t_33 = __Pyx_PyObject_Call(__pyx_t_32, __pyx_t_2, NULL); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_39 = __Pyx_PyObject_to_MemoryviewSlice_d_dc_unsigned_char(__pyx_t_33, PyBUF_WRITABLE); if (unlikely(!__pyx_t_39.memview)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_bluemap_array, 1);
  __pyx_v_12PygameShader_6shader_bluemap_array = __pyx_t_39;
  __pyx_t_39.memview = NULL;
  __pyx_t_39.data = NULL;
/* … */
  __pyx_tuple__60 = PyTuple_Pack(2, __pyx_int_45, __pyx_int_3); if (unlikely(!__pyx_tuple__60)) __PYX_ERR(1, 6046, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__60);
  __Pyx_GIVEREF(__pyx_tuple__60);
 6047: 
+6048: i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+6049: for t in BLUEMAP:
  __Pyx_GetModuleGlobalName(__pyx_t_33, __pyx_n_s_BLUEMAP); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  if (likely(PyList_CheckExact(__pyx_t_33)) || PyTuple_CheckExact(__pyx_t_33)) {
    __pyx_t_2 = __pyx_t_33; __Pyx_INCREF(__pyx_t_2); __pyx_t_40 = 0;
    __pyx_t_41 = NULL;
  } else {
    __pyx_t_40 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_33); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_41 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_41)) __PYX_ERR(1, 6049, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  for (;;) {
    if (likely(!__pyx_t_41)) {
      if (likely(PyList_CheckExact(__pyx_t_2))) {
        if (__pyx_t_40 >= PyList_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_33 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_33); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 6049, __pyx_L1_error)
        #else
        __pyx_t_33 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6049, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_33);
        #endif
      } else {
        if (__pyx_t_40 >= PyTuple_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_33 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_33); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 6049, __pyx_L1_error)
        #else
        __pyx_t_33 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6049, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_33);
        #endif
      }
    } else {
      __pyx_t_33 = __pyx_t_41(__pyx_t_2);
      if (unlikely(!__pyx_t_33)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();
          else __PYX_ERR(1, 6049, __pyx_L1_error)
        }
        break;
      }
      __Pyx_GOTREF(__pyx_t_33);
    }
    if (!(likely(PyTuple_CheckExact(__pyx_t_33))||((__pyx_t_33) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_t_33)->tp_name), 0))) __PYX_ERR(1, 6049, __pyx_L1_error)
    __Pyx_XGOTREF(__pyx_v_12PygameShader_6shader_t);
    __Pyx_DECREF_SET(__pyx_v_12PygameShader_6shader_t, ((PyObject*)__pyx_t_33));
    __Pyx_GIVEREF(__pyx_t_33);
    __pyx_t_33 = 0;
/* … */
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6050:     bluemap_array[i, 0] = t[0]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6050, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 0)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6050, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundLocalError("bluemap_array"); __PYX_ERR(1, 6050, __pyx_L1_error) }
    __pyx_t_44 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_43 = 0;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_44 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_43)) )) = __pyx_t_42;
+6051:     bluemap_array[i, 1] = t[1]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6051, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 1)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6051, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundLocalError("bluemap_array"); __PYX_ERR(1, 6051, __pyx_L1_error) }
    __pyx_t_43 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_44 = 1;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_43 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_44)) )) = __pyx_t_42;
+6052:     bluemap_array[i, 2] = t[2]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6052, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 2)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6052, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundLocalError("bluemap_array"); __PYX_ERR(1, 6052, __pyx_L1_error) }
    __pyx_t_44 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_43 = 2;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_44 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_43)) )) = __pyx_t_42;
+6053:     i += 1
    __pyx_v_12PygameShader_6shader_i = (__pyx_v_12PygameShader_6shader_i + 1);
 6054: 
 6055: @cython.binding(False)
 6056: @cython.boundscheck(False)
 6057: @cython.wraparound(False)
 6058: @cython.nonecheck(False)
 6059: @cython.cdivision(True)
+6060: cpdef inline void bluescale(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_151bluescale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_bluescale(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  CYTHON_UNUSED unsigned int __pyx_v_w;
  CYTHON_UNUSED unsigned int __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned int __pyx_v_s;
  int __pyx_v_i;
  CYTHON_UNUSED int __pyx_v_size;
  unsigned int __pyx_v_index;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  CYTHON_UNUSED short __pyx_v_bitsize;
  CYTHON_UNUSED short __pyx_v_bytesize;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bluescale", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.bluescale", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array, 1);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_151bluescale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_150bluescale[] = "\n    MAP AN IMAGE INTO A BLUE EQUIVALENT FORMAT\n    THIS ALGORITHM IS USING THE WAVELENGTH FROM 450-495 NM TO\n    REPRESENT THE IMAGE IN BLUE SHADES\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param surface_ : pygame.Surface to transform\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_151bluescale(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bluescale (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_150bluescale(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_150bluescale(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bluescale", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_bluescale(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6060, __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("PygameShader.shader.bluescale", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 6061:     """
 6062:     MAP AN IMAGE INTO A BLUE EQUIVALENT FORMAT
 6063:     THIS ALGORITHM IS USING THE WAVELENGTH FROM 450-495 NM TO
 6064:     REPRESENT THE IMAGE IN BLUE SHADES
 6065: 
 6066:     Cython cpdef function, this function can be called directly and do not require a
 6067:     hook function.
 6068: 
 6069:     :param surface_ : pygame.Surface to transform
 6070:     :return         : void
 6071:     """
 6072: 
 6073: 
 6074:     cdef:
 6075:         unsigned int w, h
+6076:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6076, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6076, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 6076, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6076, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6076, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6076, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 6076, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 6076, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyInt_As_unsigned_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6076, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_unsigned_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6076, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 6077: 
 6078:     cdef:
+6079:         unsigned char [::1] rgb_array  = surface_.get_buffer()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6079, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 6079, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rgb_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 6080:         unsigned int s
 6081:         int i
+6082:         int size = rgb_array.size
  __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_rgb_array, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6082, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6082, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6082, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_size = __pyx_t_9;
+6083:         unsigned int index = 0
  __pyx_v_index = 0;
 6084:         unsigned char *r
 6085:         unsigned char *g
 6086:         unsigned char *b
+6087:         short int bitsize = surface_.get_bitsize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bitsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6087, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6087, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 6087, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bitsize = __pyx_t_10;
+6088:         short int bytesize = surface_.get_bytesize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bytesize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6088, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6088, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 6088, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bytesize = __pyx_t_10;
 6089: 
+6090:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L6_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L7:;
      }
  }
+6091:         for i in prange(0, size, bytesize, schedule='static', num_threads=THREADS):
        __pyx_t_9 = __pyx_v_size;
        __pyx_t_10 = __pyx_v_bytesize;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static)        __pyx_t_10 = __pyx_v_bytesize;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_12; __pyx_t_11++){
                        {
                            __pyx_v_i = (int)(0 + __pyx_t_10 * __pyx_t_11);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_index = ((unsigned int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_s = ((unsigned int)0xbad0bad0);
 6092: 
+6093:             r = &rgb_array[i]
                            __pyx_t_13 = __pyx_v_i;
                            __pyx_v_r = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
+6094:             g = &rgb_array[i + 1]
                            __pyx_t_13 = (__pyx_v_i + 1);
                            __pyx_v_g = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
+6095:             b = &rgb_array[i + 2]
                            __pyx_t_13 = (__pyx_v_i + 2);
                            __pyx_v_b = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
 6096: 
+6097:             s = r[0] + g[0] + b[0]
                            __pyx_v_s = (((__pyx_v_r[0]) + (__pyx_v_g[0])) + (__pyx_v_b[0]));
+6098:             index = <int>(s * f_bluemap)
                            __pyx_v_index = ((int)(__pyx_v_s * __pyx_v_12PygameShader_6shader_f_bluemap));
 6099: 
+6100:             r[0] = <unsigned char>bluemap_array[index, 2]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("bluemap_array"); __PYX_ERR(1, 6100, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 2;
                            (__pyx_v_r[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_13)) ))));
+6101:             g[0] = <unsigned char>bluemap_array[index, 1]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("bluemap_array"); __PYX_ERR(1, 6101, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 1;
                            (__pyx_v_g[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_13)) ))));
+6102:             b[0] = <unsigned char>bluemap_array[index, 0]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_bluemap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("bluemap_array"); __PYX_ERR(1, 6102, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 0;
                            (__pyx_v_b[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_bluemap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_bluemap_array.strides[0]) )) + __pyx_t_13)) ))));
                            goto __pyx_L13;
                            __pyx_L10_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L12;
                            __pyx_L12:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates5)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_b;
                                __pyx_parallel_temp1 = __pyx_v_g;
                                __pyx_parallel_temp2 = __pyx_v_i;
                                __pyx_parallel_temp3 = __pyx_v_index;
                                __pyx_parallel_temp4 = __pyx_v_r;
                                __pyx_parallel_temp5 = __pyx_v_s;
                            }
                            __pyx_L13:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_b = __pyx_parallel_temp0;
              __pyx_v_g = __pyx_parallel_temp1;
              __pyx_v_i = __pyx_parallel_temp2;
              __pyx_v_index = __pyx_parallel_temp3;
              __pyx_v_r = __pyx_parallel_temp4;
              __pyx_v_s = __pyx_parallel_temp5;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L6_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 6103: 
 6104: 
 6105: 
 6106: @cython.binding(False)
 6107: @cython.boundscheck(False)
 6108: @cython.wraparound(False)
 6109: @cython.nonecheck(False)
 6110: @cython.cdivision(True)
+6111: cpdef tuple red_map(int wavelength, float gamma=1.0):
static PyObject *__pyx_pw_12PygameShader_6shader_153red_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_red_map(int __pyx_v_wavelength, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_red_map *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  struct rgb_color_int __pyx_v_rgb_c;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("red_map", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("PygameShader.shader.red_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_153red_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_152red_map[] = "\n    RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param wavelength   : integer; Wavelength\n    :param gamma        : float; Gamma value\n    :return             : tuple RGB values (0 ... 255)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_153red_map(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_wavelength;
  float __pyx_v_gamma;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("red_map (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_wavelength,&__pyx_n_s_gamma,0};
    PyObject* values[2] = {0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_wavelength)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_gamma);
          if (value) { values[1] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "red_map") < 0)) __PYX_ERR(1, 6111, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_wavelength = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_wavelength == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6111, __pyx_L3_error)
    if (values[1]) {
      __pyx_v_gamma = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_gamma == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 6111, __pyx_L3_error)
    } else {
      __pyx_v_gamma = ((float)1.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("red_map", 0, 1, 2, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 6111, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.red_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_152red_map(__pyx_self, __pyx_v_wavelength, __pyx_v_gamma);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_152red_map(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_wavelength, float __pyx_v_gamma) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("red_map", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 1;
  __pyx_t_2.gamma = __pyx_v_gamma;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_red_map(__pyx_v_wavelength, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6111, __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("PygameShader.shader.red_map", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_red_map {
  int __pyx_n;
  float gamma;
};
 6112:     """
 6113:     RETURN AN RGB COLOR VALUE MATCHING A SPECIFIC WAVELENGTH
 6114: 
 6115:     Cython cpdef function, this function can be called directly and do not require a
 6116:     hook function.
 6117: 
 6118:     :param wavelength   : integer; Wavelength
 6119:     :param gamma        : float; Gamma value
 6120:     :return             : tuple RGB values (0 ... 255)
 6121:     """
 6122:     cdef  rgb_color_int rgb_c
+6123:     rgb_c = wavelength_to_rgb(wavelength, gamma)
  __pyx_v_rgb_c = wavelength_to_rgb(__pyx_v_wavelength, __pyx_v_gamma);
+6124:     return rgb_c.r, rgb_c.g, rgb_c.b
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.r); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6124, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.g); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6124, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_rgb_c.b); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6124, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6124, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_3);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_r = ((PyObject*)__pyx_t_4);
  __pyx_t_4 = 0;
  goto __pyx_L0;
 6125: 
+6126: i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+6127: REDMAP = [ red_map(i, 1.0) for i in range(620, 750) ]
  __pyx_t_2 = PyList_New(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6127, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  for (__pyx_t_7 = 0x26C; __pyx_t_7 < 0x2EE; __pyx_t_7+=1) {
    __pyx_v_12PygameShader_6shader_i = __pyx_t_7;
    __pyx_t_46.__pyx_n = 1;
    __pyx_t_46.gamma = 1.0;
    __pyx_t_33 = __pyx_f_12PygameShader_6shader_red_map(__pyx_v_12PygameShader_6shader_i, 0, &__pyx_t_46); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6127, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_33);
    if (unlikely(__Pyx_ListComp_Append(__pyx_t_2, (PyObject*)__pyx_t_33))) __PYX_ERR(1, 6127, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  }
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_REDMAP, __pyx_t_2) < 0) __PYX_ERR(1, 6127, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 6128: 
+6129: cdef float f_redmap = (<float>750.0 - <float>620.0 - <float>1.0) / (<float>255.0 * <float>3.0)
  __pyx_v_12PygameShader_6shader_f_redmap = (((((float)750.0) - ((float)620.0)) - ((float)1.0)) / (((float)255.0) * ((float)3.0)));
 6130: 
+6131: cdef unsigned char[:, ::1] redmap_array = numpy.zeros((750 - 620, 3), numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_33 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_zeros); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_tuple__61);
  __Pyx_GIVEREF(__pyx_tuple__61);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_tuple__61);
  __Pyx_GIVEREF(__pyx_t_32);
  PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_32);
  __pyx_t_32 = 0;
  __pyx_t_32 = __Pyx_PyObject_Call(__pyx_t_33, __pyx_t_2, NULL); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_33); __pyx_t_33 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_39 = __Pyx_PyObject_to_MemoryviewSlice_d_dc_unsigned_char(__pyx_t_32, PyBUF_WRITABLE); if (unlikely(!__pyx_t_39.memview)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_redmap_array, 1);
  __pyx_v_12PygameShader_6shader_redmap_array = __pyx_t_39;
  __pyx_t_39.memview = NULL;
  __pyx_t_39.data = NULL;
/* … */
  __pyx_tuple__61 = PyTuple_Pack(2, __pyx_int_130, __pyx_int_3); if (unlikely(!__pyx_tuple__61)) __PYX_ERR(1, 6131, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__61);
  __Pyx_GIVEREF(__pyx_tuple__61);
 6132: 
+6133: i = 0
  __pyx_v_12PygameShader_6shader_i = 0;
+6134: for t in REDMAP:
  __Pyx_GetModuleGlobalName(__pyx_t_32, __pyx_n_s_REDMAP); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6134, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  if (likely(PyList_CheckExact(__pyx_t_32)) || PyTuple_CheckExact(__pyx_t_32)) {
    __pyx_t_2 = __pyx_t_32; __Pyx_INCREF(__pyx_t_2); __pyx_t_40 = 0;
    __pyx_t_41 = NULL;
  } else {
    __pyx_t_40 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_t_32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6134, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_41 = Py_TYPE(__pyx_t_2)->tp_iternext; if (unlikely(!__pyx_t_41)) __PYX_ERR(1, 6134, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  for (;;) {
    if (likely(!__pyx_t_41)) {
      if (likely(PyList_CheckExact(__pyx_t_2))) {
        if (__pyx_t_40 >= PyList_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_32 = PyList_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_32); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 6134, __pyx_L1_error)
        #else
        __pyx_t_32 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6134, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_32);
        #endif
      } else {
        if (__pyx_t_40 >= PyTuple_GET_SIZE(__pyx_t_2)) break;
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_32 = PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_40); __Pyx_INCREF(__pyx_t_32); __pyx_t_40++; if (unlikely(0 < 0)) __PYX_ERR(1, 6134, __pyx_L1_error)
        #else
        __pyx_t_32 = PySequence_ITEM(__pyx_t_2, __pyx_t_40); __pyx_t_40++; if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 6134, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_32);
        #endif
      }
    } else {
      __pyx_t_32 = __pyx_t_41(__pyx_t_2);
      if (unlikely(!__pyx_t_32)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();
          else __PYX_ERR(1, 6134, __pyx_L1_error)
        }
        break;
      }
      __Pyx_GOTREF(__pyx_t_32);
    }
    if (!(likely(PyTuple_CheckExact(__pyx_t_32))||((__pyx_t_32) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_t_32)->tp_name), 0))) __PYX_ERR(1, 6134, __pyx_L1_error)
    __Pyx_XGOTREF(__pyx_v_12PygameShader_6shader_t);
    __Pyx_DECREF_SET(__pyx_v_12PygameShader_6shader_t, ((PyObject*)__pyx_t_32));
    __Pyx_GIVEREF(__pyx_t_32);
    __pyx_t_32 = 0;
/* … */
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+6135:     redmap_array[i, 0] = t[0]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6135, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 0)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6135, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundLocalError("redmap_array"); __PYX_ERR(1, 6135, __pyx_L1_error) }
    __pyx_t_43 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_44 = 0;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_43 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_44)) )) = __pyx_t_42;
+6136:     redmap_array[i, 1] = t[1]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6136, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 1)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6136, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundLocalError("redmap_array"); __PYX_ERR(1, 6136, __pyx_L1_error) }
    __pyx_t_44 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_43 = 1;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_44 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_43)) )) = __pyx_t_42;
+6137:     redmap_array[i, 2] = t[2]
    if (unlikely(__pyx_v_12PygameShader_6shader_t == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6137, __pyx_L1_error)
    }
    __pyx_t_42 = __Pyx_PyInt_As_unsigned_char(PyTuple_GET_ITEM(__pyx_v_12PygameShader_6shader_t, 2)); if (unlikely((__pyx_t_42 == (unsigned char)-1) && PyErr_Occurred())) __PYX_ERR(1, 6137, __pyx_L1_error)
    if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundLocalError("redmap_array"); __PYX_ERR(1, 6137, __pyx_L1_error) }
    __pyx_t_43 = __pyx_v_12PygameShader_6shader_i;
    __pyx_t_44 = 2;
    *((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_43 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_44)) )) = __pyx_t_42;
+6138:     i += 1
    __pyx_v_12PygameShader_6shader_i = (__pyx_v_12PygameShader_6shader_i + 1);
 6139: 
 6140: 
 6141: 
 6142: @cython.binding(False)
 6143: @cython.boundscheck(False)
 6144: @cython.wraparound(False)
 6145: @cython.nonecheck(False)
 6146: @cython.cdivision(True)
+6147: cpdef inline void redscale(object surface_):
static PyObject *__pyx_pw_12PygameShader_6shader_155redscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_redscale(PyObject *__pyx_v_surface_, CYTHON_UNUSED int __pyx_skip_dispatch) {
  CYTHON_UNUSED unsigned int __pyx_v_w;
  CYTHON_UNUSED unsigned int __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned int __pyx_v_s;
  int __pyx_v_i;
  CYTHON_UNUSED int __pyx_v_size;
  unsigned int __pyx_v_index;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  CYTHON_UNUSED short __pyx_v_bitsize;
  CYTHON_UNUSED short __pyx_v_bytesize;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("redscale", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.redscale", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array, 1);
  __Pyx_RefNannyFinishContext();
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_155redscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_); /*proto*/
static char __pyx_doc_12PygameShader_6shader_154redscale[] = "\n    MAP AN IMAGE INTO A RED EQUIVALENT FORMAT\n    THIS ALGORITHM IS USING THE WAVELENGTH FROM 620 TO 750 NM TO\n    REPRESENT THE IMAGE IN RED SHADES\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param surface_ : pygame.Surface to transform\n    :return         : void\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_155redscale(PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("redscale (wrapper)", 0);
  __pyx_r = __pyx_pf_12PygameShader_6shader_154redscale(__pyx_self, ((PyObject *)__pyx_v_surface_));

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_154redscale(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("redscale", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_void_to_None(__pyx_f_12PygameShader_6shader_redscale(__pyx_v_surface_, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6147, __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("PygameShader.shader.redscale", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 6148:     """
 6149:     MAP AN IMAGE INTO A RED EQUIVALENT FORMAT
 6150:     THIS ALGORITHM IS USING THE WAVELENGTH FROM 620 TO 750 NM TO
 6151:     REPRESENT THE IMAGE IN RED SHADES
 6152: 
 6153:     Cython cpdef function, this function can be called directly and do not require a
 6154:     hook function.
 6155: 
 6156:     :param surface_ : pygame.Surface to transform
 6157:     :return         : void
 6158:     """
 6159: 
 6160: 
 6161:     cdef:
 6162:         unsigned int w, h
+6163:     w, h = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6163, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6163, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 6163, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6163, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6163, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6163, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 6163, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 6163, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyInt_As_unsigned_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6163, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_unsigned_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6163, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_w = __pyx_t_6;
  __pyx_v_h = __pyx_t_7;
 6164: 
 6165:     cdef:
+6166:         unsigned char [::1] rgb_array  = surface_.get_buffer()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_buffer); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6166, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6166, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 6166, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_rgb_array = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 6167:         unsigned int s
 6168:         int i
+6169:         int size = rgb_array.size
  __pyx_t_1 = __pyx_memoryview_fromslice(__pyx_v_rgb_array, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6169, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6169, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6169, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_size = __pyx_t_9;
+6170:         unsigned int index = 0
  __pyx_v_index = 0;
 6171:         unsigned char *r
 6172:         unsigned char *g
 6173:         unsigned char *b
+6174:         short int bitsize = surface_.get_bitsize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bitsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6174, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6174, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 6174, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bitsize = __pyx_t_10;
+6175:         short int bytesize = surface_.get_bytesize()
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_bytesize); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6175, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_3 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6175, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_short(__pyx_t_3); if (unlikely((__pyx_t_10 == (short)-1) && PyErr_Occurred())) __PYX_ERR(1, 6175, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bytesize = __pyx_t_10;
 6176: 
+6177:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L6_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L7:;
      }
  }
+6178:         for i in prange(0, size, bytesize, schedule='static', num_threads=THREADS):
        __pyx_t_9 = __pyx_v_size;
        __pyx_t_10 = __pyx_v_bytesize;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static)        __pyx_t_10 = __pyx_v_bytesize;
        if ((__pyx_t_10 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_9 - 0 + __pyx_t_10 - __pyx_t_10/abs(__pyx_t_10)) / __pyx_t_10;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) lastprivate(__pyx_v_r) lastprivate(__pyx_v_s) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_12; __pyx_t_11++){
                        {
                            __pyx_v_i = (int)(0 + __pyx_t_10 * __pyx_t_11);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_index = ((unsigned int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_s = ((unsigned int)0xbad0bad0);
 6179: 
+6180:             r = &rgb_array[i]
                            __pyx_t_13 = __pyx_v_i;
                            __pyx_v_r = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
+6181:             g = &rgb_array[i + 1]
                            __pyx_t_13 = (__pyx_v_i + 1);
                            __pyx_v_g = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
+6182:             b = &rgb_array[i + 2]
                            __pyx_t_13 = (__pyx_v_i + 2);
                            __pyx_v_b = (&(*((unsigned char *) ( /* dim=0 */ ((char *) (((unsigned char *) __pyx_v_rgb_array.data) + __pyx_t_13)) ))));
 6183: 
+6184:             s = r[0] + g[0] + b[0]
                            __pyx_v_s = (((__pyx_v_r[0]) + (__pyx_v_g[0])) + (__pyx_v_b[0]));
+6185:             index = <int>(s * f_redmap)
                            __pyx_v_index = ((int)(__pyx_v_s * __pyx_v_12PygameShader_6shader_f_redmap));
 6186: 
+6187:             r[0] = <unsigned char>redmap_array[index, 2]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("redmap_array"); __PYX_ERR(1, 6187, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 2;
                            (__pyx_v_r[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_13)) ))));
+6188:             g[0] = <unsigned char>redmap_array[index, 1]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("redmap_array"); __PYX_ERR(1, 6188, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 1;
                            (__pyx_v_g[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_13)) ))));
+6189:             b[0] = <unsigned char>redmap_array[index, 0]
                            if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("redmap_array"); __PYX_ERR(1, 6189, __pyx_L10_error) }
                            __pyx_t_14 = __pyx_v_index;
                            __pyx_t_13 = 0;
                            (__pyx_v_b[0]) = ((unsigned char)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_14 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_13)) ))));
                            goto __pyx_L13;
                            __pyx_L10_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L12;
                            __pyx_L12:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates6)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_b;
                                __pyx_parallel_temp1 = __pyx_v_g;
                                __pyx_parallel_temp2 = __pyx_v_i;
                                __pyx_parallel_temp3 = __pyx_v_index;
                                __pyx_parallel_temp4 = __pyx_v_r;
                                __pyx_parallel_temp5 = __pyx_v_s;
                            }
                            __pyx_L13:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_b = __pyx_parallel_temp0;
              __pyx_v_g = __pyx_parallel_temp1;
              __pyx_v_i = __pyx_parallel_temp2;
              __pyx_v_index = __pyx_parallel_temp3;
              __pyx_v_r = __pyx_parallel_temp4;
              __pyx_v_s = __pyx_parallel_temp5;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L6_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 6190: 
 6191: 
 6192: 
 6193: @cython.binding(False)
 6194: @cython.boundscheck(False)
 6195: @cython.wraparound(False)
 6196: @cython.nonecheck(False)
 6197: @cython.cdivision(True)
+6198: cdef inline void shader_blood_inplace_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_blood_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_, __Pyx_memviewslice __pyx_v_mask_, float __pyx_v_perc_) {
  int __pyx_v_w;
  CYTHON_UNUSED int __pyx_v_h;
  CYTHON_UNUSED int __pyx_v_bytesize;
  int __pyx_v_i;
  int __pyx_v_j;
  unsigned int __pyx_v_index;
  unsigned char *__pyx_v_r;
  float __pyx_v_theta;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_blood_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_blood_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
 6199:         unsigned char [:, :, :] rgb_array_, float [:, :] mask_, float perc_):
 6200: 
 6201:     """
 6202:     SHADER HURT EFFECT
 6203:     THE MASK DETERMINE THE CONTOUR USED FOR THE BLOOD EFFECT.
 6204: 
 6205:     The Array (rgb_array) must be a numpy array shape (w, h, 3)
 6206:     containing RGB pixels, please refer to pygame
 6207:     function pixels3d or array3d to convert an image into a
 6208:     3d array (library surfarray)
 6209: 
 6210:     :param rgb_array_   : numpy.ndarray shape (w, h, 3) of unsigned
 6211:     char representing the surface pixels
 6212:     :param mask_        : numpy.ndarray shape (w, h) of float values in range [0.0...1.0]
 6213:     :param perc_        : Percentage value in range [0.0 ... 1.0] with 1.0 being 100%
 6214: 
 6215:     :return: void
 6216:     """
+6217:     assert 0.0 <= perc_ <= 1.0, "perc_ variable must be in range[0.0 ... 1.0] got %s " % perc_
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_1 = (0.0 <= __pyx_v_perc_);
    if (__pyx_t_1) {
      __pyx_t_1 = (__pyx_v_perc_ <= 1.0);
    }
    if (unlikely(!(__pyx_t_1 != 0))) {
      __pyx_t_2 = PyFloat_FromDouble(__pyx_v_perc_); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6217, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = __Pyx_PyString_Format(__pyx_kp_s_perc__variable_must_be_in_range, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6217, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_3);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __PYX_ERR(1, 6217, __pyx_L1_error)
    }
  }
  #endif
 6218: 
 6219:     cdef:
 6220:         int w, h, bytesize
+6221:     w, h, bytesize = (<object> rgb_array_).shape
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6221, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_shape); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6221, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_2))) || (PyList_CheckExact(__pyx_t_2))) {
    PyObject* sequence = __pyx_t_2;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 3)) {
      if (size > 3) __Pyx_RaiseTooManyValuesError(3);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 6221, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); 
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 2); 
    } else {
      __pyx_t_3 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_4 = PyList_GET_ITEM(sequence, 1); 
      __pyx_t_5 = PyList_GET_ITEM(sequence, 2); 
    }
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_5);
    #else
    __pyx_t_3 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6221, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6221, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = PySequence_ITEM(sequence, 2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6221, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    #endif
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_6 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6221, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_7 = Py_TYPE(__pyx_t_6)->tp_iternext;
    index = 0; __pyx_t_3 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    index = 1; __pyx_t_4 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_4)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    index = 2; __pyx_t_5 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_5)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_5);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_7(__pyx_t_6), 3) < 0) __PYX_ERR(1, 6221, __pyx_L1_error)
    __pyx_t_7 = NULL;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_7 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 6221, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_8 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_8 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6221, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_9 = __Pyx_PyInt_As_int(__pyx_t_4); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6221, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_10 = __Pyx_PyInt_As_int(__pyx_t_5); if (unlikely((__pyx_t_10 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6221, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_w = __pyx_t_8;
  __pyx_v_h = __pyx_t_9;
  __pyx_v_bytesize = __pyx_t_10;
 6222: 
 6223:     cdef:
 6224:         unsigned int s
 6225:         int i, j
+6226:         unsigned int index = 0
  __pyx_v_index = 0;
 6227:         unsigned char *r
 6228:         unsigned char *g
 6229:         unsigned char *b
 6230:         float theta
 6231: 
 6232: 
+6233:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L7;
        }
        __pyx_L6_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L7:;
      }
  }
+6234:         for j in prange(0, h, schedule='static', num_threads=THREADS):
        __pyx_t_10 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_10 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) schedule(static)
/* … */
        __pyx_t_10 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_10 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_i) lastprivate(__pyx_v_index) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_theta) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_12; __pyx_t_11++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_11);
                            /* Initialize private variables to invalid values */
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_index = ((unsigned int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_theta = ((float)__PYX_NAN());
+6235:             for i in range(0, w):
                            __pyx_t_9 = __pyx_v_w;
                            __pyx_t_8 = __pyx_t_9;
                            for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_8; __pyx_t_13+=1) {
                              __pyx_v_i = __pyx_t_13;
 6236: 
+6237:                 r = &rgb_array_[i, j, 0]
                              __pyx_t_14 = __pyx_v_i;
                              __pyx_t_15 = __pyx_v_j;
                              __pyx_t_16 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_14 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) ))));
 6238:                 # g = &rgb_array_[i, j, 1]
 6239:                 # b = &rgb_array_[i, j, 2]
 6240: 
 6241:                 # s = r[0] + g[0] + b[0]
 6242:                 # index = <int>(s * f_redmap)
 6243: 
+6244:                 index = <int>(r[0] * f_redmap)
                              __pyx_v_index = ((int)((__pyx_v_r[0]) * __pyx_v_12PygameShader_6shader_f_redmap));
+6245:                 theta = <float>(mask_[i, j] * perc_)
                              __pyx_t_16 = __pyx_v_i;
                              __pyx_t_15 = __pyx_v_j;
                              __pyx_v_theta = ((float)((*((float *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_mask_.data + __pyx_t_16 * __pyx_v_mask_.strides[0]) ) + __pyx_t_15 * __pyx_v_mask_.strides[1]) ))) * __pyx_v_perc_));
 6246: 
 6247:                 # BEST METHOD (SLOW)
 6248:                 # r[0] = <unsigned char> (r[0] * (1.0 - theta) +
 6249:                 # <float>redmap_array[index, 0] * theta)
 6250:                 # g[0] = <unsigned char> (g[0] * (1.0 - theta) +
 6251:                 # <float>redmap_array[index, 1] * theta)
 6252:                 # b[0] = <unsigned char> (b[0] * (1.0 - theta) +
 6253:                 # <float>redmap_array[index, 2] * theta)
 6254: 
 6255:                 # ALTERNATIVE WITH BEST PERFORMANCES
+6256:                 r[0] = <unsigned char> (
                              (__pyx_v_r[0]) = ((unsigned char)__pyx_t_20);
                            }
                            goto __pyx_L15;
                            __pyx_L10_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L14;
                            __pyx_L14:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates7)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_i;
                                __pyx_parallel_temp1 = __pyx_v_index;
                                __pyx_parallel_temp2 = __pyx_v_j;
                                __pyx_parallel_temp3 = __pyx_v_r;
                                __pyx_parallel_temp4 = __pyx_v_theta;
                            }
                            __pyx_L15:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_i = __pyx_parallel_temp0;
              __pyx_v_index = __pyx_parallel_temp1;
              __pyx_v_j = __pyx_parallel_temp2;
              __pyx_v_r = __pyx_parallel_temp3;
              __pyx_v_theta = __pyx_parallel_temp4;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L6_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+6257:                     min(r[0] + <float> redmap_array[index, 0] * theta, <unsigned char>255))
                              __pyx_t_17 = ((unsigned char)0xFF);
                              if (unlikely(!__pyx_v_12PygameShader_6shader_redmap_array.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("redmap_array"); __PYX_ERR(1, 6257, __pyx_L10_error) }
                              __pyx_t_18 = __pyx_v_index;
                              __pyx_t_15 = 0;
                              __pyx_t_19 = ((__pyx_v_r[0]) + (((float)(*((unsigned char *) ( /* dim=1 */ ((char *) (((unsigned char *) ( /* dim=0 */ (__pyx_v_12PygameShader_6shader_redmap_array.data + __pyx_t_18 * __pyx_v_12PygameShader_6shader_redmap_array.strides[0]) )) + __pyx_t_15)) )))) * __pyx_v_theta));
                              if (((__pyx_t_17 < __pyx_t_19) != 0)) {
                                __pyx_t_20 = __pyx_t_17;
                              } else {
                                __pyx_t_20 = __pyx_t_19;
                              }
 6258: 
 6259: 
 6260: 
 6261: #
 6262: # def interpolant(t):
 6263: #     return t*t*t*(t*(t*6 - 15) + 10)
 6264: #
 6265: #
 6266: # def generate_perlin_noise_2d(
 6267: #         shape, res, tileable=(False, False), interpolant=interpolant
 6268: # ):
 6269: #     """Generate a 2D numpy array of perlin noise.
 6270: #
 6271: #     Args:
 6272: #         shape: The shape of the generated array (tuple of two ints).
 6273: #             This must be a multple of res.
 6274: #         res: The number of periods of noise to generate along each
 6275: #             axis (tuple of two ints). Note shape must be a multiple of
 6276: #             res.
 6277: #         tileable: If the noise should be tileable along each axis
 6278: #             (tuple of two bools). Defaults to (False, False).
 6279: #         interpolant: The interpolation function, defaults to
 6280: #             t*t*t*(t*(t*6 - 15) + 10).
 6281: #
 6282: #     Returns:
 6283: #         A numpy array of shape shape with the generated noise.
 6284: #
 6285: #     Raises:
 6286: #         ValueError: If shape is not a multiple of res.
 6287: #     """
 6288: #     delta = (res[0] / shape[0], res[1] / shape[1])
 6289: #     d = (shape[0] // res[0], shape[1] // res[1])
 6290: #     grid = numpy.mgrid[0:res[0]:delta[0], 0:res[1]:delta[1]]\
 6291: #              .transpose(1, 2, 0) % 1
 6292: #     # Gradients
 6293: #     angles = 2*numpy.pi*numpy.random.rand(res[0]+1, res[1]+1)
 6294: #     gradients = numpy.dstack((numpy.cos(angles), numpy.sin(angles)))
 6295: #     if tileable[0]:
 6296: #         gradients[-1,:] = gradients[0,:]
 6297: #     if tileable[1]:
 6298: #         gradients[:,-1] = gradients[:,0]
 6299: #     gradients = gradients.repeat(d[0], 0).repeat(d[1], 1)
 6300: #     g00 = gradients[    :-d[0],    :-d[1]]
 6301: #     g10 = gradients[d[0]:     ,    :-d[1]]
 6302: #     g01 = gradients[    :-d[0],d[1]:     ]
 6303: #     g11 = gradients[d[0]:     ,d[1]:     ]
 6304: #     # Ramps
 6305: #     n00 = numpy.sum(numpy.dstack((grid[:,:,0]  , grid[:,:,1]  )) * g00, 2)
 6306: #     n10 = numpy.sum(numpy.dstack((grid[:,:,0]-1, grid[:,:,1]  )) * g10, 2)
 6307: #     n01 = numpy.sum(numpy.dstack((grid[:,:,0]  , grid[:,:,1]-1)) * g01, 2)
 6308: #     n11 = numpy.sum(numpy.dstack((grid[:,:,0]-1, grid[:,:,1]-1)) * g11, 2)
 6309: #     # Interpolation
 6310: #     t = interpolant(grid)
 6311: #     n0 = n00*(1-t[:,:,0]) + t[:,:,0]*n10
 6312: #     n1 = n01*(1-t[:,:,0]) + t[:,:,0]*n11
 6313: #     return numpy.sqrt(2)*((1-t[:,:,1])*n0 + t[:,:,1]*n1)
 6314: #
 6315: #
 6316: #
 6317: # @cython.boundscheck(False)
 6318: # @cython.wraparound(False)
 6319: # @cython.nonecheck(False)
 6320: # @cython.cdivision(True)
 6321: # cdef inline cloud_effect_inplace_c(int frame):
 6322: #
 6323: #     cdef int w, h, i, j
 6324: #
 6325: #     # cdef float [:, :] noise_array = generate_perlin_noise_2d(
 6326: #     (800, 800), (16, 16), tileable=(True, True))
 6327: #
 6328: #     cdef float [:, :] noise_array = numpy.empty((200, 200), float32)
 6329: #
 6330: #     for j in range(0, 200):
 6331: #         for i in range(0, 200):
 6332: #             noise_array[i, j] = noise.pnoise2((i+ 50 * cos(frame * M_PI/180.0))/ 8.0,
 6333: #                           j / 8.0,
 6334: #                           octaves=8,
 6335: #                           persistence=0.25,
 6336: #                           lacunarity=2,
 6337: #                           repeatx=1024,
 6338: #                           repeaty=1024,
 6339: #                           base=0)
 6340: #
 6341: #
 6342: #     cdef:
 6343: #         unsigned char [:, :, :] dest_array = numpy.empty((800, 800, 3), numpy.uint8)
 6344: #         int ii, jj
 6345: #         int v
 6346: #
 6347: #     with nogil:
 6348: #         for i in prange(0, 800, schedule='static', num_threads=THREADS):
 6349: #             for j in range(0, 800):
 6350: #                 ii = <int>(200.0/800.0 * i)
 6351: #                 jj = <int>(200.0/800.0 * j)
 6352: #                 dest_array[i, j, 0] =<unsigned char>(noise_array[ii, jj] * 255)
 6353: #                 dest_array[i, j, 1] =<unsigned char>(noise_array[ii, jj] * 255)
 6354: #                 dest_array[i, j, 2] =<unsigned char>(noise_array[ii, jj] * 255)
 6355: #
 6356: #
 6357: #     return pygame.surfarray.make_surface(asarray(dest_array))
 6358: #
 6359: 
 6360: 
 6361: @cython.boundscheck(False)
 6362: @cython.wraparound(False)
 6363: @cython.nonecheck(False)
 6364: @cython.cdivision(True)
+6365: cpdef inline unsigned int rgb_to_int(int red, int green, int blue)nogil:
static PyObject *__pyx_pw_12PygameShader_6shader_157rgb_to_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE unsigned int __pyx_f_12PygameShader_6shader_rgb_to_int(int __pyx_v_red, int __pyx_v_green, int __pyx_v_blue, CYTHON_UNUSED int __pyx_skip_dispatch) {
  unsigned int __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_157rgb_to_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_156rgb_to_int[] = "\n    CONVERT RGB MODEL INTO A PYTHON INTEGER EQUIVALENT TO THE FUNCTION PYGAME MAP_RGB()\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param red   : Red color value,  must be in range [0..255]\n    :param green : Green color value, must be in range [0..255]\n    :param blue  : Blue color, must be in range [0.255]\n    :return      : returns a positive python integer representing the RGB values(int32)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_157rgb_to_int(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_red;
  int __pyx_v_green;
  int __pyx_v_blue;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_int (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_red,&__pyx_n_s_green,&__pyx_n_s_blue,0};
    PyObject* values[3] = {0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_red)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_green)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("rgb_to_int", 1, 3, 3, 1); __PYX_ERR(1, 6365, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_blue)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("rgb_to_int", 1, 3, 3, 2); __PYX_ERR(1, 6365, __pyx_L3_error)
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "rgb_to_int") < 0)) __PYX_ERR(1, 6365, __pyx_L3_error)
      }
    } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
      values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
      values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
    }
    __pyx_v_red = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_red == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6365, __pyx_L3_error)
    __pyx_v_green = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_green == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6365, __pyx_L3_error)
    __pyx_v_blue = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_blue == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6365, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("rgb_to_int", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 6365, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.rgb_to_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_156rgb_to_int(__pyx_self, __pyx_v_red, __pyx_v_green, __pyx_v_blue);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_156rgb_to_int(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_red, int __pyx_v_green, int __pyx_v_blue) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("rgb_to_int", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_From_unsigned_int(__pyx_f_12PygameShader_6shader_rgb_to_int(__pyx_v_red, __pyx_v_green, __pyx_v_blue, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6365, __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("PygameShader.shader.rgb_to_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 6366:     """
 6367:     CONVERT RGB MODEL INTO A PYTHON INTEGER EQUIVALENT TO THE FUNCTION PYGAME MAP_RGB()
 6368: 
 6369:     Cython cpdef function, this function can be called directly and do not require a
 6370:     hook function.
 6371: 
 6372:     :param red   : Red color value,  must be in range [0..255]
 6373:     :param green : Green color value, must be in range [0..255]
 6374:     :param blue  : Blue color, must be in range [0.255]
 6375:     :return      : returns a positive python integer representing the RGB values(int32)
 6376:     """
+6377:     return 65536 * red + 65536*10 + 256 * green + 256 + blue + 1
  __pyx_r = ((((((0x10000 * __pyx_v_red) + 0xA0000) + (0x100 * __pyx_v_green)) + 0x100) + __pyx_v_blue) + 1);
  goto __pyx_L0;
 6378: 
 6379: @cython.boundscheck(False)
 6380: @cython.wraparound(False)
 6381: @cython.nonecheck(False)
 6382: @cython.cdivision(True)
+6383: cpdef inline rgb int_to_rgb(unsigned int n)nogil:
static PyObject *__pyx_pw_12PygameShader_6shader_159int_to_rgb(PyObject *__pyx_self, PyObject *__pyx_arg_n); /*proto*/
static CYTHON_INLINE struct rgb __pyx_f_12PygameShader_6shader_int_to_rgb(unsigned int __pyx_v_n, CYTHON_UNUSED int __pyx_skip_dispatch) {
  struct rgb __pyx_v_rgb_;
  struct rgb __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_159int_to_rgb(PyObject *__pyx_self, PyObject *__pyx_arg_n); /*proto*/
static char __pyx_doc_12PygameShader_6shader_158int_to_rgb[] = "\n    CONVERT A PYTHON INTEGER INTO A RGB COLOUR MODEL (UNSIGNED CHAR VALUES [0..255]).\n    EQUIVALENT TO PYGAME UNMAP_RGB()\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    :param n : positive integer value to convert\n    :return  : return a C structure rgb containing RGB values\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_159int_to_rgb(PyObject *__pyx_self, PyObject *__pyx_arg_n) {
  unsigned int __pyx_v_n;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("int_to_rgb (wrapper)", 0);
  assert(__pyx_arg_n); {
    __pyx_v_n = __Pyx_PyInt_As_unsigned_int(__pyx_arg_n); if (unlikely((__pyx_v_n == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6383, __pyx_L3_error)
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.int_to_rgb", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_158int_to_rgb(__pyx_self, ((unsigned int)__pyx_v_n));
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_158int_to_rgb(CYTHON_UNUSED PyObject *__pyx_self, unsigned int __pyx_v_n) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("int_to_rgb", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_convert__to_py_struct__rgb(__pyx_f_12PygameShader_6shader_int_to_rgb(__pyx_v_n, 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6383, __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("PygameShader.shader.int_to_rgb", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 6384:     """
 6385:     CONVERT A PYTHON INTEGER INTO A RGB COLOUR MODEL (UNSIGNED CHAR VALUES [0..255]).
 6386:     EQUIVALENT TO PYGAME UNMAP_RGB()
 6387: 
 6388:     Cython cpdef function, this function can be called directly and do not require a
 6389:     hook function.
 6390: 
 6391:     :param n : positive integer value to convert
 6392:     :return  : return a C structure rgb containing RGB values
 6393:     """
 6394:     cdef:
 6395:         rgb rgb_
 6396: 
+6397:     rgb_.r = <float>((n >> 16) & 255)
  __pyx_v_rgb_.r = ((float)((__pyx_v_n >> 16) & 0xFF));
+6398:     rgb_.g = <float>((n >> 8) & 255)
  __pyx_v_rgb_.g = ((float)((__pyx_v_n >> 8) & 0xFF));
+6399:     rgb_.b = <float>(n & 255)
  __pyx_v_rgb_.b = ((float)(__pyx_v_n & 0xFF));
+6400:     return rgb_
  __pyx_r = __pyx_v_rgb_;
  goto __pyx_L0;
 6401: 
 6402: 
 6403: @cython.boundscheck(False)
 6404: @cython.wraparound(False)
 6405: @cython.nonecheck(False)
 6406: @cython.cdivision(True)
+6407: cdef inline make_palette_c(int width, float fh, float fs, float fl):
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_make_palette_c(int __pyx_v_width, float __pyx_v_fh, float __pyx_v_fs, float __pyx_v_fl) {
  __Pyx_memviewslice __pyx_v_palette = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  float __pyx_v_h;
  float __pyx_v_s;
  float __pyx_v_l;
  struct rgb __pyx_v_rgb_;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("make_palette_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_AddTraceback("PygameShader.shader.make_palette_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 6408:     """
 6409:     CREATE A PALETTE (ARRAY) FROM HSL VALUES (HUE, SATURATION, LIGHTNESS)
 6410: 
 6411:     e.g:
 6412:         # below: palette of 256 colors & surface (width=256, height=50).
 6413:         # hue * 6, saturation = 255.0, lightness * 2.0
 6414:         palette, surf = make_palette(256, 50, 6, 255, 2)
 6415:         palette, surf = make_palette(256, 50, 4, 255, 2)
 6416: 
 6417:     :param width  : integer, Palette width
 6418:     :param fh     : float, hue factor
 6419:     :param fs     : float, saturation factor
 6420:     :param fl     : float, lightness factor
 6421:     :return       : Return a tuple ndarray type uint32 and pygame.Surface (width, height)
 6422:     """
+6423:     assert width > 0, "Argument width should be > 0, got %s " % width
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_width > 0) != 0))) {
      __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6423, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyString_Format(__pyx_kp_s_Argument_width_should_be_0_got_s, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6423, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_2);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __PYX_ERR(1, 6423, __pyx_L1_error)
    }
  }
  #endif
 6424: 
 6425:     cdef:
+6426:         unsigned int [::1] palette = numpy.empty(width, uint32)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_numpy); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6426, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_n_s_empty); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6426, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6426, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_uint32); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6426, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = NULL;
  __pyx_t_6 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_6 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_1, __pyx_t_4};
    __pyx_t_2 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6426, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_1, __pyx_t_4};
    __pyx_t_2 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_6, 2+__pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6426, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_7 = PyTuple_New(2+__pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 6426, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (__pyx_t_5) {
      __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_5); __pyx_t_5 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_1);
    PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_6, __pyx_t_1);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_6, __pyx_t_4);
    __pyx_t_1 = 0;
    __pyx_t_4 = 0;
    __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_7, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6426, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 6426, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_palette = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 6427:         int x, y
 6428:         float h, s, l
 6429:         rgb rgb_
 6430: 
+6431:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+6432:         for x in prange(width, schedule='static', num_threads=THREADS):
        __pyx_t_6 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_6 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_h) lastprivate(__pyx_v_l) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static)
/* … */
        __pyx_t_6 = __pyx_v_width;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_6 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_h) lastprivate(__pyx_v_l) lastprivate(__pyx_v_rgb_) lastprivate(__pyx_v_s) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_10; __pyx_t_9++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_9);
                            /* Initialize private variables to invalid values */
                            __pyx_v_h = ((float)__PYX_NAN());
                            __pyx_v_l = ((float)__PYX_NAN());
                            __pyx_v_s = ((float)__PYX_NAN());
+6433:             h, s, l = <float>x * fh,  min(fs, <float>255.0), min(<float>x * fl, <float>255.0)
                            __pyx_t_11 = (((float)__pyx_v_x) * __pyx_v_fh);
                            __pyx_t_12 = ((float)255.0);
                            __pyx_t_13 = __pyx_v_fs;
                            if (((__pyx_t_12 < __pyx_t_13) != 0)) {
                              __pyx_t_14 = __pyx_t_12;
                            } else {
                              __pyx_t_14 = __pyx_t_13;
                            }
                            __pyx_t_12 = __pyx_t_14;
                            __pyx_t_14 = ((float)255.0);
                            __pyx_t_13 = (((float)__pyx_v_x) * __pyx_v_fl);
                            if (((__pyx_t_14 < __pyx_t_13) != 0)) {
                              __pyx_t_15 = __pyx_t_14;
                            } else {
                              __pyx_t_15 = __pyx_t_13;
                            }
                            __pyx_t_14 = __pyx_t_15;
                            __pyx_v_h = __pyx_t_11;
                            __pyx_v_s = __pyx_t_12;
                            __pyx_v_l = __pyx_t_14;
+6434:             rgb_ = struct_hsl_to_rgb(h * <float>ONE_360, s * <float>ONE_255, l * <float>ONE_255)
                            __pyx_v_rgb_ = struct_hsl_to_rgb((__pyx_v_h * ((float)0.002777777777777778)), (__pyx_v_s * ((float)0.00392156862745098)), (__pyx_v_l * ((float)0.00392156862745098)));
 6435:             # build the palette (1d buffer int values)
+6436:             palette[x] = rgb_to_int(<int>(rgb_.r * <float>255.0),
                            __pyx_t_16 = __pyx_v_x;
                            *((unsigned int *) ( /* dim=0 */ ((char *) (((unsigned int *) __pyx_v_palette.data) + __pyx_t_16)) )) = __pyx_f_12PygameShader_6shader_rgb_to_int(((int)(__pyx_v_rgb_.r * ((float)255.0))), ((int)(__pyx_v_rgb_.g * ((float)255.0))), ((int)((__pyx_v_rgb_.b * ((float)255.0)) * ((float)0.5))), 0);
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 6437:                                     <int>(rgb_.g * <float>255.0),
 6438:                                     <int>(rgb_.b * <float>255.0 * <float>0.5))
 6439: 
+6440:     return asarray(palette)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_asarray); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6440, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_7 = __pyx_memoryview_fromslice(__pyx_v_palette, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 6440, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_2 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_4, __pyx_t_7) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_7);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6440, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;
 6441: 
 6442: @cython.boundscheck(False)
 6443: @cython.wraparound(False)
 6444: @cython.nonecheck(False)
 6445: @cython.cdivision(False)
+6446: cdef fire_surface24_c(
static PyObject *__pyx_f_12PygameShader_6shader_fire_surface24_c(int __pyx_v_width, int __pyx_v_height, float __pyx_v_factor, __Pyx_memviewslice __pyx_v_palette, __Pyx_memviewslice __pyx_v_fire, struct __pyx_opt_args_12PygameShader_6shader_fire_surface24_c *__pyx_optional_args) {
  int __pyx_v_intensity = ((int)0);
  int __pyx_v_low = ((int)0);
  int __pyx_v_high = ((int)0);
  __Pyx_memviewslice __pyx_v_out = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  float __pyx_v_d;
  unsigned int __pyx_v_ii;
  unsigned int __pyx_v_c1;
  unsigned int __pyx_v_c2;
  CYTHON_UNUSED int __pyx_v_min_;
  CYTHON_UNUSED int __pyx_v_max_;
  int __pyx_v_middle;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_surface24_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_intensity = __pyx_optional_args->intensity;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_low = __pyx_optional_args->low;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_high = __pyx_optional_args->high;
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_AddTraceback("PygameShader.shader.fire_surface24_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_out, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+6447:         int width,
struct __pyx_opt_args_12PygameShader_6shader_fire_surface24_c {
  int __pyx_n;
  int intensity;
  int low;
  int high;
};
 6448:         int height,
 6449:         float factor,
 6450:         unsigned int [::1] palette,
 6451:         float [:, ::1] fire,
 6452:         int intensity = 0,
 6453:         int low       = 0,
 6454:         int high      = 0,
 6455: ):
 6456:     """
 6457: 
 6458:     CREATE A FIRE EFFECT
 6459: 
 6460:     * Do not call this function directly
 6461: 
 6462:     :param width    : integer; max width of the effect
 6463:     :param height   : integer; max height of the effect
 6464:     :param factor   : float; factor to reduce the flame effect
 6465:     :param palette  : ndarray; Color palette 1d numpy array (colors buffer unsigned int values)
 6466:     :param fire     : ndarray; 2d array (x, y) (contiguous) containing float values
 6467:     :param intensity: integer; Control the flame intensity default 0 (low intensity), range [0...32]
 6468:     :param low      : integer; The x lowest position of the effect, x must be >=0 and < high
 6469:     :param high     : integer; The x highest position of the effect, x must be > low and <= high
 6470:     :return         : Return a numpy array containing the fire effect array shape
 6471:      (w, h, 3) of RGB pixels
 6472:     """
 6473: 
 6474:     cdef:
 6475:         # flame opacity palette
+6476:         unsigned char [:, :, ::1] out = zeros((width, height, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_zeros); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_height); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_int_3);
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 6476, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_out = __pyx_t_5;
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
+6477:         int x = 0, y = 0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 6478:         float d
+6479:         unsigned int ii=0
  __pyx_v_ii = 0;
+6480:         unsigned c1 = 0, c2 = 0
  __pyx_v_c1 = 0;
  __pyx_v_c2 = 0;
 6481: 
 6482:     cdef int min_, max_, middle
 6483: 
 6484: 
+6485:     if low != 0 or high != 0:
  __pyx_t_7 = ((__pyx_v_low != 0) != 0);
  if (!__pyx_t_7) {
  } else {
    __pyx_t_6 = __pyx_t_7;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_7 = ((__pyx_v_high != 0) != 0);
  __pyx_t_6 = __pyx_t_7;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_6) {
/* … */
    goto __pyx_L3;
  }
+6486:         assert 0 <= low < high, "Argument low_ must be < high_"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_6 = (0 <= __pyx_v_low);
      if (__pyx_t_6) {
        __pyx_t_6 = (__pyx_v_low < __pyx_v_high);
      }
      if (unlikely(!(__pyx_t_6 != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_low__must_be_high);
        __PYX_ERR(1, 6486, __pyx_L1_error)
      }
    }
    #endif
+6487:         assert high <= width, "Argument high must be <= width"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      if (unlikely(!((__pyx_v_high <= __pyx_v_width) != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_high_must_be_width);
        __PYX_ERR(1, 6487, __pyx_L1_error)
      }
    }
    #endif
 6488: 
+6489:         middle = low + ((high - low) >> 1)
    __pyx_v_middle = (__pyx_v_low + ((__pyx_v_high - __pyx_v_low) >> 1));
+6490:         min_ = randRange(low, middle)
    __pyx_v_min_ = randRange(__pyx_v_low, __pyx_v_middle);
+6491:         max_ = randRange(middle + 1, high)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_high);
 6492:     else:
+6493:         middle = width >> 1
  /*else*/ {
    __pyx_v_middle = (__pyx_v_width >> 1);
+6494:         min_ = randRange(0, middle)
    __pyx_v_min_ = randRange(0, __pyx_v_middle);
+6495:         max_ = randRange(middle +1, width)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_width);
  }
  __pyx_L3:;
 6496: 
 6497: 
+6498:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L8;
        }
        __pyx_L7_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L8:;
      }
  }
 6499:         # POPULATE TO THE BASE OF THE FIRE (THIS WILL CONFIGURE THE FLAME ASPECT)
+6500:         for x in prange(min_, max_, schedule='static', num_threads=THREADS):
        __pyx_t_8 = __pyx_v_min_;
        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_8 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static)        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_8 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_11; __pyx_t_10++){
                        {
                            __pyx_v_x = (int)(__pyx_t_8 + 1 * __pyx_t_10);
+6501:                 fire[height-1, x] = randRange(intensity, 260)
                            __pyx_t_12 = (__pyx_v_height - 1);
                            __pyx_t_13 = __pyx_v_x;
                            *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_12 * __pyx_v_fire.strides[0]) )) + __pyx_t_13)) )) = randRange(__pyx_v_intensity, 0x104);
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
 6502: 
 6503: 
 6504:         # DILUTE THE FLAME EFFECT (DECREASE THE MAXIMUM INT VALUE) WHEN THE FLAME TRAVEL UPWARD
+6505:         for y in prange(1, height-1, schedule='static', num_threads=THREADS):
        __pyx_t_14 = (__pyx_v_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_14 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_14 = (__pyx_v_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_14 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_16; __pyx_t_15++){
                        {
                            __pyx_v_y = (int)(1 + 1 * __pyx_t_15);
                            /* Initialize private variables to invalid values */
                            __pyx_v_c1 = ((unsigned int)0xbad0bad0);
                            __pyx_v_c2 = ((unsigned int)0xbad0bad0);
                            __pyx_v_d = ((float)__PYX_NAN());
                            __pyx_v_ii = ((unsigned int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
 6506: 
+6507:             for x in range(0, width):
                            __pyx_t_11 = __pyx_v_width;
                            __pyx_t_10 = __pyx_t_11;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_10; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 6508: 
+6509:                     c1 = (y + 1) % height
                              __pyx_t_17 = (__pyx_v_y + 1);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6509, __pyx_L17_error)
                              }
                              __pyx_v_c1 = __Pyx_mod_long(__pyx_t_17, __pyx_v_height);
+6510:                     c2 = x % width
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6510, __pyx_L17_error)
                              }
                              __pyx_v_c2 = __Pyx_mod_int(__pyx_v_x, __pyx_v_width);
+6511:                     d = (fire[c1, (x - 1 + width) % width]
                              __pyx_t_17 = ((__pyx_v_x - 1) + __pyx_v_width);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6511, __pyx_L17_error)
                              }
                              __pyx_t_18 = __pyx_v_c1;
                              __pyx_t_13 = __Pyx_mod_long(__pyx_t_17, __pyx_v_width);
+6512:                        + fire[c1, c2]
                              __pyx_t_19 = __pyx_v_c1;
                              __pyx_t_20 = __pyx_v_c2;
+6513:                        + fire[c1, (x + 1) % width]
                              __pyx_t_21 = (__pyx_v_x + 1);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6513, __pyx_L17_error)
                              }
                              __pyx_t_22 = __pyx_v_c1;
                              __pyx_t_12 = __Pyx_mod_long(__pyx_t_21, __pyx_v_width);
+6514:                        + fire[(y + 2) % height, c2]) * factor
                              __pyx_t_23 = (__pyx_v_y + 2);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6514, __pyx_L17_error)
                              }
                              __pyx_t_24 = __Pyx_mod_long(__pyx_t_23, __pyx_v_height);
                              __pyx_t_25 = __pyx_v_c2;
                              __pyx_v_d = (((((*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_18 * __pyx_v_fire.strides[0]) )) + __pyx_t_13)) ))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_19 * __pyx_v_fire.strides[0]) )) + __pyx_t_20)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_22 * __pyx_v_fire.strides[0]) )) + __pyx_t_12)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_24 * __pyx_v_fire.strides[0]) )) + __pyx_t_25)) )))) * __pyx_v_factor);
 6515: 
+6516:                     d = d - <float>(rand() * 0.0001)
                              __pyx_v_d = (__pyx_v_d - ((float)(rand() * 0.0001)));
 6517: 
 6518:                     # Cap the values
+6519:                     if d <0:
                              __pyx_t_6 = ((__pyx_v_d < 0.0) != 0);
                              if (__pyx_t_6) {
/* … */
                              }
+6520:                         d = 0.0
                                __pyx_v_d = 0.0;
 6521: 
 6522:                     # CAP THE VALUE TO 255
+6523:                     if d>255.0:
                              __pyx_t_6 = ((__pyx_v_d > 255.0) != 0);
                              if (__pyx_t_6) {
/* … */
                              }
+6524:                         d = <float>255.0
                                __pyx_v_d = ((float)255.0);
+6525:                     fire[y, x] = d
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_12 = __pyx_v_x;
                              *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_24 * __pyx_v_fire.strides[0]) )) + __pyx_t_12)) )) = __pyx_v_d;
 6526: 
+6527:                     ii = palette[<unsigned int>d % width]
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6527, __pyx_L17_error)
                              }
                              __pyx_t_25 = (((unsigned int)__pyx_v_d) % __pyx_v_width);
                              __pyx_v_ii = (*((unsigned int *) ( /* dim=0 */ ((char *) (((unsigned int *) __pyx_v_palette.data) + __pyx_t_25)) )));
 6528: 
+6529:                     out[x, y, 0] = (ii >> 16) & 255
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_12 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_13)) )) = ((__pyx_v_ii >> 16) & 0xFF);
+6530:                     out[x, y, 1] = (ii >> 8) & 255
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_12 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_13 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_12)) )) = ((__pyx_v_ii >> 8) & 0xFF);
+6531:                     out[x, y, 2] = ii & 255
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_13 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_12 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_13)) )) = (__pyx_v_ii & 0xFF);
                            }
                            goto __pyx_L24;
                            __pyx_L17_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L23;
                            __pyx_L23:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates8)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_c1;
                                __pyx_parallel_temp1 = __pyx_v_c2;
                                __pyx_parallel_temp2 = __pyx_v_d;
                                __pyx_parallel_temp3 = __pyx_v_ii;
                                __pyx_parallel_temp4 = __pyx_v_x;
                                __pyx_parallel_temp5 = __pyx_v_y;
                            }
                            __pyx_L24:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_c1 = __pyx_parallel_temp0;
              __pyx_v_c2 = __pyx_parallel_temp1;
              __pyx_v_d = __pyx_parallel_temp2;
              __pyx_v_ii = __pyx_parallel_temp3;
              __pyx_v_x = __pyx_parallel_temp4;
              __pyx_v_y = __pyx_parallel_temp5;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L7_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 6532: 
+6533:     return asarray(out)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_asarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6533, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_out, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6533, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_1)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_2 = (__pyx_t_1) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_1, __pyx_t_3) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_3);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6533, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;
 6534: 
 6535: 
 6536: 
 6537: @cython.boundscheck(False)
 6538: @cython.wraparound(False)
 6539: @cython.nonecheck(False)
 6540: @cython.cdivision(False)
+6541: cdef fire_surface24_c_border(
static PyObject *__pyx_f_12PygameShader_6shader_fire_surface24_c_border(int __pyx_v_width, int __pyx_v_height, float __pyx_v_factor, __Pyx_memviewslice __pyx_v_palette, __Pyx_memviewslice __pyx_v_fire, struct __pyx_opt_args_12PygameShader_6shader_fire_surface24_c_border *__pyx_optional_args) {
  int __pyx_v_intensity = ((int)0);
  int __pyx_v_low = ((int)0);
  int __pyx_v_high = ((int)0);
  __Pyx_memviewslice __pyx_v_out = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  float __pyx_v_d;
  unsigned int __pyx_v_ii;
  unsigned int __pyx_v_c1;
  unsigned int __pyx_v_c2;
  CYTHON_UNUSED int __pyx_v_min_;
  CYTHON_UNUSED int __pyx_v_max_;
  int __pyx_v_middle;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fire_surface24_c_border", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_intensity = __pyx_optional_args->intensity;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_low = __pyx_optional_args->low;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_high = __pyx_optional_args->high;
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_AddTraceback("PygameShader.shader.fire_surface24_c_border", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_out, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+6542:         int width,
struct __pyx_opt_args_12PygameShader_6shader_fire_surface24_c_border {
  int __pyx_n;
  int intensity;
  int low;
  int high;
};
 6543:         int height,
 6544: 
 6545:         float factor,
 6546:         unsigned int [::1] palette,
 6547:         float [:, ::1] fire,
 6548:         int intensity = 0,
 6549:         int low       = 0,
 6550:         int high      = 0,
 6551: ):
 6552:     """
 6553: 
 6554:     CREATE A FIRE EFFECT (BORDER EFFECT)
 6555: 
 6556:     * Do not call this function directly
 6557: 
 6558:     :param width    : integer; max width of the effect
 6559:     :param height   : integer; max height of the effect
 6560:     :param factor   : float; factor to reduce the flame effect
 6561:     :param palette  : ndarray; Color palette 1d numpy array (colors buffer unsigned int values)
 6562:     :param fire     : ndarray; 2d array (x, y) (contiguous) containing float values
 6563:     :param intensity: integer; Control the flame intensity default 0 (low intensity), range [0...32]
 6564:     :param low      : integer; The x lowest position of the effect, x must be >=0 and < high
 6565:     :param high     : integer; The x highest position of the effect, x must be > low and <= high
 6566:     :return         : Return a numpy array containing the fire effect array
 6567:     shape (w, h, 3) of RGB pixels
 6568:     """
 6569: 
 6570:     cdef:
 6571:         # flame opacity palette
+6572:         unsigned char [:, :, ::1] out = zeros((width, height, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_zeros); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_height); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_int_3);
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 6572, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_out = __pyx_t_5;
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
+6573:         int x = 0, y = 0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 6574:         float d
+6575:         unsigned int ii=0
  __pyx_v_ii = 0;
+6576:         unsigned c1 = 0, c2 = 0
  __pyx_v_c1 = 0;
  __pyx_v_c2 = 0;
 6577: 
 6578:     cdef int min_, max_, middle
 6579: 
 6580: 
+6581:     if low != 0 or high != 0:
  __pyx_t_7 = ((__pyx_v_low != 0) != 0);
  if (!__pyx_t_7) {
  } else {
    __pyx_t_6 = __pyx_t_7;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_7 = ((__pyx_v_high != 0) != 0);
  __pyx_t_6 = __pyx_t_7;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_6) {
/* … */
    goto __pyx_L3;
  }
+6582:         assert 0 <= low < high, "Argument low_ must be < high_"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_6 = (0 <= __pyx_v_low);
      if (__pyx_t_6) {
        __pyx_t_6 = (__pyx_v_low < __pyx_v_high);
      }
      if (unlikely(!(__pyx_t_6 != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_low__must_be_high);
        __PYX_ERR(1, 6582, __pyx_L1_error)
      }
    }
    #endif
+6583:         assert high <= width, "Argument high must be <= width"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      if (unlikely(!((__pyx_v_high <= __pyx_v_width) != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_high_must_be_width);
        __PYX_ERR(1, 6583, __pyx_L1_error)
      }
    }
    #endif
 6584: 
+6585:         middle = low + ((high - low) >> 1)
    __pyx_v_middle = (__pyx_v_low + ((__pyx_v_high - __pyx_v_low) >> 1));
+6586:         min_ = randRange(low, middle)
    __pyx_v_min_ = randRange(__pyx_v_low, __pyx_v_middle);
+6587:         max_ = randRange(middle + 1, high)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_high);
 6588:     else:
+6589:         middle = width >> 1
  /*else*/ {
    __pyx_v_middle = (__pyx_v_width >> 1);
+6590:         min_ = randRange(0, middle)
    __pyx_v_min_ = randRange(0, __pyx_v_middle);
+6591:         max_ = randRange(middle +1, width)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_width);
  }
  __pyx_L3:;
 6592: 
 6593: 
+6594:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L8;
        }
        __pyx_L7_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L8:;
      }
  }
 6595:         # POPULATE TO THE BASE OF THE FIRE (THIS WILL CONFIGURE THE FLAME ASPECT)
 6596:         # for x in prange(min_, max_, schedule='static', num_threads=THREADS
 6597:         #         fire[height - 1, x] = randRange(intensity, 260)
 6598: 
 6599:         # FIRE ARRAY IS [HEIGHT, WIDTH]
+6600:         for x in prange(min_, max_, schedule='static', num_threads=THREADS):
        __pyx_t_8 = __pyx_v_min_;
        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_8 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static)        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_8 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_11; __pyx_t_10++){
                        {
                            __pyx_v_x = (int)(__pyx_t_8 + 1 * __pyx_t_10);
+6601:                 fire[x % height, (height - 1) % width] = randRange(intensity, 260)
                            if (unlikely(__pyx_v_height == 0)) {
                              #ifdef WITH_THREAD
                              PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                              #endif
                              PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                              #ifdef WITH_THREAD
                              __Pyx_PyGILState_Release(__pyx_gilstate_save);
                              #endif
                              __PYX_ERR(1, 6601, __pyx_L11_error)
                            }
                            __pyx_t_12 = (__pyx_v_height - 1);
                            if (unlikely(__pyx_v_width == 0)) {
                              #ifdef WITH_THREAD
                              PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                              #endif
                              PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                              #ifdef WITH_THREAD
                              __Pyx_PyGILState_Release(__pyx_gilstate_save);
                              #endif
                              __PYX_ERR(1, 6601, __pyx_L11_error)
                            }
                            __pyx_t_13 = __Pyx_mod_int(__pyx_v_x, __pyx_v_height);
                            __pyx_t_14 = __Pyx_mod_long(__pyx_t_12, __pyx_v_width);
                            *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_13 * __pyx_v_fire.strides[0]) )) + __pyx_t_14)) )) = randRange(__pyx_v_intensity, 0x104);
                            goto __pyx_L14;
                            __pyx_L11_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L13;
                            __pyx_L13:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates9)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_x;
                            }
                            __pyx_L14:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_x = __pyx_parallel_temp0;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L7_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
 6602: 
 6603: 
 6604:         # DILUTE THE FLAME EFFECT (DECREASE THE MAXIMUM INT VALUE) WHEN THE FLAME TRAVEL UPWARD
+6605:         for y in prange(1, height - 1, schedule='static', num_threads=THREADS):
        __pyx_t_12 = (__pyx_v_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_12 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_12 = (__pyx_v_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_12 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_16; __pyx_t_15++){
                        {
                            __pyx_v_y = (int)(1 + 1 * __pyx_t_15);
                            /* Initialize private variables to invalid values */
                            __pyx_v_c1 = ((unsigned int)0xbad0bad0);
                            __pyx_v_c2 = ((unsigned int)0xbad0bad0);
                            __pyx_v_d = ((float)__PYX_NAN());
                            __pyx_v_ii = ((unsigned int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
 6606: 
+6607:             for x in range(0, width):
                            __pyx_t_11 = __pyx_v_width;
                            __pyx_t_10 = __pyx_t_11;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_10; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 6608: 
+6609:                     c1 = (y + 1) % height
                              __pyx_t_17 = (__pyx_v_y + 1);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6609, __pyx_L17_error)
                              }
                              __pyx_v_c1 = __Pyx_mod_long(__pyx_t_17, __pyx_v_height);
+6610:                     c2 = x % width
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6610, __pyx_L17_error)
                              }
                              __pyx_v_c2 = __Pyx_mod_int(__pyx_v_x, __pyx_v_width);
+6611:                     d = (fire[c1, (x - 1 + width) % width]
                              __pyx_t_17 = ((__pyx_v_x - 1) + __pyx_v_width);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6611, __pyx_L17_error)
                              }
                              __pyx_t_18 = __pyx_v_c1;
                              __pyx_t_14 = __Pyx_mod_long(__pyx_t_17, __pyx_v_width);
+6612:                        + fire[c1, c2]
                              __pyx_t_19 = __pyx_v_c1;
                              __pyx_t_20 = __pyx_v_c2;
+6613:                        + fire[c1, (x + 1) % width]
                              __pyx_t_21 = (__pyx_v_x + 1);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6613, __pyx_L17_error)
                              }
                              __pyx_t_22 = __pyx_v_c1;
                              __pyx_t_13 = __Pyx_mod_long(__pyx_t_21, __pyx_v_width);
+6614:                        + fire[(y + 2) % height, c2]) * factor
                              __pyx_t_23 = (__pyx_v_y + 2);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6614, __pyx_L17_error)
                              }
                              __pyx_t_24 = __Pyx_mod_long(__pyx_t_23, __pyx_v_height);
                              __pyx_t_25 = __pyx_v_c2;
                              __pyx_v_d = (((((*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_18 * __pyx_v_fire.strides[0]) )) + __pyx_t_14)) ))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_19 * __pyx_v_fire.strides[0]) )) + __pyx_t_20)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_22 * __pyx_v_fire.strides[0]) )) + __pyx_t_13)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_24 * __pyx_v_fire.strides[0]) )) + __pyx_t_25)) )))) * __pyx_v_factor);
 6615: 
+6616:                     d = d - <float>(rand() * 0.0001)
                              __pyx_v_d = (__pyx_v_d - ((float)(rand() * 0.0001)));
 6617: 
 6618:                     # Cap the values
+6619:                     if d <0:
                              __pyx_t_6 = ((__pyx_v_d < 0.0) != 0);
                              if (__pyx_t_6) {
/* … */
                              }
+6620:                         d = 0.0
                                __pyx_v_d = 0.0;
 6621: 
+6622:                     if d>255.0:
                              __pyx_t_6 = ((__pyx_v_d > 255.0) != 0);
                              if (__pyx_t_6) {
/* … */
                              }
+6623:                         d = <float>255.0
                                __pyx_v_d = ((float)255.0);
 6624: 
+6625:                     fire[x % height , y % width] = d
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6625, __pyx_L17_error)
                              }
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6625, __pyx_L17_error)
                              }
                              __pyx_t_24 = __Pyx_mod_int(__pyx_v_x, __pyx_v_height);
                              __pyx_t_13 = __Pyx_mod_int(__pyx_v_y, __pyx_v_width);
                              *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_fire.data + __pyx_t_24 * __pyx_v_fire.strides[0]) )) + __pyx_t_13)) )) = __pyx_v_d;
 6626: 
+6627:                     ii = palette[<unsigned int>d % width]
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 6627, __pyx_L17_error)
                              }
                              __pyx_t_25 = (((unsigned int)__pyx_v_d) % __pyx_v_width);
                              __pyx_v_ii = (*((unsigned int *) ( /* dim=0 */ ((char *) (((unsigned int *) __pyx_v_palette.data) + __pyx_t_25)) )));
 6628: 
+6629:                     out[x, y, 0] = (ii >> 16) & 255
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_14 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_13 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_14)) )) = ((__pyx_v_ii >> 16) & 0xFF);
+6630:                     out[x, y, 1] = (ii >> 8) & 255
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_14 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_13)) )) = ((__pyx_v_ii >> 8) & 0xFF);
+6631:                     out[x, y, 2] = ii & 255
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_14 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_13 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_14)) )) = (__pyx_v_ii & 0xFF);
                            }
                            goto __pyx_L24;
                            __pyx_L17_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L23;
                            __pyx_L23:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates10)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_c1;
                                __pyx_parallel_temp1 = __pyx_v_c2;
                                __pyx_parallel_temp2 = __pyx_v_d;
                                __pyx_parallel_temp3 = __pyx_v_ii;
                                __pyx_parallel_temp4 = __pyx_v_x;
                                __pyx_parallel_temp5 = __pyx_v_y;
                            }
                            __pyx_L24:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_c1 = __pyx_parallel_temp0;
              __pyx_v_c2 = __pyx_parallel_temp1;
              __pyx_v_d = __pyx_parallel_temp2;
              __pyx_v_ii = __pyx_parallel_temp3;
              __pyx_v_x = __pyx_parallel_temp4;
              __pyx_v_y = __pyx_parallel_temp5;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L7_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 6632: 
+6633:     return asarray(out)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_asarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6633, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_out, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6633, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_1 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_1)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_2 = (__pyx_t_1) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_1, __pyx_t_3) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_3);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6633, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;
 6634: 
 6635: 
 6636: # CUSTOM FIRE PALETTE
 6637: # arr = numpy.array([0, 1,       # violet
 6638: #                    0, 1,       # blue
 6639: #                    0, 1,       # green
 6640: #                    2, 619,     # yellow
 6641: #                    620, 650,   # orange
 6642: #                    651, 660],  # red
 6643: #                   numpy.int)
 6644: #
 6645: # HEATMAP = [custom_map(i - 20, arr, 1.0) for i in range(380, 800)]
 6646: # heatmap_array = numpy.zeros((800 - 380, 3), uint8)
 6647: # heatmap_rescale = numpy.zeros(255, numpy.uint)
 6648: # i = 0
 6649: # for t in HEATMAP:
 6650: #     heatmap_array[i, 0] = t[0]
 6651: #     heatmap_array[i, 1] = t[1]
 6652: #     heatmap_array[i, 2] = t[2]
 6653: #     i += 1
 6654: # for r in range(0, 255):
 6655: #     s = int(r * (800.0-380.0)/255)
 6656: #     heatmap_rescale[r] = rgb_to_int(heatmap_array[s][0], heatmap_array[s][1], heatmap_array[s][2])
 6657: # heatmap_rescale = numpy.ascontiguousarray(heatmap_rescale[::-1])
 6658: # -------- main loop ----
 6659: # if frame % 2 == 0:
 6660: # surface_ = fire_effect(
 6661: #     width, height, 3.95 + random.uniform(0.002, 0.008),
 6662: #     heatmap_rescale,
 6663: #     FIRE_ARRAY,
 6664: #     reduce_factor_=3,  fire_intensity_=8,
 6665: #     smooth_=True, bloom_=True, fast_bloom_=True,
 6666: #     bpf_threshold_=70, low_=0, high_=800, brightness_=True, brightness_intensity_=0.1,
 6667: #     adjust_palette_=False, hsv_=(10,  80, 1.8), transpose_=False, border_=False, surface_=None)
 6668: 
 6669: @cython.boundscheck(False)
 6670: @cython.wraparound(False)
 6671: @cython.nonecheck(False)
 6672: @cython.cdivision(True)
+6673: cdef inline shader_fire_effect_c(
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_shader_fire_effect_c(int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_fire_, struct __pyx_opt_args_12PygameShader_6shader_shader_fire_effect_c *__pyx_optional_args) {
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)3);
  unsigned short __pyx_v_fire_intensity_ = ((unsigned short)32);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __PYX_XDEC_MEMVIEW(&__pyx_t_15, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_18, 1);
  __Pyx_AddTraceback("PygameShader.shader.shader_fire_effect_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_fire_surface_smallest);
  __Pyx_XDECREF(__pyx_v_rgb_array_);
  __Pyx_XDECREF(__pyx_v_fire_effect);
  __PYX_XDEC_MEMVIEW(&__pyx_v_palette_, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+6674:         int width_,
struct __pyx_opt_args_12PygameShader_6shader_shader_fire_effect_c {
  int __pyx_n;
  unsigned short reduce_factor_;
  unsigned short fire_intensity_;
  int smooth_;
  int bloom_;
  int fast_bloom_;
  unsigned char bpf_threshold_;
  unsigned int low_;
  unsigned int high_;
  int brightness_;
  float brightness_intensity_;
  PyObject *surface_;
  int adjust_palette_;
  PyObject *hsl_;
  int transpose_;
  int border_;
  int blur_;
};
 6675:         int height_,
 6676:         float factor_,
 6677:         unsigned int [::1] palette_,
 6678:         float [:, ::1] fire_,
 6679:         unsigned short int reduce_factor_ = 3,
 6680:         unsigned short int fire_intensity_= 32,
+6681:         bint smooth_                      = True,
  int __pyx_v_smooth_ = ((int)1);
+6682:         bint bloom_                       = True,
  int __pyx_v_bloom_ = ((int)1);
+6683:         bint fast_bloom_                  = True,
  int __pyx_v_fast_bloom_ = ((int)1);
  unsigned char __pyx_v_bpf_threshold_ = ((unsigned char)0);
  unsigned int __pyx_v_low_ = ((unsigned int)0);
  unsigned int __pyx_v_high_ = ((unsigned int)0x258);
 6684:         unsigned char bpf_threshold_      = 0,
 6685:         unsigned int low_                 = 0,
 6686:         unsigned int high_                = 600,
+6687:         bint brightness_                  = True,
  int __pyx_v_brightness_ = ((int)1);
  float __pyx_v_brightness_intensity_ = ((float)0.15);
 6688:         float brightness_intensity_       = 0.15,
+6689:         object surface_                   = None,
  PyObject *__pyx_v_surface_ = ((PyObject *)Py_None);
+6690:         bint adjust_palette_              = False,
  int __pyx_v_adjust_palette_ = ((int)0);
+6691:         tuple hsl_                        = (10, 80, 1.8),
  PyObject *__pyx_v_hsl_ = ((PyObject*)__pyx_tuple__23);
/* … */
  __pyx_tuple__23 = PyTuple_Pack(3, __pyx_int_10, __pyx_int_80, __pyx_float_1_8); if (unlikely(!__pyx_tuple__23)) __PYX_ERR(1, 6691, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__23);
  __Pyx_GIVEREF(__pyx_tuple__23);
+6692:         bint transpose_                   = False,
  int __pyx_v_transpose_ = ((int)0);
+6693:         bint border_                      = False,
  int __pyx_v_border_ = ((int)0);
+6694:         bint blur_                        = True
  int __pyx_v_blur_ = ((int)1);
  int __pyx_v_w4;
  int __pyx_v_h4;
  int __pyx_v_f_height;
  int __pyx_v_f_width;
  PyObject *__pyx_v_fire_surface_smallest = NULL;
  PyObject *__pyx_v_rgb_array_ = NULL;
  PyObject *__pyx_v_fire_effect = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_fire_effect_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_fire_intensity_ = __pyx_optional_args->fire_intensity_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_smooth_ = __pyx_optional_args->smooth_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_bloom_ = __pyx_optional_args->bloom_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_fast_bloom_ = __pyx_optional_args->fast_bloom_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_bpf_threshold_ = __pyx_optional_args->bpf_threshold_;
                if (__pyx_optional_args->__pyx_n > 6) {
                  __pyx_v_low_ = __pyx_optional_args->low_;
                  if (__pyx_optional_args->__pyx_n > 7) {
                    __pyx_v_high_ = __pyx_optional_args->high_;
                    if (__pyx_optional_args->__pyx_n > 8) {
                      __pyx_v_brightness_ = __pyx_optional_args->brightness_;
                      if (__pyx_optional_args->__pyx_n > 9) {
                        __pyx_v_brightness_intensity_ = __pyx_optional_args->brightness_intensity_;
                        if (__pyx_optional_args->__pyx_n > 10) {
                          __pyx_v_surface_ = __pyx_optional_args->surface_;
                          if (__pyx_optional_args->__pyx_n > 11) {
                            __pyx_v_adjust_palette_ = __pyx_optional_args->adjust_palette_;
                            if (__pyx_optional_args->__pyx_n > 12) {
                              __pyx_v_hsl_ = __pyx_optional_args->hsl_;
                              if (__pyx_optional_args->__pyx_n > 13) {
                                __pyx_v_transpose_ = __pyx_optional_args->transpose_;
                                if (__pyx_optional_args->__pyx_n > 14) {
                                  __pyx_v_border_ = __pyx_optional_args->border_;
                                  if (__pyx_optional_args->__pyx_n > 15) {
                                    __pyx_v_blur_ = __pyx_optional_args->blur_;
                                  }
                                }
                              }
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
  __PYX_INC_MEMVIEW(&__pyx_v_palette_, 1);
 6695:         ):
 6696:     """
 6697: 
 6698:     FIRE SHADER EFFECT 
 6699: 
 6700:     * FIRE TEXTURE SIZES 
 6701:     
 6702:     input width_  : integer,  
 6703:     input height_ : integer
 6704:     
 6705:     width_ and height_ values define the size of the texture e.g Surface(width x height)
 6706: 
 6707:     * FIRE ASPECT (CONTROL OVER THE WIDTH): 
 6708:     
 6709:     inputs low_ : integer  
 6710:     input high_ : integer 
 6711:     
 6712:     Optional arguments low_ & high_ (integer values) define the width 's limits of the fire effect. 
 6713:     low_ for the starting point and high_ for the ending of the effect.
 6714:     e.g low_ = 10 and high_ = 200. The fire effect will be contain within width = 10 and 200
 6715:     low_ & high_ values must be in range [0 ... width_]  
 6716:         
 6717:     * FIRE HEIGHT:
 6718:     
 6719:     input factor_ : float
 6720:     
 6721:     The fire maximum height can be adjust with the variable factor_ (float value)
 6722:     value > 3.95 will contain the effect within the display 
 6723:     value < 3.95 will enlarge the effect over the display height  
 6724:     Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually 
 6725:     to contain the fire effect within the display
 6726:         
 6727:     * SPEED CONSIDERATION
 6728:     
 6729:     input reduce_factor_ : integer
 6730:     
 6731:     The argument reduce_factor_ control the size of the texture to be processed 
 6732:     e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)
 6733:     Smaller texture improve the overall performances but will slightly degrade the fire aspect, 
 6734:     especially if the blur and smooth option are not enabled.
 6735:     Recommended value for reduce_factor_ is 3 (fast process)   
 6736:     reduce_factor_ values must be an integer in range [ 0 ... 4] 
 6737:     The reduce_factor_ value will have a significant impact on the fire effect maximum height, 
 6738:     adjust the argument factor_ accordingly
 6739: 
 6740:     * FIRE INTENSITY AT THE SOURCE
 6741:     
 6742:     input fire_intensity_: integer
 6743:     
 6744:     Set the fire intensity with the variable fire_intensity_, 0 low flame,
 6745:     32 maximum flame effect
 6746:     Values must be an int in range [0 ... 32] 
 6747: 
 6748:     * SMOOTHING THE EFFECT
 6749:     
 6750:     input smooth_: True | False
 6751:     
 6752:     When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear 
 6753:     filtering) or False the final texture will be adjust with the scale function.
 6754:     Set this variable to False if you need the best performance for the effect or if you require
 6755:     a pixelated fire effect. Otherwise set the variable to True for a more realistic effect. 
 6756: 
 6757:     
 6758:     * BLOOM EFFECT 
 6759:     
 6760:     input bloom_         : True | False
 6761:     input fast_bloom_    : True | False
 6762:     input bpf_threshold_ : integer
 6763:        
 6764:     Fire effect produce a bright and smooth light effect to the background texture where the fire 
 6765:     intensity is at its maximum.
 6766:     Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances
 6767:     The flag fast_bloom_ define a very fast bloom algo using only the smallest texture 
 6768:     to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect 
 6769:     project for more details.
 6770:     When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will 
 6771:     produce a more realistic fire effect (this will slightly degrade the overall performances). 
 6772:     If the fire effect is too bright, you can always adjust the bright pass filter value
 6773:     bpf_threshold_(this will adjust the bloom intensity)
 6774:     bpf_threshold_ value must be in range [ 0 ... 255]   
 6775:     Below 128 the bloom effect will be more noticeable and above 128 only the brightest
 6776:     area will be enhanced.
 6777: 
 6778:     * LIGHT EFFECT INTENSITY
 6779: 
 6780:     input brightness_            : True | False
 6781:     input brightness_intensity_  : float
 6782: 
 6783:     When the flag is set to True, the algorithm will use an external function, 
 6784:     <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture
 6785:     A custom color can be passed to the function defining the pixels to be ignored during the 
 6786:     process (default is black color).
 6787:     the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness 
 6788:     of the flame effect and positive values will increase the brightness of the effect (causing
 6789:     bright white patches on the fire texture). 
 6790:     Values below -0.4 will cause the fire effect to be translucent and this effect can also be 
 6791:     used for simulating ascending heat convection effects on a background texture.
 6792:     
 6793:     
 6794:     * OPTIONAL SURFACE
 6795:       
 6796:     input surface_ : pygame.Surface
 6797:       
 6798:     This is an optional surface that can be passed to the shader to improve the performances 
 6799:     and to avoid a new surface to be generated every iterations. The surface size must match 
 6800:     exactly the reduce texture dimensions otherwise an exception will be raise. 
 6801:     see reduce_factor_ option to determine the fire texture size that will be processed.
 6802:     
 6803:     * COLOR PALETTE ADJUSTMENT  
 6804:     
 6805:     input adjust_palette_ : True | False
 6806:     input hsl_            : (10, 80, 1.8)
 6807: 
 6808:     Set this flag to True to modify the color palette of the fire texture. 
 6809:     This allow the HSL color model to be apply to the palette values
 6810:     You can redefine the palette when the flag is True and by customizing a tuple of 3 float 
 6811:     values, default is (10, 80, 1.8). 
 6812:     The first value control the palette hue value, the second is for the saturation and last, 
 6813:     the palette color lightness. 
 6814:     With the variable hsl_ you can rotate the palette colors and define a new flame
 6815:     aspect/color/intensity
 6816: 
 6817:     * FLAME ORIENTATION / DIRECTION & BORDER FLAME EFFECT
 6818:      
 6819:     input transpose_ = True | False,
 6820:     input border_    = True | False,
 6821:     
 6822:     transpose_ = True, this will transpose the final array 
 6823:     for e.g :  
 6824:     If the final fire texture is (w, h) after setting the transpose flag, the final 
 6825:     fire texture will become (h, w). As a result the fire effect will be transversal (starting 
 6826:     from the right of the display to the left side). 
 6827:     You can always transpose / flip the texture to get the right flame orientation  
 6828:     BORDER FLAME EFFECT 
 6829:     border_ = True to create a flame effect burning the edge of the display
 6830:     
 6831:     * FINAL TOUCH
 6832:     
 6833:     input blur_ : True | False
 6834:     
 6835:     This will will blur the fire effect for a more realistic appearance, remove all the jagged 
 6836:     edge when and pixelated effect
 6837:     
 6838:     
 6839:     :param width_           : integer; Size (width) of the surface or display in pixels
 6840:     :param height_          : integer; size (height) of the surface or display in pixels
 6841:     :param factor_          : float; Value controlling the fire height value
 6842:                               must be in range [3.95 ... 4.2].
 6843:                               The value 3.95 gives the highest flame effect
 6844:     :param palette_         : numpy.ndarray, buffer containing mapped RGB colors (uint values)
 6845:     :param fire_            : numpy.ndarray shape (w, h) containing float values (fire intensity).
 6846:                               For better performance it is advised to set the array to the size 
 6847:                               of the texture after applying the reduction_factor_.
 6848:                               For example if the reduction_factor_ is 2, the texture would have 
 6849:                               width >> 1 and height >> 1 and the fire_array should be set to 
 6850:                               numpy.empty((height >> 1, width >> 1), float32)
 6851:     :param reduce_factor_   : unsigned short int ; Can be either 0, 1, 2, 3, 4. 
 6852:                               2 and 3 provide the best performance and the best looking effect.
 6853:     :param fire_intensity_  : Integer; Control the original amount of energy at the
 6854:                               bottom of the fire, must be in range of [0 ... 32]. 
 6855:                               32 being the maximum value and the maximum fire intensity
 6856:     :param smooth_          : boolean; True smoothscale (bi-linear filtering) or
 6857:                               scale algorithm jagged edges (mush faster)
 6858:     :param bloom_           : boolean; True or False, True apply a bloom effect to the fire effect
 6859:     :param fast_bloom_      : boolean; Fastest bloom. This reduce the amount of calculation
 6860:     :param bpf_threshold_   : integer; control the bright pass filter threshold
 6861:                               value, must be in range [0 ... 255].
 6862:                               Maximum brightness amplification with threshold = 0, 
 6863:                               when bpf_threshold_ = 255, no change.
 6864:     :param low_             : integer; Starting position x for the fire effect
 6865:     :param high_            : integer; Ending position x for the fire effect
 6866:     :param brightness_      : boolean; True apply a bright filter shader to the array.
 6867:                               Increase overall brightness of the effect
 6868:     :param brightness_intensity_: float; must be in range [-1.0 ... 1.0] control
 6869:                               the brightness intensity
 6870:                               of the effect
 6871:     :param surface_         : pygame.Surface. Pass a surface to the shader for
 6872:                               better performance, otherwise algo is creating a new surface each 
 6873:                               calls.
 6874:     :param adjust_palette_  : boolean; True adjust the palette setting HSL
 6875:                               (hue, saturation, luminescence).
 6876:                               Be aware that if adjust_palette is True, the optional palette 
 6877:                               passed to the Shader will be disregarded
 6878:     :param hsl_             : tuple; float values of hue, saturation and luminescence.
 6879:                               Hue in range [0.0 ... 100],  saturation [0...100], 
 6880:                               luminescence [0.0 ... 2.0]
 6881:     :param transpose_       : boolean; Transpose the array (w, h) become (h, w).
 6882:                               The fire effect will start from the left and move to the right
 6883:     :param border_          : boolean; Flame effect affect the border of the texture
 6884:     :param blur_            : boolean; Blur the fire effect
 6885:     :return                 : Return a pygame surface that can be blit directly to the game display
 6886: 
 6887:     """
 6888: 
 6889: 
 6890:     cdef int w4, h4
 6891: 
 6892:     # TEXTURE DIVIDE BY POWER OF 2
+6893:     if reduce_factor_ in (0, 1, 2):
  switch (__pyx_v_reduce_factor_) {
    case 0:
    case 1:
    case 2:
/* … */
    break;
    case 3:
+6894:         w4, h4 = width_ >> reduce_factor_, height_ >> reduce_factor_
    __pyx_t_1 = (__pyx_v_width_ >> __pyx_v_reduce_factor_);
    __pyx_t_2 = (__pyx_v_height_ >> __pyx_v_reduce_factor_);
    __pyx_v_w4 = __pyx_t_1;
    __pyx_v_h4 = __pyx_t_2;
 6895: 
 6896:     # TEXTURE 150 x 150 * ratio
+6897:     elif reduce_factor_ == 3:
    break;
    case 4:
 6898:         # CUSTOM SIZE WIDTH 150 AND RATIO * HIGH
+6899:         w4 = 150
    __pyx_v_w4 = 0x96;
+6900:         h4 = <int>(150 * height_/width_)
    __pyx_v_h4 = ((int)((0x96 * __pyx_v_height_) / __pyx_v_width_));
+6901:         low_ = <int>(low_ * low_/width_)
    __pyx_v_low_ = ((int)((__pyx_v_low_ * __pyx_v_low_) / __pyx_v_width_));
+6902:         high_ = <int>(high_ * 150/width_)
    __pyx_v_high_ = ((int)((__pyx_v_high_ * 0x96) / __pyx_v_width_));
+6903:         reduce_factor_ = 0
    __pyx_v_reduce_factor_ = 0;
 6904: 
 6905:     # TEXTURE 100 x 100 * ratio
+6906:     elif reduce_factor_ == 4:
    break;
    default: break;
  }
+6907:         w4 = 100
    __pyx_v_w4 = 0x64;
+6908:         h4 = <int> (100 * height_ / width_)
    __pyx_v_h4 = ((int)((0x64 * __pyx_v_height_) / __pyx_v_width_));
+6909:         low_ = <int> (low_ * low_ / width_)
    __pyx_v_low_ = ((int)((__pyx_v_low_ * __pyx_v_low_) / __pyx_v_width_));
+6910:         high_ = <int> (high_ * 100 / width_)
    __pyx_v_high_ = ((int)((__pyx_v_high_ * 0x64) / __pyx_v_width_));
+6911:         reduce_factor_ = 0
    __pyx_v_reduce_factor_ = 0;
 6912: 
 6913:     cdef int f_height, f_width
+6914:     f_height, f_width = (<object>fire_).shape[:2]
  __pyx_t_3 = __pyx_memoryview_fromslice(__pyx_v_fire_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_shape); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyObject_GetSlice(__pyx_t_4, 0, 2, NULL, NULL, &__pyx_slice__24, 0, 1, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_3))) || (PyList_CheckExact(__pyx_t_3))) {
    PyObject* sequence = __pyx_t_3;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 6914, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_4 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_5 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_5);
    #else
    __pyx_t_4 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6914, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6914, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    #endif
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_6 = PyObject_GetIter(__pyx_t_3); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6914, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_7 = Py_TYPE(__pyx_t_6)->tp_iternext;
    index = 0; __pyx_t_4 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_4)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    index = 1; __pyx_t_5 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_5)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_5);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_7(__pyx_t_6), 2) < 0) __PYX_ERR(1, 6914, __pyx_L1_error)
    __pyx_t_7 = NULL;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_7 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 6914, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_2 = __Pyx_PyInt_As_int(__pyx_t_4); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_1 = __Pyx_PyInt_As_int(__pyx_t_5); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_f_height = __pyx_t_2;
  __pyx_v_f_width = __pyx_t_1;
/* … */
  __pyx_slice__24 = PySlice_New(Py_None, __pyx_int_2, Py_None); if (unlikely(!__pyx_slice__24)) __PYX_ERR(1, 6914, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_slice__24);
  __Pyx_GIVEREF(__pyx_slice__24);
 6915: 
+6916:     assert f_width >= w4 or f_height >= h4,\
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_9 = ((__pyx_v_f_width >= __pyx_v_w4) != 0);
    if (!__pyx_t_9) {
    } else {
      __pyx_t_8 = __pyx_t_9;
      goto __pyx_L5_bool_binop_done;
    }
    __pyx_t_9 = ((__pyx_v_f_height >= __pyx_v_h4) != 0);
    __pyx_t_8 = __pyx_t_9;
    __pyx_L5_bool_binop_done:;
    if (unlikely(!__pyx_t_8)) {
 6917:         "Fire array size mismatch the texture size.\n" \
+6918:         "Set fire_ array to numpy.empty((%s, %s), dtype=numpy.float32)" % (h4, w4)
      __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6918, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6918, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6918, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_GIVEREF(__pyx_t_3);
      PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
      __Pyx_GIVEREF(__pyx_t_5);
      PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_5);
      __pyx_t_3 = 0;
      __pyx_t_5 = 0;
      __pyx_t_5 = __Pyx_PyString_Format(__pyx_kp_s_Fire_array_size_mismatch_the_tex, __pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6918, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_5);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __PYX_ERR(1, 6916, __pyx_L1_error)
    }
  }
  #endif
 6919: 
+6920:     if surface_ is None:
  __pyx_t_8 = (__pyx_v_surface_ == Py_None);
  __pyx_t_9 = (__pyx_t_8 != 0);
  if (__pyx_t_9) {
/* … */
    goto __pyx_L7;
  }
+6921:         fire_surface_smallest = pygame.Surface((w4, h4)).convert()
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pygame); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_Surface); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_10 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_11 = PyTuple_New(2); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_GIVEREF(__pyx_t_3);
    PyTuple_SET_ITEM(__pyx_t_11, 0, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_10);
    PyTuple_SET_ITEM(__pyx_t_11, 1, __pyx_t_10);
    __pyx_t_3 = 0;
    __pyx_t_10 = 0;
    __pyx_t_10 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_6);
      if (likely(__pyx_t_10)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
        __Pyx_INCREF(__pyx_t_10);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_6, function);
      }
    }
    __pyx_t_4 = (__pyx_t_10) ? __Pyx_PyObject_Call2Args(__pyx_t_6, __pyx_t_10, __pyx_t_11) : __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_t_11);
    __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_convert); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_6, function);
      }
    }
    __pyx_t_5 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_6);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6921, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_v_fire_surface_smallest = __pyx_t_5;
    __pyx_t_5 = 0;
 6922: 
 6923:     else:
+6924:         if PyObject_IsInstance(surface_, pygame.Surface):
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_pygame); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6924, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_Surface); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6924, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_9 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_6); if (unlikely(__pyx_t_9 == ((int)-1))) __PYX_ERR(1, 6924, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_8 = (__pyx_t_9 != 0);
    if (likely(__pyx_t_8)) {
/* … */
      goto __pyx_L8;
    }
+6925:             assert surface_.get_width() == w4 and surface_.get_height() == h4, \
      #ifndef CYTHON_WITHOUT_ASSERTIONS
      if (unlikely(!Py_OptimizeFlag)) {
        __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_width); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_4 = NULL;
        if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_5))) {
          __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_5);
          if (likely(__pyx_t_4)) {
            PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
            __Pyx_INCREF(__pyx_t_4);
            __Pyx_INCREF(function);
            __Pyx_DECREF_SET(__pyx_t_5, function);
          }
        }
        __pyx_t_6 = (__pyx_t_4) ? __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_4) : __Pyx_PyObject_CallNoArg(__pyx_t_5);
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_4 = PyObject_RichCompare(__pyx_t_6, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_9 < 0)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (__pyx_t_9) {
        } else {
          __pyx_t_8 = __pyx_t_9;
          goto __pyx_L9_bool_binop_done;
        }
        __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_height); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_6 = NULL;
        if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_5))) {
          __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
          if (likely(__pyx_t_6)) {
            PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
            __Pyx_INCREF(__pyx_t_6);
            __Pyx_INCREF(function);
            __Pyx_DECREF_SET(__pyx_t_5, function);
          }
        }
        __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_6) : __Pyx_PyObject_CallNoArg(__pyx_t_5);
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_6 = PyObject_RichCompare(__pyx_t_4, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_6); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely(__pyx_t_9 < 0)) __PYX_ERR(1, 6925, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        __pyx_t_8 = __pyx_t_9;
        __pyx_L9_bool_binop_done:;
        if (unlikely(!__pyx_t_8)) {
 6926:             "Surface argument has incorrect dimension surface must be (w:%s, h:%s) got (%s, %s)\n" \
 6927:             "Set argument surface_ to None to avoid this error message"\
+6928:             % (w4, h4, surface_.get_width(), surface_.get_height())
          __pyx_t_6 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_6);
          __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_5);
          __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_width); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_11);
          __pyx_t_10 = NULL;
          if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_11))) {
            __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_11);
            if (likely(__pyx_t_10)) {
              PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_11);
              __Pyx_INCREF(__pyx_t_10);
              __Pyx_INCREF(function);
              __Pyx_DECREF_SET(__pyx_t_11, function);
            }
          }
          __pyx_t_4 = (__pyx_t_10) ? __Pyx_PyObject_CallOneArg(__pyx_t_11, __pyx_t_10) : __Pyx_PyObject_CallNoArg(__pyx_t_11);
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_4);
          __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
          __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_height); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
          __pyx_t_3 = NULL;
          if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_10))) {
            __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_10);
            if (likely(__pyx_t_3)) {
              PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
              __Pyx_INCREF(__pyx_t_3);
              __Pyx_INCREF(function);
              __Pyx_DECREF_SET(__pyx_t_10, function);
            }
          }
          __pyx_t_11 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_10, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_10);
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_11);
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          __pyx_t_10 = PyTuple_New(4); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
          __Pyx_GIVEREF(__pyx_t_6);
          PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_6);
          __Pyx_GIVEREF(__pyx_t_5);
          PyTuple_SET_ITEM(__pyx_t_10, 1, __pyx_t_5);
          __Pyx_GIVEREF(__pyx_t_4);
          PyTuple_SET_ITEM(__pyx_t_10, 2, __pyx_t_4);
          __Pyx_GIVEREF(__pyx_t_11);
          PyTuple_SET_ITEM(__pyx_t_10, 3, __pyx_t_11);
          __pyx_t_6 = 0;
          __pyx_t_5 = 0;
          __pyx_t_4 = 0;
          __pyx_t_11 = 0;
          __pyx_t_11 = __Pyx_PyString_Format(__pyx_kp_s_Surface_argument_has_incorrect_d, __pyx_t_10); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6928, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_11);
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          PyErr_SetObject(PyExc_AssertionError, __pyx_t_11);
          __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
          __PYX_ERR(1, 6925, __pyx_L1_error)
        }
      }
      #endif
+6929:             fire_surface_smallest = surface_
      __Pyx_INCREF(__pyx_v_surface_);
      __pyx_v_fire_surface_smallest = __pyx_v_surface_;
 6930:         else:
+6931:             raise ValueError("Argument surface_ must be a Surface type got %s " % type(surface_))
    /*else*/ {
      __pyx_t_11 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_Surf, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6931, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __pyx_t_10 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_11); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6931, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_Raise(__pyx_t_10, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __PYX_ERR(1, 6931, __pyx_L1_error)
    }
    __pyx_L8:;
  }
  __pyx_L7:;
 6932: 
+6933:     if adjust_palette_:
  __pyx_t_8 = (__pyx_v_adjust_palette_ != 0);
  if (__pyx_t_8) {
/* … */
  }
+6934:         palette_= make_palette_c(w4, hsl_[0], hsl_[1], hsl_[2])
    if (unlikely(__pyx_v_hsl_ == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6934, __pyx_L1_error)
    }
    __pyx_t_12 = __pyx_PyFloat_AsFloat(PyTuple_GET_ITEM(__pyx_v_hsl_, 0)); if (unlikely((__pyx_t_12 == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 6934, __pyx_L1_error)
    if (unlikely(__pyx_v_hsl_ == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6934, __pyx_L1_error)
    }
    __pyx_t_13 = __pyx_PyFloat_AsFloat(PyTuple_GET_ITEM(__pyx_v_hsl_, 1)); if (unlikely((__pyx_t_13 == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 6934, __pyx_L1_error)
    if (unlikely(__pyx_v_hsl_ == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable");
      __PYX_ERR(1, 6934, __pyx_L1_error)
    }
    __pyx_t_14 = __pyx_PyFloat_AsFloat(PyTuple_GET_ITEM(__pyx_v_hsl_, 2)); if (unlikely((__pyx_t_14 == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 6934, __pyx_L1_error)
    __pyx_t_10 = __pyx_f_12PygameShader_6shader_make_palette_c(__pyx_v_w4, __pyx_t_12, __pyx_t_13, __pyx_t_14); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6934, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_15 = __Pyx_PyObject_to_MemoryviewSlice_dc_unsigned_int(__pyx_t_10, PyBUF_WRITABLE); if (unlikely(!__pyx_t_15.memview)) __PYX_ERR(1, 6934, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __PYX_XDEC_MEMVIEW(&__pyx_v_palette_, 1);
    __pyx_v_palette_ = __pyx_t_15;
    __pyx_t_15.memview = NULL;
    __pyx_t_15.data = NULL;
 6935: 
+6936:     if border_:
  __pyx_t_8 = (__pyx_v_border_ != 0);
  if (__pyx_t_8) {
/* … */
    goto __pyx_L12;
  }
 6937:         # CREATE THE FIRE EFFECT ONTO A PYGAME SURFACE
+6938:         rgb_array_ = fire_surface24_c_border(
    __pyx_t_16.__pyx_n = 3;
    __pyx_t_16.intensity = __pyx_v_fire_intensity_;
    __pyx_t_16.low = (__pyx_v_low_ >> __pyx_v_reduce_factor_);
    __pyx_t_16.high = (__pyx_v_high_ >> __pyx_v_reduce_factor_);
    __pyx_t_10 = __pyx_f_12PygameShader_6shader_fire_surface24_c_border(__pyx_v_w4, __pyx_v_h4, (((float)1.0) / __pyx_v_factor_), __pyx_v_palette_, __pyx_v_fire_, &__pyx_t_16); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6938, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_v_rgb_array_ = __pyx_t_10;
    __pyx_t_10 = 0;
 6939:             w4, h4, <float>1.0 / factor_, palette_, fire_, fire_intensity_,
 6940:             low_ >> reduce_factor_, high_ >> reduce_factor_)
 6941:     else:
+6942:         rgb_array_ = fire_surface24_c(
  /*else*/ {
/* … */
    __pyx_t_17.__pyx_n = 3;
    __pyx_t_17.intensity = __pyx_v_fire_intensity_;
    __pyx_t_17.low = (__pyx_v_low_ >> __pyx_v_reduce_factor_);
    __pyx_t_17.high = (__pyx_v_high_ >> __pyx_v_reduce_factor_);
    __pyx_t_10 = __pyx_f_12PygameShader_6shader_fire_surface24_c(__pyx_v_w4, __pyx_v_h4, (((float)1.0) / __pyx_v_factor_), __pyx_v_palette_, __pyx_v_fire_, &__pyx_t_17); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6942, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_v_rgb_array_ = __pyx_t_10;
    __pyx_t_10 = 0;
  }
  __pyx_L12:;
 6943:             w4, h4, <float>1.0 / factor_, palette_, fire_, fire_intensity_,
 6944:                     low_ >> reduce_factor_, high_ >> reduce_factor_)
 6945: 
 6946:     # BRIGHTNESS SHADER
+6947:     if brightness_:
  __pyx_t_8 = (__pyx_v_brightness_ != 0);
  if (__pyx_t_8) {
/* … */
  }
 6948:         # EXCLUDE BLACK COLORS (DEFAULT)
+6949:         assert -1.0 <= brightness_intensity_ <= 1.0, \
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_8 = (-1.0 <= __pyx_v_brightness_intensity_);
      if (__pyx_t_8) {
        __pyx_t_8 = (__pyx_v_brightness_intensity_ <= 1.0);
      }
      if (unlikely(!(__pyx_t_8 != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_brightness_intensity_mu);
        __PYX_ERR(1, 6949, __pyx_L1_error)
      }
    }
    #endif
 6950:             "Argument brightness intensity must be in range [-1.0 ... 1.0]"
+6951:         shader_brightness24_exclude_inplace_c(rgb_array_=rgb_array_,
    __pyx_t_18 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_rgb_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_18.memview)) __PYX_ERR(1, 6951, __pyx_L1_error)
/* … */
    __pyx_t_19.__pyx_n = 2;
    __pyx_t_19.shift_ = __pyx_v_brightness_intensity_;
    __pyx_t_19.color_ = __pyx_tuple__9;
    __pyx_f_12PygameShader_6shader_shader_brightness24_exclude_inplace_c(__pyx_t_18, &__pyx_t_19); 
    __PYX_XDEC_MEMVIEW(&__pyx_t_18, 1);
    __pyx_t_18.memview = NULL;
    __pyx_t_18.data = NULL;
 6952:                                               shift_=brightness_intensity_, color_=(0, 0, 0))
 6953: 
+6954:     if blur_:
  __pyx_t_8 = (__pyx_v_blur_ != 0);
  if (__pyx_t_8) {
/* … */
  }
+6955:         shader_blur5x5_array24_inplace_c(rgb_array_)
    __pyx_t_18 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_rgb_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_18.memview)) __PYX_ERR(1, 6955, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_18, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_18, 1);
    __pyx_t_18.memview = NULL;
    __pyx_t_18.data = NULL;
 6956: 
+6957:     if transpose_:
  __pyx_t_8 = (__pyx_v_transpose_ != 0);
  if (__pyx_t_8) {
/* … */
  }
+6958:         rgb_array_ = rgb_array_.transpose(1, 0, 2)
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_rgb_array_, __pyx_n_s_transpose_2); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6958, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_11 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_tuple__25, NULL); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6958, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF_SET(__pyx_v_rgb_array_, __pyx_t_11);
    __pyx_t_11 = 0;
/* … */
  __pyx_tuple__25 = PyTuple_Pack(3, __pyx_int_1, __pyx_int_0, __pyx_int_2); if (unlikely(!__pyx_tuple__25)) __PYX_ERR(1, 6958, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__25);
  __Pyx_GIVEREF(__pyx_tuple__25);
+6959:         fire_surface_smallest = rotate(fire_surface_smallest, 90)
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_n_s_rotate); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6959, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_4 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_10);
      if (likely(__pyx_t_4)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_10, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_10)) {
      PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_fire_surface_smallest, __pyx_int_90};
      __pyx_t_11 = __Pyx_PyFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6959, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_GOTREF(__pyx_t_11);
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_10)) {
      PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_fire_surface_smallest, __pyx_int_90};
      __pyx_t_11 = __Pyx_PyCFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6959, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_GOTREF(__pyx_t_11);
    } else
    #endif
    {
      __pyx_t_5 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6959, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      if (__pyx_t_4) {
        __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4); __pyx_t_4 = NULL;
      }
      __Pyx_INCREF(__pyx_v_fire_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_fire_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_5, 0+__pyx_t_1, __pyx_v_fire_surface_smallest);
      __Pyx_INCREF(__pyx_int_90);
      __Pyx_GIVEREF(__pyx_int_90);
      PyTuple_SET_ITEM(__pyx_t_5, 1+__pyx_t_1, __pyx_int_90);
      __pyx_t_11 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_t_5, NULL); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6959, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    }
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF_SET(__pyx_v_fire_surface_smallest, __pyx_t_11);
    __pyx_t_11 = 0;
 6960: 
 6961: 
 6962:     # CONVERT THE ARRAY INTO A PYGAME SURFACE
+6963:     array_to_surface(fire_surface_smallest, rgb_array_)
  __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_n_s_array_to_surface); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6963, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_5 = NULL;
  __pyx_t_1 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_10))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_10);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_10, function);
      __pyx_t_1 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_fire_surface_smallest, __pyx_v_rgb_array_};
    __pyx_t_11 = __Pyx_PyFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6963, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_11);
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_10)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_fire_surface_smallest, __pyx_v_rgb_array_};
    __pyx_t_11 = __Pyx_PyCFunction_FastCall(__pyx_t_10, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6963, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_11);
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_5) {
      __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_5); __pyx_t_5 = NULL;
    }
    __Pyx_INCREF(__pyx_v_fire_surface_smallest);
    __Pyx_GIVEREF(__pyx_v_fire_surface_smallest);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_1, __pyx_v_fire_surface_smallest);
    __Pyx_INCREF(__pyx_v_rgb_array_);
    __Pyx_GIVEREF(__pyx_v_rgb_array_);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_1, __pyx_v_rgb_array_);
    __pyx_t_11 = __Pyx_PyObject_Call(__pyx_t_10, __pyx_t_4, NULL); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
 6964: 
 6965: 
 6966:     # BLOOM SHADER EFFECT
+6967:     if bloom_:
  __pyx_t_8 = (__pyx_v_bloom_ != 0);
  if (__pyx_t_8) {
/* … */
  }
+6968:         assert 0 <= bpf_threshold_ < 256, \
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_8 = (0 <= __pyx_v_bpf_threshold_);
      if (__pyx_t_8) {
        __pyx_t_8 = (__pyx_v_bpf_threshold_ < 0x100);
      }
      if (unlikely(!(__pyx_t_8 != 0))) {
+6969:             "Argument bpf_threshold_ must be in range [0 ... 256] got %s " % bpf_threshold_
        __pyx_t_11 = __Pyx_PyInt_From_unsigned_char(__pyx_v_bpf_threshold_); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6969, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_10 = __Pyx_PyString_Format(__pyx_kp_s_Argument_bpf_threshold__must_be, __pyx_t_11); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6969, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        PyErr_SetObject(PyExc_AssertionError, __pyx_t_10);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __PYX_ERR(1, 6968, __pyx_L1_error)
      }
    }
    #endif
+6970:         shader_bloom_effect_array24_c(fire_surface_smallest, bpf_threshold_, fast_=fast_bloom_)
    __pyx_t_20.__pyx_n = 1;
    __pyx_t_20.fast_ = __pyx_v_fast_bloom_;
    __pyx_f_12PygameShader_6shader_shader_bloom_effect_array24_c(__pyx_v_fire_surface_smallest, __pyx_v_bpf_threshold_, &__pyx_t_20); 
 6971: 
 6972:     # RESCALE THE SURFACE TO THE FULL SIZE
+6973:     if smooth_:
  __pyx_t_8 = (__pyx_v_smooth_ != 0);
  if (__pyx_t_8) {
/* … */
    goto __pyx_L17;
  }
+6974:         fire_effect = smoothscale(fire_surface_smallest, (width_, height_))
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_width_); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_height_); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_5);
    __pyx_t_4 = 0;
    __pyx_t_5 = 0;
    __pyx_t_5 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_11);
      if (likely(__pyx_t_5)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_11);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_11, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_11)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_fire_surface_smallest, __pyx_t_6};
      __pyx_t_10 = __Pyx_PyFunction_FastCall(__pyx_t_11, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6974, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_11)) {
      PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_v_fire_surface_smallest, __pyx_t_6};
      __pyx_t_10 = __Pyx_PyCFunction_FastCall(__pyx_t_11, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6974, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    } else
    #endif
    {
      __pyx_t_4 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6974, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__pyx_t_5) {
        __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_5); __pyx_t_5 = NULL;
      }
      __Pyx_INCREF(__pyx_v_fire_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_fire_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_1, __pyx_v_fire_surface_smallest);
      __Pyx_GIVEREF(__pyx_t_6);
      PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_1, __pyx_t_6);
      __pyx_t_6 = 0;
      __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_11, __pyx_t_4, NULL); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6974, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_v_fire_effect = __pyx_t_10;
    __pyx_t_10 = 0;
 6975:     else:
+6976:         fire_effect = scale(fire_surface_smallest, (width_, height_))
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_n_s_scale); if (unlikely(!__pyx_t_11)) __PYX_ERR(1, 6976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_width_); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_6 = __Pyx_PyInt_From_int(__pyx_v_height_); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 6976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_5 = PyTuple_New(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6976, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_6);
    PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_6);
    __pyx_t_4 = 0;
    __pyx_t_6 = 0;
    __pyx_t_6 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_11);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_11);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_11, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_11)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_fire_surface_smallest, __pyx_t_5};
      __pyx_t_10 = __Pyx_PyFunction_FastCall(__pyx_t_11, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6976, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_11)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_fire_surface_smallest, __pyx_t_5};
      __pyx_t_10 = __Pyx_PyCFunction_FastCall(__pyx_t_11, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6976, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    } else
    #endif
    {
      __pyx_t_4 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6976, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__pyx_t_6) {
        __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_6); __pyx_t_6 = NULL;
      }
      __Pyx_INCREF(__pyx_v_fire_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_fire_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_1, __pyx_v_fire_surface_smallest);
      __Pyx_GIVEREF(__pyx_t_5);
      PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_1, __pyx_t_5);
      __pyx_t_5 = 0;
      __pyx_t_10 = __Pyx_PyObject_Call(__pyx_t_11, __pyx_t_4, NULL); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 6976, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_v_fire_effect = __pyx_t_10;
    __pyx_t_10 = 0;
  }
  __pyx_L17:;
 6977: 
+6978:     return fire_effect
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_fire_effect);
  __pyx_r = __pyx_v_fire_effect;
  goto __pyx_L0;
 6979: 
 6980: 
 6981: 
 6982: @cython.boundscheck(False)
 6983: @cython.wraparound(False)
 6984: @cython.nonecheck(False)
 6985: @cython.cdivision(False)
+6986: cdef cloud_surface24_c(
static PyObject *__pyx_f_12PygameShader_6shader_cloud_surface24_c(int __pyx_v_width, int __pyx_v_height, float __pyx_v_factor, __Pyx_memviewslice __pyx_v_palette, __Pyx_memviewslice __pyx_v_cloud_, struct __pyx_opt_args_12PygameShader_6shader_cloud_surface24_c *__pyx_optional_args) {
  int __pyx_v_intensity = ((int)0);
  int __pyx_v_low = ((int)0);
  int __pyx_v_high = ((int)0);
  int __pyx_v_new_height;
  __Pyx_memviewslice __pyx_v_out = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  float __pyx_v_d;
  unsigned int __pyx_v_ii;
  unsigned int __pyx_v_c1;
  unsigned int __pyx_v_c2;
  int __pyx_v_p_length;
  CYTHON_UNUSED int __pyx_v_min_;
  CYTHON_UNUSED int __pyx_v_max_;
  int __pyx_v_middle;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cloud_surface24_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_intensity = __pyx_optional_args->intensity;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_low = __pyx_optional_args->low;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_high = __pyx_optional_args->high;
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __Pyx_AddTraceback("PygameShader.shader.cloud_surface24_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_out, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+6987:         int width,
struct __pyx_opt_args_12PygameShader_6shader_cloud_surface24_c {
  int __pyx_n;
  int intensity;
  int low;
  int high;
};
 6988:         int height,
 6989:         float factor,
 6990:         unsigned int [::1] palette,
 6991:         float [:, ::1] cloud_,
 6992:         int intensity = 0,
 6993:         int low       = 0,
 6994:         int high      = 0,
 6995:     ):
 6996: 
 6997:     """
 6998:     CLOUD PROCESSING FUNCTION
 6999: 
 7000:     * Do not call that function directly, this function is a sub function of cloud_effect
 7001: 
 7002:     :param width    : integer; Size (width) of the surface or display in pixels
 7003:     :param height   : integer; size (height) of the surface or display in pixels
 7004:     :param factor   : float; Value controlling the cloud size value must
 7005:                       be in range [3.95 ... 4.2].
 7006:                       value 3.95 will fill entirely the display with the cloud while value
 7007:                       above 3.95 will shrink the cloud effect
 7008:     :param palette  : numpy.ndarray, buffer containing mapped RGB colors (uint values)
 7009:     :param cloud_   : numpy.ndarray shape (w, h) containing float values (cloud intensity).
 7010:     :param intensity: integer; Determine the guaranteed amount of smoke the cloud
 7011:                       effect will generate at the base
 7012:                       of the effect (value must be in range [0 .. 260]). If you provide zero a 
 7013:                       random value between 0 ... 260 will be
 7014:                       assigned. If you provide 250, a random value between 250 and 260 will be set.
 7015:     :param low      : integer; low determine the X starting position on the display,
 7016:                       if you provide a value of
 7017:                       100 pixels, the effect will start at the position 100 from the display
 7018:                       (first 100 pixels will bot be affected by the cloud/smoke effect)
 7019:     :param high     : integer; high determine the X ending position on the display,
 7020:                       if you provide a value of 800 pixels, the effect will end at the 
 7021:                       position 800 from the display (last remaining pixels will not be affected
 7022:                       by the cloud/smoke effect)
 7023:     :return         : Return a numpy array shape (w, h, 3) containing the RGB pixels (smoke effect)
 7024:     """
 7025: 
 7026:     cdef:
+7027:         int new_height = height
  __pyx_v_new_height = __pyx_v_height;
+7028:         unsigned char [:, :, ::1] out = empty((width, new_height, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_empty); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyInt_From_int(__pyx_v_new_height); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_3);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_int_3);
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_5 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_2, PyBUF_WRITABLE); if (unlikely(!__pyx_t_5.memview)) __PYX_ERR(1, 7028, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_out = __pyx_t_5;
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
+7029:         int x = 0, y = 0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 7030:         float d
+7031:         unsigned int ii=0
  __pyx_v_ii = 0;
+7032:         unsigned c1 = 0, c2 = 0
  __pyx_v_c1 = 0;
  __pyx_v_c2 = 0;
+7033:         int p_length = (<object>palette).size
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_palette, 1, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_int, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_int, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7033, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_size); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7033, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6 = __Pyx_PyInt_As_int(__pyx_t_4); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7033, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_p_length = __pyx_t_6;
 7034: 
 7035:     cdef int min_, max_, middle
 7036: 
+7037:     if low != 0 or high != 0:
  __pyx_t_8 = ((__pyx_v_low != 0) != 0);
  if (!__pyx_t_8) {
  } else {
    __pyx_t_7 = __pyx_t_8;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_8 = ((__pyx_v_high != 0) != 0);
  __pyx_t_7 = __pyx_t_8;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_7) {
/* … */
    goto __pyx_L3;
  }
+7038:         assert 0 <= low < high, "Argument low_ must be < high_"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_7 = (0 <= __pyx_v_low);
      if (__pyx_t_7) {
        __pyx_t_7 = (__pyx_v_low < __pyx_v_high);
      }
      if (unlikely(!(__pyx_t_7 != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_low__must_be_high);
        __PYX_ERR(1, 7038, __pyx_L1_error)
      }
    }
    #endif
+7039:         assert high <= width,   "Argument high must be <= width"
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      if (unlikely(!((__pyx_v_high <= __pyx_v_width) != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_high_must_be_width);
        __PYX_ERR(1, 7039, __pyx_L1_error)
      }
    }
    #endif
 7040: 
+7041:         middle = low + ((high - low) >> 1)
    __pyx_v_middle = (__pyx_v_low + ((__pyx_v_high - __pyx_v_low) >> 1));
+7042:         min_ = randRange(low, middle)
    __pyx_v_min_ = randRange(__pyx_v_low, __pyx_v_middle);
+7043:         max_ = randRange(middle + 1, high)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_high);
 7044:     else:
+7045:         middle = width >> 1
  /*else*/ {
    __pyx_v_middle = (__pyx_v_width >> 1);
+7046:         min_ = randRange(0, middle)
    __pyx_v_min_ = randRange(0, __pyx_v_middle);
+7047:         max_ = randRange(middle +1, width)
    __pyx_v_max_ = randRange((__pyx_v_middle + 1), __pyx_v_width);
  }
  __pyx_L3:;
 7048: 
 7049: 
+7050:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L8;
        }
        __pyx_L7_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L8:;
      }
  }
 7051:         # POPULATE TO THE BASE OF THE FIRE (THIS WILL CONFIGURE THE FLAME ASPECT)
+7052:         for x in prange(min_, max_, schedule='static', num_threads=THREADS):
        __pyx_t_6 = __pyx_v_min_;
        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_6 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static)        __pyx_t_9 = __pyx_v_max_;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_11 = (__pyx_t_9 - __pyx_t_6 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_11 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_10 = 0; __pyx_t_10 < __pyx_t_11; __pyx_t_10++){
                        {
                            __pyx_v_x = (int)(__pyx_t_6 + 1 * __pyx_t_10);
+7053:                 cloud_[(new_height - 1) % height, x % width] = randRange(intensity, 260)
                            __pyx_t_12 = (__pyx_v_new_height - 1);
                            if (unlikely(__pyx_v_height == 0)) {
                              #ifdef WITH_THREAD
                              PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                              #endif
                              PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                              #ifdef WITH_THREAD
                              __Pyx_PyGILState_Release(__pyx_gilstate_save);
                              #endif
                              __PYX_ERR(1, 7053, __pyx_L11_error)
                            }
                            if (unlikely(__pyx_v_width == 0)) {
                              #ifdef WITH_THREAD
                              PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                              #endif
                              PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                              #ifdef WITH_THREAD
                              __Pyx_PyGILState_Release(__pyx_gilstate_save);
                              #endif
                              __PYX_ERR(1, 7053, __pyx_L11_error)
                            }
                            __pyx_t_13 = __Pyx_mod_long(__pyx_t_12, __pyx_v_height);
                            __pyx_t_14 = __Pyx_mod_int(__pyx_v_x, __pyx_v_width);
                            *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_13 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_14)) )) = randRange(__pyx_v_intensity, 0x104);
                            goto __pyx_L14;
                            __pyx_L11_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L13;
                            __pyx_L13:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates11)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_x;
                            }
                            __pyx_L14:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_x = __pyx_parallel_temp0;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L7_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
 7054: 
 7055: 
 7056:         # DILUTE THE FLAME EFFECT (DECREASE THE MAXIMUM INT VALUE) WHEN THE FLAME TRAVEL UPWARD
+7057:         for y in prange(0, new_height - 1, schedule='static', num_threads=THREADS):
        __pyx_t_12 = (__pyx_v_new_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_12 = (__pyx_v_new_height - 1);
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_16 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_16 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_d) lastprivate(__pyx_v_ii) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_15 = 0; __pyx_t_15 < __pyx_t_16; __pyx_t_15++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_15);
                            /* Initialize private variables to invalid values */
                            __pyx_v_c1 = ((unsigned int)0xbad0bad0);
                            __pyx_v_c2 = ((unsigned int)0xbad0bad0);
                            __pyx_v_d = ((float)__PYX_NAN());
                            __pyx_v_ii = ((unsigned int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
 7058: 
+7059:             for x in range(0, width):
                            __pyx_t_11 = __pyx_v_width;
                            __pyx_t_10 = __pyx_t_11;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_10; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 7060: 
+7061:                     c1 = (y + 1) % height
                              __pyx_t_17 = (__pyx_v_y + 1);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7061, __pyx_L17_error)
                              }
                              __pyx_v_c1 = __Pyx_mod_long(__pyx_t_17, __pyx_v_height);
+7062:                     c2 = x % width
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7062, __pyx_L17_error)
                              }
                              __pyx_v_c2 = __Pyx_mod_int(__pyx_v_x, __pyx_v_width);
+7063:                     d = (cloud_[c1, (x - 1 + width) % width]
                              __pyx_t_17 = ((__pyx_v_x - 1) + __pyx_v_width);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7063, __pyx_L17_error)
                              }
                              __pyx_t_18 = __pyx_v_c1;
                              __pyx_t_14 = __Pyx_mod_long(__pyx_t_17, __pyx_v_width);
+7064:                        + cloud_[c1, c2]
                              __pyx_t_19 = __pyx_v_c1;
                              __pyx_t_20 = __pyx_v_c2;
+7065:                        + cloud_[c1, (x + 1) % width]
                              __pyx_t_21 = (__pyx_v_x + 1);
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7065, __pyx_L17_error)
                              }
                              __pyx_t_22 = __pyx_v_c1;
                              __pyx_t_13 = __Pyx_mod_long(__pyx_t_21, __pyx_v_width);
+7066:                        + cloud_[(y + 2) % height, c2]) * factor
                              __pyx_t_23 = (__pyx_v_y + 2);
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7066, __pyx_L17_error)
                              }
                              __pyx_t_24 = __Pyx_mod_long(__pyx_t_23, __pyx_v_height);
                              __pyx_t_25 = __pyx_v_c2;
                              __pyx_v_d = (((((*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_18 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_14)) ))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_19 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_20)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_22 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_13)) )))) + (*((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_24 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_25)) )))) * __pyx_v_factor);
 7067: 
+7068:                     d = d - <float>(rand() * 0.0001)
                              __pyx_v_d = (__pyx_v_d - ((float)(rand() * 0.0001)));
 7069: 
 7070:                     # Cap the values
+7071:                     if d <0:
                              __pyx_t_7 = ((__pyx_v_d < 0.0) != 0);
                              if (__pyx_t_7) {
/* … */
                              }
+7072:                         d = 0.0
                                __pyx_v_d = 0.0;
 7073: 
 7074:                     # CAP THE VALUE TO 255
+7075:                     if d>512.0:
                              __pyx_t_7 = ((__pyx_v_d > 512.0) != 0);
                              if (__pyx_t_7) {
/* … */
                              }
+7076:                         d = <float>512.0
                                __pyx_v_d = ((float)512.0);
+7077:                     cloud_[y % height, x % width] = d
                              if (unlikely(__pyx_v_height == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7077, __pyx_L17_error)
                              }
                              if (unlikely(__pyx_v_width == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7077, __pyx_L17_error)
                              }
                              __pyx_t_24 = __Pyx_mod_int(__pyx_v_y, __pyx_v_height);
                              __pyx_t_13 = __Pyx_mod_int(__pyx_v_x, __pyx_v_width);
                              *((float *) ( /* dim=1 */ ((char *) (((float *) ( /* dim=0 */ (__pyx_v_cloud_.data + __pyx_t_24 * __pyx_v_cloud_.strides[0]) )) + __pyx_t_13)) )) = __pyx_v_d;
 7078: 
+7079:                     ii = palette[<unsigned int>d % p_length]
                              if (unlikely(__pyx_v_p_length == 0)) {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                                __PYX_ERR(1, 7079, __pyx_L17_error)
                              }
                              __pyx_t_25 = (((unsigned int)__pyx_v_d) % __pyx_v_p_length);
                              __pyx_v_ii = (*((unsigned int *) ( /* dim=0 */ ((char *) (((unsigned int *) __pyx_v_palette.data) + __pyx_t_25)) )));
 7080: 
+7081:                     out[x, y, 0] = (ii >> 16) & 255
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_14 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_13 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_14)) )) = ((__pyx_v_ii >> 16) & 0xFF);
+7082:                     out[x, y, 1] = (ii >> 8) & 255
                              __pyx_t_14 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_14 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_13)) )) = ((__pyx_v_ii >> 8) & 0xFF);
+7083:                     out[x, y, 2] = ii & 255
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_14 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_out.data + __pyx_t_13 * __pyx_v_out.strides[0]) ) + __pyx_t_24 * __pyx_v_out.strides[1]) )) + __pyx_t_14)) )) = (__pyx_v_ii & 0xFF);
                            }
                            goto __pyx_L24;
                            __pyx_L17_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L23;
                            __pyx_L23:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates12)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_c1;
                                __pyx_parallel_temp1 = __pyx_v_c2;
                                __pyx_parallel_temp2 = __pyx_v_d;
                                __pyx_parallel_temp3 = __pyx_v_ii;
                                __pyx_parallel_temp4 = __pyx_v_x;
                                __pyx_parallel_temp5 = __pyx_v_y;
                            }
                            __pyx_L24:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_c1 = __pyx_parallel_temp0;
              __pyx_v_c2 = __pyx_parallel_temp1;
              __pyx_v_d = __pyx_parallel_temp2;
              __pyx_v_ii = __pyx_parallel_temp3;
              __pyx_v_x = __pyx_parallel_temp4;
              __pyx_v_y = __pyx_parallel_temp5;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L7_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 7084: 
+7085:     return asarray(out[:, 0:height, :])
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_asarray); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7085, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_5.data = __pyx_v_out.data;
  __pyx_t_5.memview = __pyx_v_out.memview;
  __PYX_INC_MEMVIEW(&__pyx_t_5, 0);
  __pyx_t_5.shape[0] = __pyx_v_out.shape[0];
__pyx_t_5.strides[0] = __pyx_v_out.strides[0];
    __pyx_t_5.suboffsets[0] = -1;

__pyx_t_11 = -1;
  if (unlikely(__pyx_memoryview_slice_memviewslice(
    &__pyx_t_5,
    __pyx_v_out.shape[1], __pyx_v_out.strides[1], __pyx_v_out.suboffsets[1],
    1,
    1,
    &__pyx_t_11,
    0,
    __pyx_v_height,
    0,
    1,
    1,
    0,
    1) < 0))
{
    __PYX_ERR(1, 7085, __pyx_L1_error)
}

__pyx_t_5.shape[2] = __pyx_v_out.shape[2];
__pyx_t_5.strides[2] = __pyx_v_out.strides[2];
    __pyx_t_5.suboffsets[2] = -1;

__pyx_t_3 = __pyx_memoryview_fromslice(__pyx_t_5, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7085, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __PYX_XDEC_MEMVIEW(&__pyx_t_5, 1);
  __pyx_t_5.memview = NULL;
  __pyx_t_5.data = NULL;
  __pyx_t_1 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_1)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_4 = (__pyx_t_1) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_1, __pyx_t_3) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7085, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_4;
  __pyx_t_4 = 0;
  goto __pyx_L0;
 7086: 
 7087: 
 7088: # CLOUD ARRAY PALETTE
 7089: # cloud_rescale = numpy.zeros(256 * 2 * 3, numpy.uint)
 7090: #
 7091: # arr1 = create_horizontal_gradient_1d(255, (0, 0, 0), (255, 255, 255))
 7092: # arr2 = create_horizontal_gradient_1d(255, (255, 255, 255), (0, 0, 0))
 7093: # arr3 = numpy.concatenate((arr1, arr2), axis=None)
 7094: # i = 0
 7095: # for r in range(0, 1530, 3):
 7096: #     cloud_rescale[i] = rgb_to_int(arr3[r], arr3[r+1], arr3[r+2])
 7097: #     i += 1
 7098: # -------- main loop ----------
 7099: # surface_ = cloud_effect(
 7100: #             width, height, 3.956 + random.uniform(0.002, 0.008),
 7101: #             heatmap_rescale,
 7102: #             CLOUD_ARRAY,
 7103: #             reduce_factor_=2,  cloud_intensity_=75,
 7104: #             smooth_=True, bloom_=False, fast_bloom_=True,
 7105: #             bpf_threshold_=80, low_=0, high_=800, brightness_=False, brightness_intensity_=0.1,
 7106: #             transpose_=False, surface_=None, blur_=False)
 7107: 
 7108: # TODO MASK ? TO MOVE CLOUD ?
 7109: 
 7110: @cython.boundscheck(False)
 7111: @cython.wraparound(False)
 7112: @cython.nonecheck(False)
 7113: @cython.cdivision(False)
+7114: cdef inline shader_cloud_effect_c(
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_shader_cloud_effect_c(int __pyx_v_width_, int __pyx_v_height_, float __pyx_v_factor_, __Pyx_memviewslice __pyx_v_palette_, __Pyx_memviewslice __pyx_v_cloud_, struct __pyx_opt_args_12PygameShader_6shader_shader_cloud_effect_c *__pyx_optional_args) {
  unsigned short __pyx_v_reduce_factor_ = ((unsigned short)2);
  unsigned short __pyx_v_cloud_intensity_ = ((unsigned short)16);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_13);
  __PYX_XDEC_MEMVIEW(&__pyx_t_15, 1);
  __Pyx_AddTraceback("PygameShader.shader.shader_cloud_effect_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_cloud_surface_smallest);
  __Pyx_XDECREF(__pyx_v_rgb_array_);
  __Pyx_XDECREF(__pyx_v_cloud_effect);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
+7115:         int width_,
struct __pyx_opt_args_12PygameShader_6shader_shader_cloud_effect_c {
  int __pyx_n;
  unsigned short reduce_factor_;
  unsigned short cloud_intensity_;
  int smooth_;
  int bloom_;
  int fast_bloom_;
  unsigned short bpf_threshold_;
  unsigned int low_;
  unsigned int high_;
  int brightness_;
  float brightness_intensity_;
  PyObject *surface_;
  int transpose_;
  int blur_;
};
 7116:         int height_,
 7117:         float factor_,
 7118:         unsigned int [::1] palette_,
 7119:         float [:, ::1] cloud_,
 7120: 
 7121:         # OPTIONAL
 7122:         unsigned short int reduce_factor_   = 2,
 7123:         unsigned short int cloud_intensity_ = 16,
+7124:         bint smooth_                        = True,
  int __pyx_v_smooth_ = ((int)1);
+7125:         bint bloom_                         = False,
  int __pyx_v_bloom_ = ((int)0);
+7126:         bint fast_bloom_                    = True,
  int __pyx_v_fast_bloom_ = ((int)1);
  unsigned short __pyx_v_bpf_threshold_ = ((unsigned short)0x80);
  unsigned int __pyx_v_low_ = ((unsigned int)0);
  unsigned int __pyx_v_high_ = ((unsigned int)0);
 7127:         unsigned short int bpf_threshold_   = 128,
 7128:         unsigned int low_                   = 0,
 7129:         unsigned int high_                  = 0,
+7130:         bint brightness_                    = False,
  int __pyx_v_brightness_ = ((int)0);
  float __pyx_v_brightness_intensity_ = ((float)0.0);
 7131:         float brightness_intensity_         = 0.0,
+7132:         object surface_                     = None,
  PyObject *__pyx_v_surface_ = ((PyObject *)Py_None);
+7133:         bint transpose_                     = False,
  int __pyx_v_transpose_ = ((int)0);
+7134:         bint blur_                          = True
  int __pyx_v_blur_ = ((int)1);
  int __pyx_v_w4;
  int __pyx_v_h4;
  int __pyx_v_f_height;
  int __pyx_v_f_width;
  PyObject *__pyx_v_cloud_surface_smallest = NULL;
  PyObject *__pyx_v_rgb_array_ = NULL;
  PyObject *__pyx_v_cloud_effect = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_cloud_effect_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_reduce_factor_ = __pyx_optional_args->reduce_factor_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_cloud_intensity_ = __pyx_optional_args->cloud_intensity_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_smooth_ = __pyx_optional_args->smooth_;
          if (__pyx_optional_args->__pyx_n > 3) {
            __pyx_v_bloom_ = __pyx_optional_args->bloom_;
            if (__pyx_optional_args->__pyx_n > 4) {
              __pyx_v_fast_bloom_ = __pyx_optional_args->fast_bloom_;
              if (__pyx_optional_args->__pyx_n > 5) {
                __pyx_v_bpf_threshold_ = __pyx_optional_args->bpf_threshold_;
                if (__pyx_optional_args->__pyx_n > 6) {
                  __pyx_v_low_ = __pyx_optional_args->low_;
                  if (__pyx_optional_args->__pyx_n > 7) {
                    __pyx_v_high_ = __pyx_optional_args->high_;
                    if (__pyx_optional_args->__pyx_n > 8) {
                      __pyx_v_brightness_ = __pyx_optional_args->brightness_;
                      if (__pyx_optional_args->__pyx_n > 9) {
                        __pyx_v_brightness_intensity_ = __pyx_optional_args->brightness_intensity_;
                        if (__pyx_optional_args->__pyx_n > 10) {
                          __pyx_v_surface_ = __pyx_optional_args->surface_;
                          if (__pyx_optional_args->__pyx_n > 11) {
                            __pyx_v_transpose_ = __pyx_optional_args->transpose_;
                            if (__pyx_optional_args->__pyx_n > 12) {
                              __pyx_v_blur_ = __pyx_optional_args->blur_;
                            }
                          }
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
 7135:         ):
 7136:     """
 7137:     GENERATE CLOUD /SMOKE ON THE GAME DISPLAY 
 7138:     
 7139:     * CLOUD TEXTURE SIZES 
 7140:     
 7141:     input width_  : integer,  
 7142:     input height_ : integer
 7143:     
 7144:     width_ and height_ values define the size of the texture e.g Surface(width x height)
 7145: 
 7146:     * CLOUD ASPECT (CONTROL OVER THE WIDTH): 
 7147:     
 7148:     inputs low_ : integer  
 7149:     input high_ : integer 
 7150:     
 7151:     Optional arguments low_ & high_ (integer values) define the width 's limits of the cloud 
 7152:     effect. low_ for the starting point and high_ for the ending of the effect.
 7153:     e.g low_ = 10 and high_ = 200. The cloud effect will be contain within width = 10 and 200
 7154:     low_ & high_ values must be in range [0 ... width_]  
 7155:         
 7156:     * CLOUD HEIGHT:
 7157:     
 7158:     input factor_ : float
 7159:     
 7160:     The cloud maximum height can be adjust with the variable factor_ (float value)
 7161:     value > 3.95 will contain the effect within the display 
 7162:     value < 3.95 will enlarge the effect over the display height  
 7163:     Recommended value is 3.95 with reduce_factor_ = 3 otherwise adjust the value manually 
 7164:     to contain the cloud effect within the display
 7165:         
 7166:     * SPEED CONSIDERATION
 7167:     
 7168:     input reduce_factor_ : integer
 7169:     
 7170:     The argument reduce_factor_ control the size of the texture to be processed 
 7171:     e.g : a value of 2, divide by 4 the pygame surface define by the values (width_ & height_)
 7172:     Smaller texture improve the overall performances but will slightly degrade the cloud aspect, 
 7173:     especially if the blur and smooth option are not enabled.
 7174:     Recommended value for reduce_factor_ is 3 (fast process)   
 7175:     reduce_factor_ values must be an integer in range [ 0 ... 4] 
 7176:     The reduce_factor_ value will have a significant impact on the cloud effect maximum height, 
 7177:     adjust the argument factor_ accordingly
 7178: 
 7179:     * CLOUD INTENSITY AT THE SOURCE
 7180:     
 7181:     input cloud_intensity_: integer
 7182:     
 7183:     Set the cloud intensity with the variable cloud_intensity_, 0 low flame,
 7184:     32 maximum flame effect
 7185:     Values must be an int in range [0 ... 32] 
 7186: 
 7187:     * SMOOTHING THE EFFECT
 7188:     
 7189:     input smooth_: True | False
 7190:     
 7191:     When smooth_ is True the algorithm will use the pygame function smoothscale (bi-linear 
 7192:     filtering) or False the final texture will be adjust with the scale function.
 7193:     Set this variable to False if you need the best performance for the effect or if you require
 7194:     a pixelated cloud effect. Otherwise set the variable to True for a more realistic effect. 
 7195:    
 7196:     * BLOOM EFFECT 
 7197:     
 7198:     input bloom_         : True | False
 7199:     input fast_bloom_    : True | False
 7200:     input bpf_threshold_ : integer
 7201:        
 7202:     Bloom effect produce a bright and smooth light effect to the background texture where the cloud 
 7203:     intensity is at its maximum.
 7204:     Use the flag fast_bloom_ for a compromise between a realistic effect and the best performances
 7205:     The flag fast_bloom_ define a very fast bloom algo using only the smallest texture 
 7206:     to create a bloom effect (all the intermediate textures will be bypassed). See the bloom effect 
 7207:     project for more details.
 7208:     When fast_bloom is False, all the sub-surfaces will be blit to the final effect and will 
 7209:     produce a more realistic cloud effect (this will slightly degrade the overall performances). 
 7210:     If the cloud effect is too bright, you can always adjust the bright pass filter value
 7211:     bpf_threshold_(this will adjust the bloom intensity)
 7212:     bpf_threshold_ value must be in range [ 0 ... 255]   
 7213:     Below 128 the bloom effect will be more noticeable and above 128 only the brightest
 7214:     area will be enhanced.
 7215: 
 7216:     * LIGHT EFFECT INTENSITY
 7217: 
 7218:     input brightness_            : True | False
 7219:     input brightness_intensity_  : float
 7220: 
 7221:     When the flag is set to True, the algorithm will use an external function, 
 7222:     <shader_brightness24_exclude_inplace_c> to increase the brightness of the effect / texture
 7223:     A custom color can be passed to the function defining the pixels to be ignored during the 
 7224:     process (default is black color).
 7225:     the value must be in range [-1.0 ... 1.0]. Values below zero will decrease the brightness 
 7226:     of the cloud effect and positive values will increase the brightness of the effect (causing
 7227:     bright white patches on the cloud texture). 
 7228:     Values below -0.4 will cause the cloud effect to be translucent 
 7229:     
 7230:     
 7231:     * OPTIONAL SURFACE
 7232:       
 7233:     input surface_ : pygame.Surface
 7234:       
 7235:     This is an optional surface that can be passed to the shader to improve the performances 
 7236:     and to avoid a new surface to be generated every iterations. The surface size must match 
 7237:     exactly the reduce texture dimensions otherwise an exception will be raise. 
 7238:     see reduce_factor_ option to determine the cloud texture size that will be processed.
 7239:     
 7240: 
 7241:     * CLOUD ORIENTATION / DIRECTION 
 7242:      
 7243:     input transpose_ = True | False,
 7244:     
 7245:     transpose_ = True, this will transpose the final array 
 7246:     for e.g :  
 7247:     If the final cloud texture is (w, h) after setting the transpose flag, the final 
 7248:     cloud texture will become (h, w). As a result the cloud effect will be transversal (starting 
 7249:     from the right of the display to the left side). 
 7250:     You can always transpose / flip the texture to get the right cloud orientation  
 7251:     
 7252:     * FINAL TOUCH
 7253:     
 7254:     input blur_ : True | False
 7255:     
 7256:     This will will blur the cloud effect for a more realistic appearance, remove all the jagged 
 7257:     edge when and pixelated effect
 7258:     
 7259:     :param width_               : integer; Texture size (width) 
 7260:     :param height_              : integer; Texture size (height)
 7261:     :param factor_              : float; Floating value used to control the size of the cloud
 7262:                                   effect. Value must be in range [3.95 ... 4.2]. Value > 3.95 
 7263:                                   will contain the smoke/ cloud effect within the display. 
 7264:                                   Values < 3.95 will enlarge the smoke effect.                              
 7265:     :param palette_             : numpy.ndarray or cython memoryview containing the color for the 
 7266:                                   cloud effect (buffer containing mapped RGB colors (uint values))
 7267:     :param cloud_               : numpy.ndarray shape (w, h) containing float values 
 7268:                                   (cloud intensity). For better performance it is advised to set the
 7269:                                   array to the size of the texture after applying the 
 7270:                                   reduction_factor_. For example if the reduction_factor_ is 2, 
 7271:                                   the texture would have to be width >> 1 and height >> 1 and the 
 7272:                                   cloud_ array should be equivalent to numpy.empty((height >> 1, 
 7273:                                   width >> 1), float32)
 7274:     :param reduce_factor_       : integer; unsigned short int ; Can be either 0, 1, 2, 3, 4. 
 7275:                                   2 and 3 provide the best performance and the best looking effect.
 7276:     :param cloud_intensity_     : integer; Determine the amount of smoke the cloud
 7277:                                   effect will generate at the base of the effect (value must be in 
 7278:                                   range [0 .. 260]). If you provide zero a random value between 
 7279:                                   0 ... 260 will be assigned. If you provide 250, a random value 
 7280:                                   between 250 and 260 will be set for the amount of smoke. 
 7281:                                   The highest the value, the more dense the cloud effect will be
 7282:     :param smooth_              : boolean; True use a smoothscale (bi-linear filtering) or
 7283:                                   False -> scale algorithm jagged edges (mush faster)
 7284:     :param bloom_               : True | False, Add a bloom effect when the flag is set to True
 7285:                                   The bloom effect will smooth the cloud and create a dense smoke 
 7286:                                   areas where the cloud is the brightest.  
 7287:     :param fast_bloom_          : True | False; This set a fast algorithm for the bloom effect (the 
 7288:                                   bloom effect will use the smallest texture)
 7289:     :param bpf_threshold_       : integer; Bright pass filter value must be in range [ 0 ... 255]
 7290:                                   0 produce the maximum bloom effect
 7291:     :param low_                 : integer; must be in range [ 0 ... width_], left position of the 
 7292:                                   cloud effect 
 7293:     :param high_                : integer; must be in range [ 0 ... height_], right position of the
 7294:                                   cloud effect
 7295:     :param brightness_          : True | False; Increase the brightness of the cloud effect when 
 7296:                                   True
 7297:     :param brightness_intensity_: float; Set the brightness intensity of the cloud. The value must 
 7298:                                   be in range [-1.0 ... +1.0]. Changing the value overtime will 
 7299:                                   generate a realistic cloud effect. Negative value will generate 
 7300:                                   translucent patch of smoke on the background image
 7301:     :param surface_             : Pygame.Surface; Pass a surface to the shader for
 7302:                                   better performance, otherwise a new surface will be created each 
 7303:                                   calls.
 7304:     :param transpose_           : boolean; Transpose the array (w, h) become (h, w).
 7305:                                   The cloud effect will start from the left and move to the right
 7306:     :param blur_                : boolean; Blur the cloud effect
 7307:     :return                     : Return a pygame surface that can be blit directly to the game 
 7308:                                   display
 7309:     """
 7310: 
 7311: 
 7312:     cdef int w4, h4
 7313: 
 7314:     # TEXTURE DIVIDE BY POWER OF 2
+7315:     if reduce_factor_ in (0, 1, 2):
  switch (__pyx_v_reduce_factor_) {
    case 0:
    case 1:
    case 2:
/* … */
    break;
    case 3:
+7316:         w4, h4 = width_ >> reduce_factor_, height_ >> reduce_factor_
    __pyx_t_1 = (__pyx_v_width_ >> __pyx_v_reduce_factor_);
    __pyx_t_2 = (__pyx_v_height_ >> __pyx_v_reduce_factor_);
    __pyx_v_w4 = __pyx_t_1;
    __pyx_v_h4 = __pyx_t_2;
 7317: 
 7318:     # TEXTURE 150 x 150 * ratio
+7319:     elif reduce_factor_ == 3:
    break;
    case 4:
 7320:         # CUSTOM SIZE WIDTH 150 AND RATIO * HIGH
+7321:         w4 = 150
    __pyx_v_w4 = 0x96;
+7322:         h4 = <int>(150 * height_/width_)
    __pyx_t_3 = (0x96 * __pyx_v_height_);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7322, __pyx_L1_error)
    }
    else if (sizeof(long) == sizeof(long) && (!(((int)-1) > 0)) && unlikely(__pyx_v_width_ == (int)-1)  && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_t_3))) {
      PyErr_SetString(PyExc_OverflowError, "value too large to perform division");
      __PYX_ERR(1, 7322, __pyx_L1_error)
    }
    __pyx_v_h4 = ((int)__Pyx_div_long(__pyx_t_3, __pyx_v_width_));
+7323:         low_ = <int>(low_ * low_/width_)
    __pyx_t_4 = (__pyx_v_low_ * __pyx_v_low_);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7323, __pyx_L1_error)
    }
    __pyx_v_low_ = ((int)(__pyx_t_4 / __pyx_v_width_));
+7324:         high_ = <int>(high_ * 150/width_)
    __pyx_t_3 = (__pyx_v_high_ * 0x96);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7324, __pyx_L1_error)
    }
    else if (sizeof(long) == sizeof(long) && (!(((int)-1) > 0)) && unlikely(__pyx_v_width_ == (int)-1)  && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_t_3))) {
      PyErr_SetString(PyExc_OverflowError, "value too large to perform division");
      __PYX_ERR(1, 7324, __pyx_L1_error)
    }
    __pyx_v_high_ = ((int)__Pyx_div_long(__pyx_t_3, __pyx_v_width_));
+7325:         reduce_factor_ = 0
    __pyx_v_reduce_factor_ = 0;
 7326: 
 7327:     # TEXTURE 100 x 100 * ratio
+7328:     elif reduce_factor_ == 4:
    break;
    default: break;
  }
+7329:         w4 = 100
    __pyx_v_w4 = 0x64;
+7330:         h4 = <int> (100 * height_ / width_)
    __pyx_t_3 = (0x64 * __pyx_v_height_);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7330, __pyx_L1_error)
    }
    else if (sizeof(long) == sizeof(long) && (!(((int)-1) > 0)) && unlikely(__pyx_v_width_ == (int)-1)  && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_t_3))) {
      PyErr_SetString(PyExc_OverflowError, "value too large to perform division");
      __PYX_ERR(1, 7330, __pyx_L1_error)
    }
    __pyx_v_h4 = ((int)__Pyx_div_long(__pyx_t_3, __pyx_v_width_));
+7331:         low_ = <int> (low_ * low_ / width_)
    __pyx_t_4 = (__pyx_v_low_ * __pyx_v_low_);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7331, __pyx_L1_error)
    }
    __pyx_v_low_ = ((int)(__pyx_t_4 / __pyx_v_width_));
+7332:         high_ = <int> (high_ * 100 / width_)
    __pyx_t_3 = (__pyx_v_high_ * 0x64);
    if (unlikely(__pyx_v_width_ == 0)) {
      PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero");
      __PYX_ERR(1, 7332, __pyx_L1_error)
    }
    else if (sizeof(long) == sizeof(long) && (!(((int)-1) > 0)) && unlikely(__pyx_v_width_ == (int)-1)  && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_t_3))) {
      PyErr_SetString(PyExc_OverflowError, "value too large to perform division");
      __PYX_ERR(1, 7332, __pyx_L1_error)
    }
    __pyx_v_high_ = ((int)__Pyx_div_long(__pyx_t_3, __pyx_v_width_));
+7333:         reduce_factor_ = 0
    __pyx_v_reduce_factor_ = 0;
 7334: 
 7335:     cdef int f_height, f_width
+7336:     f_height, f_width = (<object> cloud_).shape[:2]
  __pyx_t_5 = __pyx_memoryview_fromslice(__pyx_v_cloud_, 2, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_shape); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_GetSlice(__pyx_t_6, 0, 2, NULL, NULL, &__pyx_slice__24, 0, 1, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_5))) || (PyList_CheckExact(__pyx_t_5))) {
    PyObject* sequence = __pyx_t_5;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 7336, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_6 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_7 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_6 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_7 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx_t_7);
    #else
    __pyx_t_6 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    #endif
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_8 = PyObject_GetIter(__pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7336, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_9 = Py_TYPE(__pyx_t_8)->tp_iternext;
    index = 0; __pyx_t_6 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_6);
    index = 1; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_7);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 2) < 0) __PYX_ERR(1, 7336, __pyx_L1_error)
    __pyx_t_9 = NULL;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_9 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 7336, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_2 = __Pyx_PyInt_As_int(__pyx_t_6); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7336, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_1 = __Pyx_PyInt_As_int(__pyx_t_7); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7336, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_f_height = __pyx_t_2;
  __pyx_v_f_width = __pyx_t_1;
 7337: 
+7338:     assert f_width >= w4 or f_height >= h4, \
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    __pyx_t_11 = ((__pyx_v_f_width >= __pyx_v_w4) != 0);
    if (!__pyx_t_11) {
    } else {
      __pyx_t_10 = __pyx_t_11;
      goto __pyx_L5_bool_binop_done;
    }
    __pyx_t_11 = ((__pyx_v_f_height >= __pyx_v_h4) != 0);
    __pyx_t_10 = __pyx_t_11;
    __pyx_L5_bool_binop_done:;
    if (unlikely(!__pyx_t_10)) {
 7339:         "Cloud array size mismatch the texture size.\n" \
+7340:         "Set cloud array to numpy.empty((%s, %s), dtype=numpy.float32)" % (h4, w4)
      __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7340, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7340, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7340, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_GIVEREF(__pyx_t_5);
      PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_5);
      __Pyx_GIVEREF(__pyx_t_7);
      PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_7);
      __pyx_t_5 = 0;
      __pyx_t_7 = 0;
      __pyx_t_7 = __Pyx_PyString_Format(__pyx_kp_s_Cloud_array_size_mismatch_the_te, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7340, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      PyErr_SetObject(PyExc_AssertionError, __pyx_t_7);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __PYX_ERR(1, 7338, __pyx_L1_error)
    }
  }
  #endif
 7341: 
+7342:     if surface_ is None:
  __pyx_t_10 = (__pyx_v_surface_ == Py_None);
  __pyx_t_11 = (__pyx_t_10 != 0);
  if (__pyx_t_11) {
/* … */
    goto __pyx_L7;
  }
+7343:         cloud_surface_smallest = pygame.Surface((w4, h4)).convert()
    __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_pygame); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_Surface); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_12 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_13 = PyTuple_New(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __Pyx_GIVEREF(__pyx_t_5);
    PyTuple_SET_ITEM(__pyx_t_13, 0, __pyx_t_5);
    __Pyx_GIVEREF(__pyx_t_12);
    PyTuple_SET_ITEM(__pyx_t_13, 1, __pyx_t_12);
    __pyx_t_5 = 0;
    __pyx_t_12 = 0;
    __pyx_t_12 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_8);
      if (likely(__pyx_t_12)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_8);
        __Pyx_INCREF(__pyx_t_12);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_8, function);
      }
    }
    __pyx_t_6 = (__pyx_t_12) ? __Pyx_PyObject_Call2Args(__pyx_t_8, __pyx_t_12, __pyx_t_13) : __Pyx_PyObject_CallOneArg(__pyx_t_8, __pyx_t_13);
    __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_convert); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_6 = NULL;
    if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_8);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_8);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_8, function);
      }
    }
    __pyx_t_7 = (__pyx_t_6) ? __Pyx_PyObject_CallOneArg(__pyx_t_8, __pyx_t_6) : __Pyx_PyObject_CallNoArg(__pyx_t_8);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7343, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_v_cloud_surface_smallest = __pyx_t_7;
    __pyx_t_7 = 0;
 7344: 
 7345:     else:
+7346:         if PyObject_IsInstance(surface_, pygame.Surface):
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_pygame); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7346, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_n_s_Surface); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7346, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_11 = PyObject_IsInstance(__pyx_v_surface_, __pyx_t_8); if (unlikely(__pyx_t_11 == ((int)-1))) __PYX_ERR(1, 7346, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = (__pyx_t_11 != 0);
    if (likely(__pyx_t_10)) {
/* … */
      goto __pyx_L8;
    }
+7347:             assert surface_.get_width() == w4 and surface_.get_height() == h4, \
      #ifndef CYTHON_WITHOUT_ASSERTIONS
      if (unlikely(!Py_OptimizeFlag)) {
        __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_width); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_6 = NULL;
        if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_7))) {
          __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_7);
          if (likely(__pyx_t_6)) {
            PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
            __Pyx_INCREF(__pyx_t_6);
            __Pyx_INCREF(function);
            __Pyx_DECREF_SET(__pyx_t_7, function);
          }
        }
        __pyx_t_8 = (__pyx_t_6) ? __Pyx_PyObject_CallOneArg(__pyx_t_7, __pyx_t_6) : __Pyx_PyObject_CallNoArg(__pyx_t_7);
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_6 = PyObject_RichCompare(__pyx_t_8, __pyx_t_7, Py_EQ); __Pyx_XGOTREF(__pyx_t_6); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely(__pyx_t_11 < 0)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (__pyx_t_11) {
        } else {
          __pyx_t_10 = __pyx_t_11;
          goto __pyx_L9_bool_binop_done;
        }
        __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_height); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_8 = NULL;
        if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_7))) {
          __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_7);
          if (likely(__pyx_t_8)) {
            PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7);
            __Pyx_INCREF(__pyx_t_8);
            __Pyx_INCREF(function);
            __Pyx_DECREF_SET(__pyx_t_7, function);
          }
        }
        __pyx_t_6 = (__pyx_t_8) ? __Pyx_PyObject_CallOneArg(__pyx_t_7, __pyx_t_8) : __Pyx_PyObject_CallNoArg(__pyx_t_7);
        __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
        if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_8 = PyObject_RichCompare(__pyx_t_6, __pyx_t_7, Py_EQ); __Pyx_XGOTREF(__pyx_t_8); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_8); if (unlikely(__pyx_t_11 < 0)) __PYX_ERR(1, 7347, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __pyx_t_10 = __pyx_t_11;
        __pyx_L9_bool_binop_done:;
        if (unlikely(!__pyx_t_10)) {
 7348:             "Surface argument has incorrect dimension surface must be (w:%s, h:%s) got (%s, %s)\n" \
 7349:             "Set argument surface_ to None to avoid this error message"\
+7350:             % (w4, h4, surface_.get_width(), surface_.get_height())
          __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_w4); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_8);
          __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_h4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_7);
          __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_width); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
          __pyx_t_12 = NULL;
          if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_13))) {
            __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_13);
            if (likely(__pyx_t_12)) {
              PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_13);
              __Pyx_INCREF(__pyx_t_12);
              __Pyx_INCREF(function);
              __Pyx_DECREF_SET(__pyx_t_13, function);
            }
          }
          __pyx_t_6 = (__pyx_t_12) ? __Pyx_PyObject_CallOneArg(__pyx_t_13, __pyx_t_12) : __Pyx_PyObject_CallNoArg(__pyx_t_13);
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_6);
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_height); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_12);
          __pyx_t_5 = NULL;
          if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_12))) {
            __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_12);
            if (likely(__pyx_t_5)) {
              PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_12);
              __Pyx_INCREF(__pyx_t_5);
              __Pyx_INCREF(function);
              __Pyx_DECREF_SET(__pyx_t_12, function);
            }
          }
          __pyx_t_13 = (__pyx_t_5) ? __Pyx_PyObject_CallOneArg(__pyx_t_12, __pyx_t_5) : __Pyx_PyObject_CallNoArg(__pyx_t_12);
          __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
          if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          __pyx_t_12 = PyTuple_New(4); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_12);
          __Pyx_GIVEREF(__pyx_t_8);
          PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_8);
          __Pyx_GIVEREF(__pyx_t_7);
          PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_7);
          __Pyx_GIVEREF(__pyx_t_6);
          PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_t_6);
          __Pyx_GIVEREF(__pyx_t_13);
          PyTuple_SET_ITEM(__pyx_t_12, 3, __pyx_t_13);
          __pyx_t_8 = 0;
          __pyx_t_7 = 0;
          __pyx_t_6 = 0;
          __pyx_t_13 = 0;
          __pyx_t_13 = __Pyx_PyString_Format(__pyx_kp_s_Surface_argument_has_incorrect_d, __pyx_t_12); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7350, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          PyErr_SetObject(PyExc_AssertionError, __pyx_t_13);
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          __PYX_ERR(1, 7347, __pyx_L1_error)
        }
      }
      #endif
+7351:             cloud_surface_smallest = surface_
      __Pyx_INCREF(__pyx_v_surface_);
      __pyx_v_cloud_surface_smallest = __pyx_v_surface_;
 7352:         else:
+7353:             raise ValueError("Argument surface_ must be a Surface type got %s " % type(surface_))
    /*else*/ {
      __pyx_t_13 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Argument_surface__must_be_a_Surf, ((PyObject *)Py_TYPE(__pyx_v_surface_))); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7353, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      __pyx_t_12 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_13); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7353, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      __Pyx_Raise(__pyx_t_12, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      __PYX_ERR(1, 7353, __pyx_L1_error)
    }
    __pyx_L8:;
  }
  __pyx_L7:;
 7354: 
+7355:     rgb_array_ = cloud_surface24_c(
  __pyx_t_14.__pyx_n = 3;
  __pyx_t_14.intensity = __pyx_v_cloud_intensity_;
  __pyx_t_14.low = (__pyx_v_low_ >> __pyx_v_reduce_factor_);
  __pyx_t_14.high = (__pyx_v_high_ >> __pyx_v_reduce_factor_);
  __pyx_t_12 = __pyx_f_12PygameShader_6shader_cloud_surface24_c(__pyx_v_w4, __pyx_v_h4, (((float)1.0) / __pyx_v_factor_), __pyx_v_palette_, __pyx_v_cloud_, &__pyx_t_14); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7355, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __pyx_v_rgb_array_ = __pyx_t_12;
  __pyx_t_12 = 0;
+7356:         w4, h4, <float>1.0 / factor_, palette_, cloud_, cloud_intensity_,
  if (unlikely(__pyx_v_factor_ == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float division");
    __PYX_ERR(1, 7356, __pyx_L1_error)
  }
 7357:                 low_ >> reduce_factor_, high_ >> reduce_factor_)
 7358: 
 7359:     # BRIGHTNESS SHADER
+7360:     if brightness_:
  __pyx_t_10 = (__pyx_v_brightness_ != 0);
  if (__pyx_t_10) {
/* … */
  }
 7361:         # EXCLUDE BLACK COLORS (DEFAULT)
+7362:         assert -1.0 <= brightness_intensity_ <= 1.0, \
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_10 = (-1.0 <= __pyx_v_brightness_intensity_);
      if (__pyx_t_10) {
        __pyx_t_10 = (__pyx_v_brightness_intensity_ <= 1.0);
      }
      if (unlikely(!(__pyx_t_10 != 0))) {
        PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_brightness_intensity_mu);
        __PYX_ERR(1, 7362, __pyx_L1_error)
      }
    }
    #endif
 7363:             "Argument brightness intensity must be in range [-1.0 ... 1.0]"
+7364:         shader_brightness24_exclude_inplace_c(rgb_array_=rgb_array_,
    __pyx_t_15 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_rgb_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_15.memview)) __PYX_ERR(1, 7364, __pyx_L1_error)
/* … */
    __pyx_t_16.__pyx_n = 2;
    __pyx_t_16.shift_ = __pyx_v_brightness_intensity_;
    __pyx_t_16.color_ = __pyx_tuple__9;
    __pyx_f_12PygameShader_6shader_shader_brightness24_exclude_inplace_c(__pyx_t_15, &__pyx_t_16); 
    __PYX_XDEC_MEMVIEW(&__pyx_t_15, 1);
    __pyx_t_15.memview = NULL;
    __pyx_t_15.data = NULL;
 7365:                                               shift_=brightness_intensity_, color_=(0, 0, 0))
 7366: 
+7367:     if blur_:
  __pyx_t_10 = (__pyx_v_blur_ != 0);
  if (__pyx_t_10) {
/* … */
  }
+7368:         shader_blur5x5_array24_inplace_c(rgb_array_)
    __pyx_t_15 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_rgb_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_15.memview)) __PYX_ERR(1, 7368, __pyx_L1_error)
    __pyx_f_12PygameShader_6shader_shader_blur5x5_array24_inplace_c(__pyx_t_15, NULL);
    __PYX_XDEC_MEMVIEW(&__pyx_t_15, 1);
    __pyx_t_15.memview = NULL;
    __pyx_t_15.data = NULL;
 7369: 
+7370:     if transpose_:
  __pyx_t_10 = (__pyx_v_transpose_ != 0);
  if (__pyx_t_10) {
/* … */
    goto __pyx_L13;
  }
+7371:         rgb_array_ = rgb_array_.transpose(1, 0, 2)
    __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_v_rgb_array_, __pyx_n_s_transpose_2); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7371, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_13 = __Pyx_PyObject_Call(__pyx_t_12, __pyx_tuple__25, NULL); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7371, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF_SET(__pyx_v_rgb_array_, __pyx_t_13);
    __pyx_t_13 = 0;
+7372:         cloud_surface_smallest = make_surface(rgb_array_)
    __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7372, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_6 = NULL;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_12))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_12);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_12);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_12, function);
      }
    }
    __pyx_t_13 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_12, __pyx_t_6, __pyx_v_rgb_array_) : __Pyx_PyObject_CallOneArg(__pyx_t_12, __pyx_v_rgb_array_);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7372, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF_SET(__pyx_v_cloud_surface_smallest, __pyx_t_13);
    __pyx_t_13 = 0;
 7373:     else:
 7374:         # CONVERT THE ARRAY INTO A PYGAME SURFACE
+7375:         array_to_surface(cloud_surface_smallest, rgb_array_)
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_n_s_array_to_surface); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7375, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_6 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_12))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_12);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_12);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_12, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_12)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_cloud_surface_smallest, __pyx_v_rgb_array_};
      __pyx_t_13 = __Pyx_PyFunction_FastCall(__pyx_t_12, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7375, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_13);
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_12)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_cloud_surface_smallest, __pyx_v_rgb_array_};
      __pyx_t_13 = __Pyx_PyCFunction_FastCall(__pyx_t_12, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7375, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_13);
    } else
    #endif
    {
      __pyx_t_7 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7375, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      if (__pyx_t_6) {
        __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __pyx_t_6 = NULL;
      }
      __Pyx_INCREF(__pyx_v_cloud_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_cloud_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_1, __pyx_v_cloud_surface_smallest);
      __Pyx_INCREF(__pyx_v_rgb_array_);
      __Pyx_GIVEREF(__pyx_v_rgb_array_);
      PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_1, __pyx_v_rgb_array_);
      __pyx_t_13 = __Pyx_PyObject_Call(__pyx_t_12, __pyx_t_7, NULL); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7375, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    }
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
  }
  __pyx_L13:;
 7376: 
 7377: 
 7378:     # BLOOM SHADER EFFECT
+7379:     if bloom_:
  __pyx_t_10 = (__pyx_v_bloom_ != 0);
  if (__pyx_t_10) {
/* … */
  }
+7380:         assert 0 <= bpf_threshold_ < 256, \
    #ifndef CYTHON_WITHOUT_ASSERTIONS
    if (unlikely(!Py_OptimizeFlag)) {
      __pyx_t_10 = (0 <= __pyx_v_bpf_threshold_);
      if (__pyx_t_10) {
        __pyx_t_10 = (__pyx_v_bpf_threshold_ < 0x100);
      }
      if (unlikely(!(__pyx_t_10 != 0))) {
+7381:             "Argument bpf_threshold_ must be in range [0 ... 256] got %s " % bpf_threshold_
        __pyx_t_13 = __Pyx_PyInt_From_unsigned_short(__pyx_v_bpf_threshold_); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7381, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_12 = __Pyx_PyString_Format(__pyx_kp_s_Argument_bpf_threshold__must_be, __pyx_t_13); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7381, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        PyErr_SetObject(PyExc_AssertionError, __pyx_t_12);
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        __PYX_ERR(1, 7380, __pyx_L1_error)
      }
    }
    #endif
+7382:         shader_bloom_effect_array24_c(cloud_surface_smallest, bpf_threshold_, fast_=fast_bloom_)
    __pyx_t_17.__pyx_n = 1;
    __pyx_t_17.fast_ = __pyx_v_fast_bloom_;
    __pyx_f_12PygameShader_6shader_shader_bloom_effect_array24_c(__pyx_v_cloud_surface_smallest, __pyx_v_bpf_threshold_, &__pyx_t_17); 
 7383: 
 7384:     # RESCALE THE SURFACE TO THE FULL SIZE
+7385:     if smooth_:
  __pyx_t_10 = (__pyx_v_smooth_ != 0);
  if (__pyx_t_10) {
/* … */
    goto __pyx_L15;
  }
+7386:         cloud_effect = smoothscale(cloud_surface_smallest, (width_, height_))
    __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7386, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_width_); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7386, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_6 = __Pyx_PyInt_From_int(__pyx_v_height_); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7386, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7386, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_7);
    __Pyx_GIVEREF(__pyx_t_6);
    PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_6);
    __pyx_t_7 = 0;
    __pyx_t_6 = 0;
    __pyx_t_6 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_13))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_13);
      if (likely(__pyx_t_6)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_13);
        __Pyx_INCREF(__pyx_t_6);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_13, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_13)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_cloud_surface_smallest, __pyx_t_8};
      __pyx_t_12 = __Pyx_PyFunction_FastCall(__pyx_t_13, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7386, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_13)) {
      PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_v_cloud_surface_smallest, __pyx_t_8};
      __pyx_t_12 = __Pyx_PyCFunction_FastCall(__pyx_t_13, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7386, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    } else
    #endif
    {
      __pyx_t_7 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7386, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      if (__pyx_t_6) {
        __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6); __pyx_t_6 = NULL;
      }
      __Pyx_INCREF(__pyx_v_cloud_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_cloud_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_1, __pyx_v_cloud_surface_smallest);
      __Pyx_GIVEREF(__pyx_t_8);
      PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_1, __pyx_t_8);
      __pyx_t_8 = 0;
      __pyx_t_12 = __Pyx_PyObject_Call(__pyx_t_13, __pyx_t_7, NULL); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7386, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    }
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
    __pyx_v_cloud_effect = __pyx_t_12;
    __pyx_t_12 = 0;
 7387:     else:
+7388:         cloud_effect = scale(cloud_surface_smallest, (width_, height_))
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_n_s_scale); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 7388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_width_); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_8 = __Pyx_PyInt_From_int(__pyx_v_height_); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_6 = PyTuple_New(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_7);
    __Pyx_GIVEREF(__pyx_t_8);
    PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_8);
    __pyx_t_7 = 0;
    __pyx_t_8 = 0;
    __pyx_t_8 = NULL;
    __pyx_t_1 = 0;
    if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_13))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_13);
      if (likely(__pyx_t_8)) {
        PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_13);
        __Pyx_INCREF(__pyx_t_8);
        __Pyx_INCREF(function);
        __Pyx_DECREF_SET(__pyx_t_13, function);
        __pyx_t_1 = 1;
      }
    }
    #if CYTHON_FAST_PYCALL
    if (PyFunction_Check(__pyx_t_13)) {
      PyObject *__pyx_temp[3] = {__pyx_t_8, __pyx_v_cloud_surface_smallest, __pyx_t_6};
      __pyx_t_12 = __Pyx_PyFunction_FastCall(__pyx_t_13, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7388, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    } else
    #endif
    #if CYTHON_FAST_PYCCALL
    if (__Pyx_PyFastCFunction_Check(__pyx_t_13)) {
      PyObject *__pyx_temp[3] = {__pyx_t_8, __pyx_v_cloud_surface_smallest, __pyx_t_6};
      __pyx_t_12 = __Pyx_PyCFunction_FastCall(__pyx_t_13, __pyx_temp+1-__pyx_t_1, 2+__pyx_t_1); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7388, __pyx_L1_error)
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    } else
    #endif
    {
      __pyx_t_7 = PyTuple_New(2+__pyx_t_1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7388, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      if (__pyx_t_8) {
        __Pyx_GIVEREF(__pyx_t_8); PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_8); __pyx_t_8 = NULL;
      }
      __Pyx_INCREF(__pyx_v_cloud_surface_smallest);
      __Pyx_GIVEREF(__pyx_v_cloud_surface_smallest);
      PyTuple_SET_ITEM(__pyx_t_7, 0+__pyx_t_1, __pyx_v_cloud_surface_smallest);
      __Pyx_GIVEREF(__pyx_t_6);
      PyTuple_SET_ITEM(__pyx_t_7, 1+__pyx_t_1, __pyx_t_6);
      __pyx_t_6 = 0;
      __pyx_t_12 = __Pyx_PyObject_Call(__pyx_t_13, __pyx_t_7, NULL); if (unlikely(!__pyx_t_12)) __PYX_ERR(1, 7388, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    }
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
    __pyx_v_cloud_effect = __pyx_t_12;
    __pyx_t_12 = 0;
  }
  __pyx_L15:;
 7389: 
+7390:     return cloud_effect
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_cloud_effect);
  __pyx_r = __pyx_v_cloud_effect;
  goto __pyx_L0;
 7391: 
 7392: 
 7393: 
 7394: @cython.boundscheck(False)
 7395: @cython.wraparound(False)
 7396: @cython.nonecheck(False)
 7397: @cython.cdivision(True)
+7398: cdef inline mirroring_c(unsigned char[:, :, :] rgb_array_):
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_mirroring_c(__Pyx_memviewslice __pyx_v_rgb_array_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_x2;
  int __pyx_v_x3;
  int __pyx_v_x;
  int __pyx_v_y;
  __Pyx_memviewslice __pyx_v_new_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_10);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_AddTraceback("PygameShader.shader.mirroring_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_new_array, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7399: 
 7400:     """
 7401:     SHADER MIRRORING
 7402: 
 7403:     This method create a mirror image placed to the right side of the
 7404:      original image referenced by rgb_array_
 7405: 
 7406:     The Array (rgb_array) must be a numpy array shape (w, h, 3)
 7407:     containing RGB pixels, please refer to pygame
 7408:     function pixels3d or array3d to convert an image into a 3d
 7409:     array (library surfarray)
 7410: 
 7411:     :param rgb_array_: numpy ndarray shape (w, h, 3) containing RGB pixels
 7412:     :return          : returns a numpy ndarray shape (w, h, 3) with transformation
 7413:     """
 7414: 
 7415:     cdef:
 7416:         Py_ssize_t w, h
 7417:         int x2, x3
+7418:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 7419: 
 7420: 
 7421:     cdef:
 7422:         int x, y
+7423:         unsigned char [:, :, :] new_array = empty((w, h, 3), uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_empty); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_8 = PyTuple_New(3); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_7);
  PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_7);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_8, 2, __pyx_int_3);
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_uint8); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_6 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_6)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_8, __pyx_t_7};
    __pyx_t_4 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7423, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[3] = {__pyx_t_6, __pyx_t_8, __pyx_t_7};
    __pyx_t_4 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7423, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  {
    __pyx_t_10 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7423, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    if (__pyx_t_6) {
      __Pyx_GIVEREF(__pyx_t_6); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_6); __pyx_t_6 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_8);
    PyTuple_SET_ITEM(__pyx_t_10, 0+__pyx_t_9, __pyx_t_8);
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_10, 1+__pyx_t_9, __pyx_t_7);
    __pyx_t_8 = 0;
    __pyx_t_7 = 0;
    __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_10, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7423, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 7423, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_new_array = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 7424:         unsigned char *r
 7425:         unsigned char *g
 7426:         unsigned char *b
 7427: 
+7428:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+7429:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_x3) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_x3) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_12; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_x2 = ((int)0xbad0bad0);
                            __pyx_v_x3 = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
+7430:             for y in range(h):
                            __pyx_t_13 = __pyx_v_h;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_14; __pyx_t_9+=1) {
                              __pyx_v_y = __pyx_t_9;
 7431: 
+7432:                 r = &rgb_array_[x, y, 0]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[2]) ))));
+7433:                 g = &rgb_array_[x, y, 1]
                              __pyx_t_17 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_17 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))));
+7434:                 b = &rgb_array_[x, y, 2]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[2]) ))));
 7435: 
+7436:                 x2 = x >> 1
                              __pyx_v_x2 = (__pyx_v_x >> 1);
+7437:                 new_array[x2, y, 0] = r[0]
                              __pyx_t_17 = __pyx_v_x2;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_17 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_15 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_r[0]);
+7438:                 new_array[x2, y, 1] = g[0]
                              __pyx_t_15 = __pyx_v_x2;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_15 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_17 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_g[0]);
+7439:                 new_array[x2, y, 2] = b[0]
                              __pyx_t_17 = __pyx_v_x2;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_17 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_15 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_b[0]);
+7440:                 x3 = <int>w - x2 -1
                              __pyx_v_x3 = ((((int)__pyx_v_w) - __pyx_v_x2) - 1);
+7441:                 new_array[x3, y, 0] = r[0]
                              __pyx_t_15 = __pyx_v_x3;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_15 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_17 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_r[0]);
+7442:                 new_array[x3, y, 1] = g[0]
                              __pyx_t_17 = __pyx_v_x3;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_17 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_15 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_g[0]);
+7443:                 new_array[x3, y, 2] = b[0]
                              __pyx_t_15 = __pyx_v_x3;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_new_array.data + __pyx_t_15 * __pyx_v_new_array.strides[0]) ) + __pyx_t_16 * __pyx_v_new_array.strides[1]) ) + __pyx_t_17 * __pyx_v_new_array.strides[2]) )) = (__pyx_v_b[0]);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 7444: 
+7445:     return asarray(new_array)
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_asarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7445, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_10 = __pyx_memoryview_fromslice(__pyx_v_new_array, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7445, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_7 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_7)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
    }
  }
  __pyx_t_4 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_7, __pyx_t_10) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_t_10);
  __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7445, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_r = __pyx_t_4;
  __pyx_t_4 = 0;
  goto __pyx_L0;
 7446: 
 7447: 
 7448: 
 7449: @cython.boundscheck(False)
 7450: @cython.wraparound(False)
 7451: @cython.nonecheck(False)
 7452: @cython.cdivision(True)
+7453: cdef inline mirroring_inplace_c(unsigned char[:, :, :] rgb_array_):
static CYTHON_INLINE PyObject *__pyx_f_12PygameShader_6shader_mirroring_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  int __pyx_v_x2;
  int __pyx_v_x3;
  int __pyx_v_x;
  int __pyx_v_y;
  __Pyx_memviewslice __pyx_v_rgb_array_copy = { 0, 0, { 0 }, { 0 }, { 0 } };
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("mirroring_inplace_c", 0);
/* … */
  /* function exit code */
  __pyx_r = Py_None; __Pyx_INCREF(Py_None);
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_AddTraceback("PygameShader.shader.mirroring_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_copy, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7454: 
 7455:     """
 7456:     SHADER MIRRORING (INPLACE)
 7457: 
 7458:     This method create a mirror image placed to the right side of
 7459:      the original image referenced by rgb_array_
 7460: 
 7461:     The Array (rgb_array) must be a numpy array shape (w, h, 3)
 7462:     containing RGB pixels, please refer to pygame
 7463:     function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 7464: 
 7465:     :param rgb_array_: numpy ndarray shape (w, h, 3) containing RGB pixels
 7466:     :return          : void
 7467:     """
 7468: 
 7469:     cdef:
 7470:         Py_ssize_t w, h
 7471:         int x2, x3
+7472:     w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 7473: 
 7474:     cdef:
 7475:         int x, y
+7476:         unsigned char [:, :, :] rgb_array_copy = numpy.array(rgb_array_, copy=True)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_numpy); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_array_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_copy, Py_True) < 0) __PYX_ERR(1, 7476, __pyx_L1_error)
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_7, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 7476, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_v_rgb_array_copy = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
 7477:         unsigned char *r
 7478:         unsigned char *g
 7479:         unsigned char *b
 7480: 
+7481:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+7482:         for x in prange(w, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_x3) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_r) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_x2) lastprivate(__pyx_v_x3) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_9; __pyx_t_2++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_x2 = ((int)0xbad0bad0);
                            __pyx_v_x3 = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
+7483:             for y in range(h):
                            __pyx_t_10 = __pyx_v_h;
                            __pyx_t_11 = __pyx_t_10;
                            for (__pyx_t_12 = 0; __pyx_t_12 < __pyx_t_11; __pyx_t_12+=1) {
                              __pyx_v_y = __pyx_t_12;
 7484: 
+7485:                 r = &rgb_array_copy[x, y, 0]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[2]) ))));
+7486:                 g = &rgb_array_copy[x, y, 1]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[2]) ))));
+7487:                 b = &rgb_array_copy[x, y, 2]
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_copy.data + __pyx_t_13 * __pyx_v_rgb_array_copy.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_copy.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_copy.strides[2]) ))));
 7488: 
+7489:                 x2 = x >> 1
                              __pyx_v_x2 = (__pyx_v_x >> 1);
+7490:                 rgb_array_[x2, y, 0] = r[0]
                              __pyx_t_15 = __pyx_v_x2;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_r[0]);
+7491:                 rgb_array_[x2, y, 1] = g[0]
                              __pyx_t_13 = __pyx_v_x2;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_g[0]);
+7492:                 rgb_array_[x2, y, 2] = b[0]
                              __pyx_t_15 = __pyx_v_x2;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_b[0]);
 7493: 
+7494:                 x3 = <int>w - x2 - 1
                              __pyx_v_x3 = ((((int)__pyx_v_w) - __pyx_v_x2) - 1);
 7495: 
+7496:                 rgb_array_[x3, y, 0] = r[0]
                              __pyx_t_13 = __pyx_v_x3;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_r[0]);
+7497:                 rgb_array_[x3, y, 1] = g[0]
                              __pyx_t_15 = __pyx_v_x3;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_g[0]);
+7498:                 rgb_array_[x3, y, 2] = b[0]
                              __pyx_t_13 = __pyx_v_x3;
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = (__pyx_v_b[0]);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 7499: 
 7500: 
 7501: @cython.boundscheck(False)
 7502: @cython.wraparound(False)
 7503: @cython.nonecheck(False)
 7504: @cython.cdivision(True)
+7505: cpdef tuple dampening(
static PyObject *__pyx_pw_12PygameShader_6shader_161dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static PyObject *__pyx_f_12PygameShader_6shader_dampening(PyObject *__pyx_v_surface_, int __pyx_v_frame_, int __pyx_v_display_width, int __pyx_v_display_height_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_dampening *__pyx_optional_args) {
  float __pyx_v_amplitude_ = ((float)50.0);
  int __pyx_v_duration_ = ((int)30);
  float __pyx_v_freq_ = ((float)20.0);
  float __pyx_v_t;
  int __pyx_v_width;
  int __pyx_v_height;
  float __pyx_v_tm;
  PyObject *__pyx_v_surf = 0;
  int __pyx_v_new_width;
  int __pyx_v_new_height;
  int __pyx_v_diff_x;
  int __pyx_v_diff_y;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dampening", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_amplitude_ = __pyx_optional_args->amplitude_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_duration_ = __pyx_optional_args->duration_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_freq_ = __pyx_optional_args->freq_;
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("PygameShader.shader.dampening", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_surf);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_161dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_160dampening[] = "\n    DAMPENING EFFECT\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    Compatible with image 24-32 bit\n    The length of the effect equal duration_ * freq_\n\n    e.g :\n    surf, xx, yy = dampening(BCK, frame, width, height,\n    amplitude_=100, duration_=40, freq_=15)\n    SCREEN.blit(surf, (xx, yy))\n\n    :param surface_       : pygame.Surface (compatible 24 - 32 bit)\n    :param frame_         : integer; Frame number (linear variable changing overtime)\n    :param display_width  : integer; Size of your game display (width)\n    :param display_height_: integer; size of your game display (height)\n    :param amplitude_     : float; Amplitude of the dampening effect  (default is 50)\n    :param duration_      : integer; Duration of the effect (default value is 30)\n    :param freq_          : float; change the speed of the effect default value is 20.0.\n    A small value will decrease\n    the overall timing of the effect while a larger value will increase the duration of the effect.\n    :return               : Tuple values containing the Surface and the position (x, y)\n    with x & y are the top\n     left corner of the\n    image\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_161dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_surface_ = 0;
  int __pyx_v_frame_;
  int __pyx_v_display_width;
  int __pyx_v_display_height_;
  float __pyx_v_amplitude_;
  int __pyx_v_duration_;
  float __pyx_v_freq_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dampening (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_surface,&__pyx_n_s_frame_2,&__pyx_n_s_display_width,&__pyx_n_s_display_height,&__pyx_n_s_amplitude,&__pyx_n_s_duration,&__pyx_n_s_freq,0};
    PyObject* values[7] = {0,0,0,0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_surface)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_frame_2)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("dampening", 0, 4, 7, 1); __PYX_ERR(1, 7505, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_display_width)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("dampening", 0, 4, 7, 2); __PYX_ERR(1, 7505, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (likely((values[3] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_display_height)) != 0)) kw_args--;
        else {
          __Pyx_RaiseArgtupleInvalid("dampening", 0, 4, 7, 3); __PYX_ERR(1, 7505, __pyx_L3_error)
        }
        CYTHON_FALLTHROUGH;
        case  4:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_amplitude);
          if (value) { values[4] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  5:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_duration);
          if (value) { values[5] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  6:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_freq);
          if (value) { values[6] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "dampening") < 0)) __PYX_ERR(1, 7505, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  7: values[6] = PyTuple_GET_ITEM(__pyx_args, 6);
        CYTHON_FALLTHROUGH;
        case  6: values[5] = PyTuple_GET_ITEM(__pyx_args, 5);
        CYTHON_FALLTHROUGH;
        case  5: values[4] = PyTuple_GET_ITEM(__pyx_args, 4);
        CYTHON_FALLTHROUGH;
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_surface_ = values[0];
    __pyx_v_frame_ = __Pyx_PyInt_As_int(values[1]); if (unlikely((__pyx_v_frame_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7507, __pyx_L3_error)
    __pyx_v_display_width = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_display_width == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7508, __pyx_L3_error)
    __pyx_v_display_height_ = __Pyx_PyInt_As_int(values[3]); if (unlikely((__pyx_v_display_height_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7509, __pyx_L3_error)
    if (values[4]) {
      __pyx_v_amplitude_ = __pyx_PyFloat_AsFloat(values[4]); if (unlikely((__pyx_v_amplitude_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 7510, __pyx_L3_error)
    } else {
      __pyx_v_amplitude_ = ((float)50.0);
    }
    if (values[5]) {
      __pyx_v_duration_ = __Pyx_PyInt_As_int(values[5]); if (unlikely((__pyx_v_duration_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7511, __pyx_L3_error)
    } else {
      __pyx_v_duration_ = ((int)30);
    }
    if (values[6]) {
      __pyx_v_freq_ = __pyx_PyFloat_AsFloat(values[6]); if (unlikely((__pyx_v_freq_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 7512, __pyx_L3_error)
    } else {
      __pyx_v_freq_ = ((float)20.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dampening", 0, 4, 7, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 7505, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.dampening", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_160dampening(__pyx_self, __pyx_v_surface_, __pyx_v_frame_, __pyx_v_display_width, __pyx_v_display_height_, __pyx_v_amplitude_, __pyx_v_duration_, __pyx_v_freq_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_160dampening(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_surface_, int __pyx_v_frame_, int __pyx_v_display_width, int __pyx_v_display_height_, float __pyx_v_amplitude_, int __pyx_v_duration_, float __pyx_v_freq_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dampening", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 3;
  __pyx_t_2.amplitude_ = __pyx_v_amplitude_;
  __pyx_t_2.duration_ = __pyx_v_duration_;
  __pyx_t_2.freq_ = __pyx_v_freq_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_dampening(__pyx_v_surface_, __pyx_v_frame_, __pyx_v_display_width, __pyx_v_display_height_, 0, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7505, __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("PygameShader.shader.dampening", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7506:         object surface_,
 7507:         int frame_,
 7508:         int display_width,
 7509:         int display_height_,
 7510:         float amplitude_=50.0,
 7511:         int duration_=30,
 7512:         float freq_=20.0):
 7513: 
 7514:     """
 7515:     DAMPENING EFFECT
 7516: 
 7517:     Cython cpdef function, this function can be called directly and do not require a
 7518:     hook function.
 7519: 
 7520:     Compatible with image 24-32 bit
 7521:     The length of the effect equal duration_ * freq_
 7522: 
 7523:     e.g :
 7524:     surf, xx, yy = dampening(BCK, frame, width, height,
 7525:     amplitude_=100, duration_=40, freq_=15)
 7526:     SCREEN.blit(surf, (xx, yy))
 7527: 
 7528:     :param surface_       : pygame.Surface (compatible 24 - 32 bit)
 7529:     :param frame_         : integer; Frame number (linear variable changing overtime)
 7530:     :param display_width  : integer; Size of your game display (width)
 7531:     :param display_height_: integer; size of your game display (height)
 7532:     :param amplitude_     : float; Amplitude of the dampening effect  (default is 50)
 7533:     :param duration_      : integer; Duration of the effect (default value is 30)
 7534:     :param freq_          : float; change the speed of the effect default value is 20.0.
 7535:     A small value will decrease
 7536:     the overall timing of the effect while a larger value will increase the duration of the effect.
 7537:     :return               : Tuple values containing the Surface and the position (x, y)
 7538:     with x & y are the top
 7539:      left corner of the
 7540:     image
 7541:     """
 7542: 
+7543:     assert freq_ > 0.0, "Argument freq_ must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_freq_ > 0.0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_freq__must_be_0);
      __PYX_ERR(1, 7543, __pyx_L1_error)
    }
  }
  #endif
+7544:     assert duration_ > 0.0, "Argument duration_ must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_duration_ > 0.0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_duration__must_be_0);
      __PYX_ERR(1, 7544, __pyx_L1_error)
    }
  }
  #endif
 7545: 
+7546:     cdef float t = damped_oscillation((frame_ / freq_) % duration_)
  __pyx_v_t = __pyx_f_12PygameShader_6shader_damped_oscillation(fmodf((__pyx_v_frame_ / __pyx_v_freq_), __pyx_v_duration_));
 7547:     cdef int width, height,
+7548:     cdef float tm = t * amplitude_
  __pyx_v_tm = (__pyx_v_t * __pyx_v_amplitude_);
 7549: 
+7550:     width, height = surface_.get_size()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_get_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7550, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7550, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 7550, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_2 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_3 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_3);
    #else
    __pyx_t_2 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7550, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7550, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_4 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7550, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_4)->tp_iternext;
    index = 0; __pyx_t_2 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_2)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    index = 1; __pyx_t_3 = __pyx_t_5(__pyx_t_4); if (unlikely(!__pyx_t_3)) goto __pyx_L3_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_4), 2) < 0) __PYX_ERR(1, 7550, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L4_unpacking_done;
    __pyx_L3_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 7550, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_t_6 = __Pyx_PyInt_As_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7550, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7550, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_width = __pyx_t_6;
  __pyx_v_height = __pyx_t_7;
 7551: 
+7552:     if width + tm < 0:
  __pyx_t_8 = (((__pyx_v_width + __pyx_v_tm) < 0.0) != 0);
  if (__pyx_t_8) {
/* … */
  }
+7553:         tm = 0
    __pyx_v_tm = 0.0;
+7554:     if height + tm < 0:
  __pyx_t_8 = (((__pyx_v_height + __pyx_v_tm) < 0.0) != 0);
  if (__pyx_t_8) {
/* … */
  }
+7555:         tm = 0
    __pyx_v_tm = 0.0;
+7556:     cdef object surf = smoothscale(surface_, (<int>tm +<int> (width + <int>tm),
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_smoothscale); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7556, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = __Pyx_PyInt_From_int((((int)__pyx_v_tm) + ((int)(__pyx_v_width + ((int)__pyx_v_tm))))); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7556, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
/* … */
  __pyx_t_9 = PyTuple_New(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7556, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_4);
  __pyx_t_2 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  __pyx_t_7 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_7 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface_, __pyx_t_9};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_7, 2+__pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7556, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_4, __pyx_v_surface_, __pyx_t_9};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_7, 2+__pyx_t_7); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7556, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  } else
  #endif
  {
    __pyx_t_2 = PyTuple_New(2+__pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__pyx_t_4) {
      __Pyx_GIVEREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4); __pyx_t_4 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface_);
    __Pyx_GIVEREF(__pyx_v_surface_);
    PyTuple_SET_ITEM(__pyx_t_2, 0+__pyx_t_7, __pyx_v_surface_);
    __Pyx_GIVEREF(__pyx_t_9);
    PyTuple_SET_ITEM(__pyx_t_2, 1+__pyx_t_7, __pyx_t_9);
    __pyx_t_9 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_2, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_surf = __pyx_t_1;
  __pyx_t_1 = 0;
+7557:                                               <int>tm +<int> (height + <int>tm)))
  __pyx_t_4 = __Pyx_PyInt_From_int((((int)__pyx_v_tm) + ((int)(__pyx_v_height + ((int)__pyx_v_tm))))); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7557, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
 7558:     cdef int new_width, new_height
+7559:     new_width, new_height = surf.get_size()
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_surf, __pyx_n_s_get_size); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7559, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7559, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if ((likely(PyTuple_CheckExact(__pyx_t_1))) || (PyList_CheckExact(__pyx_t_1))) {
    PyObject* sequence = __pyx_t_1;
    Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
    if (unlikely(size != 2)) {
      if (size > 2) __Pyx_RaiseTooManyValuesError(2);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(1, 7559, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); 
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1); 
    } else {
      __pyx_t_3 = PyList_GET_ITEM(sequence, 0); 
      __pyx_t_2 = PyList_GET_ITEM(sequence, 1); 
    }
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_2);
    #else
    __pyx_t_3 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7559, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_2 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7559, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_9 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7559, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = Py_TYPE(__pyx_t_9)->tp_iternext;
    index = 0; __pyx_t_3 = __pyx_t_5(__pyx_t_9); if (unlikely(!__pyx_t_3)) goto __pyx_L7_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_3);
    index = 1; __pyx_t_2 = __pyx_t_5(__pyx_t_9); if (unlikely(!__pyx_t_2)) goto __pyx_L7_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_5(__pyx_t_9), 2) < 0) __PYX_ERR(1, 7559, __pyx_L1_error)
    __pyx_t_5 = NULL;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    goto __pyx_L8_unpacking_done;
    __pyx_L7_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __pyx_t_5 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(1, 7559, __pyx_L1_error)
    __pyx_L8_unpacking_done:;
  }
  __pyx_t_7 = __Pyx_PyInt_As_int(__pyx_t_3); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7559, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_6 = __Pyx_PyInt_As_int(__pyx_t_2); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7559, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_new_width = __pyx_t_7;
  __pyx_v_new_height = __pyx_t_6;
 7560: 
+7561:     cdef int diff_x = display_width - new_width
  __pyx_v_diff_x = (__pyx_v_display_width - __pyx_v_new_width);
+7562:     cdef int diff_y = display_height_ - new_height
  __pyx_v_diff_y = (__pyx_v_display_height_ - __pyx_v_new_height);
 7563: 
+7564:     return surf, diff_x >> 1, diff_y >> 1
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyInt_From_long((__pyx_v_diff_x >> 1)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7564, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_From_long((__pyx_v_diff_y >> 1)); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7564, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyTuple_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7564, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_v_surf);
  __Pyx_GIVEREF(__pyx_v_surf);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_surf);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_t_2);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_r = ((PyObject*)__pyx_t_3);
  __pyx_t_3 = 0;
  goto __pyx_L0;
 7565: 
 7566: 
 7567: @cython.boundscheck(False)
 7568: @cython.wraparound(False)
 7569: @cython.nonecheck(False)
 7570: @cython.cdivision(False)
+7571: cpdef inline float lateral_dampening(int frame_, float amplitude_=50.0,
static PyObject *__pyx_pw_12PygameShader_6shader_163lateral_dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static CYTHON_INLINE float __pyx_f_12PygameShader_6shader_lateral_dampening(int __pyx_v_frame_, CYTHON_UNUSED int __pyx_skip_dispatch, struct __pyx_opt_args_12PygameShader_6shader_lateral_dampening *__pyx_optional_args) {
  float __pyx_v_amplitude_ = ((float)50.0);
  int __pyx_v_duration_ = ((int)30);
  float __pyx_v_freq_ = ((float)20.0);
  float __pyx_v_t;
  float __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("lateral_dampening", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_amplitude_ = __pyx_optional_args->amplitude_;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_duration_ = __pyx_optional_args->duration_;
        if (__pyx_optional_args->__pyx_n > 2) {
          __pyx_v_freq_ = __pyx_optional_args->freq_;
        }
      }
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_WriteUnraisable("PygameShader.shader.lateral_dampening", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_12PygameShader_6shader_163lateral_dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static char __pyx_doc_12PygameShader_6shader_162lateral_dampening[] = "\n    DAMPENING EFFECT\n\n    * This method return the lateral displacement (x)\n\n    e.g:\n    tm = lateral_dampening(frame, amplitude_=50.0, duration_=35, freq_=5.0)\n    SCREEN.blit(BCK, (tm, 0), special_flags=0)\n\n    Cython cpdef function, this function can be called directly and do not require a\n    hook function.\n\n    The length of the effect equal duration_ * freq_\n\n    :param frame_    : integer; Your game frame number\n    :param amplitude_: float; Represent the amplitude of the dampening effect.\n                       An amplitude of 1.0 will have no effect.Default value is 50.0\n    :param duration_ : float; This represent the duration of the effect, default value is 30\n    :param freq_     : float; change the speed of the effect default value is 20.0.\n                       A small value will decrease\n                       the overall timing of the effect while a larger value will increase the \n                       duration of the effect.\n    :return          : Return a float corresponding to the lateral displacement (x)\n    ";
static PyObject *__pyx_pw_12PygameShader_6shader_163lateral_dampening(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_frame_;
  float __pyx_v_amplitude_;
  int __pyx_v_duration_;
  float __pyx_v_freq_;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("lateral_dampening (wrapper)", 0);
  {
    static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_frame_2,&__pyx_n_s_amplitude,&__pyx_n_s_duration,&__pyx_n_s_freq,0};
    PyObject* values[4] = {0,0,0,0};
    if (unlikely(__pyx_kwds)) {
      Py_ssize_t kw_args;
      const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
      switch (pos_args) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      kw_args = PyDict_Size(__pyx_kwds);
      switch (pos_args) {
        case  0:
        if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_frame_2)) != 0)) kw_args--;
        else goto __pyx_L5_argtuple_error;
        CYTHON_FALLTHROUGH;
        case  1:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_amplitude);
          if (value) { values[1] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  2:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_duration);
          if (value) { values[2] = value; kw_args--; }
        }
        CYTHON_FALLTHROUGH;
        case  3:
        if (kw_args > 0) {
          PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_freq);
          if (value) { values[3] = value; kw_args--; }
        }
      }
      if (unlikely(kw_args > 0)) {
        if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "lateral_dampening") < 0)) __PYX_ERR(1, 7571, __pyx_L3_error)
      }
    } else {
      switch (PyTuple_GET_SIZE(__pyx_args)) {
        case  4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
        CYTHON_FALLTHROUGH;
        case  3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
        CYTHON_FALLTHROUGH;
        case  2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
        CYTHON_FALLTHROUGH;
        case  1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
        break;
        default: goto __pyx_L5_argtuple_error;
      }
    }
    __pyx_v_frame_ = __Pyx_PyInt_As_int(values[0]); if (unlikely((__pyx_v_frame_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7571, __pyx_L3_error)
    if (values[1]) {
      __pyx_v_amplitude_ = __pyx_PyFloat_AsFloat(values[1]); if (unlikely((__pyx_v_amplitude_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 7571, __pyx_L3_error)
    } else {
      __pyx_v_amplitude_ = ((float)50.0);
    }
    if (values[2]) {
      __pyx_v_duration_ = __Pyx_PyInt_As_int(values[2]); if (unlikely((__pyx_v_duration_ == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 7572, __pyx_L3_error)
    } else {
      __pyx_v_duration_ = ((int)30);
    }
    if (values[3]) {
      __pyx_v_freq_ = __pyx_PyFloat_AsFloat(values[3]); if (unlikely((__pyx_v_freq_ == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 7572, __pyx_L3_error)
    } else {
      __pyx_v_freq_ = ((float)20.0);
    }
  }
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("lateral_dampening", 0, 1, 4, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 7571, __pyx_L3_error)
  __pyx_L3_error:;
  __Pyx_AddTraceback("PygameShader.shader.lateral_dampening", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_12PygameShader_6shader_162lateral_dampening(__pyx_self, __pyx_v_frame_, __pyx_v_amplitude_, __pyx_v_duration_, __pyx_v_freq_);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* function exit code */
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_12PygameShader_6shader_162lateral_dampening(CYTHON_UNUSED PyObject *__pyx_self, int __pyx_v_frame_, float __pyx_v_amplitude_, int __pyx_v_duration_, float __pyx_v_freq_) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("lateral_dampening", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2.__pyx_n = 3;
  __pyx_t_2.amplitude_ = __pyx_v_amplitude_;
  __pyx_t_2.duration_ = __pyx_v_duration_;
  __pyx_t_2.freq_ = __pyx_v_freq_;
  __pyx_t_1 = __pyx_f_12PygameShader_6shader_lateral_dampening(__pyx_v_frame_, 0, &__pyx_t_2); 
  __pyx_t_3 = PyFloat_FromDouble(__pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7571, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("PygameShader.shader.lateral_dampening", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7572:                                      int duration_=30, float freq_=20.0):
 7573:     """
 7574:     DAMPENING EFFECT
 7575: 
 7576:     * This method return the lateral displacement (x)
 7577: 
 7578:     e.g:
 7579:     tm = lateral_dampening(frame, amplitude_=50.0, duration_=35, freq_=5.0)
 7580:     SCREEN.blit(BCK, (tm, 0), special_flags=0)
 7581: 
 7582:     Cython cpdef function, this function can be called directly and do not require a
 7583:     hook function.
 7584: 
 7585:     The length of the effect equal duration_ * freq_
 7586: 
 7587:     :param frame_    : integer; Your game frame number
 7588:     :param amplitude_: float; Represent the amplitude of the dampening effect.
 7589:                        An amplitude of 1.0 will have no effect.Default value is 50.0
 7590:     :param duration_ : float; This represent the duration of the effect, default value is 30
 7591:     :param freq_     : float; change the speed of the effect default value is 20.0.
 7592:                        A small value will decrease
 7593:                        the overall timing of the effect while a larger value will increase the 
 7594:                        duration of the effect.
 7595:     :return          : Return a float corresponding to the lateral displacement (x)
 7596:     """
+7597:     assert freq_ > 0, "Argument freq_ must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_freq_ > 0.0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_freq__must_be_0);
      __PYX_ERR(1, 7597, __pyx_L1_error)
    }
  }
  #endif
+7598:     assert duration_ > 0, "Argument duration_ must be > 0"
  #ifndef CYTHON_WITHOUT_ASSERTIONS
  if (unlikely(!Py_OptimizeFlag)) {
    if (unlikely(!((__pyx_v_duration_ > 0) != 0))) {
      PyErr_SetObject(PyExc_AssertionError, __pyx_kp_s_Argument_duration__must_be_0);
      __PYX_ERR(1, 7598, __pyx_L1_error)
    }
  }
  #endif
 7599: 
+7600:     cdef float t = damped_oscillation((<float>frame_ / freq_) % duration_) * amplitude_
  if (unlikely(__pyx_v_freq_ == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float division");
    __PYX_ERR(1, 7600, __pyx_L1_error)
  }
  __pyx_t_1 = (((float)__pyx_v_frame_) / __pyx_v_freq_);
  if (unlikely(__pyx_v_duration_ == 0)) {
    PyErr_SetString(PyExc_ZeroDivisionError, "float divmod()");
    __PYX_ERR(1, 7600, __pyx_L1_error)
  }
  __pyx_v_t = (__pyx_f_12PygameShader_6shader_damped_oscillation(__Pyx_mod_float(__pyx_t_1, __pyx_v_duration_)) * __pyx_v_amplitude_);
+7601:     return t
  __pyx_r = __pyx_v_t;
  goto __pyx_L0;
 7602: 
 7603: # --------------------------------------------------------------------------------------------------------
 7604: # KERNEL DEFINITION FOR SHARPEN ALGORITHM
+7605: cdef float [:, :] SHARPEN_KERNEL = numpy.array(([0, -1, 0],
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7605, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_32 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_array_2); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 7605, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyList_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7605, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_2, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_2, 1, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_2, 2, __pyx_int_0);
/* … */
  __pyx_t_30 = PyTuple_New(3); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 7605, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_30, 0, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_33);
  PyTuple_SET_ITEM(__pyx_t_30, 1, __pyx_t_33);
  __Pyx_GIVEREF(__pyx_t_31);
  PyTuple_SET_ITEM(__pyx_t_30, 2, __pyx_t_31);
  __pyx_t_2 = 0;
  __pyx_t_33 = 0;
  __pyx_t_31 = 0;
  __pyx_t_31 = __Pyx_PyObject_CallOneArg(__pyx_t_32, __pyx_t_30); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 7605, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
+7606:                       [-1, 5, -1],
  __pyx_t_33 = PyList_New(3); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 7606, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_33, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_5);
  __Pyx_GIVEREF(__pyx_int_5);
  PyList_SET_ITEM(__pyx_t_33, 1, __pyx_int_5);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_33, 2, __pyx_int_neg_1);
+7607:                       [0, -1, 0])).astype(dtype=float32)
  __pyx_t_31 = PyList_New(3); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_31, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_31, 1, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_31, 2, __pyx_int_0);
/* … */
  __pyx_t_30 = __Pyx_PyObject_GetAttrStr(__pyx_t_31, __pyx_n_s_astype); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  __pyx_t_31 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_GetModuleGlobalName(__pyx_t_32, __pyx_n_s_float32); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  if (PyDict_SetItem(__pyx_t_31, __pyx_n_s_dtype, __pyx_t_32) < 0) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __pyx_t_32 = __Pyx_PyObject_Call(__pyx_t_30, __pyx_empty_tuple, __pyx_t_31); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  __pyx_t_34 = __Pyx_PyObject_to_MemoryviewSlice_dsds_float(__pyx_t_32, PyBUF_WRITABLE); if (unlikely(!__pyx_t_34.memview)) __PYX_ERR(1, 7607, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
  __PYX_XDEC_MEMVIEW(&__pyx_v_12PygameShader_6shader_SHARPEN_KERNEL, 1);
  __pyx_v_12PygameShader_6shader_SHARPEN_KERNEL = __pyx_t_34;
  __pyx_t_34.memview = NULL;
  __pyx_t_34.data = NULL;
+7608: cdef int HALF_KERNEL = len(SHARPEN_KERNEL) >> 1
  if (unlikely(!__pyx_v_12PygameShader_6shader_SHARPEN_KERNEL.memview)) { __Pyx_RaiseUnboundLocalError("SHARPEN_KERNEL"); __PYX_ERR(1, 7608, __pyx_L1_error) }
  __pyx_t_47 = __Pyx_MemoryView_Len(__pyx_v_12PygameShader_6shader_SHARPEN_KERNEL); 
  __pyx_v_12PygameShader_6shader_HALF_KERNEL = (__pyx_t_47 >> 1);
 7609: 
 7610: @cython.boundscheck(False)
 7611: @cython.wraparound(False)
 7612: @cython.nonecheck(False)
 7613: @cython.cdivision(True)
+7614: cdef inline void shader_sharpen_filter_inplace_c(unsigned char [:, :, :] rgb_array_):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_shader_sharpen_filter_inplace_c(__Pyx_memviewslice __pyx_v_rgb_array_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_rgb_array_1 = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_xx;
  int __pyx_v_yy;
  short __pyx_v_kernel_offset_y;
  short __pyx_v_kernel_offset_x;
  float __pyx_v_r;
  float __pyx_v_g;
  float __pyx_v_b;
  float __pyx_v_k;
  unsigned char *__pyx_v_rr;
  unsigned char *__pyx_v_gg;
  unsigned char *__pyx_v_bb;
  int __pyx_v_w_1;
  int __pyx_v_h_1;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("shader_sharpen_filter_inplace_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_10);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_WriteUnraisable("PygameShader.shader.shader_sharpen_filter_inplace_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_rgb_array_1, 1);
  __Pyx_RefNannyFinishContext();
}
 7615:         """
 7616:         SHARPEN IMAGE APPLYING THE BELOW 3 X 3 KERNEL OVER EVERY PIXELS.
 7617: 
 7618:         The Array (rgb_array) must be a numpy array shape (w, h, 3)
 7619:         containing RGB pixels, please refer to pygame
 7620:         function pixels3d or array3d to convert an image into a 3d array (library surfarray)
 7621: 
 7622:         pixels convoluted outside image edges will be set to adjacent edge value
 7623:         [0 , -1,  0]
 7624:         [-1,  5, -1]
 7625:         [0 , -1,  0]
 7626: 
 7627:         e.g
 7628:         sharpen(surface_)
 7629: 
 7630:         :param rgb_array_: numpy.ndarray shape (w, h, 3) containing all the RGB pixels
 7631:         :return          : void
 7632:         """
 7633: 
 7634:         # texture sizes
 7635:         cdef Py_ssize_t w, h
+7636:         w, h = rgb_array_.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array_.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 7637: 
 7638:         cdef:
 7639: 
+7640:             unsigned char [:, :, :] rgb_array_1 = numpy.empty((w, h, 3), uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_numpy); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_n_s_empty); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_7 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_8 = PyTuple_New(3); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_7);
  PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_7);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_8, 2, __pyx_int_3);
  __pyx_t_5 = 0;
  __pyx_t_7 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_n_s_uint8); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_5 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_5)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_8, __pyx_t_7};
    __pyx_t_4 = __Pyx_PyFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7640, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[3] = {__pyx_t_5, __pyx_t_8, __pyx_t_7};
    __pyx_t_4 = __Pyx_PyCFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7640, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  } else
  #endif
  {
    __pyx_t_10 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7640, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    if (__pyx_t_5) {
      __Pyx_GIVEREF(__pyx_t_5); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_5); __pyx_t_5 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_8);
    PyTuple_SET_ITEM(__pyx_t_10, 0+__pyx_t_9, __pyx_t_8);
    __Pyx_GIVEREF(__pyx_t_7);
    PyTuple_SET_ITEM(__pyx_t_10, 1+__pyx_t_9, __pyx_t_7);
    __pyx_t_8 = 0;
    __pyx_t_7 = 0;
    __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_t_10, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7640, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  }
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 7640, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_rgb_array_1 = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
 7641:             int x, y, xx, yy
 7642:             short kernel_offset_y, kernel_offset_x
 7643:             float r, g, b, k
 7644:             unsigned char *rr
 7645:             unsigned char *gg
 7646:             unsigned char *bb
+7647:             int w_1 = <int>w - 1
  __pyx_v_w_1 = (((int)__pyx_v_w) - 1);
+7648:             int h_1 = <int>h - 1
  __pyx_v_h_1 = (((int)__pyx_v_h) - 1);
 7649: 
+7650:         with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L4_error: {
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L1_error;
        }
        __pyx_L5:;
      }
  }
 7651: 
+7652:             for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_12 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_12 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_12; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((float)__PYX_NAN());
                            __pyx_v_bb = ((unsigned char *)1);
                            __pyx_v_g = ((float)__PYX_NAN());
                            __pyx_v_gg = ((unsigned char *)1);
                            __pyx_v_k = ((float)__PYX_NAN());
                            __pyx_v_kernel_offset_x = ((short)0xbad0bad0);
                            __pyx_v_kernel_offset_y = ((short)0xbad0bad0);
                            __pyx_v_r = ((float)__PYX_NAN());
                            __pyx_v_rr = ((unsigned char *)1);
                            __pyx_v_x = ((int)0xbad0bad0);
                            __pyx_v_xx = ((int)0xbad0bad0);
                            __pyx_v_yy = ((int)0xbad0bad0);
 7653: 
+7654:                 for x in range(w):
                            __pyx_t_13 = __pyx_v_w;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_14; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 7655: 
+7656:                     rr = &rgb_array_1[x, y, 0]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 0;
                              __pyx_v_rr = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_15 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb_array_1.strides[2]) ))));
+7657:                     gg = &rgb_array_1[x, y, 1]
                              __pyx_t_17 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              __pyx_v_gg = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_17 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_1.strides[2]) ))));
+7658:                     bb = &rgb_array_1[x, y, 2]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_16 = __pyx_v_y;
                              __pyx_t_17 = 2;
                              __pyx_v_bb = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_15 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_16 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_17 * __pyx_v_rgb_array_1.strides[2]) ))));
 7659: 
+7660:                     r, g, b = 0, 0, 0
                              __pyx_t_18 = 0.0;
                              __pyx_t_19 = 0.0;
                              __pyx_t_20 = 0.0;
                              __pyx_v_r = __pyx_t_18;
                              __pyx_v_g = __pyx_t_19;
                              __pyx_v_b = __pyx_t_20;
 7661: 
+7662:                     for kernel_offset_y in range(-HALF_KERNEL, HALF_KERNEL + 1):
                              __pyx_t_21 = (__pyx_v_12PygameShader_6shader_HALF_KERNEL + 1);
                              __pyx_t_22 = __pyx_t_21;
                              for (__pyx_t_23 = (-__pyx_v_12PygameShader_6shader_HALF_KERNEL); __pyx_t_23 < __pyx_t_22; __pyx_t_23+=1) {
                                __pyx_v_kernel_offset_y = __pyx_t_23;
 7663: 
+7664:                         for kernel_offset_x in range(-HALF_KERNEL, HALF_KERNEL + 1):
                                __pyx_t_24 = (__pyx_v_12PygameShader_6shader_HALF_KERNEL + 1);
                                __pyx_t_25 = __pyx_t_24;
                                for (__pyx_t_26 = (-__pyx_v_12PygameShader_6shader_HALF_KERNEL); __pyx_t_26 < __pyx_t_25; __pyx_t_26+=1) {
                                  __pyx_v_kernel_offset_x = __pyx_t_26;
 7665: 
+7666:                             xx = x + kernel_offset_x
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kernel_offset_x);
+7667:                             yy = y + kernel_offset_y
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_kernel_offset_y);
 7668: 
+7669:                             if xx < 0:
                                  __pyx_t_27 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_27) {
/* … */
                                    goto __pyx_L16;
                                  }
+7670:                                 xx = 0
                                    __pyx_v_xx = 0;
+7671:                             elif xx > w_1:
                                  __pyx_t_27 = ((__pyx_v_xx > __pyx_v_w_1) != 0);
                                  if (__pyx_t_27) {
/* … */
                                  }
                                  __pyx_L16:;
+7672:                                 xx = w_1
                                    __pyx_v_xx = __pyx_v_w_1;
 7673: 
+7674:                             if yy < 0:
                                  __pyx_t_27 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_27) {
/* … */
                                    goto __pyx_L17;
                                  }
+7675:                                 yy = 0
                                    __pyx_v_yy = 0;
+7676:                             elif yy > h_1:
                                  __pyx_t_27 = ((__pyx_v_yy > __pyx_v_h_1) != 0);
                                  if (__pyx_t_27) {
/* … */
                                  }
                                  __pyx_L17:;
+7677:                                 yy = h_1
                                    __pyx_v_yy = __pyx_v_h_1;
 7678: 
+7679:                             k = SHARPEN_KERNEL[kernel_offset_y + HALF_KERNEL,
                                  if (unlikely(!__pyx_v_12PygameShader_6shader_SHARPEN_KERNEL.memview)) { __Pyx_RaiseUnboundMemoryviewSliceNogil("SHARPEN_KERNEL"); __PYX_ERR(1, 7679, __pyx_L8_error) }
/* … */
                                  __pyx_t_17 = (__pyx_v_kernel_offset_y + __pyx_v_12PygameShader_6shader_HALF_KERNEL);
                                  __pyx_t_16 = (__pyx_v_kernel_offset_x + __pyx_v_12PygameShader_6shader_HALF_KERNEL);
                                  __pyx_v_k = (*((float *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_12PygameShader_6shader_SHARPEN_KERNEL.data + __pyx_t_17 * __pyx_v_12PygameShader_6shader_SHARPEN_KERNEL.strides[0]) ) + __pyx_t_16 * __pyx_v_12PygameShader_6shader_SHARPEN_KERNEL.strides[1]) )));
 7680:                                                kernel_offset_x + HALF_KERNEL]
 7681: 
+7682:                             r = r + rgb_array_[xx, yy, 0] * k
                                  __pyx_t_16 = __pyx_v_xx;
                                  __pyx_t_17 = __pyx_v_yy;
                                  __pyx_t_15 = 0;
                                  __pyx_v_r = (__pyx_v_r + ((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))) * __pyx_v_k));
+7683:                             g = g + rgb_array_[xx, yy, 1] * k
                                  __pyx_t_15 = __pyx_v_xx;
                                  __pyx_t_17 = __pyx_v_yy;
                                  __pyx_t_16 = 1;
                                  __pyx_v_g = (__pyx_v_g + ((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_.strides[2]) ))) * __pyx_v_k));
+7684:                             b = b + rgb_array_[xx, yy, 2] * k
                                  __pyx_t_16 = __pyx_v_xx;
                                  __pyx_t_17 = __pyx_v_yy;
                                  __pyx_t_15 = 2;
                                  __pyx_v_b = (__pyx_v_b + ((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_16 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) ))) * __pyx_v_k));
                                }
                              }
 7685: 
+7686:                     if r < 0:
                              __pyx_t_27 = ((__pyx_v_r < 0.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7687:                         r = 0
                                __pyx_v_r = 0.0;
+7688:                     if g < 0:
                              __pyx_t_27 = ((__pyx_v_g < 0.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7689:                         g = 0
                                __pyx_v_g = 0.0;
+7690:                     if b < 0:
                              __pyx_t_27 = ((__pyx_v_b < 0.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7691:                         b = 0
                                __pyx_v_b = 0.0;
+7692:                     if r > 255:
                              __pyx_t_27 = ((__pyx_v_r > 255.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7693:                         r= 255
                                __pyx_v_r = 255.0;
+7694:                     if g > 255:
                              __pyx_t_27 = ((__pyx_v_g > 255.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7695:                         g = 255
                                __pyx_v_g = 255.0;
+7696:                     if b > 255:
                              __pyx_t_27 = ((__pyx_v_b > 255.0) != 0);
                              if (__pyx_t_27) {
/* … */
                              }
+7697:                         b = 255
                                __pyx_v_b = 255.0;
 7698: 
+7699:                     rr[0] = <unsigned char>r
                              (__pyx_v_rr[0]) = ((unsigned char)__pyx_v_r);
+7700:                     gg[0] = <unsigned char>g
                              (__pyx_v_gg[0]) = ((unsigned char)__pyx_v_g);
+7701:                     bb[0] = <unsigned char>b
                              (__pyx_v_bb[0]) = ((unsigned char)__pyx_v_b);
                            }
                            goto __pyx_L25;
                            __pyx_L8_error:;
                            {
                                #ifdef WITH_THREAD
                                PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                                #endif
                                #ifdef _OPENMP
                                #pragma omp flush(__pyx_parallel_exc_type)
                                #endif /* _OPENMP */
                                if (!__pyx_parallel_exc_type) {
                                  __Pyx_ErrFetchWithState(&__pyx_parallel_exc_type, &__pyx_parallel_exc_value, &__pyx_parallel_exc_tb);
                                  __pyx_parallel_filename = __pyx_filename; __pyx_parallel_lineno = __pyx_lineno; __pyx_parallel_clineno = __pyx_clineno;
                                  __Pyx_GOTREF(__pyx_parallel_exc_type);
                                }
                                #ifdef WITH_THREAD
                                __Pyx_PyGILState_Release(__pyx_gilstate_save);
                                #endif
                            }
                            __pyx_parallel_why = 4;
                            goto __pyx_L24;
                            __pyx_L24:;
                            #ifdef _OPENMP
                            #pragma omp critical(__pyx_parallel_lastprivates13)
                            #endif /* _OPENMP */
                            {
                                __pyx_parallel_temp0 = __pyx_v_b;
                                __pyx_parallel_temp1 = __pyx_v_bb;
                                __pyx_parallel_temp2 = __pyx_v_g;
                                __pyx_parallel_temp3 = __pyx_v_gg;
                                __pyx_parallel_temp4 = __pyx_v_k;
                                __pyx_parallel_temp5 = __pyx_v_kernel_offset_x;
                                __pyx_parallel_temp6 = __pyx_v_kernel_offset_y;
                                __pyx_parallel_temp7 = __pyx_v_r;
                                __pyx_parallel_temp8 = __pyx_v_rr;
                                __pyx_parallel_temp9 = __pyx_v_x;
                                __pyx_parallel_temp10 = __pyx_v_xx;
                                __pyx_parallel_temp11 = __pyx_v_y;
                                __pyx_parallel_temp12 = __pyx_v_yy;
                            }
                            __pyx_L25:;
                            #ifdef _OPENMP
                            #pragma omp flush(__pyx_parallel_why)
                            #endif /* _OPENMP */
                        }
                    }
                    #ifdef _OPENMP
                    Py_END_ALLOW_THREADS
                    #else
{
#ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    #endif /* _OPENMP */
                    /* Clean up any temporaries */
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                    #ifndef _OPENMP
}
#endif /* _OPENMP */
                }
            }
            if (__pyx_parallel_exc_type) {
              /* This may have been overridden by a continue, break or return in another thread. Prefer the error. */
              __pyx_parallel_why = 4;
            }
            if (__pyx_parallel_why) {
              __pyx_v_b = __pyx_parallel_temp0;
              __pyx_v_bb = __pyx_parallel_temp1;
              __pyx_v_g = __pyx_parallel_temp2;
              __pyx_v_gg = __pyx_parallel_temp3;
              __pyx_v_k = __pyx_parallel_temp4;
              __pyx_v_kernel_offset_x = __pyx_parallel_temp5;
              __pyx_v_kernel_offset_y = __pyx_parallel_temp6;
              __pyx_v_r = __pyx_parallel_temp7;
              __pyx_v_rr = __pyx_parallel_temp8;
              __pyx_v_x = __pyx_parallel_temp9;
              __pyx_v_xx = __pyx_parallel_temp10;
              __pyx_v_y = __pyx_parallel_temp11;
              __pyx_v_yy = __pyx_parallel_temp12;
              switch (__pyx_parallel_why) {
                    case 4:
                {
                    #ifdef WITH_THREAD
                    PyGILState_STATE __pyx_gilstate_save = __Pyx_PyGILState_Ensure();
                    #endif
                    __Pyx_GIVEREF(__pyx_parallel_exc_type);
                    __Pyx_ErrRestoreWithState(__pyx_parallel_exc_type, __pyx_parallel_exc_value, __pyx_parallel_exc_tb);
                    __pyx_filename = __pyx_parallel_filename; __pyx_lineno = __pyx_parallel_lineno; __pyx_clineno = __pyx_parallel_clineno;
                    #ifdef WITH_THREAD
                    __Pyx_PyGILState_Release(__pyx_gilstate_save);
                    #endif
                }
                goto __pyx_L4_error;
              }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
 7702: 
+7703:             for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_12 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_3 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_3 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_12 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_3 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_3 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_3; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_x = ((int)0xbad0bad0);
 7704: 
+7705:                 for x in range(w):
                            __pyx_t_13 = __pyx_v_w;
                            __pyx_t_14 = __pyx_t_13;
                            for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_14; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
+7706:                     rgb_array_[x, y, 0] = rgb_array_1[x, y, 0]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_17 = __pyx_v_y;
                              __pyx_t_16 = 0;
                              __pyx_t_28 = __pyx_v_x;
                              __pyx_t_29 = __pyx_v_y;
                              __pyx_t_30 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_28 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_29 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_30 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_15 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_1.strides[2]) )));
+7707:                     rgb_array_[x, y, 1] = rgb_array_1[x, y, 1]
                              __pyx_t_16 = __pyx_v_x;
                              __pyx_t_17 = __pyx_v_y;
                              __pyx_t_15 = 1;
                              __pyx_t_30 = __pyx_v_x;
                              __pyx_t_29 = __pyx_v_y;
                              __pyx_t_28 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_30 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_29 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_28 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_16 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_1.strides[2]) )));
+7708:                     rgb_array_[x, y, 2] = rgb_array_1[x, y, 2]
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_17 = __pyx_v_y;
                              __pyx_t_16 = 2;
                              __pyx_t_28 = __pyx_v_x;
                              __pyx_t_29 = __pyx_v_y;
                              __pyx_t_30 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_28 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_29 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_30 * __pyx_v_rgb_array_.strides[2]) )) = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_1.data + __pyx_t_15 * __pyx_v_rgb_array_1.strides[0]) ) + __pyx_t_17 * __pyx_v_rgb_array_1.strides[1]) ) + __pyx_t_16 * __pyx_v_rgb_array_1.strides[2]) )));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 7709: 
 7710: 
 7711: # Added to version 1.0.1
 7712: @cython.boundscheck(False)
 7713: @cython.wraparound(False)
 7714: @cython.nonecheck(False)
 7715: @cython.cdivision(True)
+7716: cdef cartoon_effect(
static PyObject *__pyx_f_12PygameShader_6shader_cartoon_effect(PyObject *__pyx_v_surface_, int __pyx_v_sobel_threshold_, int __pyx_v_median_kernel_, int __pyx_v_color_, int __pyx_v_flag_) {
  PyObject *__pyx_v_surface_branch_1 = NULL;
  PyObject *__pyx_v_array_ = NULL;
  PyObject *__pyx_v_arr = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cartoon_effect", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_AddTraceback("PygameShader.shader.cartoon_effect", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_surface_branch_1);
  __Pyx_XDECREF(__pyx_v_array_);
  __Pyx_XDECREF(__pyx_v_arr);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7717:         object surface_,
 7718:         int sobel_threshold_,
 7719:         int median_kernel_,
 7720:         int color_, int flag_):
 7721:     """
 7722: 
 7723:     :param surface_: pygame.Surface compatible 24 - 32 bit 
 7724:     :param sobel_threshold_: integer sobel threshold
 7725:     :param median_kernel_  : integer median kernel  
 7726:     :param color_          : integer; color reduction value (max color)
 7727:     :param flag_           : integer; Blend flag e.g (BLEND_RGB_ADD, BLEND_RGB_SUB, 
 7728:                              BLEND_RGB_MULT, BLEND_RGB_MAX, BLEND_RGB_MIN  
 7729:     :return               : Return a pygame Surface with the cartoon effect 
 7730:     """
 7731: 
 7732:     # First branch from the surface_
 7733:     # surface_branch_1
+7734:     surface_branch_1 = surface_.copy()
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_copy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7734, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7734, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_surface_branch_1 = __pyx_t_1;
  __pyx_t_1 = 0;
+7735:     array_ = canny_blur5x5_surface24_c(surface_branch_1)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_canny_blur5x5_surface24_c); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_3, __pyx_v_surface_branch_1) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v_surface_branch_1);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_array_ = __pyx_t_1;
  __pyx_t_1 = 0;
+7736:     shader_greyscale_luminosity24_inplace_c(array_)
  __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(1, 7736, __pyx_L1_error)
  __pyx_f_12PygameShader_6shader_shader_greyscale_luminosity24_inplace_c(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1);
  __pyx_t_4.memview = NULL;
  __pyx_t_4.data = NULL;
+7737:     shader_sobel24_inplace_c(array_, sobel_threshold_)
  __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_array_, PyBUF_WRITABLE); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(1, 7737, __pyx_L1_error)
  __pyx_t_5.__pyx_n = 1;
  __pyx_t_5.threshold = __pyx_v_sobel_threshold_;
  __pyx_f_12PygameShader_6shader_shader_sobel24_inplace_c(__pyx_t_4, &__pyx_t_5); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1);
  __pyx_t_4.memview = NULL;
  __pyx_t_4.data = NULL;
 7738: 
 7739:     # Second branch
+7740:     arr = pixels3d(surface_)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7740, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_2, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_3, __pyx_v_surface_) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v_surface_);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7740, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_arr = __pyx_t_1;
  __pyx_t_1 = 0;
+7741:     shader_median_filter24_inplace_c(arr, median_kernel_)
  __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_arr, PyBUF_WRITABLE); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(1, 7741, __pyx_L1_error)
  __pyx_t_6.__pyx_n = 1;
  __pyx_t_6.kernel_size_ = __pyx_v_median_kernel_;
  __pyx_f_12PygameShader_6shader_shader_median_filter24_inplace_c(__pyx_t_4, &__pyx_t_6); 
  __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1);
  __pyx_t_4.memview = NULL;
  __pyx_t_4.data = NULL;
 7742: 
 7743:     # median_fast(
 7744:     #     surface_,
 7745:     #     kernel_size_=median_kernel_,
 7746:     #     reduce_factor_=2)
 7747: 
 7748:     # Color reduction
+7749:     shader_color_reduction24_inplace_c(arr, color_)
  __pyx_t_4 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_v_arr, PyBUF_WRITABLE); if (unlikely(!__pyx_t_4.memview)) __PYX_ERR(1, 7749, __pyx_L1_error)
  __pyx_f_12PygameShader_6shader_shader_color_reduction24_inplace_c(__pyx_t_4, __pyx_v_color_);
  __PYX_XDEC_MEMVIEW(&__pyx_t_4, 1);
  __pyx_t_4.memview = NULL;
  __pyx_t_4.data = NULL;
 7750: 
+7751:     del arr
  __Pyx_DECREF(__pyx_v_arr);
  __pyx_v_arr = NULL;
 7752: 
 7753:     # Blend both branch
+7754:     surface_.blit(make_surface(array_), (0, 0), special_flags=flag_)
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_surface_, __pyx_n_s_blit); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_7 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_7)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_2 = (__pyx_t_7) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_7, __pyx_v_array_) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_array_);
  __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
  __Pyx_INCREF(__pyx_tuple__12);
  __Pyx_GIVEREF(__pyx_tuple__12);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_tuple__12);
  __pyx_t_2 = 0;
  __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_7 = __Pyx_PyInt_From_int(__pyx_v_flag_); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  if (PyDict_SetItem(__pyx_t_2, __pyx_n_s_special_flags, __pyx_t_7) < 0) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 7754, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
 7755: 
+7756:     return surface_
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_surface_);
  __pyx_r = __pyx_v_surface_;
  goto __pyx_L0;
 7757: 
 7758: 
 7759: 
 7760: # TODO ADD TO TESTING
 7761: # Added to version 1.0.1
 7762: @cython.boundscheck(False)
 7763: @cython.wraparound(False)
 7764: @cython.nonecheck(False)
 7765: @cython.cdivision(True)
+7766: cdef object blending(object source_, object destination_, float percentage_):
static PyObject *__pyx_f_12PygameShader_6shader_blending(PyObject *__pyx_v_source_, PyObject *__pyx_v_destination_, float __pyx_v_percentage_) {
  __Pyx_memviewslice __pyx_v_source_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  __Pyx_memviewslice __pyx_v_destination_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_v_e = NULL;
  int __pyx_v_c1;
  int __pyx_v_c2;
  int __pyx_v_c3;
  int __pyx_v_i;
  int __pyx_v_j;
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_final_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  float __pyx_v_c4;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("blending", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __PYX_XDEC_MEMVIEW(&__pyx_t_11, 1);
  __Pyx_XDECREF(__pyx_t_24);
  __Pyx_XDECREF(__pyx_t_25);
  __Pyx_AddTraceback("PygameShader.shader.blending", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_source_array, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_destination_array, 1);
  __Pyx_XDECREF(__pyx_v_e);
  __PYX_XDEC_MEMVIEW(&__pyx_v_final_array, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7767:     """
 7768:     BLEND A SOURCE TEXTURE TOWARD A DESTINATION TEXTURE (TRANSITION EFFECT)
 7769: 
 7770:     * Video system must be initialised 
 7771:     * source_ & destination_ Textures must be same sizes
 7772:     * Compatible with 24 - 32 bit surface
 7773:     * Output create a new surface
 7774:     * Image returned is converted for fast blit (convert())
 7775: 
 7776:     :param source_     : pygame.Surface (Source)
 7777:     :param destination_: pygame.Surface (Destination)
 7778:     :param percentage_ : float; Percentage value between [0.0 ... 100.0]
 7779:     :return: return    : Return a 24 bit pygame.Surface and blended with a percentage
 7780:                          of the destination texture.
 7781:     """
 7782: 
 7783:     cdef:
 7784:             unsigned char [:, :, :] source_array
 7785:             unsigned char [:, :, :] destination_array
 7786: 
+7787:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
/* … */
    __Pyx_XGIVEREF(__pyx_t_1);
    __Pyx_XGIVEREF(__pyx_t_2);
    __Pyx_XGIVEREF(__pyx_t_3);
    __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }
+7788:         source_array      = pixels3d(source_)
      __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7788, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_6 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
        __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
        if (likely(__pyx_t_6)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
          __Pyx_INCREF(__pyx_t_6);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_5, function);
        }
      }
      __pyx_t_4 = (__pyx_t_6) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_6, __pyx_v_source_) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_v_source_);
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7788, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_4, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 7788, __pyx_L3_error)
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_v_source_array = __pyx_t_7;
      __pyx_t_7.memview = NULL;
      __pyx_t_7.data = NULL;
 7789: 
+7790:     except Exception as e:
    __pyx_t_8 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(&((PyTypeObject*)PyExc_Exception)[0])));
    if (__pyx_t_8) {
      __Pyx_AddTraceback("PygameShader.shader.blending", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_5, &__pyx_t_6) < 0) __PYX_ERR(1, 7790, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_v_e = __pyx_t_5;
+7791:         raise ValueError("\nCannot reference source pixels into a 3d array.\n %s " % e)
      __pyx_t_9 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Cannot_reference_source_pixels, __pyx_v_e); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7791, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __pyx_t_10 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_9); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7791, __pyx_L5_except_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_Raise(__pyx_t_10, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __PYX_ERR(1, 7791, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;
    __pyx_L5_except_error:;
 7792: 
+7793:     try:
  {
    /*try:*/ {
/* … */
    }
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    goto __pyx_L16_try_end;
    __pyx_L11_error:;
    __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
/* … */
    __Pyx_XGIVEREF(__pyx_t_3);
    __Pyx_XGIVEREF(__pyx_t_2);
    __Pyx_XGIVEREF(__pyx_t_1);
    __Pyx_ExceptionReset(__pyx_t_3, __pyx_t_2, __pyx_t_1);
    goto __pyx_L1_error;
    __pyx_L16_try_end:;
  }
+7794:         destination_array = pixels3d(destination_)
      __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_pixels3d); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7794, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_4 = NULL;
      if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
        __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_5);
        if (likely(__pyx_t_4)) {
          PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
          __Pyx_INCREF(__pyx_t_4);
          __Pyx_INCREF(function);
          __Pyx_DECREF_SET(__pyx_t_5, function);
        }
      }
      __pyx_t_6 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_5, __pyx_t_4, __pyx_v_destination_) : __Pyx_PyObject_CallOneArg(__pyx_t_5, __pyx_v_destination_);
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7794, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_6, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 7794, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __pyx_v_destination_array = __pyx_t_7;
      __pyx_t_7.memview = NULL;
      __pyx_t_7.data = NULL;
 7795: 
+7796:     except Exception as e:
    __pyx_t_8 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(&((PyTypeObject*)PyExc_Exception)[0])));
    if (__pyx_t_8) {
      __Pyx_AddTraceback("PygameShader.shader.blending", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_5, &__pyx_t_4) < 0) __PYX_ERR(1, 7796, __pyx_L13_except_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_v_e = __pyx_t_5;
+7797:         raise ValueError("\nCannot reference destination pixels into a 3d array.\n %s " % e)
      __pyx_t_10 = __Pyx_PyString_FormatSafe(__pyx_kp_s_Cannot_reference_destination_pi, __pyx_v_e); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7797, __pyx_L13_except_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_9 = __Pyx_PyObject_CallOneArg(__pyx_builtin_ValueError, __pyx_t_10); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7797, __pyx_L13_except_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_Raise(__pyx_t_9, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __PYX_ERR(1, 7797, __pyx_L13_except_error)
    }
    goto __pyx_L13_except_error;
    __pyx_L13_except_error:;
 7798: 
 7799:     cdef:
 7800: 
 7801:         int c1, c2, c3
+7802:         int i=0, j=0
  __pyx_v_i = 0;
  __pyx_v_j = 0;
+7803:         Py_ssize_t w = source_array.shape[0]
  __pyx_v_w = (__pyx_v_source_array.shape[0]);
+7804:         Py_ssize_t h = source_array.shape[1]
  __pyx_v_h = (__pyx_v_source_array.shape[1]);
+7805:         unsigned char[:, :, ::1] final_array = empty((h, w, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_empty); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_9 = PyTuple_New(3); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_6);
  PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_6);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_9, 2, __pyx_int_3);
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_6 = PyTuple_New(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_GIVEREF(__pyx_t_9);
  PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_9);
  __pyx_t_9 = 0;
  __pyx_t_9 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_uint8); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  if (PyDict_SetItem(__pyx_t_9, __pyx_n_s_dtype, __pyx_t_5) < 0) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_6, __pyx_t_9); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_11 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_5, PyBUF_WRITABLE); if (unlikely(!__pyx_t_11.memview)) __PYX_ERR(1, 7805, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_v_final_array = __pyx_t_11;
  __pyx_t_11.memview = NULL;
  __pyx_t_11.data = NULL;
+7806:         float c4 = percentage_ / <float> 100.0
  __pyx_v_c4 = (__pyx_v_percentage_ / ((float)100.0));
 7807:         unsigned char *r
 7808:         unsigned char *g
 7809:         unsigned char *b
 7810: 
+7811:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L21;
        }
        __pyx_L21:;
      }
  }
+7812:         for j in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_12 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_14 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_14 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static)
/* … */
        __pyx_t_12 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_14 = (__pyx_t_12 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_14 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_c1) lastprivate(__pyx_v_c2) lastprivate(__pyx_v_c3) lastprivate(__pyx_v_g) lastprivate(__pyx_v_i) firstprivate(__pyx_v_j) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_14; __pyx_t_13++){
                        {
                            __pyx_v_j = (int)(0 + 1 * __pyx_t_13);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_c1 = ((int)0xbad0bad0);
                            __pyx_v_c2 = ((int)0xbad0bad0);
                            __pyx_v_c3 = ((int)0xbad0bad0);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_i = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
+7813:             for i in range(w):
                            __pyx_t_15 = __pyx_v_w;
                            __pyx_t_16 = __pyx_t_15;
                            for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_16; __pyx_t_8+=1) {
                              __pyx_v_i = __pyx_t_8;
 7814: 
+7815:                 r = &source_array[i, j, 0]
                              __pyx_t_17 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_19 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_17 * __pyx_v_source_array.strides[0]) ) + __pyx_t_18 * __pyx_v_source_array.strides[1]) ) + __pyx_t_19 * __pyx_v_source_array.strides[2]) ))));
+7816:                 g = &source_array[i, j, 1]
                              __pyx_t_19 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_17 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_19 * __pyx_v_source_array.strides[0]) ) + __pyx_t_18 * __pyx_v_source_array.strides[1]) ) + __pyx_t_17 * __pyx_v_source_array.strides[2]) ))));
+7817:                 b = &source_array[i, j, 2]
                              __pyx_t_17 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_19 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_source_array.data + __pyx_t_17 * __pyx_v_source_array.strides[0]) ) + __pyx_t_18 * __pyx_v_source_array.strides[1]) ) + __pyx_t_19 * __pyx_v_source_array.strides[2]) ))));
 7818: 
+7819:                 c1 = min(<int> (<float> destination_array[i, j, 0] * c4 +
                              __pyx_t_20 = 0xFF;
                              __pyx_t_19 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_17 = 0;
/* … */
                              __pyx_t_21 = ((int)((((float)(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_destination_array.data + __pyx_t_19 * __pyx_v_destination_array.strides[0]) ) + __pyx_t_18 * __pyx_v_destination_array.strides[1]) ) + __pyx_t_17 * __pyx_v_destination_array.strides[2]) )))) * __pyx_v_c4) + ((__pyx_v_r[0]) * (((float)1.0) - __pyx_v_c4))));
+7820:                                 r[0] * (<float> 1.0 - c4)), 255)
                              if (((__pyx_t_20 < __pyx_t_21) != 0)) {
                                __pyx_t_22 = __pyx_t_20;
                              } else {
                                __pyx_t_22 = __pyx_t_21;
                              }
                              __pyx_v_c1 = __pyx_t_22;
+7821:                 c2 = min(<int> (<float> destination_array[i, j, 1] * c4 +
                              __pyx_t_22 = 0xFF;
                              __pyx_t_17 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_19 = 1;
/* … */
                              __pyx_t_21 = ((int)((((float)(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_destination_array.data + __pyx_t_17 * __pyx_v_destination_array.strides[0]) ) + __pyx_t_18 * __pyx_v_destination_array.strides[1]) ) + __pyx_t_19 * __pyx_v_destination_array.strides[2]) )))) * __pyx_v_c4) + ((__pyx_v_g[0]) * (((float)1.0) - __pyx_v_c4))));
+7822:                                 g[0] * (<float> 1.0 - c4)), 255)
                              if (((__pyx_t_22 < __pyx_t_21) != 0)) {
                                __pyx_t_20 = __pyx_t_22;
                              } else {
                                __pyx_t_20 = __pyx_t_21;
                              }
                              __pyx_v_c2 = __pyx_t_20;
+7823:                 c3 = min(<int> (<float> destination_array[i, j, 2] * c4 +
                              __pyx_t_20 = 0xFF;
                              __pyx_t_19 = __pyx_v_i;
                              __pyx_t_18 = __pyx_v_j;
                              __pyx_t_17 = 2;
/* … */
                              __pyx_t_21 = ((int)((((float)(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_destination_array.data + __pyx_t_19 * __pyx_v_destination_array.strides[0]) ) + __pyx_t_18 * __pyx_v_destination_array.strides[1]) ) + __pyx_t_17 * __pyx_v_destination_array.strides[2]) )))) * __pyx_v_c4) + ((__pyx_v_b[0]) * (((float)1.0) - __pyx_v_c4))));
+7824:                                 b[0] * (<float> 1.0 - c4)), 255)
                              if (((__pyx_t_20 < __pyx_t_21) != 0)) {
                                __pyx_t_22 = __pyx_t_20;
                              } else {
                                __pyx_t_22 = __pyx_t_21;
                              }
                              __pyx_v_c3 = __pyx_t_22;
+7825:                 if c1 < 0:
                              __pyx_t_23 = ((__pyx_v_c1 < 0) != 0);
                              if (__pyx_t_23) {
/* … */
                              }
+7826:                     c1 = 0
                                __pyx_v_c1 = 0;
+7827:                 if c2 < 0:
                              __pyx_t_23 = ((__pyx_v_c2 < 0) != 0);
                              if (__pyx_t_23) {
/* … */
                              }
+7828:                     c2 = 0
                                __pyx_v_c2 = 0;
+7829:                 if c3 < 0:
                              __pyx_t_23 = ((__pyx_v_c3 < 0) != 0);
                              if (__pyx_t_23) {
/* … */
                              }
+7830:                     c3 = 0
                                __pyx_v_c3 = 0;
+7831:                 final_array[j, i, 0] = c1
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = __pyx_v_i;
                              __pyx_t_19 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_final_array.data + __pyx_t_17 * __pyx_v_final_array.strides[0]) ) + __pyx_t_18 * __pyx_v_final_array.strides[1]) )) + __pyx_t_19)) )) = __pyx_v_c1;
+7832:                 final_array[j, i, 1] = c2
                              __pyx_t_19 = __pyx_v_j;
                              __pyx_t_18 = __pyx_v_i;
                              __pyx_t_17 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_final_array.data + __pyx_t_19 * __pyx_v_final_array.strides[0]) ) + __pyx_t_18 * __pyx_v_final_array.strides[1]) )) + __pyx_t_17)) )) = __pyx_v_c2;
+7833:                 final_array[j, i, 2] = c3
                              __pyx_t_17 = __pyx_v_j;
                              __pyx_t_18 = __pyx_v_i;
                              __pyx_t_19 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_final_array.data + __pyx_t_17 * __pyx_v_final_array.strides[0]) ) + __pyx_t_18 * __pyx_v_final_array.strides[1]) )) + __pyx_t_19)) )) = __pyx_v_c3;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 7834: 
+7835:     return pygame.image.frombuffer(final_array, (w, h), 'RGB').convert()
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_pygame); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_image); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_final_array, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_10 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_24 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_24)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_24);
  __pyx_t_25 = PyTuple_New(2); if (unlikely(!__pyx_t_25)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_25);
  __Pyx_GIVEREF(__pyx_t_10);
  PyTuple_SET_ITEM(__pyx_t_25, 0, __pyx_t_10);
  __Pyx_GIVEREF(__pyx_t_24);
  PyTuple_SET_ITEM(__pyx_t_25, 1, __pyx_t_24);
  __pyx_t_10 = 0;
  __pyx_t_24 = 0;
  __pyx_t_24 = NULL;
  __pyx_t_8 = 0;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_24 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_24)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_24);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
      __pyx_t_8 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[4] = {__pyx_t_24, __pyx_t_4, __pyx_t_25, __pyx_n_s_RGB};
    __pyx_t_9 = __Pyx_PyFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_8, 3+__pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7835, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[4] = {__pyx_t_24, __pyx_t_4, __pyx_t_25, __pyx_n_s_RGB};
    __pyx_t_9 = __Pyx_PyCFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_8, 3+__pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7835, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0;
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0;
  } else
  #endif
  {
    __pyx_t_10 = PyTuple_New(3+__pyx_t_8); if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 7835, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    if (__pyx_t_24) {
      __Pyx_GIVEREF(__pyx_t_24); PyTuple_SET_ITEM(__pyx_t_10, 0, __pyx_t_24); __pyx_t_24 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_10, 0+__pyx_t_8, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_25);
    PyTuple_SET_ITEM(__pyx_t_10, 1+__pyx_t_8, __pyx_t_25);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_10, 2+__pyx_t_8, __pyx_n_s_RGB);
    __pyx_t_4 = 0;
    __pyx_t_25 = 0;
    __pyx_t_9 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_t_10, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 7835, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  }
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_n_s_convert); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_9)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_9);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
    }
  }
  __pyx_t_5 = (__pyx_t_9) ? __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_t_9) : __Pyx_PyObject_CallNoArg(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
  if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7835, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_r = __pyx_t_5;
  __pyx_t_5 = 0;
  goto __pyx_L0;
 7836: 
 7837: 
 7838: @cython.boundscheck(False)
 7839: @cython.wraparound(False)
 7840: @cython.nonecheck(False)
 7841: @cython.cdivision(True)
+7842: cdef inline void dirt_lens_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_dirt_lens_c(PyObject *__pyx_v_source_, PyObject *__pyx_v_lens_model_, int __pyx_v_flag_, struct __pyx_opt_args_12PygameShader_6shader_dirt_lens_c *__pyx_optional_args) {
  float __pyx_v_light_ = ((float)0.0);
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dirt_lens_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_light_ = __pyx_optional_args->light_;
    }
  }
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_WriteUnraisable("PygameShader.shader.dirt_lens_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_dirt_lens_c {
  int __pyx_n;
  float light_;
};
 7843:         object source_,
 7844:         object lens_model_,
 7845:         int flag_,
 7846:         float light_=0.0):
 7847: 
+7848:     if light_!=0.0:
  __pyx_t_1 = ((__pyx_v_light_ != 0.0) != 0);
  if (__pyx_t_1) {
/* … */
  }
+7849:         brightness(lens_model_, light_)
    __pyx_f_12PygameShader_6shader_brightness(__pyx_v_lens_model_, __pyx_v_light_, 0);
+7850:     source_.blit(lens_model_, (0, 0), special_flags=flag_)
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_source_, __pyx_n_s_blit); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF(__pyx_v_lens_model_);
  __Pyx_GIVEREF(__pyx_v_lens_model_);
  PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_v_lens_model_);
  __Pyx_INCREF(__pyx_tuple__12);
  __Pyx_GIVEREF(__pyx_tuple__12);
  PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_tuple__12);
  __pyx_t_4 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyInt_From_int(__pyx_v_flag_); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_special_flags, __pyx_t_5) < 0) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_t_3, __pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 7850, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
 7851: 
 7852: 
 7853: # TODO DITHERING WITH KERNEL INSTEAD
 7854: @cython.boundscheck(False)
 7855: @cython.wraparound(False)
 7856: @cython.nonecheck(False)
 7857: @cython.cdivision(True)
+7858: cdef object dithering_c(float [:, :, :] rgb_array_, int factor_):
static PyObject *__pyx_f_12PygameShader_6shader_dithering_c(__Pyx_memviewslice __pyx_v_rgb_array_, int __pyx_v_factor_) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  float __pyx_v_new_red;
  float __pyx_v_new_green;
  float __pyx_v_new_blue;
  float __pyx_v_quantization_error_red;
  float __pyx_v_quantization_error_green;
  float __pyx_v_quantization_error_blue;
  float __pyx_v_oldr;
  float __pyx_v_oldg;
  float __pyx_v_oldb;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_XDECREF(__pyx_t_17);
  __Pyx_XDECREF(__pyx_t_18);
  __Pyx_XDECREF(__pyx_t_19);
  __Pyx_XDECREF(__pyx_t_20);
  __Pyx_XDECREF(__pyx_t_21);
  __Pyx_XDECREF(__pyx_t_22);
  __Pyx_AddTraceback("PygameShader.shader.dithering_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 7859: 
 7860:     """
 7861:     Dithering is used in computer graphics to create the illusion of "color depth" in images with
 7862:     a limited color palette - a technique also known as color quantization. In a dithered image,
 7863:     colors that are not available in the palette are approximated by a diffusion of colored pixels
 7864:     from within the available palette. The human eye perceives the diffusion as a mixture of 
 7865:     the colors within it (see color vision). Dithered images, particularly those with relatively
 7866:     few colors, can often be distinguished by a characteristic graininess or speckled appearance.
 7867:     
 7868:     factor_ represent the color number per RGB channel, values must be (2, 3, 4 .. etc)
 7869:     and 2 means two colors per channels (2x2x2 = total 8 colors)
 7870:     
 7871:     
 7872:     :param rgb_array_: pygame.Surface compatible 24-32 bit
 7873:     :param factor_: integer; color per channel; must be > 1. 
 7874:     A value of 2 means a total of 8 colors
 7875:     :return: pygame surface 24-32 bit    
 7876:     """
 7877: 
 7878:     cdef Py_ssize_t w, h
+7879:     w = <object> rgb_array_.shape[ 0 ] - 1
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7879, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_SubtractObjC(__pyx_t_1, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7879, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_3 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 7879, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_w = __pyx_t_3;
+7880:     h = <object> rgb_array_.shape[ 1 ] - 1
  __pyx_t_2 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[1])); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7880, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_1 = __Pyx_PyInt_SubtractObjC(__pyx_t_2, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7880, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_3 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_3 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 7880, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_h = __pyx_t_3;
 7881: 
 7882:     cdef:
+7883:         int x=0, y=0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 7884:         float new_red, new_green, new_blue
 7885:         float quantization_error_red, quantization_error_green, quantization_error_blue
 7886:         float oldr, oldg, oldb
 7887: 
+7888:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 7889: 
+7890:         for y in prange(1, h, schedule='static', num_threads=THREADS, chunksize=2**8):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_new_blue) lastprivate(__pyx_v_new_green) lastprivate(__pyx_v_new_red) lastprivate(__pyx_v_oldb) lastprivate(__pyx_v_oldg) lastprivate(__pyx_v_oldr) lastprivate(__pyx_v_quantization_error_blue) lastprivate(__pyx_v_quantization_error_green) lastprivate(__pyx_v_quantization_error_red) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y)            __pyx_t_6 = __Pyx_pow_long(2, 8);
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_new_blue) lastprivate(__pyx_v_new_green) lastprivate(__pyx_v_new_red) lastprivate(__pyx_v_oldb) lastprivate(__pyx_v_oldg) lastprivate(__pyx_v_oldr) lastprivate(__pyx_v_quantization_error_blue) lastprivate(__pyx_v_quantization_error_green) lastprivate(__pyx_v_quantization_error_red) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static, __pyx_t_6) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_5; __pyx_t_4++){
                        {
                            __pyx_v_y = (int)(1 + 1 * __pyx_t_4);
                            /* Initialize private variables to invalid values */
                            __pyx_v_new_blue = ((float)__PYX_NAN());
                            __pyx_v_new_green = ((float)__PYX_NAN());
                            __pyx_v_new_red = ((float)__PYX_NAN());
                            __pyx_v_oldb = ((float)__PYX_NAN());
                            __pyx_v_oldg = ((float)__PYX_NAN());
                            __pyx_v_oldr = ((float)__PYX_NAN());
                            __pyx_v_quantization_error_blue = ((float)__PYX_NAN());
                            __pyx_v_quantization_error_green = ((float)__PYX_NAN());
                            __pyx_v_quantization_error_red = ((float)__PYX_NAN());
                            __pyx_v_x = ((int)0xbad0bad0);
 7891: 
+7892:             for x in range(1, w):
                            __pyx_t_7 = __pyx_v_w;
                            __pyx_t_8 = __pyx_t_7;
                            for (__pyx_t_9 = 1; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 7893: 
+7894:                 oldr = rgb_array_[x, y, 0]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 0;
                              __pyx_v_oldr = (*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
+7895:                 oldg = rgb_array_[x, y, 1]
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 1;
                              __pyx_v_oldg = (*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )));
+7896:                 oldb = rgb_array_[x, y, 2]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 2;
                              __pyx_v_oldb = (*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
 7897: 
+7898:                 new_red   = <float>round_c(oldr * (factor_ - 1)) / (factor_ - 1)
                              __pyx_v_new_red = (((float)round((__pyx_v_oldr * (__pyx_v_factor_ - 1)))) / (__pyx_v_factor_ - 1));
+7899:                 new_green = <float>round_c(oldg * (factor_ - 1)) / (factor_ - 1)
                              __pyx_v_new_green = (((float)round((__pyx_v_oldg * (__pyx_v_factor_ - 1)))) / (__pyx_v_factor_ - 1));
+7900:                 new_blue  = <float>round_c(oldb * (factor_ - 1)) / (factor_ - 1)
                              __pyx_v_new_blue = (((float)round((__pyx_v_oldb * (__pyx_v_factor_ - 1)))) / (__pyx_v_factor_ - 1));
 7901: 
+7902:                 rgb_array_[x, y, 0] = new_red
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 0;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_red;
+7903:                 rgb_array_[x, y, 1] = new_green
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 1;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_green;
+7904:                 rgb_array_[x, y, 2] = new_blue
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 2;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_blue;
 7905: 
+7906:                 quantization_error_red   = <float>(oldr - new_red)
                              __pyx_v_quantization_error_red = ((float)(__pyx_v_oldr - __pyx_v_new_red));
+7907:                 quantization_error_green = <float>(oldg - new_green)
                              __pyx_v_quantization_error_green = ((float)(__pyx_v_oldg - __pyx_v_new_green));
+7908:                 quantization_error_blue  = <float>(oldb - new_blue)
                              __pyx_v_quantization_error_blue = ((float)(__pyx_v_oldb - __pyx_v_new_blue));
 7909: 
+7910:                 rgb_array_[x + 1, y, 0] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C1));
+7911:                     rgb_array_[x + 1, y, 0] + quantization_error_red * C1
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 0;
+7912:                 rgb_array_[x + 1, y, 1] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C1));
+7913:                     rgb_array_[x + 1, y, 1] + quantization_error_green * C1
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 1;
+7914:                 rgb_array_[x + 1, y, 2] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C1));
+7915:                     rgb_array_[x + 1, y, 2] + quantization_error_blue * C1
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 2;
 7916: 
+7917:                 rgb_array_[x - 1, y + 1, 0] = \
                              __pyx_t_15 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 0;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C2));
+7918:                     rgb_array_[x - 1, y + 1, 0] + quantization_error_red * C2
                              __pyx_t_12 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 0;
+7919:                 rgb_array_[x - 1, y + 1, 1] = \
                              __pyx_t_13 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 1;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C2));
+7920:                     rgb_array_[x - 1, y + 1, 1] + quantization_error_green * C2
                              __pyx_t_10 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 1;
+7921:                 rgb_array_[x - 1, y + 1, 2] = \
                              __pyx_t_15 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 2;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C2));
+7922:                     rgb_array_[x - 1, y + 1, 2] + quantization_error_blue * C2
                              __pyx_t_12 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 2;
 7923: 
+7924:                 rgb_array_[x, y + 1, 0] = \
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 0;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C3));
+7925:                     rgb_array_[x, y + 1, 0] + quantization_error_red * C3
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 0;
+7926:                 rgb_array_[x, y + 1, 1] = \
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 1;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C3));
+7927:                     rgb_array_[x, y + 1, 1] + quantization_error_green * C3
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 1;
+7928:                 rgb_array_[x, y + 1, 2] = \
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 2;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C3));
+7929:                     rgb_array_[x, y + 1, 2] + quantization_error_blue * C3
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 2;
 7930: 
+7931:                 rgb_array_[x + 1, y + 1, 0] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 0;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C4));
+7932:                     rgb_array_[x + 1, y + 1, 0] + quantization_error_red * C4
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 0;
+7933:                 rgb_array_[x + 1, y + 1, 1] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 1;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C4));
+7934:                     rgb_array_[x + 1, y + 1, 1] + quantization_error_green * C4
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 1;
+7935:                 rgb_array_[x + 1, y + 1, 2] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 2;
                              *((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((*((float *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C4));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+7936:                     rgb_array_[x + 1, y + 1, 2] + quantization_error_blue * C4
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 2;
 7937: 
+7938:     return make_surface(numpy.multiply(asarray(rgb_array_), 255.0).astype(dtype=uint8)).convert()
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_16, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_GetModuleGlobalName(__pyx_t_18, __pyx_n_s_numpy); if (unlikely(!__pyx_t_18)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_18);
  __pyx_t_19 = __Pyx_PyObject_GetAttrStr(__pyx_t_18, __pyx_n_s_multiply); if (unlikely(!__pyx_t_19)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_19);
  __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_20, __pyx_n_s_asarray); if (unlikely(!__pyx_t_20)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_20);
  __pyx_t_21 = __pyx_memoryview_fromslice(__pyx_v_rgb_array_, 3, (PyObject *(*)(char *)) __pyx_memview_get_float, (int (*)(char *, PyObject *)) __pyx_memview_set_float, 0);; if (unlikely(!__pyx_t_21)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_21);
  __pyx_t_22 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_20))) {
    __pyx_t_22 = PyMethod_GET_SELF(__pyx_t_20);
    if (likely(__pyx_t_22)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_20);
      __Pyx_INCREF(__pyx_t_22);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_20, function);
    }
  }
  __pyx_t_18 = (__pyx_t_22) ? __Pyx_PyObject_Call2Args(__pyx_t_20, __pyx_t_22, __pyx_t_21) : __Pyx_PyObject_CallOneArg(__pyx_t_20, __pyx_t_21);
  __Pyx_XDECREF(__pyx_t_22); __pyx_t_22 = 0;
  __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
  if (unlikely(!__pyx_t_18)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_18);
  __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
  __pyx_t_20 = NULL;
  __pyx_t_9 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_19))) {
    __pyx_t_20 = PyMethod_GET_SELF(__pyx_t_19);
    if (likely(__pyx_t_20)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_19);
      __Pyx_INCREF(__pyx_t_20);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_19, function);
      __pyx_t_9 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_19)) {
    PyObject *__pyx_temp[3] = {__pyx_t_20, __pyx_t_18, __pyx_float_255_0};
    __pyx_t_17 = __Pyx_PyFunction_FastCall(__pyx_t_19, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 7938, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
    __Pyx_GOTREF(__pyx_t_17);
    __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_19)) {
    PyObject *__pyx_temp[3] = {__pyx_t_20, __pyx_t_18, __pyx_float_255_0};
    __pyx_t_17 = __Pyx_PyCFunction_FastCall(__pyx_t_19, __pyx_temp+1-__pyx_t_9, 2+__pyx_t_9); if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 7938, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
    __Pyx_GOTREF(__pyx_t_17);
    __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
  } else
  #endif
  {
    __pyx_t_21 = PyTuple_New(2+__pyx_t_9); if (unlikely(!__pyx_t_21)) __PYX_ERR(1, 7938, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    if (__pyx_t_20) {
      __Pyx_GIVEREF(__pyx_t_20); PyTuple_SET_ITEM(__pyx_t_21, 0, __pyx_t_20); __pyx_t_20 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_18);
    PyTuple_SET_ITEM(__pyx_t_21, 0+__pyx_t_9, __pyx_t_18);
    __Pyx_INCREF(__pyx_float_255_0);
    __Pyx_GIVEREF(__pyx_float_255_0);
    PyTuple_SET_ITEM(__pyx_t_21, 1+__pyx_t_9, __pyx_float_255_0);
    __pyx_t_18 = 0;
    __pyx_t_17 = __Pyx_PyObject_Call(__pyx_t_19, __pyx_t_21, NULL); if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 7938, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_17);
    __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
  }
  __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
  __pyx_t_19 = __Pyx_PyObject_GetAttrStr(__pyx_t_17, __pyx_n_s_astype); if (unlikely(!__pyx_t_19)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_19);
  __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
  __pyx_t_17 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_17)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_17);
  __Pyx_GetModuleGlobalName(__pyx_t_21, __pyx_n_s_uint8); if (unlikely(!__pyx_t_21)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_21);
  if (PyDict_SetItem(__pyx_t_17, __pyx_n_s_dtype, __pyx_t_21) < 0) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
  __pyx_t_21 = __Pyx_PyObject_Call(__pyx_t_19, __pyx_empty_tuple, __pyx_t_17); if (unlikely(!__pyx_t_21)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_21);
  __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
  __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
  __pyx_t_17 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_16))) {
    __pyx_t_17 = PyMethod_GET_SELF(__pyx_t_16);
    if (likely(__pyx_t_17)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
      __Pyx_INCREF(__pyx_t_17);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_16, function);
    }
  }
  __pyx_t_2 = (__pyx_t_17) ? __Pyx_PyObject_Call2Args(__pyx_t_16, __pyx_t_17, __pyx_t_21) : __Pyx_PyObject_CallOneArg(__pyx_t_16, __pyx_t_21);
  __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0;
  __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_convert); if (unlikely(!__pyx_t_16)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_16);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_16))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_16);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_16);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_16, function);
    }
  }
  __pyx_t_1 = (__pyx_t_2) ? __Pyx_PyObject_CallOneArg(__pyx_t_16, __pyx_t_2) : __Pyx_PyObject_CallNoArg(__pyx_t_16);
  __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7938, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;
 7939: 
 7940: 
 7941: 
 7942: @cython.boundscheck(False)
 7943: @cython.wraparound(False)
 7944: @cython.nonecheck(False)
 7945: @cython.cdivision(True)
+7946: cdef inline void dithering_int_c(unsigned char[:, :, :] rgb_array_, int factor_):
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_dithering_int_c(__Pyx_memviewslice __pyx_v_rgb_array_, int __pyx_v_factor_) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  unsigned char __pyx_v_new_red;
  unsigned char __pyx_v_new_green;
  unsigned char __pyx_v_new_blue;
  int __pyx_v_quantization_error_red;
  int __pyx_v_quantization_error_green;
  int __pyx_v_quantization_error_blue;
  unsigned char __pyx_v_oldr;
  unsigned char __pyx_v_oldg;
  unsigned char __pyx_v_oldb;
  float __pyx_v_c5;
  float __pyx_v_c6;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dithering_int_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_WriteUnraisable("PygameShader.shader.dithering_int_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
 7947: 
 7948: 
 7949:     cdef Py_ssize_t w, h
+7950:     w = <object> rgb_array_.shape[ 0 ] - 1
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7950, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyInt_SubtractObjC(__pyx_t_1, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7950, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = __Pyx_PyIndex_AsSsize_t(__pyx_t_2); if (unlikely((__pyx_t_3 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 7950, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_w = __pyx_t_3;
+7951:     h = <object> rgb_array_.shape[ 1 ] - 1
  __pyx_t_2 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[1])); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7951, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_1 = __Pyx_PyInt_SubtractObjC(__pyx_t_2, __pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 7951, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_3 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_3 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 7951, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_h = __pyx_t_3;
 7952: 
 7953:     cdef:
+7954:         int x=0, y=0
  __pyx_v_x = 0;
  __pyx_v_y = 0;
 7955:         unsigned char new_red, new_green, new_blue
 7956:         int quantization_error_red, quantization_error_green, quantization_error_blue
 7957:         unsigned char oldr, oldg, oldb
+7958:         float c5 = <float>255.0 / <float>(factor_ -1)
  __pyx_v_c5 = (((float)255.0) / ((float)(__pyx_v_factor_ - 1)));
+7959:         float c6 = <float>(factor_ -1) * ONE_255
  __pyx_v_c6 = (((float)(__pyx_v_factor_ - 1)) * 0.00392156862745098);
 7960: 
 7961: 
+7962:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 7963: 
+7964:         for y in prange(1, h, schedule='static', num_threads=THREADS, chunksize=2**8):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_new_blue) lastprivate(__pyx_v_new_green) lastprivate(__pyx_v_new_red) lastprivate(__pyx_v_oldb) lastprivate(__pyx_v_oldg) lastprivate(__pyx_v_oldr) lastprivate(__pyx_v_quantization_error_blue) lastprivate(__pyx_v_quantization_error_green) lastprivate(__pyx_v_quantization_error_red) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y)            __pyx_t_6 = __Pyx_pow_long(2, 8);
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_5 = (__pyx_t_3 - 1 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_5 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_new_blue) lastprivate(__pyx_v_new_green) lastprivate(__pyx_v_new_red) lastprivate(__pyx_v_oldb) lastprivate(__pyx_v_oldg) lastprivate(__pyx_v_oldr) lastprivate(__pyx_v_quantization_error_blue) lastprivate(__pyx_v_quantization_error_green) lastprivate(__pyx_v_quantization_error_red) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static, __pyx_t_6) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_4 = 0; __pyx_t_4 < __pyx_t_5; __pyx_t_4++){
                        {
                            __pyx_v_y = (int)(1 + 1 * __pyx_t_4);
                            /* Initialize private variables to invalid values */
                            __pyx_v_new_blue = ((unsigned char)'?');
                            __pyx_v_new_green = ((unsigned char)'?');
                            __pyx_v_new_red = ((unsigned char)'?');
                            __pyx_v_oldb = ((unsigned char)'?');
                            __pyx_v_oldg = ((unsigned char)'?');
                            __pyx_v_oldr = ((unsigned char)'?');
                            __pyx_v_quantization_error_blue = ((int)0xbad0bad0);
                            __pyx_v_quantization_error_green = ((int)0xbad0bad0);
                            __pyx_v_quantization_error_red = ((int)0xbad0bad0);
                            __pyx_v_x = ((int)0xbad0bad0);
 7965: 
+7966:             for x in range(1, w):
                            __pyx_t_7 = __pyx_v_w;
                            __pyx_t_8 = __pyx_t_7;
                            for (__pyx_t_9 = 1; __pyx_t_9 < __pyx_t_8; __pyx_t_9+=1) {
                              __pyx_v_x = __pyx_t_9;
 7967: 
+7968:                 oldr = rgb_array_[x, y, 0]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 0;
                              __pyx_v_oldr = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
+7969:                 oldg = rgb_array_[x, y, 1]
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 1;
                              __pyx_v_oldg = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )));
+7970:                 oldb = rgb_array_[x, y, 2]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 2;
                              __pyx_v_oldb = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )));
 7971: 
 7972: 
+7973:                 new_red = <unsigned int> (<int>nearbyint(c6 * oldr) * <int>c5)
                              __pyx_v_new_red = ((unsigned int)(((int)nearbyint((__pyx_v_c6 * __pyx_v_oldr))) * ((int)__pyx_v_c5)));
+7974:                 new_green = <unsigned int> (<int>nearbyint(c6 * oldg) * <int>c5)
                              __pyx_v_new_green = ((unsigned int)(((int)nearbyint((__pyx_v_c6 * __pyx_v_oldg))) * ((int)__pyx_v_c5)));
+7975:                 new_blue = <unsigned int> (<int>nearbyint(c6 * oldb) * <int>c5)
                              __pyx_v_new_blue = ((unsigned int)(((int)nearbyint((__pyx_v_c6 * __pyx_v_oldb))) * ((int)__pyx_v_c5)));
 7976: 
+7977:                 rgb_array_[x, y, 0] = new_red
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_red;
+7978:                 rgb_array_[x, y, 1] = new_green
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_green;
+7979:                 rgb_array_[x, y, 2] = new_blue
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) )) = __pyx_v_new_blue;
 7980: 
+7981:                 quantization_error_red   = int(oldr - new_red)
                              __pyx_v_quantization_error_red = (__pyx_v_oldr - __pyx_v_new_red);
+7982:                 quantization_error_green = int(oldg - new_green)
                              __pyx_v_quantization_error_green = (__pyx_v_oldg - __pyx_v_new_green);
+7983:                 quantization_error_blue  = int(oldb - new_blue)
                              __pyx_v_quantization_error_blue = (__pyx_v_oldb - __pyx_v_new_blue);
 7984: 
+7985:                 rgb_array_[x + 1, y, 0] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C1)));
+7986:                     <unsigned char>(rgb_array_[x + 1, y, 0] + quantization_error_red * C1)
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 0;
+7987:                 rgb_array_[x + 1, y, 1] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_13 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C1)));
+7988:                     <unsigned char>(rgb_array_[x + 1, y, 1] + quantization_error_green * C1)
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_10 = 1;
+7989:                 rgb_array_[x + 1, y, 2] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = __pyx_v_y;
                              __pyx_t_15 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C1)));
+7990:                     <unsigned char>(rgb_array_[x + 1, y, 2] + quantization_error_blue * C1)
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = __pyx_v_y;
                              __pyx_t_12 = 2;
 7991: 
+7992:                 rgb_array_[x - 1, y + 1, 0] = \
                              __pyx_t_15 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C2)));
+7993:                     <unsigned char>(rgb_array_[x - 1, y + 1, 0] + quantization_error_red * C2)
                              __pyx_t_12 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 0;
+7994:                 rgb_array_[x - 1, y + 1, 1] = \
                              __pyx_t_13 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C2)));
+7995:                     <unsigned char>(rgb_array_[x - 1, y + 1, 1] + quantization_error_green * C2)
                              __pyx_t_10 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 1;
+7996:                 rgb_array_[x - 1, y + 1, 2] = \
                              __pyx_t_15 = (__pyx_v_x - 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C2)));
+7997:                     <unsigned char>(rgb_array_[x - 1, y + 1, 2] + quantization_error_blue * C2)
                              __pyx_t_12 = (__pyx_v_x - 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 2;
 7998: 
+7999:                 rgb_array_[x, y + 1, 0] = \
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C3)));
+8000:                     <unsigned char>(rgb_array_[x, y + 1, 0] + quantization_error_red * C3)
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 0;
+8001:                 rgb_array_[x, y + 1, 1] = \
                              __pyx_t_15 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C3)));
+8002:                     <unsigned char>(rgb_array_[x, y + 1, 1] + quantization_error_green * C3)
                              __pyx_t_12 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 1;
+8003:                 rgb_array_[x, y + 1, 2] = \
                              __pyx_t_13 = __pyx_v_x;
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C3)));
+8004:                     <unsigned char>(rgb_array_[x, y + 1, 2] + quantization_error_blue * C3)
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 2;
 8005: 
+8006:                 rgb_array_[x + 1, y + 1, 0] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_red * __pyx_v_12PygameShader_6shader_C4)));
+8007:                     <unsigned char>(rgb_array_[x + 1, y + 1, 0] + quantization_error_red * C4)
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 0;
+8008:                 rgb_array_[x + 1, y + 1, 1] = \
                              __pyx_t_13 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_15 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_13 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_15 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_10 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_12 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_green * __pyx_v_12PygameShader_6shader_C4)));
+8009:                     <unsigned char>(rgb_array_[x + 1, y + 1, 1] + quantization_error_green * C4)
                              __pyx_t_10 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_12 = 1;
+8010:                 rgb_array_[x + 1, y + 1, 2] = \
                              __pyx_t_15 = (__pyx_v_x + 1);
                              __pyx_t_14 = (__pyx_v_y + 1);
                              __pyx_t_13 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_15 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_14 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_13 * __pyx_v_rgb_array_.strides[2]) )) = ((unsigned char)((*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_12 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_11 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array_.strides[2]) ))) + (__pyx_v_quantization_error_blue * __pyx_v_12PygameShader_6shader_C4)));
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
+8011:                     <unsigned char>(rgb_array_[x + 1, y + 1, 2] + quantization_error_blue * C4)
                              __pyx_t_12 = (__pyx_v_x + 1);
                              __pyx_t_11 = (__pyx_v_y + 1);
                              __pyx_t_10 = 2;
 8012: 
 8013: 
 8014: 
 8015: @cython.boundscheck(False)
 8016: @cython.wraparound(False)
 8017: @cython.nonecheck(False)
 8018: @cython.cdivision(True)
+8019: cdef inline void convert_27colors_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_convert_27colors_c(__Pyx_memviewslice __pyx_v_rgb_array) {
  Py_ssize_t __pyx_v_w;
  CYTHON_UNUSED Py_ssize_t __pyx_v_h;
  int __pyx_v_x;
  int __pyx_v_y;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_f;
  float __pyx_v_c1;
  CYTHON_UNUSED int __pyx_v_index;
  float __pyx_v_rr;
  float __pyx_v_gg;
  float __pyx_v_bb;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("convert_27colors_c", 0);
/* … */
  /* function exit code */
  __Pyx_RefNannyFinishContext();
}
 8020:         unsigned char [:, :, :] rgb_array):
 8021: 
 8022:     """
 8023:     THIS ALGORITHM CONVERT AN IMAGE USING 27 COLORS ONLY
 8024:     
 8025:     :param rgb_array: numpy.ndarray; containing the pixels RGB. Array shape (w, h, 3)  
 8026:     :return: void 
 8027:     """
 8028:     cdef Py_ssize_t w, h
+8029:     w, h = rgb_array.shape[:2]
  __pyx_t_1 = __pyx_v_rgb_array.shape;
  __pyx_t_2 = (__pyx_t_1[0]);
  __pyx_t_3 = (__pyx_t_1[1]);
  __pyx_v_w = __pyx_t_2;
  __pyx_v_h = __pyx_t_3;
 8030: 
 8031:     cdef:
+8032:         int x=0
  __pyx_v_x = 0;
+8033:         int y=0
  __pyx_v_y = 0;
 8034:         unsigned char *r
 8035:         unsigned char *g
 8036:         unsigned char *b
+8037:         float f = <float> 255.0 / <float> 2
  __pyx_v_f = (((float)255.0) / ((float)2));
+8038:         float c1 = <float>2 / <float>255.0
  __pyx_v_c1 = (((float)2) / ((float)255.0));
+8039:         int index = 0
  __pyx_v_index = 0;
 8040:         float rr, gg, bb
 8041: 
+8042:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+8043:         for y in prange(h, schedule='static', num_threads=THREADS):
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static)
/* … */
        __pyx_t_3 = __pyx_v_h;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_3 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_bb) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gg) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rr) lastprivate(__pyx_v_x) firstprivate(__pyx_v_y) lastprivate(__pyx_v_y) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_2 = 0; __pyx_t_2 < __pyx_t_4; __pyx_t_2++){
                        {
                            __pyx_v_y = (int)(0 + 1 * __pyx_t_2);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_bb = ((float)__PYX_NAN());
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_gg = ((float)__PYX_NAN());
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_rr = ((float)__PYX_NAN());
                            __pyx_v_x = ((int)0xbad0bad0);
+8044:             for x in range(0, w):
                            __pyx_t_5 = __pyx_v_w;
                            __pyx_t_6 = __pyx_t_5;
                            for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_6; __pyx_t_7+=1) {
                              __pyx_v_x = __pyx_t_7;
 8045: 
+8046:                 r = &rgb_array[x, y, 0]
                              __pyx_t_8 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_10 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
+8047:                 g = &rgb_array[x, y, 1]
                              __pyx_t_10 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_8 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_10 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_8 * __pyx_v_rgb_array.strides[2]) ))));
+8048:                 b = &rgb_array[x, y, 2]
                              __pyx_t_8 = __pyx_v_x;
                              __pyx_t_9 = __pyx_v_y;
                              __pyx_t_10 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_8 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[2]) ))));
 8049: 
+8050:                 rr = <float>round_c(c1 * <float> r[ 0 ] ) * f
                              __pyx_v_rr = (((float)round((__pyx_v_c1 * ((float)(__pyx_v_r[0]))))) * __pyx_v_f);
+8051:                 gg = <float>round_c(c1 * <float> g[ 0 ] ) * f
                              __pyx_v_gg = (((float)round((__pyx_v_c1 * ((float)(__pyx_v_g[0]))))) * __pyx_v_f);
+8052:                 bb = <float>round_c(c1 * <float> b[ 0 ] ) * f
                              __pyx_v_bb = (((float)round((__pyx_v_c1 * ((float)(__pyx_v_b[0]))))) * __pyx_v_f);
 8053: 
+8054:                 r[ 0 ] = <unsigned char>rr
                              (__pyx_v_r[0]) = ((unsigned char)__pyx_v_rr);
+8055:                 g[ 0 ] = <unsigned char>gg
                              (__pyx_v_g[0]) = ((unsigned char)__pyx_v_gg);
+8056:                 b[ 0 ] = <unsigned char>bb
                              (__pyx_v_b[0]) = ((unsigned char)__pyx_v_bb);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 8057: 
 8058: 
 8059: @cython.binding(False)
 8060: @cython.boundscheck(False)
 8061: @cython.wraparound(False)
 8062: @cython.nonecheck(False)
 8063: @cython.cdivision(True)
+8064: cdef object spectrum_c(int width, int height, float gamma=1.0):
static PyObject *__pyx_f_12PygameShader_6shader_spectrum_c(int __pyx_v_width, int __pyx_v_height, struct __pyx_opt_args_12PygameShader_6shader_spectrum_c *__pyx_optional_args) {
  float __pyx_v_gamma = ((float)1.0);
  int __pyx_v_i;
  int __pyx_v_k;
  struct rgb_color_int __pyx_v_rgb_c;
  __Pyx_memviewslice __pyx_v_spectrum_array = { 0, 0, { 0 }, { 0 }, { 0 } };
  PyObject *__pyx_v_surface = 0;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("spectrum_c", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_gamma = __pyx_optional_args->gamma;
    }
  }
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __PYX_XDEC_MEMVIEW(&__pyx_t_7, 1);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_AddTraceback("PygameShader.shader.spectrum_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_spectrum_array, 1);
  __Pyx_XDECREF(__pyx_v_surface);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* … */
struct __pyx_opt_args_12PygameShader_6shader_spectrum_c {
  int __pyx_n;
  float gamma;
};
 8065: 
 8066:     """
 8067:     CREATE A PYGAME SURFACE DISPLAYING THE LIGHT SPECTRUM 380-750 nm
 8068:     
 8069:     Color   Wavelength(nm) Frequency(THz)
 8070:     Red     620-750        484-400
 8071:     Orange  590-620        508-484
 8072:     Yellow  570-590        526-508
 8073:     Green   495-570        606-526
 8074:     Blue    450-495        668-606
 8075:     Violet  380-450        789-668
 8076:     
 8077:     :param width: integer; width of the image
 8078:     :param height: integer; height of the image
 8079:     :param gamma: float; gamma value 
 8080:     :return: Return a pygame surface 24-bit (width, height) converted for fast 
 8081:     blit 
 8082:     
 8083:     """
 8084: 
 8085:     cdef:
 8086:         int i, j, k
 8087:         rgb_color_int rgb_c
 8088:         unsigned char [:, :, :] spectrum_array =\
+8089:             numpy.empty((370, 1, 3), numpy.uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_empty); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_uint8); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  __pyx_t_5 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
      __pyx_t_5 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_tuple__26, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8089, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_3)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_tuple__26, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyCFunction_FastCall(__pyx_t_3, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8089, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else
  #endif
  {
    __pyx_t_6 = PyTuple_New(2+__pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 8089, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__pyx_t_2) {
      __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_2); __pyx_t_2 = NULL;
    }
    __Pyx_INCREF(__pyx_tuple__26);
    __Pyx_GIVEREF(__pyx_tuple__26);
    PyTuple_SET_ITEM(__pyx_t_6, 0+__pyx_t_5, __pyx_tuple__26);
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_6, 1+__pyx_t_5, __pyx_t_4);
    __pyx_t_4 = 0;
    __pyx_t_1 = __Pyx_PyObject_Call(__pyx_t_3, __pyx_t_6, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8089, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  }
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_7 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_7.memview)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_spectrum_array = __pyx_t_7;
  __pyx_t_7.memview = NULL;
  __pyx_t_7.data = NULL;
/* … */
  __pyx_tuple__26 = PyTuple_Pack(3, __pyx_int_370, __pyx_int_1, __pyx_int_3); if (unlikely(!__pyx_tuple__26)) __PYX_ERR(1, 8089, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_tuple__26);
  __Pyx_GIVEREF(__pyx_tuple__26);
 8090:         object surface
 8091: 
+8092:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+8093:         for i in prange(380, 750, schedule='static', num_threads=THREADS):
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x2EE - 0x17C + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_k) lastprivate(__pyx_v_rgb_c) schedule(static)
/* … */
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_9 = (0x2EE - 0x17C + 1 - 1/abs(1)) / 1;
            if (__pyx_t_9 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_k) lastprivate(__pyx_v_rgb_c) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_9; __pyx_t_8++){
                        {
                            __pyx_v_i = (int)(0x17C + 1 * __pyx_t_8);
                            /* Initialize private variables to invalid values */
                            __pyx_v_k = ((int)0xbad0bad0);
+8094:             rgb_c = wavelength_to_rgb(i, gamma)
                            __pyx_v_rgb_c = wavelength_to_rgb(__pyx_v_i, __pyx_v_gamma);
+8095:             k = i - 380
                            __pyx_v_k = (__pyx_v_i - 0x17C);
+8096:             spectrum_array[ k, 0, 0 ] = rgb_c.r
                            __pyx_t_5 = __pyx_v_rgb_c.r;
                            __pyx_t_10 = __pyx_v_k;
                            __pyx_t_11 = 0;
                            __pyx_t_12 = 0;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_10 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_12 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
+8097:             spectrum_array[ k, 0, 1 ] = rgb_c.g
                            __pyx_t_5 = __pyx_v_rgb_c.g;
                            __pyx_t_12 = __pyx_v_k;
                            __pyx_t_11 = 0;
                            __pyx_t_10 = 1;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_12 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_10 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
+8098:             spectrum_array[ k, 0, 2 ] = rgb_c.b
                            __pyx_t_5 = __pyx_v_rgb_c.b;
                            __pyx_t_10 = __pyx_v_k;
                            __pyx_t_11 = 0;
                            __pyx_t_12 = 2;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_10 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_12 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
+8099:             spectrum_array[ k, 1, 0 ] = rgb_c.r
                            __pyx_t_5 = __pyx_v_rgb_c.r;
                            __pyx_t_12 = __pyx_v_k;
                            __pyx_t_11 = 1;
                            __pyx_t_10 = 0;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_12 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_10 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
+8100:             spectrum_array[ k, 1, 1 ] = rgb_c.g
                            __pyx_t_5 = __pyx_v_rgb_c.g;
                            __pyx_t_10 = __pyx_v_k;
                            __pyx_t_11 = 1;
                            __pyx_t_12 = 1;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_10 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_12 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
+8101:             spectrum_array[ k, 1, 2 ] = rgb_c.b
                            __pyx_t_5 = __pyx_v_rgb_c.b;
                            __pyx_t_12 = __pyx_v_k;
                            __pyx_t_11 = 1;
                            __pyx_t_10 = 2;
                            *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_spectrum_array.data + __pyx_t_12 * __pyx_v_spectrum_array.strides[0]) ) + __pyx_t_11 * __pyx_v_spectrum_array.strides[1]) ) + __pyx_t_10 * __pyx_v_spectrum_array.strides[2]) )) = __pyx_t_5;
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 8102: 
+8103:     surface = make_surface(asarray(spectrum_array))
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_make_surface); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_asarray); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __pyx_memoryview_fromslice(__pyx_v_spectrum_array, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_13 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_13 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_13)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_13);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
    }
  }
  __pyx_t_6 = (__pyx_t_13) ? __Pyx_PyObject_Call2Args(__pyx_t_4, __pyx_t_13, __pyx_t_2) : __Pyx_PyObject_CallOneArg(__pyx_t_4, __pyx_t_2);
  __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 8103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_4, __pyx_t_6) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_6);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_surface = __pyx_t_1;
  __pyx_t_1 = 0;
+8104:     surface = scale(surface, (width, height)).convert()
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_scale); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_4 = __Pyx_PyInt_From_int(__pyx_v_width); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyInt_From_int(__pyx_v_height); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_13 = PyTuple_New(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_13);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_13, 0, __pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_13, 1, __pyx_t_2);
  __pyx_t_4 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = NULL;
  __pyx_t_5 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_2)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
      __pyx_t_5 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_v_surface, __pyx_t_13};
    __pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8104, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_6)) {
    PyObject *__pyx_temp[3] = {__pyx_t_2, __pyx_v_surface, __pyx_t_13};
    __pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_6, __pyx_temp+1-__pyx_t_5, 2+__pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8104, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
  } else
  #endif
  {
    __pyx_t_4 = PyTuple_New(2+__pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8104, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (__pyx_t_2) {
      __Pyx_GIVEREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_2); __pyx_t_2 = NULL;
    }
    __Pyx_INCREF(__pyx_v_surface);
    __Pyx_GIVEREF(__pyx_v_surface);
    PyTuple_SET_ITEM(__pyx_t_4, 0+__pyx_t_5, __pyx_v_surface);
    __Pyx_GIVEREF(__pyx_t_13);
    PyTuple_SET_ITEM(__pyx_t_4, 1+__pyx_t_5, __pyx_t_13);
    __pyx_t_13 = 0;
    __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_6, __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8104, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_n_s_convert); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = NULL;
  if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_6);
    if (likely(__pyx_t_3)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_6, function);
    }
  }
  __pyx_t_1 = (__pyx_t_3) ? __Pyx_PyObject_CallOneArg(__pyx_t_6, __pyx_t_3) : __Pyx_PyObject_CallNoArg(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8104, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF_SET(__pyx_v_surface, __pyx_t_1);
  __pyx_t_1 = 0;
+8105:     return surface
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_surface);
  __pyx_r = __pyx_v_surface;
  goto __pyx_L0;
 8106: 
 8107: 
 8108: 
 8109: 
 8110: @cython.binding(False)
 8111: @cython.boundscheck(False)
 8112: @cython.wraparound(False)
 8113: @cython.nonecheck(False)
 8114: @cython.cdivision(True)
+8115: cdef inline void palette_change_c(
static CYTHON_INLINE void __pyx_f_12PygameShader_6shader_palette_change_c(__Pyx_memviewslice __pyx_v_rgb_array, __Pyx_memviewslice __pyx_v_palette_) {
  int __pyx_v_i;
  int __pyx_v_j;
  CYTHON_UNUSED Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  struct rgb __pyx_v_rgb_;
  struct rgb __pyx_v_rgb_c;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  Py_ssize_t __pyx_v_p_length;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("palette_change_c", 0);
/* … */
  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_WriteUnraisable("PygameShader.shader.palette_change_c", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}
 8116:         unsigned char [:, :, :] rgb_array,
 8117:         float [:, :] palette_):
 8118: 
 8119: 
 8120:     cdef:
 8121:         int i, j
+8122:         Py_ssize_t w = <object>rgb_array.shape[0]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8122, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8122, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_w = __pyx_t_2;
+8123:         Py_ssize_t h = <object>rgb_array.shape[1]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array.shape[1])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8123, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_h = __pyx_t_2;
 8124:         rgb rgb_
 8125:         rgb rgb_c
 8126:         unsigned char *r
 8127:         unsigned char *g
 8128:         unsigned char *b
+8129:         Py_ssize_t p_length = <object>palette_.shape[0]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_palette_.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8129, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8129, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_p_length = __pyx_t_2;
 8130: 
+8131:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
+8132:         for i in prange(w, schedule='static', num_threads=THREADS, chunksize=w * h):
        __pyx_t_2 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_)            __pyx_t_5 = (__pyx_v_w * __pyx_v_h);
/* … */
        __pyx_t_2 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_4 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_4 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) firstprivate(__pyx_v_i) lastprivate(__pyx_v_i) lastprivate(__pyx_v_j) lastprivate(__pyx_v_r) lastprivate(__pyx_v_rgb_) schedule(static, __pyx_t_5) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_4; __pyx_t_3++){
                        {
                            __pyx_v_i = (int)(0 + 1 * __pyx_t_3);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_j = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
+8133:             for j in range(h):
                            __pyx_t_6 = __pyx_v_h;
                            __pyx_t_7 = __pyx_t_6;
                            for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_7; __pyx_t_8+=1) {
                              __pyx_v_j = __pyx_t_8;
+8134:                 r = &rgb_array[i, j, 0]
                              __pyx_t_9 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_11 = 0;
                              __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_9 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_array.strides[2]) ))));
+8135:                 g = &rgb_array[i, j, 1]
                              __pyx_t_11 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_9 = 1;
                              __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_11 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_9 * __pyx_v_rgb_array.strides[2]) ))));
+8136:                 b = &rgb_array[i, j, 2]
                              __pyx_t_9 = __pyx_v_i;
                              __pyx_t_10 = __pyx_v_j;
                              __pyx_t_11 = 2;
                              __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array.data + __pyx_t_9 * __pyx_v_rgb_array.strides[0]) ) + __pyx_t_10 * __pyx_v_rgb_array.strides[1]) ) + __pyx_t_11 * __pyx_v_rgb_array.strides[2]) ))));
 8137: 
+8138:                 rgb_c.r = r[0]
                              __pyx_v_rgb_c.r = (__pyx_v_r[0]);
+8139:                 rgb_c.g = g[0]
                              __pyx_v_rgb_c.g = (__pyx_v_g[0]);
+8140:                 rgb_c.b = b[0]
                              __pyx_v_rgb_c.b = (__pyx_v_b[0]);
 8141: 
+8142:                 rgb_ = close_color(rgb_c, palette_, p_length)
                              __pyx_v_rgb_ = __pyx_f_12PygameShader_4misc_close_color(__pyx_v_rgb_c, __pyx_v_palette_, __pyx_v_p_length);
 8143: 
+8144:                 r[0] = <unsigned char>rgb_.r
                              (__pyx_v_r[0]) = ((unsigned char)__pyx_v_rgb_.r);
+8145:                 g[0] = <unsigned char>rgb_.g
                              (__pyx_v_g[0]) = ((unsigned char)__pyx_v_rgb_.g);
+8146:                 b[0] = <unsigned char>rgb_.b
                              (__pyx_v_b[0]) = ((unsigned char)__pyx_v_rgb_.b);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 8147: 
 8148: 
 8149: 
 8150: 
 8151: @cython.boundscheck(False)
 8152: @cython.wraparound(False)
 8153: @cython.nonecheck(False)
 8154: @cython.cdivision(True)
+8155: cdef float distance_ (float x1, float y1, float x2, float y2)nogil:
static float __pyx_f_12PygameShader_6shader_distance_(float __pyx_v_x1, float __pyx_v_y1, float __pyx_v_x2, float __pyx_v_y2) {
  float __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}
+8156:   return <float>sqrt((x1-x2)*(x1-x2) + (y1-y2)*(y1-y2));
  __pyx_r = ((float)sqrt((((__pyx_v_x1 - __pyx_v_x2) * (__pyx_v_x1 - __pyx_v_x2)) + ((__pyx_v_y1 - __pyx_v_y2) * (__pyx_v_y1 - __pyx_v_y2)))));
  goto __pyx_L0;
 8157: 
 8158: @cython.boundscheck(False)
 8159: @cython.wraparound(False)
 8160: @cython.nonecheck(False)
 8161: @cython.cdivision(True)
+8162: cdef float gaussian_ (float v, float sigma2)nogil:
static float __pyx_f_12PygameShader_6shader_gaussian_(float __pyx_v_v, float __pyx_v_sigma2) {
  float __pyx_r;
/* … */
  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}
+8163:   return (<float>1.0 / (<float>M_PI * sigma2)) * <float>exp(-(v * v ) / sigma2)
  __pyx_r = ((((float)1.0) / (((float)__pyx_v_12PygameShader_6shader_M_PI) * __pyx_v_sigma2)) * ((float)exp(((-(__pyx_v_v * __pyx_v_v)) / __pyx_v_sigma2))));
  goto __pyx_L0;
 8164: 
 8165: @cython.boundscheck(False)
 8166: @cython.wraparound(False)
 8167: @cython.nonecheck(False)
 8168: @cython.cdivision(True)
+8169: cdef bilateral_filter24_c(
static PyObject *__pyx_f_12PygameShader_6shader_bilateral_filter24_c(__Pyx_memviewslice __pyx_v_rgb_array_, float __pyx_v_sigma_s_, float __pyx_v_sigma_i_) {
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_bilateral = { 0, 0, { 0 }, { 0 }, { 0 } };
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_xx;
  int __pyx_v_yy;
  int __pyx_v_k;
  int __pyx_v_kx;
  int __pyx_v_ky;
  float __pyx_v_gs;
  float __pyx_v_wr;
  float __pyx_v_wg;
  float __pyx_v_wb;
  float __pyx_v_ir;
  float __pyx_v_ig;
  float __pyx_v_ib;
  float __pyx_v_wpr;
  float __pyx_v_wpg;
  float __pyx_v_wpb;
  unsigned char *__pyx_v_r;
  unsigned char *__pyx_v_g;
  unsigned char *__pyx_v_b;
  float __pyx_v_sigma_i2;
  float __pyx_v_sigma_s2;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("bilateral_filter24_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1);
  __Pyx_XDECREF(__pyx_t_25);
  __Pyx_XDECREF(__pyx_t_26);
  __Pyx_AddTraceback("PygameShader.shader.bilateral_filter24_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __PYX_XDEC_MEMVIEW(&__pyx_v_bilateral, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 8170:         unsigned char [:, :, :] rgb_array_,
 8171:         float sigma_s_,
 8172:         float sigma_i_
 8173: ):
 8174:     """
 8175:     A bilateral filter is a non-linear, edge-preserving, and noise-reducing
 8176:     smoothing filter for images. It replaces the intensity of each pixel with a
 8177:     weighted average of intensity values from nearby pixels. This weight can be
 8178:     based on a Gaussian distribution.
 8179: 
 8180:     Here, the normalization factor and the range weight are new terms added to 
 8181:     the previous equation. sigma_s  denotes the spatial extent of the kernel, i.e. 
 8182:     the size of the neighborhood, and sigma_r  denotes the minimum amplitude of an edge.
 8183:     It ensures that only those pixels with intensity values similar to that of the
 8184:     central pixel are considered for blurring, while sharp intensity changes are maintained.
 8185:     The smaller the value of sigma_r  , the sharper the edge. As sigma_r  tends to infinity,  
 8186:     the equation tends to a Gaussian blur.
 8187:     
 8188:     :param rgb_array_: Surface, 24-32 bit format (alpha channel will be ignored)
 8189:     
 8190:     :param sigma_s_: float sigma_s : Spatial extent of the kernel, size of the 
 8191:     considered neighborhood
 8192:     
 8193:     :param sigma_i_: float sigma_i (also call sigma_r) range kernel, minimum amplitude of an edge.
 8194:     
 8195:     :return: return a filtered Surface
 8196:     """
 8197: 
 8198:     cdef Py_ssize_t w, h
+8199:     w = <object>rgb_array_.shape[ 0 ]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8199, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8199, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_w = __pyx_t_2;
+8200:     h = <object> rgb_array_.shape[ 1 ]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[1])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8200, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8200, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_h = __pyx_t_2;
 8201: 
 8202:     cdef:
+8203:         unsigned char [:, :, :] bilateral = empty((h, w, 3), dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_empty); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_4);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_int_3);
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_5);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_5);
  __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_uint8); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_5, __pyx_n_s_dtype, __pyx_t_3) < 0) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_4, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_dsdsds_unsigned_char(__pyx_t_3, PyBUF_WRITABLE); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(1, 8203, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_bilateral = __pyx_t_6;
  __pyx_t_6.memview = NULL;
  __pyx_t_6.data = NULL;
 8204:         int x, y, xx, yy
+8205:         int k = 3
  __pyx_v_k = 3;
 8206:         int kx, ky
 8207:         float gs, wr, wg, wb, ir, ig, ib , wpr, wpg, wpb
 8208:         unsigned char *r
 8209:         unsigned char *g
 8210:         unsigned char *b
+8211:         float sigma_i2 = 2 * sigma_i_ * sigma_i_
  __pyx_v_sigma_i2 = ((2.0 * __pyx_v_sigma_i_) * __pyx_v_sigma_i_);
+8212:         float sigma_s2 = 2 * sigma_s_ * sigma_s_
  __pyx_v_sigma_s2 = ((2.0 * __pyx_v_sigma_s_) * __pyx_v_sigma_s_);
 8213: 
+8214:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 8215: 
+8216:         for x in prange(0, w, schedule='static', num_threads=THREADS):
        __pyx_t_2 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_8 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_8 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gs) lastprivate(__pyx_v_ib) lastprivate(__pyx_v_ig) lastprivate(__pyx_v_ir) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_r) lastprivate(__pyx_v_wb) lastprivate(__pyx_v_wg) lastprivate(__pyx_v_wpb) lastprivate(__pyx_v_wpg) lastprivate(__pyx_v_wpr) lastprivate(__pyx_v_wr) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_2 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_8 = (__pyx_t_2 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_8 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_g) lastprivate(__pyx_v_gs) lastprivate(__pyx_v_ib) lastprivate(__pyx_v_ig) lastprivate(__pyx_v_ir) lastprivate(__pyx_v_kx) lastprivate(__pyx_v_ky) lastprivate(__pyx_v_r) lastprivate(__pyx_v_wb) lastprivate(__pyx_v_wg) lastprivate(__pyx_v_wpb) lastprivate(__pyx_v_wpg) lastprivate(__pyx_v_wpr) lastprivate(__pyx_v_wr) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_8; __pyx_t_7++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_7);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((unsigned char *)1);
                            __pyx_v_g = ((unsigned char *)1);
                            __pyx_v_gs = ((float)__PYX_NAN());
                            __pyx_v_ib = ((float)__PYX_NAN());
                            __pyx_v_ig = ((float)__PYX_NAN());
                            __pyx_v_ir = ((float)__PYX_NAN());
                            __pyx_v_kx = ((int)0xbad0bad0);
                            __pyx_v_ky = ((int)0xbad0bad0);
                            __pyx_v_r = ((unsigned char *)1);
                            __pyx_v_wb = ((float)__PYX_NAN());
                            __pyx_v_wg = ((float)__PYX_NAN());
                            __pyx_v_wpb = ((float)__PYX_NAN());
                            __pyx_v_wpg = ((float)__PYX_NAN());
                            __pyx_v_wpr = ((float)__PYX_NAN());
                            __pyx_v_wr = ((float)__PYX_NAN());
                            __pyx_v_xx = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_yy = ((int)0xbad0bad0);
+8217:             for y in range(0, h):
                            __pyx_t_9 = __pyx_v_h;
                            __pyx_t_10 = __pyx_t_9;
                            for (__pyx_t_11 = 0; __pyx_t_11 < __pyx_t_10; __pyx_t_11+=1) {
                              __pyx_v_y = __pyx_t_11;
 8218: 
+8219:                 ir, ig, ib = 0, 0, 0
                              __pyx_t_12 = 0.0;
                              __pyx_t_13 = 0.0;
                              __pyx_t_14 = 0.0;
                              __pyx_v_ir = __pyx_t_12;
                              __pyx_v_ig = __pyx_t_13;
                              __pyx_v_ib = __pyx_t_14;
+8220:                 wpr, wpg, wpb = 0, 0, 0
                              __pyx_t_14 = 0.0;
                              __pyx_t_13 = 0.0;
                              __pyx_t_12 = 0.0;
                              __pyx_v_wpr = __pyx_t_14;
                              __pyx_v_wpg = __pyx_t_13;
                              __pyx_v_wpb = __pyx_t_12;
 8221: 
+8222:                 for ky in range(-k, k + 1):
                              __pyx_t_15 = (__pyx_v_k + 1);
                              __pyx_t_16 = __pyx_t_15;
                              for (__pyx_t_17 = (-__pyx_v_k); __pyx_t_17 < __pyx_t_16; __pyx_t_17+=1) {
                                __pyx_v_ky = __pyx_t_17;
+8223:                     for kx in range(-k, k + 1):
                                __pyx_t_18 = (__pyx_v_k + 1);
                                __pyx_t_19 = __pyx_t_18;
                                for (__pyx_t_20 = (-__pyx_v_k); __pyx_t_20 < __pyx_t_19; __pyx_t_20+=1) {
                                  __pyx_v_kx = __pyx_t_20;
 8224: 
+8225:                         xx = x + kx
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kx);
+8226:                         yy = y + ky
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_ky);
 8227: 
+8228:                         if xx < 0:
                                  __pyx_t_21 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                    goto __pyx_L16;
                                  }
+8229:                             xx = 0
                                    __pyx_v_xx = 0;
+8230:                         elif xx > w:
                                  __pyx_t_21 = ((__pyx_v_xx > __pyx_v_w) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
                                  __pyx_L16:;
+8231:                             xx = w
                                    __pyx_v_xx = __pyx_v_w;
 8232: 
+8233:                         if yy < 0:
                                  __pyx_t_21 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_21) {
/* … */
                                    goto __pyx_L17;
                                  }
+8234:                             yy = 0
                                    __pyx_v_yy = 0;
+8235:                         elif yy > h:
                                  __pyx_t_21 = ((__pyx_v_yy > __pyx_v_h) != 0);
                                  if (__pyx_t_21) {
/* … */
                                  }
                                  __pyx_L17:;
+8236:                             yy = h
                                    __pyx_v_yy = __pyx_v_h;
 8237: 
+8238:                         gs = gaussian_(distance_(xx, yy, x, y), sigma_s2)
                                  __pyx_v_gs = __pyx_f_12PygameShader_6shader_gaussian_(__pyx_f_12PygameShader_6shader_distance_(__pyx_v_xx, __pyx_v_yy, __pyx_v_x, __pyx_v_y), __pyx_v_sigma_s2);
 8239: 
+8240:                         r = &rgb_array_[xx, yy, 0]
                                  __pyx_t_22 = __pyx_v_xx;
                                  __pyx_t_23 = __pyx_v_yy;
                                  __pyx_t_24 = 0;
                                  __pyx_v_r = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_22 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[2]) ))));
+8241:                         g = &rgb_array_[xx, yy, 1]
                                  __pyx_t_24 = __pyx_v_xx;
                                  __pyx_t_23 = __pyx_v_yy;
                                  __pyx_t_22 = 1;
                                  __pyx_v_g = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_24 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array_.strides[2]) ))));
+8242:                         b = &rgb_array_[xx, yy, 2]
                                  __pyx_t_22 = __pyx_v_xx;
                                  __pyx_t_23 = __pyx_v_yy;
                                  __pyx_t_24 = 2;
                                  __pyx_v_b = (&(*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_22 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[2]) ))));
 8243: 
+8244:                         wr = gaussian_(r[0] - rgb_array_[x, y, 0], sigma_i2) * gs
                                  __pyx_t_24 = __pyx_v_x;
                                  __pyx_t_23 = __pyx_v_y;
                                  __pyx_t_22 = 0;
                                  __pyx_v_wr = (__pyx_f_12PygameShader_6shader_gaussian_(((__pyx_v_r[0]) - (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_24 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array_.strides[2]) )))), __pyx_v_sigma_i2) * __pyx_v_gs);
+8245:                         wg = gaussian_(g[0] - rgb_array_[x, y, 1], sigma_i2) * gs
                                  __pyx_t_22 = __pyx_v_x;
                                  __pyx_t_23 = __pyx_v_y;
                                  __pyx_t_24 = 1;
                                  __pyx_v_wg = (__pyx_f_12PygameShader_6shader_gaussian_(((__pyx_v_g[0]) - (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_22 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[2]) )))), __pyx_v_sigma_i2) * __pyx_v_gs);
+8246:                         wb = gaussian_(b[0] - rgb_array_[x, y, 2], sigma_i2) * gs
                                  __pyx_t_24 = __pyx_v_x;
                                  __pyx_t_23 = __pyx_v_y;
                                  __pyx_t_22 = 2;
                                  __pyx_v_wb = (__pyx_f_12PygameShader_6shader_gaussian_(((__pyx_v_b[0]) - (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_24 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_22 * __pyx_v_rgb_array_.strides[2]) )))), __pyx_v_sigma_i2) * __pyx_v_gs);
 8247: 
+8248:                         ir = ir + r[0] * wr
                                  __pyx_v_ir = (__pyx_v_ir + ((__pyx_v_r[0]) * __pyx_v_wr));
+8249:                         ig = ig + g[0] * wg
                                  __pyx_v_ig = (__pyx_v_ig + ((__pyx_v_g[0]) * __pyx_v_wg));
+8250:                         ib = ib + b[0] * wb
                                  __pyx_v_ib = (__pyx_v_ib + ((__pyx_v_b[0]) * __pyx_v_wb));
 8251: 
+8252:                         wpr = wpr + wr
                                  __pyx_v_wpr = (__pyx_v_wpr + __pyx_v_wr);
+8253:                         wpg = wpg + wg
                                  __pyx_v_wpg = (__pyx_v_wpg + __pyx_v_wg);
+8254:                         wpb = wpb + wb
                                  __pyx_v_wpb = (__pyx_v_wpb + __pyx_v_wb);
                                }
                              }
 8255: 
+8256:                 ir = ir / wpr
                              __pyx_v_ir = (__pyx_v_ir / __pyx_v_wpr);
+8257:                 ig = ig / wpg
                              __pyx_v_ig = (__pyx_v_ig / __pyx_v_wpg);
+8258:                 ib = ib / wpb
                              __pyx_v_ib = (__pyx_v_ib / __pyx_v_wpb);
 8259: 
+8260:                 bilateral[y, x, 0] = <int>ir
                              __pyx_t_22 = __pyx_v_y;
                              __pyx_t_23 = __pyx_v_x;
                              __pyx_t_24 = 0;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_bilateral.data + __pyx_t_22 * __pyx_v_bilateral.strides[0]) ) + __pyx_t_23 * __pyx_v_bilateral.strides[1]) ) + __pyx_t_24 * __pyx_v_bilateral.strides[2]) )) = ((int)__pyx_v_ir);
+8261:                 bilateral[y, x, 1] = <int>ig
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_23 = __pyx_v_x;
                              __pyx_t_22 = 1;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_bilateral.data + __pyx_t_24 * __pyx_v_bilateral.strides[0]) ) + __pyx_t_23 * __pyx_v_bilateral.strides[1]) ) + __pyx_t_22 * __pyx_v_bilateral.strides[2]) )) = ((int)__pyx_v_ig);
+8262:                 bilateral[y, x, 2] = <int>ib
                              __pyx_t_22 = __pyx_v_y;
                              __pyx_t_23 = __pyx_v_x;
                              __pyx_t_24 = 2;
                              *((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_bilateral.data + __pyx_t_22 * __pyx_v_bilateral.strides[0]) ) + __pyx_t_23 * __pyx_v_bilateral.strides[1]) ) + __pyx_t_24 * __pyx_v_bilateral.strides[2]) )) = ((int)__pyx_v_ib);
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 8263: 
 8264: 
+8265:     return frombuffer(bilateral, (w, h), 'RGB')
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 8265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = __pyx_memoryview_fromslice(__pyx_v_bilateral, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_1 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_25 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_25)) __PYX_ERR(1, 8265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_25);
  __pyx_t_26 = PyTuple_New(2); if (unlikely(!__pyx_t_26)) __PYX_ERR(1, 8265, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_26);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_26, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_25);
  PyTuple_SET_ITEM(__pyx_t_26, 1, __pyx_t_25);
  __pyx_t_1 = 0;
  __pyx_t_25 = 0;
  __pyx_t_25 = NULL;
  __pyx_t_11 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_25 = PyMethod_GET_SELF(__pyx_t_5);
    if (likely(__pyx_t_25)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_25);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_5, function);
      __pyx_t_11 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[4] = {__pyx_t_25, __pyx_t_4, __pyx_t_26, __pyx_n_s_RGB};
    __pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8265, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_26); __pyx_t_26 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_5)) {
    PyObject *__pyx_temp[4] = {__pyx_t_25, __pyx_t_4, __pyx_t_26, __pyx_n_s_RGB};
    __pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_5, __pyx_temp+1-__pyx_t_11, 3+__pyx_t_11); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8265, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_26); __pyx_t_26 = 0;
  } else
  #endif
  {
    __pyx_t_1 = PyTuple_New(3+__pyx_t_11); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8265, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    if (__pyx_t_25) {
      __Pyx_GIVEREF(__pyx_t_25); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_25); __pyx_t_25 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_4);
    PyTuple_SET_ITEM(__pyx_t_1, 0+__pyx_t_11, __pyx_t_4);
    __Pyx_GIVEREF(__pyx_t_26);
    PyTuple_SET_ITEM(__pyx_t_1, 1+__pyx_t_11, __pyx_t_26);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_1, 2+__pyx_t_11, __pyx_n_s_RGB);
    __pyx_t_4 = 0;
    __pyx_t_26 = 0;
    __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_5, __pyx_t_1, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8265, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 8266: 
 8267: 
 8268: 
 8269: 
 8270: EMBOSS_KERNEL = \
+8271:     numpy.array((
  __Pyx_GetModuleGlobalName(__pyx_t_32, __pyx_n_s_numpy); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 8271, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __pyx_t_31 = __Pyx_PyObject_GetAttrStr(__pyx_t_32, __pyx_n_s_array_2); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 8271, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __Pyx_DECREF(__pyx_t_32); __pyx_t_32 = 0;
/* … */
  __pyx_t_29 = __Pyx_PyObject_CallOneArg(__pyx_t_31, __pyx_t_28); if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 8271, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  __Pyx_DECREF(__pyx_t_28); __pyx_t_28 = 0;
+8272:         [-1, -1, -1, -1, 0],
  __pyx_t_32 = PyList_New(5); if (unlikely(!__pyx_t_32)) __PYX_ERR(1, 8272, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_32);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_32, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_32, 1, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_32, 2, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_32, 3, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_32, 4, __pyx_int_0);
/* … */
  __pyx_t_28 = PyTuple_New(5); if (unlikely(!__pyx_t_28)) __PYX_ERR(1, 8272, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_28);
  __Pyx_GIVEREF(__pyx_t_32);
  PyTuple_SET_ITEM(__pyx_t_28, 0, __pyx_t_32);
  __Pyx_GIVEREF(__pyx_t_30);
  PyTuple_SET_ITEM(__pyx_t_28, 1, __pyx_t_30);
  __Pyx_GIVEREF(__pyx_t_33);
  PyTuple_SET_ITEM(__pyx_t_28, 2, __pyx_t_33);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_28, 3, __pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_29);
  PyTuple_SET_ITEM(__pyx_t_28, 4, __pyx_t_29);
  __pyx_t_32 = 0;
  __pyx_t_30 = 0;
  __pyx_t_33 = 0;
  __pyx_t_2 = 0;
  __pyx_t_29 = 0;
+8273:         [-1, -1, -1, 0,  1],
  __pyx_t_30 = PyList_New(5); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 8273, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_30, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_30, 1, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_30, 2, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_30, 3, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_30, 4, __pyx_int_1);
+8274:         [-1, -1,  0, 1,  1],
  __pyx_t_33 = PyList_New(5); if (unlikely(!__pyx_t_33)) __PYX_ERR(1, 8274, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_33);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_33, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_33, 1, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_33, 2, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_33, 3, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_33, 4, __pyx_int_1);
+8275:         [-1,  0,  1, 1,  1],
  __pyx_t_2 = PyList_New(5); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8275, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_INCREF(__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_int_neg_1);
  PyList_SET_ITEM(__pyx_t_2, 0, __pyx_int_neg_1);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_2, 1, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_2, 2, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_2, 3, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_2, 4, __pyx_int_1);
+8276:         [ 0,  1,  1, 1,  1])).astype(dtype=numpy.float32, order='C')
  __pyx_t_29 = PyList_New(5); if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __Pyx_INCREF(__pyx_int_0);
  __Pyx_GIVEREF(__pyx_int_0);
  PyList_SET_ITEM(__pyx_t_29, 0, __pyx_int_0);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_29, 1, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_29, 2, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_29, 3, __pyx_int_1);
  __Pyx_INCREF(__pyx_int_1);
  __Pyx_GIVEREF(__pyx_int_1);
  PyList_SET_ITEM(__pyx_t_29, 4, __pyx_int_1);
/* … */
  __pyx_t_28 = __Pyx_PyObject_GetAttrStr(__pyx_t_29, __pyx_n_s_astype); if (unlikely(!__pyx_t_28)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_28);
  __Pyx_DECREF(__pyx_t_29); __pyx_t_29 = 0;
  __pyx_t_29 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __Pyx_GetModuleGlobalName(__pyx_t_31, __pyx_n_s_numpy); if (unlikely(!__pyx_t_31)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_31);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_31, __pyx_n_s_float32); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_31); __pyx_t_31 = 0;
  if (PyDict_SetItem(__pyx_t_29, __pyx_n_s_dtype, __pyx_t_2) < 0) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (PyDict_SetItem(__pyx_t_29, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 8276, __pyx_L1_error)
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_28, __pyx_empty_tuple, __pyx_t_29); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8276, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_28); __pyx_t_28 = 0;
  __Pyx_DECREF(__pyx_t_29); __pyx_t_29 = 0;
  if (PyDict_SetItem(__pyx_d, __pyx_n_s_EMBOSS_KERNEL, __pyx_t_2) < 0) __PYX_ERR(1, 8270, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
 8277: 
 8278: @cython.boundscheck(False)
 8279: @cython.wraparound(False)
 8280: @cython.nonecheck(False)
 8281: @cython.cdivision(True)
+8282: cdef object emboss5x5_c(unsigned char [:, :, :] rgb_array_):
static PyObject *__pyx_f_12PygameShader_6shader_emboss5x5_c(__Pyx_memviewslice __pyx_v_rgb_array_) {
  PyObject *__pyx_v_k_weight = NULL;
  Py_ssize_t __pyx_v_k_length;
  Py_ssize_t __pyx_v_half_kernel;
  Py_ssize_t __pyx_v_w;
  Py_ssize_t __pyx_v_h;
  __Pyx_memviewslice __pyx_v_kernel = { 0, 0, { 0 }, { 0 }, { 0 } };
  CYTHON_UNUSED float __pyx_v_kernel_weight;
  short __pyx_v_kernel_half;
  __Pyx_memviewslice __pyx_v_emboss = { 0, 0, { 0 }, { 0 }, { 0 } };
  CYTHON_UNUSED int __pyx_v_kernel_length;
  int __pyx_v_x;
  int __pyx_v_y;
  int __pyx_v_xx;
  int __pyx_v_yy;
  unsigned short __pyx_v_red;
  unsigned short __pyx_v_green;
  unsigned short __pyx_v_blue;
  short __pyx_v_kernel_offset_y;
  short __pyx_v_kernel_offset_x;
  float __pyx_v_r;
  float __pyx_v_g;
  float __pyx_v_b;
  float __pyx_v_k;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("emboss5x5_c", 0);
/* … */
  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __PYX_XDEC_MEMVIEW(&__pyx_t_6, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_t_8, 1);
  __Pyx_XDECREF(__pyx_t_29);
  __Pyx_XDECREF(__pyx_t_30);
  __Pyx_AddTraceback("PygameShader.shader.emboss5x5_c", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_k_weight);
  __PYX_XDEC_MEMVIEW(&__pyx_v_kernel, 1);
  __PYX_XDEC_MEMVIEW(&__pyx_v_emboss, 1);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
 8283: 
+8284:     k_weight = numpy.sum(EMBOSS_KERNEL)
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_numpy); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8284, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_n_s_sum); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8284, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_EMBOSS_KERNEL); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8284, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    if (likely(__pyx_t_4)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_3, function);
    }
  }
  __pyx_t_1 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_4, __pyx_t_2) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8284, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_k_weight = __pyx_t_1;
  __pyx_t_1 = 0;
+8285:     k_length = len(EMBOSS_KERNEL)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_EMBOSS_KERNEL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8285, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_5 = PyObject_Length(__pyx_t_1); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-1))) __PYX_ERR(1, 8285, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_k_length = __pyx_t_5;
+8286:     half_kernel = len(EMBOSS_KERNEL) >> 1
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_EMBOSS_KERNEL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8286, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_5 = PyObject_Length(__pyx_t_1); if (unlikely(__pyx_t_5 == ((Py_ssize_t)-1))) __PYX_ERR(1, 8286, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_half_kernel = (__pyx_t_5 >> 1);
 8287: 
 8288:     # texture sizes
 8289:     cdef Py_ssize_t w, h
+8290:     w = <object>rgb_array_.shape[0]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[0])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8290, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_5 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_5 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8290, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_w = __pyx_t_5;
+8291:     h = <object>rgb_array_.shape[1]
  __pyx_t_1 = PyInt_FromSsize_t((__pyx_v_rgb_array_.shape[1])); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8291, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_5 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_5 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(1, 8291, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_h = __pyx_t_5;
 8292: 
 8293:     cdef:
+8294:         float [:, :] kernel = EMBOSS_KERNEL
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_EMBOSS_KERNEL); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8294, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_6 = __Pyx_PyObject_to_MemoryviewSlice_dsds_float(__pyx_t_1, PyBUF_WRITABLE); if (unlikely(!__pyx_t_6.memview)) __PYX_ERR(1, 8294, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_kernel = __pyx_t_6;
  __pyx_t_6.memview = NULL;
  __pyx_t_6.data = NULL;
+8295:         float kernel_weight = k_weight
  __pyx_t_7 = __pyx_PyFloat_AsFloat(__pyx_v_k_weight); if (unlikely((__pyx_t_7 == (float)-1) && PyErr_Occurred())) __PYX_ERR(1, 8295, __pyx_L1_error)
  __pyx_v_kernel_weight = __pyx_t_7;
+8296:         short kernel_half = half_kernel
  __pyx_v_kernel_half = __pyx_v_half_kernel;
+8297:         unsigned char [:, :, ::1] emboss = empty((h, w, 3), order='C', dtype=uint8)
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_empty); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_3);
  PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
  __Pyx_GIVEREF(__pyx_t_2);
  PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2);
  __Pyx_INCREF(__pyx_int_3);
  __Pyx_GIVEREF(__pyx_int_3);
  PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_int_3);
  __pyx_t_3 = 0;
  __pyx_t_2 = 0;
  __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_4);
  PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_4);
  __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyDict_NewPresized(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_order, __pyx_n_s_C) < 0) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_uint8); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_n_s_dtype, __pyx_t_3) < 0) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_t_2, __pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_8 = __Pyx_PyObject_to_MemoryviewSlice_d_d_dc_unsigned_char(__pyx_t_3, PyBUF_WRITABLE); if (unlikely(!__pyx_t_8.memview)) __PYX_ERR(1, 8297, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_emboss = __pyx_t_8;
  __pyx_t_8.memview = NULL;
  __pyx_t_8.data = NULL;
+8298:         int kernel_length = k_length
  __pyx_v_kernel_length = __pyx_v_k_length;
 8299:         int x, y, xx, yy
 8300:         unsigned short red, green, blue,
 8301:         short kernel_offset_y, kernel_offset_x
 8302:         float r, g, b, k
 8303: 
+8304:     with nogil:
  {
      #ifdef WITH_THREAD
      PyThreadState *_save;
      Py_UNBLOCK_THREADS
      __Pyx_FastGIL_Remember();
      #endif
      /*try:*/ {
/* … */
      /*finally:*/ {
        /*normal exit:*/{
          #ifdef WITH_THREAD
          __Pyx_FastGIL_Forget();
          Py_BLOCK_THREADS
          #endif
          goto __pyx_L5;
        }
        __pyx_L5:;
      }
  }
 8305: 
+8306:         for x in prange(0, w, schedule='static', num_threads=THREADS):
        __pyx_t_5 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_5 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static)
/* … */
        __pyx_t_5 = __pyx_v_w;
        if ((1 == 0)) abort();
        {
            #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
                #undef likely
                #undef unlikely
                #define likely(x)   (x)
                #define unlikely(x) (x)
            #endif
            __pyx_t_10 = (__pyx_t_5 - 0 + 1 - 1/abs(1)) / 1;
            if (__pyx_t_10 > 0)
            {
                #ifdef _OPENMP
                #pragma omp parallel
                #endif /* _OPENMP */
                {
                    #ifdef _OPENMP
                    #pragma omp for lastprivate(__pyx_v_b) lastprivate(__pyx_v_blue) lastprivate(__pyx_v_g) lastprivate(__pyx_v_green) lastprivate(__pyx_v_k) lastprivate(__pyx_v_kernel_offset_x) lastprivate(__pyx_v_kernel_offset_y) lastprivate(__pyx_v_r) lastprivate(__pyx_v_red) firstprivate(__pyx_v_x) lastprivate(__pyx_v_x) lastprivate(__pyx_v_xx) lastprivate(__pyx_v_y) lastprivate(__pyx_v_yy) schedule(static) num_threads(__pyx_v_12PygameShader_6shader_THREADS)
                    #endif /* _OPENMP */
                    for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_10; __pyx_t_9++){
                        {
                            __pyx_v_x = (int)(0 + 1 * __pyx_t_9);
                            /* Initialize private variables to invalid values */
                            __pyx_v_b = ((float)__PYX_NAN());
                            __pyx_v_blue = ((unsigned short)0xbad0bad0);
                            __pyx_v_g = ((float)__PYX_NAN());
                            __pyx_v_green = ((unsigned short)0xbad0bad0);
                            __pyx_v_k = ((float)__PYX_NAN());
                            __pyx_v_kernel_offset_x = ((short)0xbad0bad0);
                            __pyx_v_kernel_offset_y = ((short)0xbad0bad0);
                            __pyx_v_r = ((float)__PYX_NAN());
                            __pyx_v_red = ((unsigned short)0xbad0bad0);
                            __pyx_v_xx = ((int)0xbad0bad0);
                            __pyx_v_y = ((int)0xbad0bad0);
                            __pyx_v_yy = ((int)0xbad0bad0);
 8307: 
+8308:             for y in range(0, h):
                            __pyx_t_11 = __pyx_v_h;
                            __pyx_t_12 = __pyx_t_11;
                            for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_12; __pyx_t_13+=1) {
                              __pyx_v_y = __pyx_t_13;
 8309: 
+8310:                 r, g, b = 0, 0, 0
                              __pyx_t_7 = 0.0;
                              __pyx_t_14 = 0.0;
                              __pyx_t_15 = 0.0;
                              __pyx_v_r = __pyx_t_7;
                              __pyx_v_g = __pyx_t_14;
                              __pyx_v_b = __pyx_t_15;
 8311: 
+8312:                 for kernel_offset_y in range(-kernel_half, kernel_half + 1):
                              __pyx_t_16 = (__pyx_v_kernel_half + 1);
                              __pyx_t_17 = __pyx_t_16;
                              for (__pyx_t_18 = (-__pyx_v_kernel_half); __pyx_t_18 < __pyx_t_17; __pyx_t_18+=1) {
                                __pyx_v_kernel_offset_y = __pyx_t_18;
 8313: 
+8314:                     for kernel_offset_x in range(-kernel_half, kernel_half + 1):
                                __pyx_t_19 = (__pyx_v_kernel_half + 1);
                                __pyx_t_20 = __pyx_t_19;
                                for (__pyx_t_21 = (-__pyx_v_kernel_half); __pyx_t_21 < __pyx_t_20; __pyx_t_21+=1) {
                                  __pyx_v_kernel_offset_x = __pyx_t_21;
 8315: 
+8316:                         xx = x + kernel_offset_x
                                  __pyx_v_xx = (__pyx_v_x + __pyx_v_kernel_offset_x);
+8317:                         yy = y + kernel_offset_y
                                  __pyx_v_yy = (__pyx_v_y + __pyx_v_kernel_offset_y);
 8318: 
+8319:                         if xx < 0:
                                  __pyx_t_22 = ((__pyx_v_xx < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L16;
                                  }
+8320:                             xx = 0
                                    __pyx_v_xx = 0;
+8321:                         elif xx > w:
                                  __pyx_t_22 = ((__pyx_v_xx > __pyx_v_w) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L16:;
+8322:                             xx = w
                                    __pyx_v_xx = __pyx_v_w;
 8323: 
+8324:                         if yy < 0:
                                  __pyx_t_22 = ((__pyx_v_yy < 0) != 0);
                                  if (__pyx_t_22) {
/* … */
                                    goto __pyx_L17;
                                  }
+8325:                             yy = 0
                                    __pyx_v_yy = 0;
+8326:                         elif yy > h:
                                  __pyx_t_22 = ((__pyx_v_yy > __pyx_v_h) != 0);
                                  if (__pyx_t_22) {
/* … */
                                  }
                                  __pyx_L17:;
+8327:                             yy = h
                                    __pyx_v_yy = __pyx_v_h;
 8328: 
 8329: 
 8330:                         red, green, blue = \
+8331:                             rgb_array_[xx, yy, 0], \
                                  __pyx_t_23 = __pyx_v_xx;
                                  __pyx_t_24 = __pyx_v_yy;
                                  __pyx_t_25 = 0;
                                  __pyx_t_26 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )));
+8332:                             rgb_array_[xx, yy, 1],\
                                  __pyx_t_25 = __pyx_v_xx;
                                  __pyx_t_24 = __pyx_v_yy;
                                  __pyx_t_23 = 1;
                                  __pyx_t_27 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_25 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_23 * __pyx_v_rgb_array_.strides[2]) )));
+8333:                             rgb_array_[xx, yy, 2]
                                  __pyx_t_23 = __pyx_v_xx;
                                  __pyx_t_24 = __pyx_v_yy;
                                  __pyx_t_25 = 2;
                                  __pyx_t_28 = (*((unsigned char *) ( /* dim=2 */ (( /* dim=1 */ (( /* dim=0 */ (__pyx_v_rgb_array_.data + __pyx_t_23 * __pyx_v_rgb_array_.strides[0]) ) + __pyx_t_24 * __pyx_v_rgb_array_.strides[1]) ) + __pyx_t_25 * __pyx_v_rgb_array_.strides[2]) )));
                                  __pyx_v_red = __pyx_t_26;
                                  __pyx_v_green = __pyx_t_27;
                                  __pyx_v_blue = __pyx_t_28;
 8334: 
+8335:                         k = kernel[kernel_offset_y + kernel_half, kernel_offset_x + kernel_half]
                                  __pyx_t_25 = (__pyx_v_kernel_offset_y + __pyx_v_kernel_half);
                                  __pyx_t_24 = (__pyx_v_kernel_offset_x + __pyx_v_kernel_half);
                                  __pyx_v_k = (*((float *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_kernel.data + __pyx_t_25 * __pyx_v_kernel.strides[0]) ) + __pyx_t_24 * __pyx_v_kernel.strides[1]) )));
+8336:                         r = r + red * k
                                  __pyx_v_r = (__pyx_v_r + (__pyx_v_red * __pyx_v_k));
+8337:                         g = g + green * k
                                  __pyx_v_g = (__pyx_v_g + (__pyx_v_green * __pyx_v_k));
+8338:                         b = b + blue * k
                                  __pyx_v_b = (__pyx_v_b + (__pyx_v_blue * __pyx_v_k));
                                }
                              }
 8339: 
+8340:                 if r < 0:
                              __pyx_t_22 = ((__pyx_v_r < 0.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8341:                     r = 0
                                __pyx_v_r = 0.0;
+8342:                 if g < 0:
                              __pyx_t_22 = ((__pyx_v_g < 0.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8343:                     g = 0
                                __pyx_v_g = 0.0;
+8344:                 if b < 0:
                              __pyx_t_22 = ((__pyx_v_b < 0.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8345:                     b = 0
                                __pyx_v_b = 0.0;
+8346:                 if r > 255:
                              __pyx_t_22 = ((__pyx_v_r > 255.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8347:                     r= 255
                                __pyx_v_r = 255.0;
+8348:                 if g > 255:
                              __pyx_t_22 = ((__pyx_v_g > 255.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8349:                     g = 255
                                __pyx_v_g = 255.0;
+8350:                 if b > 255:
                              __pyx_t_22 = ((__pyx_v_b > 255.0) != 0);
                              if (__pyx_t_22) {
/* … */
                              }
+8351:                     b = 255
                                __pyx_v_b = 255.0;
 8352: 
+8353:                 emboss[y, x, 0], emboss[y, x, 1], \
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_25 = __pyx_v_x;
                              __pyx_t_23 = 0;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_emboss.data + __pyx_t_24 * __pyx_v_emboss.strides[0]) ) + __pyx_t_25 * __pyx_v_emboss.strides[1]) )) + __pyx_t_23)) )) = __pyx_t_28;
                              __pyx_t_23 = __pyx_v_y;
                              __pyx_t_25 = __pyx_v_x;
                              __pyx_t_24 = 1;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_emboss.data + __pyx_t_23 * __pyx_v_emboss.strides[0]) ) + __pyx_t_25 * __pyx_v_emboss.strides[1]) )) + __pyx_t_24)) )) = __pyx_t_27;
+8354:                 emboss[y, x, 2] = <unsigned char>r, <unsigned char>g, <unsigned char>b
                              __pyx_t_28 = ((unsigned char)__pyx_v_r);
                              __pyx_t_27 = ((unsigned char)__pyx_v_g);
                              __pyx_t_26 = ((unsigned char)__pyx_v_b);
/* … */
                              __pyx_t_24 = __pyx_v_y;
                              __pyx_t_25 = __pyx_v_x;
                              __pyx_t_23 = 2;
                              *((unsigned char *) ( /* dim=2 */ ((char *) (((unsigned char *) ( /* dim=1 */ (( /* dim=0 */ (__pyx_v_emboss.data + __pyx_t_24 * __pyx_v_emboss.strides[0]) ) + __pyx_t_25 * __pyx_v_emboss.strides[1]) )) + __pyx_t_23)) )) = __pyx_t_26;
                            }
                        }
                    }
                }
            }
        }
        #if ((defined(__APPLE__) || defined(__OSX__)) && (defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))))
            #undef likely
            #undef unlikely
            #define likely(x)   __builtin_expect(!!(x), 1)
            #define unlikely(x) __builtin_expect(!!(x), 0)
        #endif
      }
 8355: 
+8356:     return frombuffer(asarray(emboss), (w, h), 'RGB')
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_frombuffer); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_asarray); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_29 = __pyx_memoryview_fromslice(__pyx_v_emboss, 3, (PyObject *(*)(char *)) __pyx_memview_get_unsigned_char, (int (*)(char *, PyObject *)) __pyx_memview_set_unsigned_char, 0);; if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __pyx_t_30 = NULL;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_30 = PyMethod_GET_SELF(__pyx_t_1);
    if (likely(__pyx_t_30)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_30);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_1, function);
    }
  }
  __pyx_t_2 = (__pyx_t_30) ? __Pyx_PyObject_Call2Args(__pyx_t_1, __pyx_t_30, __pyx_t_29) : __Pyx_PyObject_CallOneArg(__pyx_t_1, __pyx_t_29);
  __Pyx_XDECREF(__pyx_t_30); __pyx_t_30 = 0;
  __Pyx_DECREF(__pyx_t_29); __pyx_t_29 = 0;
  if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyInt_FromSsize_t(__pyx_v_w); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_29 = PyInt_FromSsize_t(__pyx_v_h); if (unlikely(!__pyx_t_29)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_29);
  __pyx_t_30 = PyTuple_New(2); if (unlikely(!__pyx_t_30)) __PYX_ERR(1, 8356, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_30);
  __Pyx_GIVEREF(__pyx_t_1);
  PyTuple_SET_ITEM(__pyx_t_30, 0, __pyx_t_1);
  __Pyx_GIVEREF(__pyx_t_29);
  PyTuple_SET_ITEM(__pyx_t_30, 1, __pyx_t_29);
  __pyx_t_1 = 0;
  __pyx_t_29 = 0;
  __pyx_t_29 = NULL;
  __pyx_t_13 = 0;
  if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_29 = PyMethod_GET_SELF(__pyx_t_4);
    if (likely(__pyx_t_29)) {
      PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_29);
      __Pyx_INCREF(function);
      __Pyx_DECREF_SET(__pyx_t_4, function);
      __pyx_t_13 = 1;
    }
  }
  #if CYTHON_FAST_PYCALL
  if (PyFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[4] = {__pyx_t_29, __pyx_t_2, __pyx_t_30, __pyx_n_s_RGB};
    __pyx_t_3 = __Pyx_PyFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_13, 3+__pyx_t_13); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8356, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_29); __pyx_t_29 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  } else
  #endif
  #if CYTHON_FAST_PYCCALL
  if (__Pyx_PyFastCFunction_Check(__pyx_t_4)) {
    PyObject *__pyx_temp[4] = {__pyx_t_29, __pyx_t_2, __pyx_t_30, __pyx_n_s_RGB};
    __pyx_t_3 = __Pyx_PyCFunction_FastCall(__pyx_t_4, __pyx_temp+1-__pyx_t_13, 3+__pyx_t_13); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8356, __pyx_L1_error)
    __Pyx_XDECREF(__pyx_t_29); __pyx_t_29 = 0;
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_30); __pyx_t_30 = 0;
  } else
  #endif
  {
    __pyx_t_1 = PyTuple_New(3+__pyx_t_13); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    if (__pyx_t_29) {
      __Pyx_GIVEREF(__pyx_t_29); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_29); __pyx_t_29 = NULL;
    }
    __Pyx_GIVEREF(__pyx_t_2);
    PyTuple_SET_ITEM(__pyx_t_1, 0+__pyx_t_13, __pyx_t_2);
    __Pyx_GIVEREF(__pyx_t_30);
    PyTuple_SET_ITEM(__pyx_t_1, 1+__pyx_t_13, __pyx_t_30);
    __Pyx_INCREF(__pyx_n_s_RGB);
    __Pyx_GIVEREF(__pyx_n_s_RGB);
    PyTuple_SET_ITEM(__pyx_t_1, 2+__pyx_t_13, __pyx_n_s_RGB);
    __pyx_t_2 = 0;
    __pyx_t_30 = 0;
    __pyx_t_3 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_t_1, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 8356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;
 8357: 
 8358: 
 8359: 
 8360: