/* Generated by Cython 3.2.4 */

/* BEGIN: Cython Metadata
{
    "distutils": {
        "define_macros": [
            [
                "NPY_NO_DEPRECATED_API",
                "NPY_1_7_API_VERSION"
            ]
        ],
        "depends": [
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include/numpy/arrayobject.h",
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include/numpy/arrayscalars.h",
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include/numpy/ndarrayobject.h",
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include/numpy/ndarraytypes.h",
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include/numpy/ufuncobject.h"
        ],
        "include_dirs": [
            "/data/pub/cwrf-bias-correction-env/lib/python3.11/site-packages/numpy/_core/include"
        ],
        "name": "cftime._cftime",
        "sources": [
            "src/cftime/_cftime.pyx"
        ]
    },
    "module_name": "cftime._cftime"
}
END: Cython Metadata */

#ifndef PY_SSIZE_T_CLEAN
#define PY_SSIZE_T_CLEAN
#endif /* PY_SSIZE_T_CLEAN */
/* InitLimitedAPI */
#if defined(Py_LIMITED_API)
  #if !defined(CYTHON_LIMITED_API)
  #define CYTHON_LIMITED_API 1
  #endif
#elif defined(CYTHON_LIMITED_API)
  #ifdef _MSC_VER
  #pragma message ("Limited API usage is enabled with 'CYTHON_LIMITED_API' but 'Py_LIMITED_API' does not define a Python target version. Consider setting 'Py_LIMITED_API' instead.")
  #else
  #warning Limited API usage is enabled with 'CYTHON_LIMITED_API' but 'Py_LIMITED_API' does not define a Python target version. Consider setting 'Py_LIMITED_API' instead.
  #endif
#endif

#include "Python.h"
#ifndef Py_PYTHON_H
    #error Python headers needed to compile C extensions, please install development version of Python.
#elif PY_VERSION_HEX < 0x03080000
    #error Cython requires Python 3.8+.
#else
#define __PYX_ABI_VERSION "3_2_4"
#define CYTHON_HEX_VERSION 0x030204F0
#define CYTHON_FUTURE_DIVISION 1
/* CModulePreamble */
#include <stddef.h>
#ifndef offsetof
  #define offsetof(type, member) ( (size_t) & ((type*)0) -> member )
#endif
#if !defined(_WIN32) && !defined(WIN32) && !defined(MS_WINDOWS)
  #ifndef __stdcall
    #define __stdcall
  #endif
  #ifndef __cdecl
    #define __cdecl
  #endif
  #ifndef __fastcall
    #define __fastcall
  #endif
#endif
#ifndef DL_IMPORT
  #define DL_IMPORT(t) t
#endif
#ifndef DL_EXPORT
  #define DL_EXPORT(t) t
#endif
#define __PYX_COMMA ,
#ifndef PY_LONG_LONG
  #define PY_LONG_LONG LONG_LONG
#endif
#ifndef Py_HUGE_VAL
  #define Py_HUGE_VAL HUGE_VAL
#endif
#define __PYX_LIMITED_VERSION_HEX PY_VERSION_HEX
#if defined(GRAALVM_PYTHON)
  /* For very preliminary testing purposes. Most variables are set the same as PyPy.
     The existence of this section does not imply that anything works or is even tested */
  #define CYTHON_COMPILING_IN_PYPY 0
  #define CYTHON_COMPILING_IN_CPYTHON 0
  #define CYTHON_COMPILING_IN_LIMITED_API 0
  #define CYTHON_COMPILING_IN_GRAAL 1
  #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0
  #undef CYTHON_USE_TYPE_SLOTS
  #define CYTHON_USE_TYPE_SLOTS 0
  #undef CYTHON_USE_TYPE_SPECS
  #define CYTHON_USE_TYPE_SPECS 0
  #undef CYTHON_USE_PYTYPE_LOOKUP
  #define CYTHON_USE_PYTYPE_LOOKUP 0
  #undef CYTHON_USE_PYLIST_INTERNALS
  #define CYTHON_USE_PYLIST_INTERNALS 0
  #undef CYTHON_USE_UNICODE_INTERNALS
  #define CYTHON_USE_UNICODE_INTERNALS 0
  #undef CYTHON_USE_UNICODE_WRITER
  #define CYTHON_USE_UNICODE_WRITER 0
  #undef CYTHON_USE_PYLONG_INTERNALS
  #define CYTHON_USE_PYLONG_INTERNALS 0
  #undef CYTHON_AVOID_BORROWED_REFS
  #define CYTHON_AVOID_BORROWED_REFS 1
  #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
  #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0
  #undef CYTHON_ASSUME_SAFE_MACROS
  #define CYTHON_ASSUME_SAFE_MACROS 0
  #undef CYTHON_ASSUME_SAFE_SIZE
  #define CYTHON_ASSUME_SAFE_SIZE 0
  #undef CYTHON_UNPACK_METHODS
  #define CYTHON_UNPACK_METHODS 0
  #undef CYTHON_FAST_THREAD_STATE
  #define CYTHON_FAST_THREAD_STATE 0
  #undef CYTHON_FAST_GIL
  #define CYTHON_FAST_GIL 0
  #undef CYTHON_METH_FASTCALL
  #define CYTHON_METH_FASTCALL 0
  #undef CYTHON_FAST_PYCALL
  #define CYTHON_FAST_PYCALL 0
  #ifndef CYTHON_PEP487_INIT_SUBCLASS
    #define CYTHON_PEP487_INIT_SUBCLASS 1
  #endif
  #undef CYTHON_PEP489_MULTI_PHASE_INIT
  #define CYTHON_PEP489_MULTI_PHASE_INIT 1
  #undef CYTHON_USE_MODULE_STATE
  #define CYTHON_USE_MODULE_STATE 0
  #undef CYTHON_USE_SYS_MONITORING
  #define CYTHON_USE_SYS_MONITORING 0
  #undef CYTHON_USE_TP_FINALIZE
  #define CYTHON_USE_TP_FINALIZE 0
  #undef CYTHON_USE_AM_SEND
  #define CYTHON_USE_AM_SEND 0
  #undef CYTHON_USE_DICT_VERSIONS
  #define CYTHON_USE_DICT_VERSIONS 0
  #undef CYTHON_USE_EXC_INFO_STACK
  #define CYTHON_USE_EXC_INFO_STACK 1
  #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC
    #define CYTHON_UPDATE_DESCRIPTOR_DOC 0
  #endif
  #undef CYTHON_USE_FREELISTS
  #define CYTHON_USE_FREELISTS 0
  #undef CYTHON_IMMORTAL_CONSTANTS
  #define CYTHON_IMMORTAL_CONSTANTS 0
#elif defined(PYPY_VERSION)
  #define CYTHON_COMPILING_IN_PYPY 1
  #define CYTHON_COMPILING_IN_CPYTHON 0
  #define CYTHON_COMPILING_IN_LIMITED_API 0
  #define CYTHON_COMPILING_IN_GRAAL 0
  #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0
  #undef CYTHON_USE_TYPE_SLOTS
  #define CYTHON_USE_TYPE_SLOTS 1
  #ifndef CYTHON_USE_TYPE_SPECS
    #define CYTHON_USE_TYPE_SPECS 0
  #endif
  #undef CYTHON_USE_PYTYPE_LOOKUP
  #define CYTHON_USE_PYTYPE_LOOKUP 0
  #undef CYTHON_USE_PYLIST_INTERNALS
  #define CYTHON_USE_PYLIST_INTERNALS 0
  #undef CYTHON_USE_UNICODE_INTERNALS
  #define CYTHON_USE_UNICODE_INTERNALS 0
  #undef CYTHON_USE_UNICODE_WRITER
  #define CYTHON_USE_UNICODE_WRITER 0
  #undef CYTHON_USE_PYLONG_INTERNALS
  #define CYTHON_USE_PYLONG_INTERNALS 0
  #undef CYTHON_AVOID_BORROWED_REFS
  #define CYTHON_AVOID_BORROWED_REFS 1
  #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
  #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1
  #undef CYTHON_ASSUME_SAFE_MACROS
  #define CYTHON_ASSUME_SAFE_MACROS 0
  #ifndef CYTHON_ASSUME_SAFE_SIZE
    #define CYTHON_ASSUME_SAFE_SIZE 1
  #endif
  #undef CYTHON_UNPACK_METHODS
  #define CYTHON_UNPACK_METHODS 0
  #undef CYTHON_FAST_THREAD_STATE
  #define CYTHON_FAST_THREAD_STATE 0
  #undef CYTHON_FAST_GIL
  #define CYTHON_FAST_GIL 0
  #undef CYTHON_METH_FASTCALL
  #define CYTHON_METH_FASTCALL 0
  #undef CYTHON_FAST_PYCALL
  #define CYTHON_FAST_PYCALL 0
  #ifndef CYTHON_PEP487_INIT_SUBCLASS
    #define CYTHON_PEP487_INIT_SUBCLASS 1
  #endif
  #if PY_VERSION_HEX < 0x03090000
    #undef CYTHON_PEP489_MULTI_PHASE_INIT
    #define CYTHON_PEP489_MULTI_PHASE_INIT 0
  #elif !defined(CYTHON_PEP489_MULTI_PHASE_INIT)
    #define CYTHON_PEP489_MULTI_PHASE_INIT 1
  #endif
  #undef CYTHON_USE_MODULE_STATE
  #define CYTHON_USE_MODULE_STATE 0
  #undef CYTHON_USE_SYS_MONITORING
  #define CYTHON_USE_SYS_MONITORING 0
  #ifndef CYTHON_USE_TP_FINALIZE
    #define CYTHON_USE_TP_FINALIZE (PYPY_VERSION_NUM >= 0x07030C00)
  #endif
  #undef CYTHON_USE_AM_SEND
  #define CYTHON_USE_AM_SEND 0
  #undef CYTHON_USE_DICT_VERSIONS
  #define CYTHON_USE_DICT_VERSIONS 0
  #undef CYTHON_USE_EXC_INFO_STACK
  #define CYTHON_USE_EXC_INFO_STACK 0
  #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC
    #define CYTHON_UPDATE_DESCRIPTOR_DOC (PYPY_VERSION_NUM >= 0x07031100)
  #endif
  #undef CYTHON_USE_FREELISTS
  #define CYTHON_USE_FREELISTS 0
  #undef CYTHON_IMMORTAL_CONSTANTS
  #define CYTHON_IMMORTAL_CONSTANTS 0
#elif defined(CYTHON_LIMITED_API)
  #ifdef Py_LIMITED_API
    #undef __PYX_LIMITED_VERSION_HEX
    #define __PYX_LIMITED_VERSION_HEX Py_LIMITED_API
  #endif
  #define CYTHON_COMPILING_IN_PYPY 0
  #define CYTHON_COMPILING_IN_CPYTHON 0
  #define CYTHON_COMPILING_IN_LIMITED_API 1
  #define CYTHON_COMPILING_IN_GRAAL 0
  #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0
  #undef CYTHON_USE_TYPE_SLOTS
  #define CYTHON_USE_TYPE_SLOTS 0
  #undef CYTHON_USE_TYPE_SPECS
  #define CYTHON_USE_TYPE_SPECS 1
  #undef CYTHON_USE_PYTYPE_LOOKUP
  #define CYTHON_USE_PYTYPE_LOOKUP 0
  #undef CYTHON_USE_PYLIST_INTERNALS
  #define CYTHON_USE_PYLIST_INTERNALS 0
  #undef CYTHON_USE_UNICODE_INTERNALS
  #define CYTHON_USE_UNICODE_INTERNALS 0
  #ifndef CYTHON_USE_UNICODE_WRITER
    #define CYTHON_USE_UNICODE_WRITER 0
  #endif
  #undef CYTHON_USE_PYLONG_INTERNALS
  #define CYTHON_USE_PYLONG_INTERNALS 0
  #ifndef CYTHON_AVOID_BORROWED_REFS
    #define CYTHON_AVOID_BORROWED_REFS 0
  #endif
  #ifndef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
    #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0
  #endif
  #undef CYTHON_ASSUME_SAFE_MACROS
  #define CYTHON_ASSUME_SAFE_MACROS 0
  #undef CYTHON_ASSUME_SAFE_SIZE
  #define CYTHON_ASSUME_SAFE_SIZE 0
  #undef CYTHON_UNPACK_METHODS
  #define CYTHON_UNPACK_METHODS 0
  #undef CYTHON_FAST_THREAD_STATE
  #define CYTHON_FAST_THREAD_STATE 0
  #undef CYTHON_FAST_GIL
  #define CYTHON_FAST_GIL 0
  #undef CYTHON_METH_FASTCALL
  #define CYTHON_METH_FASTCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000)
  #undef CYTHON_FAST_PYCALL
  #define CYTHON_FAST_PYCALL 0
  #ifndef CYTHON_PEP487_INIT_SUBCLASS
    #define CYTHON_PEP487_INIT_SUBCLASS 1
  #endif
  #ifndef CYTHON_PEP489_MULTI_PHASE_INIT
    #define CYTHON_PEP489_MULTI_PHASE_INIT 1
  #endif
  #ifndef CYTHON_USE_MODULE_STATE
    #define CYTHON_USE_MODULE_STATE 0
  #endif
  #undef CYTHON_USE_SYS_MONITORING
  #define CYTHON_USE_SYS_MONITORING 0
  #ifndef CYTHON_USE_TP_FINALIZE
    #define CYTHON_USE_TP_FINALIZE 0
  #endif
  #ifndef CYTHON_USE_AM_SEND
    #define CYTHON_USE_AM_SEND (__PYX_LIMITED_VERSION_HEX >= 0x030A0000)
  #endif
  #undef CYTHON_USE_DICT_VERSIONS
  #define CYTHON_USE_DICT_VERSIONS 0
  #undef CYTHON_USE_EXC_INFO_STACK
  #define CYTHON_USE_EXC_INFO_STACK 0
  #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC
    #define CYTHON_UPDATE_DESCRIPTOR_DOC 0
  #endif
  #ifndef CYTHON_USE_FREELISTS
  #define CYTHON_USE_FREELISTS 1
  #endif
  #undef CYTHON_IMMORTAL_CONSTANTS
  #define CYTHON_IMMORTAL_CONSTANTS 0
#else
  #define CYTHON_COMPILING_IN_PYPY 0
  #define CYTHON_COMPILING_IN_CPYTHON 1
  #define CYTHON_COMPILING_IN_LIMITED_API 0
  #define CYTHON_COMPILING_IN_GRAAL 0
  #ifdef Py_GIL_DISABLED
    #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 1
  #else
    #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0
  #endif
  #if PY_VERSION_HEX < 0x030A0000
    #undef CYTHON_USE_TYPE_SLOTS
    #define CYTHON_USE_TYPE_SLOTS 1
  #elif !defined(CYTHON_USE_TYPE_SLOTS)
    #define CYTHON_USE_TYPE_SLOTS 1
  #endif
  #ifndef CYTHON_USE_TYPE_SPECS
    #define CYTHON_USE_TYPE_SPECS 0
  #endif
  #ifndef CYTHON_USE_PYTYPE_LOOKUP
    #define CYTHON_USE_PYTYPE_LOOKUP 1
  #endif
  #ifndef CYTHON_USE_PYLONG_INTERNALS
    #define CYTHON_USE_PYLONG_INTERNALS 1
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    #undef CYTHON_USE_PYLIST_INTERNALS
    #define CYTHON_USE_PYLIST_INTERNALS 0
  #elif !defined(CYTHON_USE_PYLIST_INTERNALS)
    #define CYTHON_USE_PYLIST_INTERNALS 1
  #endif
  #ifndef CYTHON_USE_UNICODE_INTERNALS
    #define CYTHON_USE_UNICODE_INTERNALS 1
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING || PY_VERSION_HEX >= 0x030B00A2
    #undef CYTHON_USE_UNICODE_WRITER
    #define CYTHON_USE_UNICODE_WRITER 0
  #elif !defined(CYTHON_USE_UNICODE_WRITER)
    #define CYTHON_USE_UNICODE_WRITER 1
  #endif
  #ifndef CYTHON_AVOID_BORROWED_REFS
    #define CYTHON_AVOID_BORROWED_REFS 0
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
    #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1
  #elif !defined(CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS)
    #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0
  #endif
  #ifndef CYTHON_ASSUME_SAFE_MACROS
    #define CYTHON_ASSUME_SAFE_MACROS 1
  #endif
  #ifndef CYTHON_ASSUME_SAFE_SIZE
    #define CYTHON_ASSUME_SAFE_SIZE 1
  #endif
  #ifndef CYTHON_UNPACK_METHODS
    #define CYTHON_UNPACK_METHODS 1
  #endif
  #ifndef CYTHON_FAST_THREAD_STATE
    #define CYTHON_FAST_THREAD_STATE 1
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    #undef CYTHON_FAST_GIL
    #define CYTHON_FAST_GIL 0
  #elif !defined(CYTHON_FAST_GIL)
    #define CYTHON_FAST_GIL (PY_VERSION_HEX < 0x030C00A6)
  #endif
  #ifndef CYTHON_METH_FASTCALL
    #define CYTHON_METH_FASTCALL 1
  #endif
  #ifndef CYTHON_FAST_PYCALL
    #define CYTHON_FAST_PYCALL 1
  #endif
  #ifndef CYTHON_PEP487_INIT_SUBCLASS
    #define CYTHON_PEP487_INIT_SUBCLASS 1
  #endif
  #ifndef CYTHON_PEP489_MULTI_PHASE_INIT
    #define CYTHON_PEP489_MULTI_PHASE_INIT 1
  #endif
  #ifndef CYTHON_USE_MODULE_STATE
    #define CYTHON_USE_MODULE_STATE 0
  #endif
  #ifndef CYTHON_USE_SYS_MONITORING
    #define CYTHON_USE_SYS_MONITORING (PY_VERSION_HEX >= 0x030d00B1)
  #endif
  #ifndef CYTHON_USE_TP_FINALIZE
    #define CYTHON_USE_TP_FINALIZE 1
  #endif
  #ifndef CYTHON_USE_AM_SEND
    #define CYTHON_USE_AM_SEND 1
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    #undef CYTHON_USE_DICT_VERSIONS
    #define CYTHON_USE_DICT_VERSIONS 0
  #elif !defined(CYTHON_USE_DICT_VERSIONS)
    #define CYTHON_USE_DICT_VERSIONS  (PY_VERSION_HEX < 0x030C00A5 && !CYTHON_USE_MODULE_STATE)
  #endif
  #ifndef CYTHON_USE_EXC_INFO_STACK
    #define CYTHON_USE_EXC_INFO_STACK 1
  #endif
  #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC
    #define CYTHON_UPDATE_DESCRIPTOR_DOC 1
  #endif
  #ifndef CYTHON_USE_FREELISTS
    #define CYTHON_USE_FREELISTS (!CYTHON_COMPILING_IN_CPYTHON_FREETHREADING)
  #endif
  #if defined(CYTHON_IMMORTAL_CONSTANTS) && PY_VERSION_HEX < 0x030C0000
    #undef CYTHON_IMMORTAL_CONSTANTS
    #define CYTHON_IMMORTAL_CONSTANTS 0  // definitely won't work
  #elif !defined(CYTHON_IMMORTAL_CONSTANTS)
    #define CYTHON_IMMORTAL_CONSTANTS (PY_VERSION_HEX >= 0x030C0000 && !CYTHON_USE_MODULE_STATE && CYTHON_COMPILING_IN_CPYTHON_FREETHREADING)
  #endif
#endif
#ifndef CYTHON_COMPRESS_STRINGS
  #define CYTHON_COMPRESS_STRINGS 1
#endif
#ifndef CYTHON_FAST_PYCCALL
#define CYTHON_FAST_PYCCALL  CYTHON_FAST_PYCALL
#endif
#ifndef CYTHON_VECTORCALL
#if CYTHON_COMPILING_IN_LIMITED_API
#define CYTHON_VECTORCALL  (__PYX_LIMITED_VERSION_HEX >= 0x030C0000)
#else
#define CYTHON_VECTORCALL  (CYTHON_FAST_PYCCALL)
#endif
#endif
#if CYTHON_USE_PYLONG_INTERNALS
  #undef SHIFT
  #undef BASE
  #undef MASK
  #ifdef SIZEOF_VOID_P
    enum { __pyx_check_sizeof_voidp = 1 / (int)(SIZEOF_VOID_P == sizeof(void*)) };
  #endif
#endif
#ifndef __has_attribute
  #define __has_attribute(x) 0
#endif
#ifndef __has_cpp_attribute
  #define __has_cpp_attribute(x) 0
#endif
#ifndef CYTHON_RESTRICT
  #if defined(__GNUC__)
    #define CYTHON_RESTRICT __restrict__
  #elif defined(_MSC_VER) && _MSC_VER >= 1400
    #define CYTHON_RESTRICT __restrict
  #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
    #define CYTHON_RESTRICT restrict
  #else
    #define CYTHON_RESTRICT
  #endif
#endif
#ifndef CYTHON_UNUSED
  #if defined(__cplusplus)
    /* for clang __has_cpp_attribute(maybe_unused) is true even before C++17
     * but leads to warnings with -pedantic, since it is a C++17 feature */
    #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L)
      #if __has_cpp_attribute(maybe_unused)
        #define CYTHON_UNUSED [[maybe_unused]]
      #endif
    #endif
  #endif
#endif
#ifndef CYTHON_UNUSED
# if defined(__GNUC__)
#   if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
#     define CYTHON_UNUSED __attribute__ ((__unused__))
#   else
#     define CYTHON_UNUSED
#   endif
# elif defined(__ICC) || (defined(__INTEL_COMPILER) && !defined(_MSC_VER))
#   define CYTHON_UNUSED __attribute__ ((__unused__))
# else
#   define CYTHON_UNUSED
# endif
#endif
#ifndef CYTHON_UNUSED_VAR
#  if defined(__cplusplus)
     template<class T> void CYTHON_UNUSED_VAR( const T& ) { }
#  else
#    define CYTHON_UNUSED_VAR(x) (void)(x)
#  endif
#endif
#ifndef CYTHON_MAYBE_UNUSED_VAR
  #define CYTHON_MAYBE_UNUSED_VAR(x) CYTHON_UNUSED_VAR(x)
#endif
#ifndef CYTHON_NCP_UNUSED
# if CYTHON_COMPILING_IN_CPYTHON && !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
#  define CYTHON_NCP_UNUSED
# else
#  define CYTHON_NCP_UNUSED CYTHON_UNUSED
# endif
#endif
#ifndef CYTHON_USE_CPP_STD_MOVE
  #if defined(__cplusplus) && (\
    __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1600))
    #define CYTHON_USE_CPP_STD_MOVE 1
  #else
    #define CYTHON_USE_CPP_STD_MOVE 0
  #endif
#endif
#define __Pyx_void_to_None(void_result) ((void)(void_result), Py_INCREF(Py_None), Py_None)
#include <stdint.h>
typedef uintptr_t  __pyx_uintptr_t;
#ifndef CYTHON_FALLTHROUGH
  #if defined(__cplusplus)
    /* for clang __has_cpp_attribute(fallthrough) is true even before C++17
     * but leads to warnings with -pedantic, since it is a C++17 feature */
    #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L)
      #if __has_cpp_attribute(fallthrough)
        #define CYTHON_FALLTHROUGH [[fallthrough]]
      #endif
    #endif
    #ifndef CYTHON_FALLTHROUGH
      #if __has_cpp_attribute(clang::fallthrough)
        #define CYTHON_FALLTHROUGH [[clang::fallthrough]]
      #elif __has_cpp_attribute(gnu::fallthrough)
        #define CYTHON_FALLTHROUGH [[gnu::fallthrough]]
      #endif
    #endif
  #endif
  #ifndef CYTHON_FALLTHROUGH
    #if __has_attribute(fallthrough)
      #define CYTHON_FALLTHROUGH __attribute__((fallthrough))
    #else
      #define CYTHON_FALLTHROUGH
    #endif
  #endif
  #if defined(__clang__) && defined(__apple_build_version__)
    #if __apple_build_version__ < 7000000
      #undef  CYTHON_FALLTHROUGH
      #define CYTHON_FALLTHROUGH
    #endif
  #endif
#endif
#ifndef Py_UNREACHABLE
  #define Py_UNREACHABLE()  assert(0); abort()
#endif
#ifdef __cplusplus
  template <typename T>
  struct __PYX_IS_UNSIGNED_IMPL {static const bool value = T(0) < T(-1);};
  #define __PYX_IS_UNSIGNED(type) (__PYX_IS_UNSIGNED_IMPL<type>::value)
#else
  #define __PYX_IS_UNSIGNED(type) (((type)-1) > 0)
#endif
#if CYTHON_COMPILING_IN_PYPY == 1
  #define __PYX_NEED_TP_PRINT_SLOT  (PY_VERSION_HEX < 0x030A0000)
#else
  #define __PYX_NEED_TP_PRINT_SLOT  (PY_VERSION_HEX < 0x03090000)
#endif
#define __PYX_REINTERPRET_FUNCION(func_pointer, other_pointer) ((func_pointer)(void(*)(void))(other_pointer))

/* CInitCode */
#ifndef CYTHON_INLINE
  #if defined(__clang__)
    #define CYTHON_INLINE __inline__ __attribute__ ((__unused__))
  #elif defined(__GNUC__)
    #define CYTHON_INLINE __inline__
  #elif defined(_MSC_VER)
    #define CYTHON_INLINE __inline
  #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
    #define CYTHON_INLINE inline
  #else
    #define CYTHON_INLINE
  #endif
#endif

/* PythonCompatibility */
#define __PYX_BUILD_PY_SSIZE_T "n"
#define CYTHON_FORMAT_SSIZE_T "z"
#define __Pyx_BUILTIN_MODULE_NAME "builtins"
#define __Pyx_DefaultClassType PyType_Type
#if CYTHON_COMPILING_IN_LIMITED_API
    #ifndef CO_OPTIMIZED
    static int CO_OPTIMIZED;
    #endif
    #ifndef CO_NEWLOCALS
    static int CO_NEWLOCALS;
    #endif
    #ifndef CO_VARARGS
    static int CO_VARARGS;
    #endif
    #ifndef CO_VARKEYWORDS
    static int CO_VARKEYWORDS;
    #endif
    #ifndef CO_ASYNC_GENERATOR
    static int CO_ASYNC_GENERATOR;
    #endif
    #ifndef CO_GENERATOR
    static int CO_GENERATOR;
    #endif
    #ifndef CO_COROUTINE
    static int CO_COROUTINE;
    #endif
#else
    #ifndef CO_COROUTINE
      #define CO_COROUTINE 0x80
    #endif
    #ifndef CO_ASYNC_GENERATOR
      #define CO_ASYNC_GENERATOR 0x200
    #endif
#endif
static int __Pyx_init_co_variables(void);
#if PY_VERSION_HEX >= 0x030900A4 || defined(Py_IS_TYPE)
  #define __Pyx_IS_TYPE(ob, type) Py_IS_TYPE(ob, type)
#else
  #define __Pyx_IS_TYPE(ob, type) (((const PyObject*)ob)->ob_type == (type))
#endif
#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_Is)
  #define __Pyx_Py_Is(x, y)  Py_Is(x, y)
#else
  #define __Pyx_Py_Is(x, y) ((x) == (y))
#endif
#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsNone)
  #define __Pyx_Py_IsNone(ob) Py_IsNone(ob)
#else
  #define __Pyx_Py_IsNone(ob) __Pyx_Py_Is((ob), Py_None)
#endif
#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsTrue)
  #define __Pyx_Py_IsTrue(ob) Py_IsTrue(ob)
#else
  #define __Pyx_Py_IsTrue(ob) __Pyx_Py_Is((ob), Py_True)
#endif
#if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsFalse)
  #define __Pyx_Py_IsFalse(ob) Py_IsFalse(ob)
#else
  #define __Pyx_Py_IsFalse(ob) __Pyx_Py_Is((ob), Py_False)
#endif
#define __Pyx_NoneAsNull(obj)  (__Pyx_Py_IsNone(obj) ? NULL : (obj))
#if PY_VERSION_HEX >= 0x030900F0 && !CYTHON_COMPILING_IN_PYPY
  #define __Pyx_PyObject_GC_IsFinalized(o) PyObject_GC_IsFinalized(o)
#else
  #define __Pyx_PyObject_GC_IsFinalized(o) _PyGC_FINALIZED(o)
#endif
#ifndef Py_TPFLAGS_CHECKTYPES
  #define Py_TPFLAGS_CHECKTYPES 0
#endif
#ifndef Py_TPFLAGS_HAVE_INDEX
  #define Py_TPFLAGS_HAVE_INDEX 0
#endif
#ifndef Py_TPFLAGS_HAVE_NEWBUFFER
  #define Py_TPFLAGS_HAVE_NEWBUFFER 0
#endif
#ifndef Py_TPFLAGS_HAVE_FINALIZE
  #define Py_TPFLAGS_HAVE_FINALIZE 0
#endif
#ifndef Py_TPFLAGS_SEQUENCE
  #define Py_TPFLAGS_SEQUENCE 0
#endif
#ifndef Py_TPFLAGS_MAPPING
  #define Py_TPFLAGS_MAPPING 0
#endif
#ifndef Py_TPFLAGS_IMMUTABLETYPE
  #define Py_TPFLAGS_IMMUTABLETYPE (1UL << 8)
#endif
#ifndef Py_TPFLAGS_DISALLOW_INSTANTIATION
  #define Py_TPFLAGS_DISALLOW_INSTANTIATION (1UL << 7)
#endif
#ifndef METH_STACKLESS
  #define METH_STACKLESS 0
#endif
#ifndef METH_FASTCALL
  #ifndef METH_FASTCALL
     #define METH_FASTCALL 0x80
  #endif
  typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject *const *args, Py_ssize_t nargs);
  typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject *const *args,
                                                          Py_ssize_t nargs, PyObject *kwnames);
#else
  #if PY_VERSION_HEX >= 0x030d00A4
  #  define __Pyx_PyCFunctionFast PyCFunctionFast
  #  define __Pyx_PyCFunctionFastWithKeywords PyCFunctionFastWithKeywords
  #else
  #  define __Pyx_PyCFunctionFast _PyCFunctionFast
  #  define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords
  #endif
#endif
#if CYTHON_METH_FASTCALL
  #define __Pyx_METH_FASTCALL METH_FASTCALL
  #define __Pyx_PyCFunction_FastCall __Pyx_PyCFunctionFast
  #define __Pyx_PyCFunction_FastCallWithKeywords __Pyx_PyCFunctionFastWithKeywords
#else
  #define __Pyx_METH_FASTCALL METH_VARARGS
  #define __Pyx_PyCFunction_FastCall PyCFunction
  #define __Pyx_PyCFunction_FastCallWithKeywords PyCFunctionWithKeywords
#endif
#if CYTHON_VECTORCALL
  #define __pyx_vectorcallfunc vectorcallfunc
  #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET  PY_VECTORCALL_ARGUMENTS_OFFSET
  #define __Pyx_PyVectorcall_NARGS(n)  PyVectorcall_NARGS((size_t)(n))
#else
  #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET  0
  #define __Pyx_PyVectorcall_NARGS(n)  ((Py_ssize_t)(n))
#endif
#if PY_VERSION_HEX >= 0x030900B1
#define __Pyx_PyCFunction_CheckExact(func)  PyCFunction_CheckExact(func)
#else
#define __Pyx_PyCFunction_CheckExact(func)  PyCFunction_Check(func)
#endif
#define __Pyx_CyOrPyCFunction_Check(func)  PyCFunction_Check(func)
#if CYTHON_COMPILING_IN_CPYTHON
#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func)  (((PyCFunctionObject*)(func))->m_ml->ml_meth)
#elif !CYTHON_COMPILING_IN_LIMITED_API
#define __Pyx_CyOrPyCFunction_GET_FUNCTION(func)  PyCFunction_GET_FUNCTION(func)
#endif
#if CYTHON_COMPILING_IN_CPYTHON
#define __Pyx_CyOrPyCFunction_GET_FLAGS(func)  (((PyCFunctionObject*)(func))->m_ml->ml_flags)
static CYTHON_INLINE PyObject* __Pyx_CyOrPyCFunction_GET_SELF(PyObject *func) {
    return (__Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_STATIC) ? NULL : ((PyCFunctionObject*)func)->m_self;
}
#endif
static CYTHON_INLINE int __Pyx__IsSameCFunction(PyObject *func, void (*cfunc)(void)) {
#if CYTHON_COMPILING_IN_LIMITED_API
    return PyCFunction_Check(func) && PyCFunction_GetFunction(func) == (PyCFunction) cfunc;
#else
    return PyCFunction_Check(func) && PyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc;
#endif
}
#define __Pyx_IsSameCFunction(func, cfunc)   __Pyx__IsSameCFunction(func, cfunc)
#if PY_VERSION_HEX < 0x03090000 || (CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000)
  #define __Pyx_PyType_FromModuleAndSpec(m, s, b)  ((void)m, PyType_FromSpecWithBases(s, b))
  typedef PyObject *(*__Pyx_PyCMethod)(PyObject *, PyTypeObject *, PyObject *const *, size_t, PyObject *);
#else
  #define __Pyx_PyType_FromModuleAndSpec(m, s, b)  PyType_FromModuleAndSpec(m, s, b)
  #define __Pyx_PyCMethod  PyCMethod
#endif
#ifndef METH_METHOD
  #define METH_METHOD 0x200
#endif
#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Malloc)
  #define PyObject_Malloc(s)   PyMem_Malloc(s)
  #define PyObject_Free(p)     PyMem_Free(p)
  #define PyObject_Realloc(p)  PyMem_Realloc(p)
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
  #define __Pyx_PyFrame_SetLineNumber(frame, lineno)
#elif CYTHON_COMPILING_IN_GRAAL && defined(GRAALPY_VERSION_NUM) && GRAALPY_VERSION_NUM > 0x19000000
  #define __Pyx_PyCode_HasFreeVars(co)  (PyCode_GetNumFree(co) > 0)
  #define __Pyx_PyFrame_SetLineNumber(frame, lineno) GraalPyFrame_SetLineNumber((frame), (lineno))
#elif CYTHON_COMPILING_IN_GRAAL
  #define __Pyx_PyCode_HasFreeVars(co)  (PyCode_GetNumFree(co) > 0)
  #define __Pyx_PyFrame_SetLineNumber(frame, lineno) _PyFrame_SetLineNumber((frame), (lineno))
#else
  #define __Pyx_PyCode_HasFreeVars(co)  (PyCode_GetNumFree(co) > 0)
  #define __Pyx_PyFrame_SetLineNumber(frame, lineno)  (frame)->f_lineno = (lineno)
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
  #define __Pyx_PyThreadState_Current PyThreadState_Get()
#elif !CYTHON_FAST_THREAD_STATE
  #define __Pyx_PyThreadState_Current PyThreadState_GET()
#elif PY_VERSION_HEX >= 0x030d00A1
  #define __Pyx_PyThreadState_Current PyThreadState_GetUnchecked()
#else
  #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet()
#endif
#if CYTHON_USE_MODULE_STATE
static CYTHON_INLINE void *__Pyx__PyModule_GetState(PyObject *op)
{
    void *result;
    result = PyModule_GetState(op);
    if (!result)
        Py_FatalError("Couldn't find the module state");
    return result;
}
#define __Pyx_PyModule_GetState(o) (__pyx_mstatetype *)__Pyx__PyModule_GetState(o)
#else
#define __Pyx_PyModule_GetState(op) ((void)op,__pyx_mstate_global)
#endif
#define __Pyx_PyObject_GetSlot(obj, name, func_ctype)  __Pyx_PyType_GetSlot(Py_TYPE((PyObject *) obj), name, func_ctype)
#define __Pyx_PyObject_TryGetSlot(obj, name, func_ctype) __Pyx_PyType_TryGetSlot(Py_TYPE(obj), name, func_ctype)
#define __Pyx_PyObject_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(Py_TYPE(obj), sub, name, func_ctype)
#define __Pyx_PyObject_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSubSlot(Py_TYPE(obj), sub, name, func_ctype)
#if CYTHON_USE_TYPE_SLOTS
  #define __Pyx_PyType_GetSlot(type, name, func_ctype)  ((type)->name)
  #define __Pyx_PyType_TryGetSlot(type, name, func_ctype) __Pyx_PyType_GetSlot(type, name, func_ctype)
  #define __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) (((type)->sub) ? ((type)->sub->name) : NULL)
  #define __Pyx_PyType_TryGetSubSlot(type, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype)
#else
  #define __Pyx_PyType_GetSlot(type, name, func_ctype)  ((func_ctype) PyType_GetSlot((type), Py_##name))
  #define __Pyx_PyType_TryGetSlot(type, name, func_ctype)\
    ((__PYX_LIMITED_VERSION_HEX >= 0x030A0000 ||\
     (PyType_GetFlags(type) & Py_TPFLAGS_HEAPTYPE) || __Pyx_get_runtime_version() >= 0x030A0000) ?\
     __Pyx_PyType_GetSlot(type, name, func_ctype) : NULL)
  #define __Pyx_PyType_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSlot(obj, name, func_ctype)
  #define __Pyx_PyType_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSlot(obj, name, func_ctype)
#endif
#if CYTHON_COMPILING_IN_CPYTHON || defined(_PyDict_NewPresized)
#define __Pyx_PyDict_NewPresized(n)  ((n <= 8) ? PyDict_New() : _PyDict_NewPresized(n))
#else
#define __Pyx_PyDict_NewPresized(n)  PyDict_New()
#endif
#define __Pyx_PyNumber_Divide(x,y)         PyNumber_TrueDivide(x,y)
#define __Pyx_PyNumber_InPlaceDivide(x,y)  PyNumber_InPlaceTrueDivide(x,y)
#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_UNICODE_INTERNALS
#define __Pyx_PyDict_GetItemStrWithError(dict, name)  _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash)
static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStr(PyObject *dict, PyObject *name) {
    PyObject *res = __Pyx_PyDict_GetItemStrWithError(dict, name);
    if (res == NULL) PyErr_Clear();
    return res;
}
#elif !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07020000
#define __Pyx_PyDict_GetItemStrWithError  PyDict_GetItemWithError
#define __Pyx_PyDict_GetItemStr           PyDict_GetItem
#else
static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStrWithError(PyObject *dict, PyObject *name) {
#if CYTHON_COMPILING_IN_PYPY
    return PyDict_GetItem(dict, name);
#else
    PyDictEntry *ep;
    PyDictObject *mp = (PyDictObject*) dict;
    long hash = ((PyStringObject *) name)->ob_shash;
    assert(hash != -1);
    ep = (mp->ma_lookup)(mp, name, hash);
    if (ep == NULL) {
        return NULL;
    }
    return ep->me_value;
#endif
}
#define __Pyx_PyDict_GetItemStr           PyDict_GetItem
#endif
#if CYTHON_USE_TYPE_SLOTS
  #define __Pyx_PyType_GetFlags(tp)   (((PyTypeObject *)tp)->tp_flags)
  #define __Pyx_PyType_HasFeature(type, feature)  ((__Pyx_PyType_GetFlags(type) & (feature)) != 0)
#else
  #define __Pyx_PyType_GetFlags(tp)   (PyType_GetFlags((PyTypeObject *)tp))
  #define __Pyx_PyType_HasFeature(type, feature)  PyType_HasFeature(type, feature)
#endif
#define __Pyx_PyObject_GetIterNextFunc(iterator)  __Pyx_PyObject_GetSlot(iterator, tp_iternext, iternextfunc)
#if CYTHON_USE_TYPE_SPECS
#define __Pyx_PyHeapTypeObject_GC_Del(obj)  {\
    PyTypeObject *type = Py_TYPE((PyObject*)obj);\
    assert(__Pyx_PyType_HasFeature(type, Py_TPFLAGS_HEAPTYPE));\
    PyObject_GC_Del(obj);\
    Py_DECREF(type);\
}
#else
#define __Pyx_PyHeapTypeObject_GC_Del(obj)  PyObject_GC_Del(obj)
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
  #define __Pyx_PyUnicode_READY(op)       (0)
  #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_ReadChar(u, i)
  #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u)   ((void)u, 1114111U)
  #define __Pyx_PyUnicode_KIND(u)         ((void)u, (0))
  #define __Pyx_PyUnicode_DATA(u)         ((void*)u)
  #define __Pyx_PyUnicode_READ(k, d, i)   ((void)k, PyUnicode_ReadChar((PyObject*)(d), i))
  #define __Pyx_PyUnicode_IS_TRUE(u)      (0 != PyUnicode_GetLength(u))
#else
  #if PY_VERSION_HEX >= 0x030C0000
    #define __Pyx_PyUnicode_READY(op)       (0)
  #else
    #define __Pyx_PyUnicode_READY(op)       (likely(PyUnicode_IS_READY(op)) ?\
                                                0 : _PyUnicode_Ready((PyObject *)(op)))
  #endif
  #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i)
  #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u)   PyUnicode_MAX_CHAR_VALUE(u)
  #define __Pyx_PyUnicode_KIND(u)         ((int)PyUnicode_KIND(u))
  #define __Pyx_PyUnicode_DATA(u)         PyUnicode_DATA(u)
  #define __Pyx_PyUnicode_READ(k, d, i)   PyUnicode_READ(k, d, i)
  #define __Pyx_PyUnicode_WRITE(k, d, i, ch)  PyUnicode_WRITE(k, d, i, (Py_UCS4) ch)
  #if PY_VERSION_HEX >= 0x030C0000
    #define __Pyx_PyUnicode_IS_TRUE(u)      (0 != PyUnicode_GET_LENGTH(u))
  #else
    #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03090000
    #define __Pyx_PyUnicode_IS_TRUE(u)      (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : ((PyCompactUnicodeObject *)(u))->wstr_length))
    #else
    #define __Pyx_PyUnicode_IS_TRUE(u)      (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u)))
    #endif
  #endif
#endif
#if CYTHON_COMPILING_IN_PYPY
  #define __Pyx_PyUnicode_Concat(a, b)      PyNumber_Add(a, b)
  #define __Pyx_PyUnicode_ConcatSafe(a, b)  PyNumber_Add(a, b)
#else
  #define __Pyx_PyUnicode_Concat(a, b)      PyUnicode_Concat(a, b)
  #define __Pyx_PyUnicode_ConcatSafe(a, b)  ((unlikely((a) == Py_None) || unlikely((b) == Py_None)) ?\
      PyNumber_Add(a, b) : __Pyx_PyUnicode_Concat(a, b))
#endif
#if CYTHON_COMPILING_IN_PYPY
  #if !defined(PyUnicode_DecodeUnicodeEscape)
    #define PyUnicode_DecodeUnicodeEscape(s, size, errors)  PyUnicode_Decode(s, size, "unicode_escape", errors)
  #endif
  #if !defined(PyUnicode_Contains)
    #define PyUnicode_Contains(u, s)  PySequence_Contains(u, s)
  #endif
  #if !defined(PyByteArray_Check)
    #define PyByteArray_Check(obj)  PyObject_TypeCheck(obj, &PyByteArray_Type)
  #endif
  #if !defined(PyObject_Format)
    #define PyObject_Format(obj, fmt)  PyObject_CallMethod(obj, "__format__", "O", fmt)
  #endif
#endif
#define __Pyx_PyUnicode_FormatSafe(a, b)  ((unlikely((a) == Py_None || (PyUnicode_Check(b) && !PyUnicode_CheckExact(b)))) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b))
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  #define __Pyx_PySequence_ListKeepNew(obj)\
    (likely(PyList_CheckExact(obj) && PyUnstable_Object_IsUniquelyReferenced(obj)) ? __Pyx_NewRef(obj) : PySequence_List(obj))
#elif CYTHON_COMPILING_IN_CPYTHON
  #define __Pyx_PySequence_ListKeepNew(obj)\
    (likely(PyList_CheckExact(obj) && Py_REFCNT(obj) == 1) ? __Pyx_NewRef(obj) : PySequence_List(obj))
#else
  #define __Pyx_PySequence_ListKeepNew(obj)  PySequence_List(obj)
#endif
#ifndef PySet_CheckExact
  #define PySet_CheckExact(obj)        __Pyx_IS_TYPE(obj, &PySet_Type)
#endif
#if PY_VERSION_HEX >= 0x030900A4
  #define __Pyx_SET_REFCNT(obj, refcnt) Py_SET_REFCNT(obj, refcnt)
  #define __Pyx_SET_SIZE(obj, size) Py_SET_SIZE(obj, size)
#else
  #define __Pyx_SET_REFCNT(obj, refcnt) Py_REFCNT(obj) = (refcnt)
  #define __Pyx_SET_SIZE(obj, size) Py_SIZE(obj) = (size)
#endif
enum __Pyx_ReferenceSharing {
  __Pyx_ReferenceSharing_DefinitelyUnique, // We created it so we know it's unshared - no need to check
  __Pyx_ReferenceSharing_OwnStrongReference,
  __Pyx_ReferenceSharing_FunctionArgument,
  __Pyx_ReferenceSharing_SharedReference, // Never trust it to be unshared because it's a global or similar
};
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && PY_VERSION_HEX >= 0x030E0000
#define __Pyx_IS_UNIQUELY_REFERENCED(o, sharing)\
    (sharing == __Pyx_ReferenceSharing_DefinitelyUnique ? 1 :\
      (sharing == __Pyx_ReferenceSharing_FunctionArgument ? PyUnstable_Object_IsUniqueReferencedTemporary(o) :\
      (sharing == __Pyx_ReferenceSharing_OwnStrongReference ? PyUnstable_Object_IsUniquelyReferenced(o) : 0)))
#elif (CYTHON_COMPILING_IN_CPYTHON && !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING) || CYTHON_COMPILING_IN_LIMITED_API
#define __Pyx_IS_UNIQUELY_REFERENCED(o, sharing) (((void)sharing), Py_REFCNT(o) == 1)
#else
#define __Pyx_IS_UNIQUELY_REFERENCED(o, sharing) (((void)o), ((void)sharing), 0)
#endif
#if CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
  #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
    #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i)
  #elif CYTHON_COMPILING_IN_LIMITED_API || !CYTHON_ASSUME_SAFE_MACROS
    #define __Pyx_PyList_GetItemRef(o, i) (likely((i) >= 0) ? PySequence_GetItem(o, i) : (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL))
  #else
    #define __Pyx_PyList_GetItemRef(o, i) PySequence_ITEM(o, i)
  #endif
#elif CYTHON_COMPILING_IN_LIMITED_API || !CYTHON_ASSUME_SAFE_MACROS
  #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
    #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i)
  #else
    #define __Pyx_PyList_GetItemRef(o, i) __Pyx_XNewRef(PyList_GetItem(o, i))
  #endif
#else
  #define __Pyx_PyList_GetItemRef(o, i) __Pyx_NewRef(PyList_GET_ITEM(o, i))
#endif
#if CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS && !CYTHON_COMPILING_IN_LIMITED_API && CYTHON_ASSUME_SAFE_MACROS
  #define __Pyx_PyList_GetItemRefFast(o, i, unsafe_shared) (__Pyx_IS_UNIQUELY_REFERENCED(o, unsafe_shared) ?\
    __Pyx_NewRef(PyList_GET_ITEM(o, i)) : __Pyx_PyList_GetItemRef(o, i))
#else
  #define __Pyx_PyList_GetItemRefFast(o, i, unsafe_shared) __Pyx_PyList_GetItemRef(o, i)
#endif
#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
#define __Pyx_PyDict_GetItemRef(dict, key, result) PyDict_GetItemRef(dict, key, result)
#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) {
  *result = PyObject_GetItem(dict, key);
  if (*result == NULL) {
    if (PyErr_ExceptionMatches(PyExc_KeyError)) {
      PyErr_Clear();
      return 0;
    }
    return -1;
  }
  return 1;
}
#else
static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) {
  *result = PyDict_GetItemWithError(dict, key);
  if (*result == NULL) {
    return PyErr_Occurred() ? -1 : 0;
  }
  Py_INCREF(*result);
  return 1;
}
#endif
#if defined(CYTHON_DEBUG_VISIT_CONST) && CYTHON_DEBUG_VISIT_CONST
  #define __Pyx_VISIT_CONST(obj)  Py_VISIT(obj)
#else
  #define __Pyx_VISIT_CONST(obj)
#endif
#if CYTHON_ASSUME_SAFE_MACROS
  #define __Pyx_PySequence_ITEM(o, i) PySequence_ITEM(o, i)
  #define __Pyx_PySequence_SIZE(seq)  Py_SIZE(seq)
  #define __Pyx_PyTuple_SET_ITEM(o, i, v) (PyTuple_SET_ITEM(o, i, v), (0))
  #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GET_ITEM(o, i)
  #define __Pyx_PyList_SET_ITEM(o, i, v) (PyList_SET_ITEM(o, i, v), (0))
  #define __Pyx_PyList_GET_ITEM(o, i) PyList_GET_ITEM(o, i)
#else
  #define __Pyx_PySequence_ITEM(o, i) PySequence_GetItem(o, i)
  #define __Pyx_PySequence_SIZE(seq)  PySequence_Size(seq)
  #define __Pyx_PyTuple_SET_ITEM(o, i, v) PyTuple_SetItem(o, i, v)
  #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GetItem(o, i)
  #define __Pyx_PyList_SET_ITEM(o, i, v) PyList_SetItem(o, i, v)
  #define __Pyx_PyList_GET_ITEM(o, i) PyList_GetItem(o, i)
#endif
#if CYTHON_ASSUME_SAFE_SIZE
  #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_GET_SIZE(o)
  #define __Pyx_PyList_GET_SIZE(o) PyList_GET_SIZE(o)
  #define __Pyx_PySet_GET_SIZE(o) PySet_GET_SIZE(o)
  #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_GET_SIZE(o)
  #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_GET_SIZE(o)
  #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GET_LENGTH(o)
#else
  #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_Size(o)
  #define __Pyx_PyList_GET_SIZE(o) PyList_Size(o)
  #define __Pyx_PySet_GET_SIZE(o) PySet_Size(o)
  #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_Size(o)
  #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_Size(o)
  #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GetLength(o)
#endif
#if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_InternFromString)
  #define PyUnicode_InternFromString(s) PyUnicode_FromString(s)
#endif
#define __Pyx_PyLong_FromHash_t PyLong_FromSsize_t
#define __Pyx_PyLong_AsHash_t   __Pyx_PyIndex_AsSsize_t
#if __PYX_LIMITED_VERSION_HEX >= 0x030A0000
    #define __Pyx_PySendResult PySendResult
#else
    typedef enum {
        PYGEN_RETURN = 0,
        PYGEN_ERROR = -1,
        PYGEN_NEXT = 1,
    } __Pyx_PySendResult;
#endif
#if CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX < 0x030A00A3
  typedef __Pyx_PySendResult (*__Pyx_pyiter_sendfunc)(PyObject *iter, PyObject *value, PyObject **result);
#else
  #define __Pyx_pyiter_sendfunc sendfunc
#endif
#if !CYTHON_USE_AM_SEND
#define __PYX_HAS_PY_AM_SEND 0
#elif __PYX_LIMITED_VERSION_HEX >= 0x030A0000
#define __PYX_HAS_PY_AM_SEND 1
#else
#define __PYX_HAS_PY_AM_SEND 2  // our own backported implementation
#endif
#if __PYX_HAS_PY_AM_SEND < 2
    #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods
#else
    typedef struct {
        unaryfunc am_await;
        unaryfunc am_aiter;
        unaryfunc am_anext;
        __Pyx_pyiter_sendfunc am_send;
    } __Pyx_PyAsyncMethodsStruct;
    #define __Pyx_SlotTpAsAsync(s) ((PyAsyncMethods*)(s))
#endif
#if CYTHON_USE_AM_SEND && PY_VERSION_HEX < 0x030A00F0
    #define __Pyx_TPFLAGS_HAVE_AM_SEND (1UL << 21)
#else
    #define __Pyx_TPFLAGS_HAVE_AM_SEND (0)
#endif
#if PY_VERSION_HEX >= 0x03090000
#define __Pyx_PyInterpreterState_Get() PyInterpreterState_Get()
#else
#define __Pyx_PyInterpreterState_Get() PyThreadState_Get()->interp
#endif
#if CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030A0000
#ifdef __cplusplus
extern "C"
#endif
PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize);
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
static int __Pyx_init_co_variable(PyObject *inspect, const char* name, int *write_to) {
    int value;
    PyObject *py_value = PyObject_GetAttrString(inspect, name);
    if (!py_value) return 0;
    value = (int) PyLong_AsLong(py_value);
    Py_DECREF(py_value);
    *write_to = value;
    return value != -1 || !PyErr_Occurred();
}
static int __Pyx_init_co_variables(void) {
    PyObject *inspect;
    int result;
    inspect = PyImport_ImportModule("inspect");
    result =
#if !defined(CO_OPTIMIZED)
        __Pyx_init_co_variable(inspect, "CO_OPTIMIZED", &CO_OPTIMIZED) &&
#endif
#if !defined(CO_NEWLOCALS)
        __Pyx_init_co_variable(inspect, "CO_NEWLOCALS", &CO_NEWLOCALS) &&
#endif
#if !defined(CO_VARARGS)
        __Pyx_init_co_variable(inspect, "CO_VARARGS", &CO_VARARGS) &&
#endif
#if !defined(CO_VARKEYWORDS)
        __Pyx_init_co_variable(inspect, "CO_VARKEYWORDS", &CO_VARKEYWORDS) &&
#endif
#if !defined(CO_ASYNC_GENERATOR)
        __Pyx_init_co_variable(inspect, "CO_ASYNC_GENERATOR", &CO_ASYNC_GENERATOR) &&
#endif
#if !defined(CO_GENERATOR)
        __Pyx_init_co_variable(inspect, "CO_GENERATOR", &CO_GENERATOR) &&
#endif
#if !defined(CO_COROUTINE)
        __Pyx_init_co_variable(inspect, "CO_COROUTINE", &CO_COROUTINE) &&
#endif
        1;
    Py_DECREF(inspect);
    return result ? 0 : -1;
}
#else
static int __Pyx_init_co_variables(void) {
    return 0;  // It's a limited API-only feature
}
#endif

/* MathInitCode */
#if defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS)
  #ifndef _USE_MATH_DEFINES
    #define _USE_MATH_DEFINES
  #endif
#endif
#include <math.h>
#if defined(__CYGWIN__) && defined(_LDBL_EQ_DBL)
#define __Pyx_truncl trunc
#else
#define __Pyx_truncl truncl
#endif

#ifndef CYTHON_CLINE_IN_TRACEBACK_RUNTIME
#define CYTHON_CLINE_IN_TRACEBACK_RUNTIME 0
#endif
#ifndef CYTHON_CLINE_IN_TRACEBACK
#define CYTHON_CLINE_IN_TRACEBACK CYTHON_CLINE_IN_TRACEBACK_RUNTIME
#endif
#if CYTHON_CLINE_IN_TRACEBACK
#define __PYX_MARK_ERR_POS(f_index, lineno)  { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; __pyx_clineno = __LINE__; (void) __pyx_clineno; }
#else
#define __PYX_MARK_ERR_POS(f_index, lineno)  { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; (void) __pyx_clineno; }
#endif
#define __PYX_ERR(f_index, lineno, Ln_error) \
    { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; }

#ifdef CYTHON_EXTERN_C
    #undef __PYX_EXTERN_C
    #define __PYX_EXTERN_C CYTHON_EXTERN_C
#elif defined(__PYX_EXTERN_C)
    #ifdef _MSC_VER
    #pragma message ("Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.")
    #else
    #warning Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.
    #endif
#else
  #ifdef __cplusplus
    #define __PYX_EXTERN_C extern "C"
  #else
    #define __PYX_EXTERN_C extern
  #endif
#endif

#define __PYX_HAVE__cftime___cftime
#define __PYX_HAVE_API__cftime___cftime
/* Early includes */
#include <string.h>
#include <stdio.h>

    /* Using NumPy API declarations from "numpy/__init__.cython-30.pxd" */
    
#include "numpy/arrayobject.h"
#include "numpy/ndarrayobject.h"
#include "numpy/ndarraytypes.h"
#include "numpy/arrayscalars.h"
#include "numpy/ufuncobject.h"
#ifdef _OPENMP
#include <omp.h>
#endif /* _OPENMP */

#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS)
#define CYTHON_WITHOUT_ASSERTIONS
#endif

#ifdef CYTHON_FREETHREADING_COMPATIBLE
#if CYTHON_FREETHREADING_COMPATIBLE
#define __Pyx_FREETHREADING_COMPATIBLE Py_MOD_GIL_NOT_USED
#else
#define __Pyx_FREETHREADING_COMPATIBLE Py_MOD_GIL_USED
#endif
#else
#define __Pyx_FREETHREADING_COMPATIBLE Py_MOD_GIL_USED
#endif
#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0
#define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0
#define __PYX_DEFAULT_STRING_ENCODING ""
#define __Pyx_PyObject_FromString __Pyx_PyBytes_FromString
#define __Pyx_PyObject_FromStringAndSize __Pyx_PyBytes_FromStringAndSize
#define __Pyx_uchar_cast(c) ((unsigned char)c)
#define __Pyx_long_cast(x) ((long)x)
#define __Pyx_fits_Py_ssize_t(v, type, is_signed)  (\
    (sizeof(type) < sizeof(Py_ssize_t))  ||\
    (sizeof(type) > sizeof(Py_ssize_t) &&\
          likely(v < (type)PY_SSIZE_T_MAX ||\
                 v == (type)PY_SSIZE_T_MAX)  &&\
          (!is_signed || likely(v > (type)PY_SSIZE_T_MIN ||\
                                v == (type)PY_SSIZE_T_MIN)))  ||\
    (sizeof(type) == sizeof(Py_ssize_t) &&\
          (is_signed || likely(v < (type)PY_SSIZE_T_MAX ||\
                               v == (type)PY_SSIZE_T_MAX)))  )
static CYTHON_INLINE int __Pyx_is_valid_index(Py_ssize_t i, Py_ssize_t limit) {
    return (size_t) i < (size_t) limit;
}
#if defined (__cplusplus) && __cplusplus >= 201103L
    #include <cstdlib>
    #define __Pyx_sst_abs(value) std::abs(value)
#elif SIZEOF_INT >= SIZEOF_SIZE_T
    #define __Pyx_sst_abs(value) abs(value)
#elif SIZEOF_LONG >= SIZEOF_SIZE_T
    #define __Pyx_sst_abs(value) labs(value)
#elif defined (_MSC_VER)
    #define __Pyx_sst_abs(value) ((Py_ssize_t)_abs64(value))
#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
    #define __Pyx_sst_abs(value) llabs(value)
#elif defined (__GNUC__)
    #define __Pyx_sst_abs(value) __builtin_llabs(value)
#else
    #define __Pyx_sst_abs(value) ((value<0) ? -value : value)
#endif
static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s);
static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*);
static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length);
static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char*);
#define __Pyx_PyByteArray_FromStringAndSize(s, l) PyByteArray_FromStringAndSize((const char*)s, l)
#define __Pyx_PyBytes_FromString        PyBytes_FromString
#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char*);
#if CYTHON_ASSUME_SAFE_MACROS
    #define __Pyx_PyBytes_AsWritableString(s)     ((char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyBytes_AsWritableSString(s)    ((signed char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyBytes_AsWritableUString(s)    ((unsigned char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyBytes_AsString(s)     ((const char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyBytes_AsSString(s)    ((const signed char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyBytes_AsUString(s)    ((const unsigned char*) PyBytes_AS_STRING(s))
    #define __Pyx_PyByteArray_AsString(s) PyByteArray_AS_STRING(s)
#else
    #define __Pyx_PyBytes_AsWritableString(s)     ((char*) PyBytes_AsString(s))
    #define __Pyx_PyBytes_AsWritableSString(s)    ((signed char*) PyBytes_AsString(s))
    #define __Pyx_PyBytes_AsWritableUString(s)    ((unsigned char*) PyBytes_AsString(s))
    #define __Pyx_PyBytes_AsString(s)     ((const char*) PyBytes_AsString(s))
    #define __Pyx_PyBytes_AsSString(s)    ((const signed char*) PyBytes_AsString(s))
    #define __Pyx_PyBytes_AsUString(s)    ((const unsigned char*) PyBytes_AsString(s))
    #define __Pyx_PyByteArray_AsString(s) PyByteArray_AsString(s)
#endif
#define __Pyx_PyObject_AsWritableString(s)    ((char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsWritableSString(s)    ((signed char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsWritableUString(s)    ((unsigned char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsSString(s)    ((const signed char*) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_AsUString(s)    ((const unsigned char*) __Pyx_PyObject_AsString(s))
#define __Pyx_PyObject_FromCString(s)  __Pyx_PyObject_FromString((const char*)s)
#define __Pyx_PyBytes_FromCString(s)   __Pyx_PyBytes_FromString((const char*)s)
#define __Pyx_PyByteArray_FromCString(s)   __Pyx_PyByteArray_FromString((const char*)s)
#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s)
#define __Pyx_PyUnicode_FromOrdinal(o)       PyUnicode_FromOrdinal((int)o)
#define __Pyx_PyUnicode_AsUnicode            PyUnicode_AsUnicode
static CYTHON_INLINE PyObject *__Pyx_NewRef(PyObject *obj) {
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_NewRef)
    return Py_NewRef(obj);
#else
    Py_INCREF(obj);
    return obj;
#endif
}
static CYTHON_INLINE PyObject *__Pyx_XNewRef(PyObject *obj) {
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_XNewRef)
    return Py_XNewRef(obj);
#else
    Py_XINCREF(obj);
    return obj;
#endif
}
static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b);
static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b);
static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*);
static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject*);
static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x);
#define __Pyx_PySequence_Tuple(obj)\
    (likely(PyTuple_CheckExact(obj)) ? __Pyx_NewRef(obj) : PySequence_Tuple(obj))
static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*);
static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t);
static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject*);
#if CYTHON_ASSUME_SAFE_MACROS
#define __Pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x))
#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AS_DOUBLE(x)
#else
#define __Pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x)
#define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AsDouble(x)
#endif
#define __Pyx_PyFloat_AsFloat(x) ((float) __Pyx_PyFloat_AsDouble(x))
#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x))
#if CYTHON_USE_PYLONG_INTERNALS
  #if PY_VERSION_HEX >= 0x030C00A7
  #ifndef _PyLong_SIGN_MASK
    #define _PyLong_SIGN_MASK 3
  #endif
  #ifndef _PyLong_NON_SIZE_BITS
    #define _PyLong_NON_SIZE_BITS 3
  #endif
  #define __Pyx_PyLong_Sign(x)  (((PyLongObject*)x)->long_value.lv_tag & _PyLong_SIGN_MASK)
  #define __Pyx_PyLong_IsNeg(x)  ((__Pyx_PyLong_Sign(x) & 2) != 0)
  #define __Pyx_PyLong_IsNonNeg(x)  (!__Pyx_PyLong_IsNeg(x))
  #define __Pyx_PyLong_IsZero(x)  (__Pyx_PyLong_Sign(x) & 1)
  #define __Pyx_PyLong_IsPos(x)  (__Pyx_PyLong_Sign(x) == 0)
  #define __Pyx_PyLong_CompactValueUnsigned(x)  (__Pyx_PyLong_Digits(x)[0])
  #define __Pyx_PyLong_DigitCount(x)  ((Py_ssize_t) (((PyLongObject*)x)->long_value.lv_tag >> _PyLong_NON_SIZE_BITS))
  #define __Pyx_PyLong_SignedDigitCount(x)\
        ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * __Pyx_PyLong_DigitCount(x))
  #if defined(PyUnstable_Long_IsCompact) && defined(PyUnstable_Long_CompactValue)
    #define __Pyx_PyLong_IsCompact(x)     PyUnstable_Long_IsCompact((PyLongObject*) x)
    #define __Pyx_PyLong_CompactValue(x)  PyUnstable_Long_CompactValue((PyLongObject*) x)
  #else
    #define __Pyx_PyLong_IsCompact(x)     (((PyLongObject*)x)->long_value.lv_tag < (2 << _PyLong_NON_SIZE_BITS))
    #define __Pyx_PyLong_CompactValue(x)  ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * (Py_ssize_t) __Pyx_PyLong_Digits(x)[0])
  #endif
  typedef Py_ssize_t  __Pyx_compact_pylong;
  typedef size_t  __Pyx_compact_upylong;
  #else
  #define __Pyx_PyLong_IsNeg(x)  (Py_SIZE(x) < 0)
  #define __Pyx_PyLong_IsNonNeg(x)  (Py_SIZE(x) >= 0)
  #define __Pyx_PyLong_IsZero(x)  (Py_SIZE(x) == 0)
  #define __Pyx_PyLong_IsPos(x)  (Py_SIZE(x) > 0)
  #define __Pyx_PyLong_CompactValueUnsigned(x)  ((Py_SIZE(x) == 0) ? 0 : __Pyx_PyLong_Digits(x)[0])
  #define __Pyx_PyLong_DigitCount(x)  __Pyx_sst_abs(Py_SIZE(x))
  #define __Pyx_PyLong_SignedDigitCount(x)  Py_SIZE(x)
  #define __Pyx_PyLong_IsCompact(x)  (Py_SIZE(x) == 0 || Py_SIZE(x) == 1 || Py_SIZE(x) == -1)
  #define __Pyx_PyLong_CompactValue(x)\
        ((Py_SIZE(x) == 0) ? (sdigit) 0 : ((Py_SIZE(x) < 0) ? -(sdigit)__Pyx_PyLong_Digits(x)[0] : (sdigit)__Pyx_PyLong_Digits(x)[0]))
  typedef sdigit  __Pyx_compact_pylong;
  typedef digit  __Pyx_compact_upylong;
  #endif
  #if PY_VERSION_HEX >= 0x030C00A5
  #define __Pyx_PyLong_Digits(x)  (((PyLongObject*)x)->long_value.ob_digit)
  #else
  #define __Pyx_PyLong_Digits(x)  (((PyLongObject*)x)->ob_digit)
  #endif
#endif
#if __PYX_DEFAULT_STRING_ENCODING_IS_UTF8
  #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL)
#elif __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
  #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeASCII(c_str, size, NULL)
#else
  #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL)
#endif


/* Test for GCC > 2.95 */
#if defined(__GNUC__)     && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)))
  #define likely(x)   __builtin_expect(!!(x), 1)
  #define unlikely(x) __builtin_expect(!!(x), 0)
#else /* !__GNUC__ or GCC < 2.95 */
  #define likely(x)   (x)
  #define unlikely(x) (x)
#endif /* __GNUC__ */
/* PretendToInitialize */
#ifdef __cplusplus
#if __cplusplus > 201103L
#include <type_traits>
#endif
template <typename T>
static void __Pyx_pretend_to_initialize(T* ptr) {
#if __cplusplus > 201103L
    if ((std::is_trivially_default_constructible<T>::value))
#endif
        *ptr = T();
    (void)ptr;
}
#else
static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; }
#endif


#if !CYTHON_USE_MODULE_STATE
static PyObject *__pyx_m = NULL;
#endif
static int __pyx_lineno;
static int __pyx_clineno = 0;
static const char * const __pyx_cfilenm = __FILE__;
static const char *__pyx_filename;

/* Header.proto */
#if !defined(CYTHON_CCOMPLEX)
  #if defined(__cplusplus)
    #define CYTHON_CCOMPLEX 1
  #elif (defined(_Complex_I) && !defined(_MSC_VER)) || ((defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L) && !defined(__STDC_NO_COMPLEX__) && !defined(_MSC_VER))
    #define CYTHON_CCOMPLEX 1
  #else
    #define CYTHON_CCOMPLEX 0
  #endif
#endif
#if CYTHON_CCOMPLEX
  #ifdef __cplusplus
    #include <complex>
  #else
    #include <complex.h>
  #endif
#endif
#if CYTHON_CCOMPLEX && !defined(__cplusplus) && defined(__sun__) && defined(__GNUC__)
  #undef _Complex_I
  #define _Complex_I 1.0fj
#endif

/* #### Code section: filename_table ### */

static const char* const __pyx_f[] = {
  "src/cftime/_cftime.pyx",
  "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd",
  "cpython/type.pxd",
};
/* #### Code section: utility_code_proto_before_types ### */
/* Atomics.proto (used by UnpackUnboundCMethod) */
#include <pythread.h>
#ifndef CYTHON_ATOMICS
    #define CYTHON_ATOMICS 1
#endif
#define __PYX_CYTHON_ATOMICS_ENABLED() CYTHON_ATOMICS
#define __PYX_GET_CYTHON_COMPILING_IN_CPYTHON_FREETHREADING() CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
#define __pyx_atomic_int_type int
#define __pyx_nonatomic_int_type int
#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\
                        (__STDC_VERSION__ >= 201112L) &&\
                        !defined(__STDC_NO_ATOMICS__))
    #include <stdatomic.h>
#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\
                    (__cplusplus >= 201103L) ||\
                    (defined(_MSC_VER) && _MSC_VER >= 1700)))
    #include <atomic>
#endif
#if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\
                        (__STDC_VERSION__ >= 201112L) &&\
                        !defined(__STDC_NO_ATOMICS__) &&\
                       ATOMIC_INT_LOCK_FREE == 2)
    #undef __pyx_atomic_int_type
    #define __pyx_atomic_int_type atomic_int
    #define __pyx_atomic_ptr_type atomic_uintptr_t
    #define __pyx_nonatomic_ptr_type uintptr_t
    #define __pyx_atomic_incr_relaxed(value) atomic_fetch_add_explicit(value, 1, memory_order_relaxed)
    #define __pyx_atomic_incr_acq_rel(value) atomic_fetch_add_explicit(value, 1, memory_order_acq_rel)
    #define __pyx_atomic_decr_acq_rel(value) atomic_fetch_sub_explicit(value, 1, memory_order_acq_rel)
    #define __pyx_atomic_sub(value, arg) atomic_fetch_sub(value, arg)
    #define __pyx_atomic_int_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired)
    #define __pyx_atomic_load(value) atomic_load(value)
    #define __pyx_atomic_store(value, new_value) atomic_store(value, new_value)
    #define __pyx_atomic_pointer_load_relaxed(value) atomic_load_explicit(value, memory_order_relaxed)
    #define __pyx_atomic_pointer_load_acquire(value) atomic_load_explicit(value, memory_order_acquire)
    #define __pyx_atomic_pointer_exchange(value, new_value) atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value)
    #define __pyx_atomic_pointer_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired)
    #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER)
        #pragma message ("Using standard C atomics")
    #elif defined(__PYX_DEBUG_ATOMICS)
        #warning "Using standard C atomics"
    #endif
#elif CYTHON_ATOMICS && (defined(__cplusplus) && (\
                    (__cplusplus >= 201103L) ||\
\
                    (defined(_MSC_VER) && _MSC_VER >= 1700)) &&\
                    ATOMIC_INT_LOCK_FREE == 2)
    #undef __pyx_atomic_int_type
    #define __pyx_atomic_int_type std::atomic_int
    #define __pyx_atomic_ptr_type std::atomic_uintptr_t
    #define __pyx_nonatomic_ptr_type uintptr_t
    #define __pyx_atomic_incr_relaxed(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_relaxed)
    #define __pyx_atomic_incr_acq_rel(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_acq_rel)
    #define __pyx_atomic_decr_acq_rel(value) std::atomic_fetch_sub_explicit(value, 1, std::memory_order_acq_rel)
    #define __pyx_atomic_sub(value, arg) std::atomic_fetch_sub(value, arg)
    #define __pyx_atomic_int_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired)
    #define __pyx_atomic_load(value) std::atomic_load(value)
    #define __pyx_atomic_store(value, new_value) std::atomic_store(value, new_value)
    #define __pyx_atomic_pointer_load_relaxed(value) std::atomic_load_explicit(value, std::memory_order_relaxed)
    #define __pyx_atomic_pointer_load_acquire(value) std::atomic_load_explicit(value, std::memory_order_acquire)
    #define __pyx_atomic_pointer_exchange(value, new_value) std::atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value)
    #define __pyx_atomic_pointer_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired)
    #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER)
        #pragma message ("Using standard C++ atomics")
    #elif defined(__PYX_DEBUG_ATOMICS)
        #warning "Using standard C++ atomics"
    #endif
#elif CYTHON_ATOMICS && (__GNUC__ >= 5 || (__GNUC__ == 4 &&\
                    (__GNUC_MINOR__ > 1 ||\
                    (__GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ >= 2))))
    #define __pyx_atomic_ptr_type void*
    #define __pyx_nonatomic_ptr_type void*
    #define __pyx_atomic_incr_relaxed(value) __sync_fetch_and_add(value, 1)
    #define __pyx_atomic_incr_acq_rel(value) __sync_fetch_and_add(value, 1)
    #define __pyx_atomic_decr_acq_rel(value) __sync_fetch_and_sub(value, 1)
    #define __pyx_atomic_sub(value, arg) __sync_fetch_and_sub(value, arg)
    static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) {
        __pyx_nonatomic_int_type old = __sync_val_compare_and_swap(value, *expected, desired);
        int result = old == *expected;
        *expected = old;
        return result;
    }
    #define __pyx_atomic_load(value) __sync_fetch_and_add(value, 0)
    #define __pyx_atomic_store(value, new_value) __sync_lock_test_and_set(value, new_value)
    #define __pyx_atomic_pointer_load_relaxed(value) __sync_fetch_and_add(value, 0)
    #define __pyx_atomic_pointer_load_acquire(value) __sync_fetch_and_add(value, 0)
    #define __pyx_atomic_pointer_exchange(value, new_value) __sync_lock_test_and_set(value, (__pyx_atomic_ptr_type)new_value)
    static CYTHON_INLINE int __pyx_atomic_pointer_cmp_exchange(__pyx_atomic_ptr_type* value, __pyx_nonatomic_ptr_type* expected, __pyx_nonatomic_ptr_type desired) {
        __pyx_nonatomic_ptr_type old = __sync_val_compare_and_swap(value, *expected, desired);
        int result = old == *expected;
        *expected = old;
        return result;
    }
    #ifdef __PYX_DEBUG_ATOMICS
        #warning "Using GNU atomics"
    #endif
#elif CYTHON_ATOMICS && defined(_MSC_VER)
    #include <intrin.h>
    #undef __pyx_atomic_int_type
    #define __pyx_atomic_int_type long
    #define __pyx_atomic_ptr_type void*
    #undef __pyx_nonatomic_int_type
    #define __pyx_nonatomic_int_type long
    #define __pyx_nonatomic_ptr_type void*
    #pragma intrinsic (_InterlockedExchangeAdd, _InterlockedExchange, _InterlockedCompareExchange, _InterlockedCompareExchangePointer, _InterlockedExchangePointer)
    #define __pyx_atomic_incr_relaxed(value) _InterlockedExchangeAdd(value, 1)
    #define __pyx_atomic_incr_acq_rel(value) _InterlockedExchangeAdd(value, 1)
    #define __pyx_atomic_decr_acq_rel(value) _InterlockedExchangeAdd(value, -1)
    #define __pyx_atomic_sub(value, arg) _InterlockedExchangeAdd(value, -arg)
    static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) {
        __pyx_nonatomic_int_type old = _InterlockedCompareExchange(value, desired, *expected);
        int result = old == *expected;
        *expected = old;
        return result;
    }
    #define __pyx_atomic_load(value) _InterlockedExchangeAdd(value, 0)
    #define __pyx_atomic_store(value, new_value) _InterlockedExchange(value, new_value)
    #define __pyx_atomic_pointer_load_relaxed(value) *(void * volatile *)value
    #define __pyx_atomic_pointer_load_acquire(value) _InterlockedCompareExchangePointer(value, 0, 0)
    #define __pyx_atomic_pointer_exchange(value, new_value) _InterlockedExchangePointer(value, (__pyx_atomic_ptr_type)new_value)
    static CYTHON_INLINE int __pyx_atomic_pointer_cmp_exchange(__pyx_atomic_ptr_type* value, __pyx_nonatomic_ptr_type* expected, __pyx_nonatomic_ptr_type desired) {
        __pyx_atomic_ptr_type old = _InterlockedCompareExchangePointer(value, desired, *expected);
        int result = old == *expected;
        *expected = old;
        return result;
    }
    #ifdef __PYX_DEBUG_ATOMICS
        #pragma message ("Using MSVC atomics")
    #endif
#else
    #undef CYTHON_ATOMICS
    #define CYTHON_ATOMICS 0
    #ifdef __PYX_DEBUG_ATOMICS
        #warning "Not using atomics"
    #endif
#endif

/* CriticalSectionsDefinition.proto (used by CriticalSections) */
#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
#define __Pyx_PyCriticalSection void*
#define __Pyx_PyCriticalSection2 void*
#define __Pyx_PyCriticalSection_End(cs)
#define __Pyx_PyCriticalSection2_End(cs)
#else
#define __Pyx_PyCriticalSection PyCriticalSection
#define __Pyx_PyCriticalSection2 PyCriticalSection2
#define __Pyx_PyCriticalSection_End PyCriticalSection_End
#define __Pyx_PyCriticalSection2_End PyCriticalSection2_End
#endif

/* CriticalSections.proto (used by ParseKeywordsImpl) */
#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
#define __Pyx_PyCriticalSection_Begin(cs, arg) (void)(cs)
#define __Pyx_PyCriticalSection2_Begin(cs, arg1, arg2) (void)(cs)
#else
#define __Pyx_PyCriticalSection_Begin PyCriticalSection_Begin
#define __Pyx_PyCriticalSection2_Begin PyCriticalSection2_Begin
#endif
#if PY_VERSION_HEX < 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API
#define __Pyx_BEGIN_CRITICAL_SECTION(o) {
#define __Pyx_END_CRITICAL_SECTION() }
#else
#define __Pyx_BEGIN_CRITICAL_SECTION Py_BEGIN_CRITICAL_SECTION
#define __Pyx_END_CRITICAL_SECTION Py_END_CRITICAL_SECTION
#endif

/* IncludeStructmemberH.proto (used by FixUpExtensionType) */
#include <structmember.h>

/* #### Code section: numeric_typedefs ### */

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":744
 * # in Cython to enable them only on the right systems.
 * 
 * ctypedef npy_int8       int8_t             # <<<<<<<<<<<<<<
 * ctypedef npy_int16      int16_t
 * ctypedef npy_int32      int32_t
*/
typedef npy_int8 __pyx_t_5numpy_int8_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":745
 * 
 * ctypedef npy_int8       int8_t
 * ctypedef npy_int16      int16_t             # <<<<<<<<<<<<<<
 * ctypedef npy_int32      int32_t
 * ctypedef npy_int64      int64_t
*/
typedef npy_int16 __pyx_t_5numpy_int16_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":746
 * ctypedef npy_int8       int8_t
 * ctypedef npy_int16      int16_t
 * ctypedef npy_int32      int32_t             # <<<<<<<<<<<<<<
 * ctypedef npy_int64      int64_t
 * 
*/
typedef npy_int32 __pyx_t_5numpy_int32_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":747
 * ctypedef npy_int16      int16_t
 * ctypedef npy_int32      int32_t
 * ctypedef npy_int64      int64_t             # <<<<<<<<<<<<<<
 * 
 * ctypedef npy_uint8      uint8_t
*/
typedef npy_int64 __pyx_t_5numpy_int64_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":749
 * ctypedef npy_int64      int64_t
 * 
 * ctypedef npy_uint8      uint8_t             # <<<<<<<<<<<<<<
 * ctypedef npy_uint16     uint16_t
 * ctypedef npy_uint32     uint32_t
*/
typedef npy_uint8 __pyx_t_5numpy_uint8_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":750
 * 
 * ctypedef npy_uint8      uint8_t
 * ctypedef npy_uint16     uint16_t             # <<<<<<<<<<<<<<
 * ctypedef npy_uint32     uint32_t
 * ctypedef npy_uint64     uint64_t
*/
typedef npy_uint16 __pyx_t_5numpy_uint16_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":751
 * ctypedef npy_uint8      uint8_t
 * ctypedef npy_uint16     uint16_t
 * ctypedef npy_uint32     uint32_t             # <<<<<<<<<<<<<<
 * ctypedef npy_uint64     uint64_t
 * 
*/
typedef npy_uint32 __pyx_t_5numpy_uint32_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":752
 * ctypedef npy_uint16     uint16_t
 * ctypedef npy_uint32     uint32_t
 * ctypedef npy_uint64     uint64_t             # <<<<<<<<<<<<<<
 * 
 * ctypedef npy_float32    float32_t
*/
typedef npy_uint64 __pyx_t_5numpy_uint64_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":754
 * ctypedef npy_uint64     uint64_t
 * 
 * ctypedef npy_float32    float32_t             # <<<<<<<<<<<<<<
 * ctypedef npy_float64    float64_t
 * #ctypedef npy_float80    float80_t
*/
typedef npy_float32 __pyx_t_5numpy_float32_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":755
 * 
 * ctypedef npy_float32    float32_t
 * ctypedef npy_float64    float64_t             # <<<<<<<<<<<<<<
 * #ctypedef npy_float80    float80_t
 * #ctypedef npy_float128   float128_t
*/
typedef npy_float64 __pyx_t_5numpy_float64_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":762
 * ctypedef double complex complex128_t
 * 
 * ctypedef npy_longlong   longlong_t             # <<<<<<<<<<<<<<
 * ctypedef npy_ulonglong  ulonglong_t
 * 
*/
typedef npy_longlong __pyx_t_5numpy_longlong_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":763
 * 
 * ctypedef npy_longlong   longlong_t
 * ctypedef npy_ulonglong  ulonglong_t             # <<<<<<<<<<<<<<
 * 
 * ctypedef npy_intp       intp_t
*/
typedef npy_ulonglong __pyx_t_5numpy_ulonglong_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":765
 * ctypedef npy_ulonglong  ulonglong_t
 * 
 * ctypedef npy_intp       intp_t             # <<<<<<<<<<<<<<
 * ctypedef npy_uintp      uintp_t
 * 
*/
typedef npy_intp __pyx_t_5numpy_intp_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":766
 * 
 * ctypedef npy_intp       intp_t
 * ctypedef npy_uintp      uintp_t             # <<<<<<<<<<<<<<
 * 
 * ctypedef npy_double     float_t
*/
typedef npy_uintp __pyx_t_5numpy_uintp_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":768
 * ctypedef npy_uintp      uintp_t
 * 
 * ctypedef npy_double     float_t             # <<<<<<<<<<<<<<
 * ctypedef npy_double     double_t
 * ctypedef npy_longdouble longdouble_t
*/
typedef npy_double __pyx_t_5numpy_float_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":769
 * 
 * ctypedef npy_double     float_t
 * ctypedef npy_double     double_t             # <<<<<<<<<<<<<<
 * ctypedef npy_longdouble longdouble_t
 * 
*/
typedef npy_double __pyx_t_5numpy_double_t;

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":770
 * ctypedef npy_double     float_t
 * ctypedef npy_double     double_t
 * ctypedef npy_longdouble longdouble_t             # <<<<<<<<<<<<<<
 * 
 * ctypedef float complex       cfloat_t
*/
typedef npy_longdouble __pyx_t_5numpy_longdouble_t;
/* #### Code section: complex_type_declarations ### */
/* Declarations.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    typedef ::std::complex< float > __pyx_t_float_complex;
  #else
    typedef float _Complex __pyx_t_float_complex;
  #endif
#else
    typedef struct { float real, imag; } __pyx_t_float_complex;
#endif
static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float, float);

/* Declarations.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    typedef ::std::complex< double > __pyx_t_double_complex;
  #else
    typedef double _Complex __pyx_t_double_complex;
  #endif
#else
    typedef struct { double real, imag; } __pyx_t_double_complex;
#endif
static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double, double);

/* Declarations.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    typedef ::std::complex< long double > __pyx_t_long_double_complex;
  #else
    typedef long double _Complex __pyx_t_long_double_complex;
  #endif
#else
    typedef struct { long double real, imag; } __pyx_t_long_double_complex;
#endif
static CYTHON_INLINE __pyx_t_long_double_complex __pyx_t_long_double_complex_from_parts(long double, long double);

/* #### Code section: type_declarations ### */

/*--- Type declarations ---*/
struct __pyx_obj_6cftime_7_cftime_datetime;
struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap;
struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap;
struct __pyx_obj_6cftime_7_cftime_Datetime360Day;
struct __pyx_obj_6cftime_7_cftime_DatetimeJulian;
struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian;
struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian;
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime;
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr;
struct __pyx_opt_args_6cftime_7_cftime_assert_valid_date;
struct __pyx_opt_args_6cftime_7_cftime__is_leap;
struct __pyx_opt_args_6cftime_7_cftime__IntJulianDayFromDate;

/* "cftime/_cftime.pyx":1755
 *         return _dayspermonth
 * 
 * cdef void assert_valid_date(datetime dt, bint (*is_leap)(int, bint),             # <<<<<<<<<<<<<<
 *                             bint julian_gregorian_mixed,
 *                             bint has_year_zero=False,
*/
struct __pyx_opt_args_6cftime_7_cftime_assert_valid_date {
  int __pyx_n;
  int has_year_zero;
  int is_360_day;
};

/* "cftime/_cftime.pyx":1931
 *     return _is_leap(year, calendar, has_year_zero=has_year_zero)
 * 
 * cdef _is_leap(int year, calendar, has_year_zero=None):             # <<<<<<<<<<<<<<
 *     cdef int tyear
 *     cdef bint leap
*/
struct __pyx_opt_args_6cftime_7_cftime__is_leap {
  int __pyx_n;
  PyObject *has_year_zero;
};

/* "cftime/_cftime.pyx":1986
 * 
 * 
 * cdef _IntJulianDayFromDate(int year,int month,int day,calendar,skip_transition=False,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """Compute integer Julian Day from year,month,day and calendar.
 * 
*/
struct __pyx_opt_args_6cftime_7_cftime__IntJulianDayFromDate {
  int __pyx_n;
  PyObject *skip_transition;
  PyObject *has_year_zero;
};

/* "cftime/_cftime.pyx":1055
 *     pass
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class datetime(object):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_datetime {
  PyObject_HEAD
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime *__pyx_vtab;
  int year;
  int month;
  int day;
  int hour;
  int minute;
  int second;
  int microsecond;
  PyObject *calendar;
  int _dayofwk;
  int _dayofyr;
  int has_year_zero;
  PyObject *tzinfo;
  int datetime_compatible;
};


/* "cftime/_cftime.pyx":2085
 * # legacy calendar specific sub-classes (will be removed in a future release).
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeNoLeap(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":2095
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeAllLeap(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":2105
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class Datetime360Day(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_Datetime360Day {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":2115
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeJulian(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_DatetimeJulian {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":2125
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeGregorian(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":2135
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeProlepticGregorian(datetime):
 *     """
*/
struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian {
  struct __pyx_obj_6cftime_7_cftime_datetime __pyx_base;
};


/* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime {
  PyObject_HEAD
  PyObject *__pyx_v_special_fd;
};


/* "cftime/_cftime.pyx":1282
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):             # <<<<<<<<<<<<<<
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
 *                 raise KeyError(msg)
*/
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr {
  PyObject_HEAD
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *__pyx_outer_scope;
  PyObject *__pyx_genexpr_arg_0;
  PyObject *__pyx_v_x;
};



/* "cftime/_cftime.pyx":1055
 *     pass
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class datetime(object):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_datetime {
  PyObject *(*_to_real_datetime)(struct __pyx_obj_6cftime_7_cftime_datetime *, int __pyx_skip_dispatch);
  PyObject *(*_getstate)(struct __pyx_obj_6cftime_7_cftime_datetime *);
  PyObject *(*_add_timedelta)(struct __pyx_obj_6cftime_7_cftime_datetime *, PyObject *);
};
static struct __pyx_vtabstruct_6cftime_7_cftime_datetime *__pyx_vtabptr_6cftime_7_cftime_datetime;


/* "cftime/_cftime.pyx":2085
 * # legacy calendar specific sub-classes (will be removed in a future release).
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeNoLeap(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeNoLeap {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeNoLeap *__pyx_vtabptr_6cftime_7_cftime_DatetimeNoLeap;


/* "cftime/_cftime.pyx":2095
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeAllLeap(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeAllLeap {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeAllLeap *__pyx_vtabptr_6cftime_7_cftime_DatetimeAllLeap;


/* "cftime/_cftime.pyx":2105
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class Datetime360Day(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_Datetime360Day {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_Datetime360Day *__pyx_vtabptr_6cftime_7_cftime_Datetime360Day;


/* "cftime/_cftime.pyx":2115
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeJulian(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeJulian {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeJulian *__pyx_vtabptr_6cftime_7_cftime_DatetimeJulian;


/* "cftime/_cftime.pyx":2125
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeGregorian(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeGregorian {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeGregorian *__pyx_vtabptr_6cftime_7_cftime_DatetimeGregorian;


/* "cftime/_cftime.pyx":2135
 *         super().__init__(*args, **kwargs)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * cdef class DatetimeProlepticGregorian(datetime):
 *     """
*/

struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeProlepticGregorian {
  struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_base;
};
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeProlepticGregorian *__pyx_vtabptr_6cftime_7_cftime_DatetimeProlepticGregorian;
/* #### Code section: utility_code_proto ### */

/* --- Runtime support code (head) --- */
/* Refnanny.proto */
#ifndef CYTHON_REFNANNY
  #define CYTHON_REFNANNY 0
#endif
#if CYTHON_REFNANNY
  typedef struct {
    void (*INCREF)(void*, PyObject*, Py_ssize_t);
    void (*DECREF)(void*, PyObject*, Py_ssize_t);
    void (*GOTREF)(void*, PyObject*, Py_ssize_t);
    void (*GIVEREF)(void*, PyObject*, Py_ssize_t);
    void* (*SetupContext)(const char*, Py_ssize_t, const char*);
    void (*FinishContext)(void**);
  } __Pyx_RefNannyAPIStruct;
  static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
  static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname);
  #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL;
  #define __Pyx_RefNannySetupContext(name, acquire_gil)\
          if (acquire_gil) {\
              PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\
              __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\
              PyGILState_Release(__pyx_gilstate_save);\
          } else {\
              __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), (__LINE__), (__FILE__));\
          }
  #define __Pyx_RefNannyFinishContextNogil() {\
              PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\
              __Pyx_RefNannyFinishContext();\
              PyGILState_Release(__pyx_gilstate_save);\
          }
  #define __Pyx_RefNannyFinishContextNogil() {\
              PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\
              __Pyx_RefNannyFinishContext();\
              PyGILState_Release(__pyx_gilstate_save);\
          }
  #define __Pyx_RefNannyFinishContext()\
          __Pyx_RefNanny->FinishContext(&__pyx_refnanny)
  #define __Pyx_INCREF(r)  __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), (__LINE__))
  #define __Pyx_DECREF(r)  __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), (__LINE__))
  #define __Pyx_GOTREF(r)  __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), (__LINE__))
  #define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), (__LINE__))
  #define __Pyx_XINCREF(r)  do { if((r) == NULL); else {__Pyx_INCREF(r); }} while(0)
  #define __Pyx_XDECREF(r)  do { if((r) == NULL); else {__Pyx_DECREF(r); }} while(0)
  #define __Pyx_XGOTREF(r)  do { if((r) == NULL); else {__Pyx_GOTREF(r); }} while(0)
  #define __Pyx_XGIVEREF(r) do { if((r) == NULL); else {__Pyx_GIVEREF(r);}} while(0)
#else
  #define __Pyx_RefNannyDeclarations
  #define __Pyx_RefNannySetupContext(name, acquire_gil)
  #define __Pyx_RefNannyFinishContextNogil()
  #define __Pyx_RefNannyFinishContext()
  #define __Pyx_INCREF(r) Py_INCREF(r)
  #define __Pyx_DECREF(r) Py_DECREF(r)
  #define __Pyx_GOTREF(r)
  #define __Pyx_GIVEREF(r)
  #define __Pyx_XINCREF(r) Py_XINCREF(r)
  #define __Pyx_XDECREF(r) Py_XDECREF(r)
  #define __Pyx_XGOTREF(r)
  #define __Pyx_XGIVEREF(r)
#endif
#define __Pyx_Py_XDECREF_SET(r, v) do {\
        PyObject *tmp = (PyObject *) r;\
        r = v; Py_XDECREF(tmp);\
    } while (0)
#define __Pyx_XDECREF_SET(r, v) do {\
        PyObject *tmp = (PyObject *) r;\
        r = v; __Pyx_XDECREF(tmp);\
    } while (0)
#define __Pyx_DECREF_SET(r, v) do {\
        PyObject *tmp = (PyObject *) r;\
        r = v; __Pyx_DECREF(tmp);\
    } while (0)
#define __Pyx_CLEAR(r)    do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0)
#define __Pyx_XCLEAR(r)   do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0)

/* PyErrExceptionMatches.proto (used by PyObjectGetAttrStrNoError) */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_PyErr_ExceptionMatches(err) __Pyx_PyErr_ExceptionMatchesInState(__pyx_tstate, err)
static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err);
#else
#define __Pyx_PyErr_ExceptionMatches(err)  PyErr_ExceptionMatches(err)
#endif

/* PyThreadStateGet.proto (used by PyErrFetchRestore) */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_PyThreadState_declare  PyThreadState *__pyx_tstate;
#define __Pyx_PyThreadState_assign  __pyx_tstate = __Pyx_PyThreadState_Current;
#if PY_VERSION_HEX >= 0x030C00A6
#define __Pyx_PyErr_Occurred()  (__pyx_tstate->current_exception != NULL)
#define __Pyx_PyErr_CurrentExceptionType()  (__pyx_tstate->current_exception ? (PyObject*) Py_TYPE(__pyx_tstate->current_exception) : (PyObject*) NULL)
#else
#define __Pyx_PyErr_Occurred()  (__pyx_tstate->curexc_type != NULL)
#define __Pyx_PyErr_CurrentExceptionType()  (__pyx_tstate->curexc_type)
#endif
#else
#define __Pyx_PyThreadState_declare
#define __Pyx_PyThreadState_assign
#define __Pyx_PyErr_Occurred()  (PyErr_Occurred() != NULL)
#define __Pyx_PyErr_CurrentExceptionType()  PyErr_Occurred()
#endif

/* PyErrFetchRestore.proto (used by PyObjectGetAttrStrNoError) */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_PyErr_Clear() __Pyx_ErrRestore(NULL, NULL, NULL)
#define __Pyx_ErrRestoreWithState(type, value, tb)  __Pyx_ErrRestoreInState(PyThreadState_GET(), type, value, tb)
#define __Pyx_ErrFetchWithState(type, value, tb)    __Pyx_ErrFetchInState(PyThreadState_GET(), type, value, tb)
#define __Pyx_ErrRestore(type, value, tb)  __Pyx_ErrRestoreInState(__pyx_tstate, type, value, tb)
#define __Pyx_ErrFetch(type, value, tb)    __Pyx_ErrFetchInState(__pyx_tstate, type, value, tb)
static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb);
static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb);
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A6
#define __Pyx_PyErr_SetNone(exc) (Py_INCREF(exc), __Pyx_ErrRestore((exc), NULL, NULL))
#else
#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc)
#endif
#else
#define __Pyx_PyErr_Clear() PyErr_Clear()
#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc)
#define __Pyx_ErrRestoreWithState(type, value, tb)  PyErr_Restore(type, value, tb)
#define __Pyx_ErrFetchWithState(type, value, tb)  PyErr_Fetch(type, value, tb)
#define __Pyx_ErrRestoreInState(tstate, type, value, tb)  PyErr_Restore(type, value, tb)
#define __Pyx_ErrFetchInState(tstate, type, value, tb)  PyErr_Fetch(type, value, tb)
#define __Pyx_ErrRestore(type, value, tb)  PyErr_Restore(type, value, tb)
#define __Pyx_ErrFetch(type, value, tb)  PyErr_Fetch(type, value, tb)
#endif

/* PyObjectGetAttrStr.proto (used by PyObjectGetAttrStrNoError) */
#if CYTHON_USE_TYPE_SLOTS
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name);
#else
#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n)
#endif

/* PyObjectGetAttrStrNoError.proto (used by GetBuiltinName) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name);

/* GetBuiltinName.proto */
static PyObject *__Pyx_GetBuiltinName(PyObject *name);

/* GetTopmostException.proto (used by SaveResetException) */
#if CYTHON_USE_EXC_INFO_STACK && CYTHON_FAST_THREAD_STATE
static _PyErr_StackItem * __Pyx_PyErr_GetTopmostException(PyThreadState *tstate);
#endif

/* SaveResetException.proto */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_ExceptionSave(type, value, tb)  __Pyx__ExceptionSave(__pyx_tstate, type, value, tb)
static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb);
#define __Pyx_ExceptionReset(type, value, tb)  __Pyx__ExceptionReset(__pyx_tstate, type, value, tb)
static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb);
#else
#define __Pyx_ExceptionSave(type, value, tb)   PyErr_GetExcInfo(type, value, tb)
#define __Pyx_ExceptionReset(type, value, tb)  PyErr_SetExcInfo(type, value, tb)
#endif

/* GetException.proto */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_GetException(type, value, tb)  __Pyx__GetException(__pyx_tstate, type, value, tb)
static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb);
#else
static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb);
#endif

/* PyImportError_Check.proto */
#define __Pyx_PyExc_ImportError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_ImportError)

/* PyObjectCall.proto (used by PyObjectFastCall) */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw);
#else
#define __Pyx_PyObject_Call(func, arg, kw) PyObject_Call(func, arg, kw)
#endif

/* PyObjectCallMethO.proto (used by PyObjectFastCall) */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg);
#endif

/* PyObjectFastCall.proto */
#define __Pyx_PyObject_FastCall(func, args, nargs)  __Pyx_PyObject_FastCallDict(func, args, (size_t)(nargs), NULL)
static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs);

/* RaiseException.export */
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause);

/* TupleAndListFromArray.proto (used by fastcall) */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n);
#endif
#if CYTHON_COMPILING_IN_CPYTHON || CYTHON_METH_FASTCALL
static CYTHON_INLINE PyObject* __Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n);
#endif

/* IncludeStringH.proto (used by BytesEquals) */
#include <string.h>

/* BytesEquals.proto (used by UnicodeEquals) */
static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals);

/* UnicodeEquals.proto (used by fastcall) */
static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals);

/* fastcall.proto */
#if CYTHON_AVOID_BORROWED_REFS
    #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_PySequence_ITEM(args, i)
#elif CYTHON_ASSUME_SAFE_MACROS
    #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_NewRef(__Pyx_PyTuple_GET_ITEM(args, i))
#else
    #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_XNewRef(PyTuple_GetItem(args, i))
#endif
#define __Pyx_NumKwargs_VARARGS(kwds) PyDict_Size(kwds)
#define __Pyx_KwValues_VARARGS(args, nargs) NULL
#define __Pyx_GetKwValue_VARARGS(kw, kwvalues, s) __Pyx_PyDict_GetItemStrWithError(kw, s)
#define __Pyx_KwargsAsDict_VARARGS(kw, kwvalues) PyDict_Copy(kw)
#if CYTHON_METH_FASTCALL
    #define __Pyx_ArgRef_FASTCALL(args, i) __Pyx_NewRef(args[i])
    #define __Pyx_NumKwargs_FASTCALL(kwds) __Pyx_PyTuple_GET_SIZE(kwds)
    #define __Pyx_KwValues_FASTCALL(args, nargs) ((args) + (nargs))
    static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API
    CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues);
  #else
    #define __Pyx_KwargsAsDict_FASTCALL(kw, kwvalues) _PyStack_AsDict(kwvalues, kw)
  #endif
#else
    #define __Pyx_ArgRef_FASTCALL __Pyx_ArgRef_VARARGS
    #define __Pyx_NumKwargs_FASTCALL __Pyx_NumKwargs_VARARGS
    #define __Pyx_KwValues_FASTCALL __Pyx_KwValues_VARARGS
    #define __Pyx_GetKwValue_FASTCALL __Pyx_GetKwValue_VARARGS
    #define __Pyx_KwargsAsDict_FASTCALL __Pyx_KwargsAsDict_VARARGS
#endif
#define __Pyx_ArgsSlice_VARARGS(args, start, stop) PyTuple_GetSlice(args, start, stop)
#if CYTHON_METH_FASTCALL || (CYTHON_COMPILING_IN_CPYTHON && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS)
#define __Pyx_ArgsSlice_FASTCALL(args, start, stop) __Pyx_PyTuple_FromArray(args + start, stop - start)
#else
#define __Pyx_ArgsSlice_FASTCALL(args, start, stop) PyTuple_GetSlice(args, start, stop)
#endif

/* py_dict_items.proto (used by OwnedDictNext) */
static CYTHON_INLINE PyObject* __Pyx_PyDict_Items(PyObject* d);

/* CallCFunction.proto (used by CallUnboundCMethod0) */
#define __Pyx_CallCFunction(cfunc, self, args)\
    ((PyCFunction)(void(*)(void))(cfunc)->func)(self, args)
#define __Pyx_CallCFunctionWithKeywords(cfunc, self, args, kwargs)\
    ((PyCFunctionWithKeywords)(void(*)(void))(cfunc)->func)(self, args, kwargs)
#define __Pyx_CallCFunctionFast(cfunc, self, args, nargs)\
    ((__Pyx_PyCFunctionFast)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs)
#define __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, nargs, kwnames)\
    ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs, kwnames)

/* PyObjectCallOneArg.proto (used by CallUnboundCMethod0) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg);

/* UnpackUnboundCMethod.proto (used by CallUnboundCMethod0) */
typedef struct {
    PyObject *type;
    PyObject **method_name;
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && CYTHON_ATOMICS
    __pyx_atomic_int_type initialized;
#endif
    PyCFunction func;
    PyObject *method;
    int flag;
} __Pyx_CachedCFunction;
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
static CYTHON_INLINE int __Pyx_CachedCFunction_GetAndSetInitializing(__Pyx_CachedCFunction *cfunc) {
#if !CYTHON_ATOMICS
    return 1;
#else
    __pyx_nonatomic_int_type expected = 0;
    if (__pyx_atomic_int_cmp_exchange(&cfunc->initialized, &expected, 1)) {
        return 0;
    }
    return expected;
#endif
}
static CYTHON_INLINE void __Pyx_CachedCFunction_SetFinishedInitializing(__Pyx_CachedCFunction *cfunc) {
#if CYTHON_ATOMICS
    __pyx_atomic_store(&cfunc->initialized, 2);
#endif
}
#else
#define __Pyx_CachedCFunction_GetAndSetInitializing(cfunc) 2
#define __Pyx_CachedCFunction_SetFinishedInitializing(cfunc)
#endif

/* CallUnboundCMethod0.proto */
CYTHON_UNUSED
static PyObject* __Pyx__CallUnboundCMethod0(__Pyx_CachedCFunction* cfunc, PyObject* self);
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_CallUnboundCMethod0(__Pyx_CachedCFunction* cfunc, PyObject* self);
#else
#define __Pyx_CallUnboundCMethod0(cfunc, self)  __Pyx__CallUnboundCMethod0(cfunc, self)
#endif

/* py_dict_values.proto (used by OwnedDictNext) */
static CYTHON_INLINE PyObject* __Pyx_PyDict_Values(PyObject* d);

/* OwnedDictNext.proto (used by ParseKeywordsImpl) */
#if CYTHON_AVOID_BORROWED_REFS
static int __Pyx_PyDict_NextRef(PyObject *p, PyObject **ppos, PyObject **pkey, PyObject **pvalue);
#else
CYTHON_INLINE
static int __Pyx_PyDict_NextRef(PyObject *p, Py_ssize_t *ppos, PyObject **pkey, PyObject **pvalue);
#endif

/* RaiseDoubleKeywords.proto (used by ParseKeywordsImpl) */
static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name);

/* ParseKeywordsImpl.export */
static int __Pyx_ParseKeywordsTuple(
    PyObject *kwds,
    PyObject * const *kwvalues,
    PyObject ** const argnames[],
    PyObject *kwds2,
    PyObject *values[],
    Py_ssize_t num_pos_args,
    Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs
);
static int __Pyx_ParseKeywordDictToDict(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject *kwds2,
    PyObject *values[],
    Py_ssize_t num_pos_args,
    const char* function_name
);
static int __Pyx_ParseKeywordDict(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject *values[],
    Py_ssize_t num_pos_args,
    Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs
);

/* CallUnboundCMethod2.proto */
CYTHON_UNUSED
static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2);
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2);
#else
#define __Pyx_CallUnboundCMethod2(cfunc, self, arg1, arg2)  __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2)
#endif

/* ParseKeywords.proto */
static CYTHON_INLINE int __Pyx_ParseKeywords(
    PyObject *kwds, PyObject *const *kwvalues, PyObject ** const argnames[],
    PyObject *kwds2, PyObject *values[],
    Py_ssize_t num_pos_args, Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs
);

/* RaiseArgTupleInvalid.proto */
static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact,
    Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found);

/* PyObjectFastCallMethod.proto */
#if CYTHON_VECTORCALL && PY_VERSION_HEX >= 0x03090000
#define __Pyx_PyObject_FastCallMethod(name, args, nargsf) PyObject_VectorcallMethod(name, args, nargsf, NULL)
#else
static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf);
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_SubtractObjC(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceSubtract(op1, op2) : PyNumber_Subtract(op1, op2))
#endif

/* PyValueError_Check.proto */
#define __Pyx_PyExc_ValueError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_ValueError)

/* RaiseTooManyValuesToUnpack.proto */
static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected);

/* RaiseNeedMoreValuesToUnpack.proto */
static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index);

/* IterFinish.proto */
static CYTHON_INLINE int __Pyx_IterFinish(void);

/* UnpackItemEndCheck.proto */
static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected);

/* SwapException.proto */
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_ExceptionSwap(type, value, tb)  __Pyx__ExceptionSwap(__pyx_tstate, type, value, tb)
static CYTHON_INLINE void __Pyx__ExceptionSwap(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb);
#else
static CYTHON_INLINE void __Pyx_ExceptionSwap(PyObject **type, PyObject **value, PyObject **tb);
#endif

/* PyDictVersioning.proto (used by GetModuleGlobalName) */
#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS
#define __PYX_DICT_VERSION_INIT  ((PY_UINT64_T) -1)
#define __PYX_GET_DICT_VERSION(dict)  (((PyDictObject*)(dict))->ma_version_tag)
#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)\
    (version_var) = __PYX_GET_DICT_VERSION(dict);\
    (cache_var) = (value);
#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) {\
    static PY_UINT64_T __pyx_dict_version = 0;\
    static PyObject *__pyx_dict_cached_value = NULL;\
    if (likely(__PYX_GET_DICT_VERSION(DICT) == __pyx_dict_version)) {\
        (VAR) = __Pyx_XNewRef(__pyx_dict_cached_value);\
    } else {\
        (VAR) = __pyx_dict_cached_value = (LOOKUP);\
        __pyx_dict_version = __PYX_GET_DICT_VERSION(DICT);\
    }\
}
static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj);
static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj);
static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version);
#else
#define __PYX_GET_DICT_VERSION(dict)  (0)
#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)
#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP)  (VAR) = (LOOKUP);
#endif

/* GetModuleGlobalName.proto */
#if CYTHON_USE_DICT_VERSIONS
#define __Pyx_GetModuleGlobalName(var, name)  do {\
    static PY_UINT64_T __pyx_dict_version = 0;\
    static PyObject *__pyx_dict_cached_value = NULL;\
    (var) = (likely(__pyx_dict_version == __PYX_GET_DICT_VERSION(__pyx_mstate_global->__pyx_d))) ?\
        (likely(__pyx_dict_cached_value) ? __Pyx_NewRef(__pyx_dict_cached_value) : __Pyx_GetBuiltinName(name)) :\
        __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\
} while(0)
#define __Pyx_GetModuleGlobalNameUncached(var, name)  do {\
    PY_UINT64_T __pyx_dict_version;\
    PyObject *__pyx_dict_cached_value;\
    (var) = __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\
} while(0)
static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value);
#else
#define __Pyx_GetModuleGlobalName(var, name)  (var) = __Pyx__GetModuleGlobalName(name)
#define __Pyx_GetModuleGlobalNameUncached(var, name)  (var) = __Pyx__GetModuleGlobalName(name)
static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name);
#endif

/* PySequenceContains.proto */
static CYTHON_INLINE int __Pyx_PySequence_ContainsTF(PyObject* item, PyObject* seq, int eq) {
    int result = PySequence_Contains(seq, item);
    return unlikely(result < 0) ? result : (result == (eq == Py_EQ));
}

/* PyLongCompare.proto */
static CYTHON_INLINE int __Pyx_PyLong_BoolEqObjC(PyObject *op1, PyObject *op2, long intval, long inplace);

/* PyObjectVectorCallKwBuilder.proto */
CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n);
#if CYTHON_VECTORCALL
#if PY_VERSION_HEX >= 0x03090000
#define __Pyx_Object_Vectorcall_CallFromBuilder PyObject_Vectorcall
#else
#define __Pyx_Object_Vectorcall_CallFromBuilder _PyObject_Vectorcall
#endif
#define __Pyx_MakeVectorcallBuilderKwds(n) PyTuple_New(n)
static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n);
static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n);
#else
#define __Pyx_Object_Vectorcall_CallFromBuilder __Pyx_PyObject_FastCallDict
#define __Pyx_MakeVectorcallBuilderKwds(n) __Pyx_PyDict_NewPresized(n)
#define __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n) PyDict_SetItem(builder, key, value)
#define __Pyx_VectorcallBuilder_AddArgStr(key, value, builder, args, n) PyDict_SetItemString(builder, key, value)
#endif

/* PyFloatBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_PyFloat_TrueDivideObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyFloat_TrueDivideObjC(op1, op2, floatval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceTrueDivide(op1, op2) : PyNumber_TrueDivide(op1, op2))
#endif

/* PyLongCompare.proto */
static CYTHON_INLINE PyObject* __Pyx_PyLong_EqObjC(PyObject *op1, PyObject *op2, long intval, long inplace);

/* GetItemInt.proto */
#define __Pyx_GetItemInt(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck, has_gil, unsafe_shared)\
    (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\
    __Pyx_GetItemInt_Fast(o, (Py_ssize_t)i, is_list, wraparound, boundscheck, unsafe_shared) :\
    (is_list ? (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL) :\
               __Pyx_GetItemInt_Generic(o, to_py_func(i))))
#define __Pyx_GetItemInt_List(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck, has_gil, unsafe_shared)\
    (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\
    __Pyx_GetItemInt_List_Fast(o, (Py_ssize_t)i, wraparound, boundscheck, unsafe_shared) :\
    (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL))
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i,
                                                              int wraparound, int boundscheck, int unsafe_shared);
#define __Pyx_GetItemInt_Tuple(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck, has_gil, unsafe_shared)\
    (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\
    __Pyx_GetItemInt_Tuple_Fast(o, (Py_ssize_t)i, wraparound, boundscheck, unsafe_shared) :\
    (PyErr_SetString(PyExc_IndexError, "tuple index out of range"), (PyObject*)NULL))
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i,
                                                              int wraparound, int boundscheck, int unsafe_shared);
static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j);
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i,
                                                     int is_list, int wraparound, int boundscheck, int unsafe_shared);

/* PyAttributeError_Check.proto */
#define __Pyx_PyExc_AttributeError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_AttributeError)

/* ObjectGetItem.proto */
#if CYTHON_USE_TYPE_SLOTS
static CYTHON_INLINE PyObject *__Pyx_PyObject_GetItem(PyObject *obj, PyObject *key);
#else
#define __Pyx_PyObject_GetItem(obj, key)  PyObject_GetItem(obj, key)
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_AddObjC(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceAdd(op1, op2) : PyNumber_Add(op1, op2))
#endif

/* RaiseUnboundLocalError.proto */
static void __Pyx_RaiseUnboundLocalError(const char *varname);

/* ListAppend.proto (used by append) */
#if CYTHON_USE_PYLIST_INTERNALS && CYTHON_ASSUME_SAFE_MACROS
static CYTHON_INLINE int __Pyx_PyList_Append(PyObject* list, PyObject* x) {
    PyListObject* L = (PyListObject*) list;
    Py_ssize_t len = Py_SIZE(list);
    if (likely(L->allocated > len) & likely(len > (L->allocated >> 1))) {
        Py_INCREF(x);
        #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000
        L->ob_item[len] = x;
        #else
        PyList_SET_ITEM(list, len, x);
        #endif
        __Pyx_SET_SIZE(list, len + 1);
        return 0;
    }
    return PyList_Append(list, x);
}
#else
#define __Pyx_PyList_Append(L,x) PyList_Append(L,x)
#endif

/* PyObjectCall2Args.proto (used by PyObjectCallMethod1) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2);

/* PyObjectGetMethod.proto (used by PyObjectCallMethod1) */
#if !(CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000)))
static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method);
#endif

/* PyObjectCallMethod1.proto (used by append) */
static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg);

/* append.proto */
static CYTHON_INLINE int __Pyx_PyObject_Append(PyObject* L, PyObject* x);

/* GetAttr3.proto */
static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *, PyObject *, PyObject *);

/* PyObjectVectorCallMethodKwBuilder.proto */
#if CYTHON_VECTORCALL && PY_VERSION_HEX >= 0x03090000
#define __Pyx_Object_VectorcallMethod_CallFromBuilder PyObject_VectorcallMethod
#else
static PyObject *__Pyx_Object_VectorcallMethod_CallFromBuilder(PyObject *name, PyObject *const *args, size_t nargsf, PyObject *kwnames);
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_MultiplyObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_MultiplyObjC(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceMultiply(op1, op2) : PyNumber_Multiply(op1, op2))
#endif

/* PyUnicodeContains.proto */
static CYTHON_INLINE int __Pyx_PyUnicode_ContainsTF(PyObject* substring, PyObject* text, int eq) {
    int result = PyUnicode_Contains(text, substring);
    return unlikely(result < 0) ? result : (result == (eq == Py_EQ));
}

/* PyOverflowError_Check.proto */
#define __Pyx_PyExc_OverflowError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_OverflowError)

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_RemainderObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_RemainderObjC(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceRemainder(op1, op2) : PyNumber_Remainder(op1, op2))
#endif

/* SetItemInt.proto */
#define __Pyx_SetItemInt(o, i, v, type, is_signed, to_py_func, is_list, wraparound, boundscheck, has_gil, unsafe_shared)\
    (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\
    __Pyx_SetItemInt_Fast(o, (Py_ssize_t)i, v, is_list, wraparound, boundscheck, unsafe_shared) :\
    (is_list ? (PyErr_SetString(PyExc_IndexError, "list assignment index out of range"), -1) :\
               __Pyx_SetItemInt_Generic(o, to_py_func(i), v)))
static int __Pyx_SetItemInt_Generic(PyObject *o, PyObject *j, PyObject *v);
static CYTHON_INLINE int __Pyx_SetItemInt_Fast(PyObject *o, Py_ssize_t i, PyObject *v,
                                               int is_list, int wraparound, int boundscheck, int unsafe_shared);

/* PyRange_Check.proto */
#if CYTHON_COMPILING_IN_PYPY && !defined(PyRange_Check)
  #define PyRange_Check(obj)  __Pyx_TypeCheck((obj), &PyRange_Type)
#endif

/* pyint_simplify.proto */
static CYTHON_INLINE int __Pyx_PyInt_FromNumber(PyObject **number_var, const char *argname, int accept_none);

/* DictGetItem.proto */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject *__Pyx_PyDict_GetItem(PyObject *d, PyObject* key);
#define __Pyx_PyObject_Dict_GetItem(obj, name)\
    (likely(PyDict_CheckExact(obj)) ?\
     __Pyx_PyDict_GetItem(obj, name) : PyObject_GetItem(obj, name))
#else
#define __Pyx_PyDict_GetItem(d, key) PyObject_GetItem(d, key)
#define __Pyx_PyObject_Dict_GetItem(obj, name)  PyObject_GetItem(obj, name)
#endif

/* pybytes_as_double.proto (used by pyunicode_as_double) */
static double __Pyx_SlowPyString_AsDouble(PyObject *obj);
static double __Pyx__PyBytes_AsDouble(PyObject *obj, const char* start, Py_ssize_t length);
static CYTHON_INLINE double __Pyx_PyBytes_AsDouble(PyObject *obj) {
    char* as_c_string;
    Py_ssize_t size;
#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE
    as_c_string = PyBytes_AS_STRING(obj);
    size = PyBytes_GET_SIZE(obj);
#else
    if (PyBytes_AsStringAndSize(obj, &as_c_string, &size) < 0) {
        return (double)-1;
    }
#endif
    return __Pyx__PyBytes_AsDouble(obj, as_c_string, size);
}
static CYTHON_INLINE double __Pyx_PyByteArray_AsDouble(PyObject *obj) {
    char* as_c_string;
    Py_ssize_t size;
#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE
    as_c_string = PyByteArray_AS_STRING(obj);
    size = PyByteArray_GET_SIZE(obj);
#else
    as_c_string = PyByteArray_AsString(obj);
    if (as_c_string == NULL) {
        return (double)-1;
    }
    size = PyByteArray_Size(obj);
#endif
    return __Pyx__PyBytes_AsDouble(obj, as_c_string, size);
}

/* pyunicode_as_double.proto */
#if !CYTHON_COMPILING_IN_PYPY && CYTHON_ASSUME_SAFE_MACROS
static const char* __Pyx__PyUnicode_AsDouble_Copy(const void* data, const int kind, char* buffer, Py_ssize_t start, Py_ssize_t end) {
    int last_was_punctuation;
    Py_ssize_t i;
    last_was_punctuation = 1;
    for (i=start; i <= end; i++) {
        Py_UCS4 chr = PyUnicode_READ(kind, data, i);
        int is_punctuation = (chr == '_') | (chr == '.');
        *buffer = (char)chr;
        buffer += (chr != '_');
        if (unlikely(chr > 127)) goto parse_failure;
        if (unlikely(last_was_punctuation & is_punctuation)) goto parse_failure;
        last_was_punctuation = is_punctuation;
    }
    if (unlikely(last_was_punctuation)) goto parse_failure;
    *buffer = '\0';
    return buffer;
parse_failure:
    return NULL;
}
static double __Pyx__PyUnicode_AsDouble_inf_nan(const void* data, int kind, Py_ssize_t start, Py_ssize_t length) {
    int matches = 1;
    Py_UCS4 chr;
    Py_UCS4 sign = PyUnicode_READ(kind, data, start);
    int is_signed = (sign == '-') | (sign == '+');
    start += is_signed;
    length -= is_signed;
    switch (PyUnicode_READ(kind, data, start)) {
        #ifdef Py_NAN
        case 'n':
        case 'N':
            if (unlikely(length != 3)) goto parse_failure;
            chr = PyUnicode_READ(kind, data, start+1);
            matches &= (chr == 'a') | (chr == 'A');
            chr = PyUnicode_READ(kind, data, start+2);
            matches &= (chr == 'n') | (chr == 'N');
            if (unlikely(!matches)) goto parse_failure;
            return (sign == '-') ? -Py_NAN : Py_NAN;
        #endif
        case 'i':
        case 'I':
            if (unlikely(length < 3)) goto parse_failure;
            chr = PyUnicode_READ(kind, data, start+1);
            matches &= (chr == 'n') | (chr == 'N');
            chr = PyUnicode_READ(kind, data, start+2);
            matches &= (chr == 'f') | (chr == 'F');
            if (likely(length == 3 && matches))
                return (sign == '-') ? -Py_HUGE_VAL : Py_HUGE_VAL;
            if (unlikely(length != 8)) goto parse_failure;
            chr = PyUnicode_READ(kind, data, start+3);
            matches &= (chr == 'i') | (chr == 'I');
            chr = PyUnicode_READ(kind, data, start+4);
            matches &= (chr == 'n') | (chr == 'N');
            chr = PyUnicode_READ(kind, data, start+5);
            matches &= (chr == 'i') | (chr == 'I');
            chr = PyUnicode_READ(kind, data, start+6);
            matches &= (chr == 't') | (chr == 'T');
            chr = PyUnicode_READ(kind, data, start+7);
            matches &= (chr == 'y') | (chr == 'Y');
            if (unlikely(!matches)) goto parse_failure;
            return (sign == '-') ? -Py_HUGE_VAL : Py_HUGE_VAL;
        case '.': case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':
            break;
        default:
            goto parse_failure;
    }
    return 0.0;
parse_failure:
    return -1.0;
}
static double __Pyx_PyUnicode_AsDouble_WithSpaces(PyObject *obj) {
    double value;
    const char *last;
    char *end;
    Py_ssize_t start, length = PyUnicode_GET_LENGTH(obj);
    const int kind = PyUnicode_KIND(obj);
    const void* data = PyUnicode_DATA(obj);
    start = 0;
    while (Py_UNICODE_ISSPACE(PyUnicode_READ(kind, data, start)))
        start++;
    while (start < length - 1 && Py_UNICODE_ISSPACE(PyUnicode_READ(kind, data, length - 1)))
        length--;
    length -= start;
    if (unlikely(length <= 0)) goto fallback;
    value = __Pyx__PyUnicode_AsDouble_inf_nan(data, kind, start, length);
    if (unlikely(value == -1.0)) goto fallback;
    if (value != 0.0) return value;
    if (length < 40) {
        char number[40];
        last = __Pyx__PyUnicode_AsDouble_Copy(data, kind, number, start, start + length);
        if (unlikely(!last)) goto fallback;
        value = PyOS_string_to_double(number, &end, NULL);
    } else {
        char *number = (char*) PyMem_Malloc((length + 1) * sizeof(char));
        if (unlikely(!number)) goto fallback;
        last = __Pyx__PyUnicode_AsDouble_Copy(data, kind, number, start, start + length);
        if (unlikely(!last)) {
            PyMem_Free(number);
            goto fallback;
        }
        value = PyOS_string_to_double(number, &end, NULL);
        PyMem_Free(number);
    }
    if (likely(end == last) || (value == (double)-1 && PyErr_Occurred())) {
        return value;
    }
fallback:
    return __Pyx_SlowPyString_AsDouble(obj);
}
#endif
static CYTHON_INLINE double __Pyx_PyUnicode_AsDouble(PyObject *obj) {
#if !CYTHON_COMPILING_IN_PYPY && CYTHON_ASSUME_SAFE_MACROS
    if (unlikely(__Pyx_PyUnicode_READY(obj) == -1))
        return (double)-1;
    if (likely(PyUnicode_IS_ASCII(obj))) {
        const char *s;
        Py_ssize_t length;
        s = PyUnicode_AsUTF8AndSize(obj, &length);
        return __Pyx__PyBytes_AsDouble(obj, s, length);
    }
    return __Pyx_PyUnicode_AsDouble_WithSpaces(obj);
#else
    return __Pyx_SlowPyString_AsDouble(obj);
#endif
}

/* FloatExceptionCheck.proto */
#define __PYX_CHECK_FLOAT_EXCEPTION(value, error_value)\
    ((error_value) == (error_value) ?\
     (value) == (error_value) :\
     (value) != (value))

/* PyIndexError_Check.proto */
#define __Pyx_PyExc_IndexError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_IndexError)

/* SliceObject.proto */
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetSlice(
        PyObject* obj, Py_ssize_t cstart, Py_ssize_t cstop,
        PyObject** py_start, PyObject** py_stop, PyObject** py_slice,
        int has_cstart, int has_cstop, int wraparound);

/* HasAttr.proto (used by ImportImpl) */
#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
#define __Pyx_HasAttr(o, n)  PyObject_HasAttrWithError(o, n)
#else
static CYTHON_INLINE int __Pyx_HasAttr(PyObject *, PyObject *);
#endif

/* ImportImpl.export */
static PyObject *__Pyx__Import(PyObject *name, PyObject *const *imported_names, Py_ssize_t len_imported_names, PyObject *qualname, PyObject *moddict, int level);

/* Import.proto */
static CYTHON_INLINE PyObject *__Pyx_Import(PyObject *name, PyObject *const *imported_names, Py_ssize_t len_imported_names, PyObject *qualname, int level);

/* ListCompAppend.proto */
#if CYTHON_USE_PYLIST_INTERNALS && CYTHON_ASSUME_SAFE_MACROS
static CYTHON_INLINE int __Pyx_ListComp_Append(PyObject* list, PyObject* x) {
    PyListObject* L = (PyListObject*) list;
    Py_ssize_t len = Py_SIZE(list);
    if (likely(L->allocated > len)) {
        Py_INCREF(x);
        #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000
        L->ob_item[len] = x;
        #else
        PyList_SET_ITEM(list, len, x);
        #endif
        __Pyx_SET_SIZE(list, len + 1);
        return 0;
    }
    return PyList_Append(list, x);
}
#else
#define __Pyx_ListComp_Append(L,x) PyList_Append(L,x)
#endif

/* pyobject_as_double.proto */
static double __Pyx__PyObject_AsDouble(PyObject* obj);
#if CYTHON_COMPILING_IN_PYPY
#define __Pyx_PyObject_AsDouble(obj)\
(likely(PyFloat_CheckExact(obj)) ? PyFloat_AS_DOUBLE(obj) :\
 likely(PyLong_CheckExact(obj)) ?\
 PyFloat_AsDouble(obj) : __Pyx__PyObject_AsDouble(obj))
#else
#define __Pyx_PyObject_AsDouble(obj)\
((likely(PyFloat_CheckExact(obj))) ?  __Pyx_PyFloat_AS_DOUBLE(obj) :\
 likely(PyLong_CheckExact(obj)) ?\
 PyLong_AsDouble(obj) : __Pyx__PyObject_AsDouble(obj))
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_MultiplyCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_MultiplyCObj(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceMultiply(op1, op2) : PyNumber_Multiply(op1, op2))
#endif

/* RaiseUnexpectedTypeError.proto */
static int __Pyx_RaiseUnexpectedTypeError(const char *expected, PyObject *obj);

/* PyObject_Unicode.proto */
#define __Pyx_PyObject_Unicode(obj)\
    (likely(PyUnicode_CheckExact(obj)) ? __Pyx_NewRef(obj) : PyObject_Str(obj))

/* PyObjectFormatAndDecref.proto */
static CYTHON_INLINE PyObject* __Pyx_PyObject_FormatSimpleAndDecref(PyObject* s, PyObject* f);
static CYTHON_INLINE PyObject* __Pyx_PyObject_FormatAndDecref(PyObject* s, PyObject* f);

/* JoinPyUnicode.export */
static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength,
                                      Py_UCS4 max_char);

/* RaiseClosureNameError.proto */
static void __Pyx_RaiseClosureNameError(const char *varname);

/* pep479.proto */
static void __Pyx_Generator_Replace_StopIteration(int in_async_gen);

/* PyKeyError_Check.proto */
#define __Pyx_PyExc_KeyError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_KeyError)

/* KeywordStringCheck.proto */
static CYTHON_INLINE int __Pyx_CheckKeywordStrings(const char* function_name, PyObject *kw);

/* PyDictContains.proto */
static CYTHON_INLINE int __Pyx_PyDict_ContainsTF(PyObject* item, PyObject* dict, int eq) {
    int result = PyDict_Contains(dict, item);
    return unlikely(result < 0) ? result : (result == (eq == Py_EQ));
}

/* PyObjectCallNoArg.proto (used by PyObjectCallMethod0) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func);

/* PyObjectCallMethod0.proto (used by dict_iter) */
static PyObject* __Pyx_PyObject_CallMethod0(PyObject* obj, PyObject* method_name);

/* RaiseNoneIterError.proto (used by UnpackTupleError) */
static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void);

/* UnpackTupleError.proto (used by UnpackTuple2) */
static void __Pyx_UnpackTupleError(PyObject *, Py_ssize_t index);

/* UnpackTuple2.proto (used by dict_iter) */
static CYTHON_INLINE int __Pyx_unpack_tuple2(
    PyObject* tuple, PyObject** value1, PyObject** value2, int is_tuple, int has_known_size, int decref_tuple);
static CYTHON_INLINE int __Pyx_unpack_tuple2_exact(
    PyObject* tuple, PyObject** value1, PyObject** value2, int decref_tuple);
static int __Pyx_unpack_tuple2_generic(
    PyObject* tuple, PyObject** value1, PyObject** value2, int has_known_size, int decref_tuple);

/* dict_iter.proto */
static CYTHON_INLINE PyObject* __Pyx_dict_iterator(PyObject* dict, int is_dict, PyObject* method_name,
                                                   Py_ssize_t* p_orig_length, int* p_is_dict);
static CYTHON_INLINE int __Pyx_dict_iter_next(PyObject* dict_or_iter, Py_ssize_t orig_length, Py_ssize_t* ppos,
                                              PyObject** pkey, PyObject** pvalue, PyObject** pitem, int is_dict);

/* RejectKeywords.export */
static void __Pyx_RejectKeywords(const char* function_name, PyObject *kwds);

/* UnicodeConcatInPlace.proto */
# if CYTHON_COMPILING_IN_CPYTHON
    #if CYTHON_REFNANNY
        #define __Pyx_PyUnicode_ConcatInPlace(left, right, unsafe_shared) __Pyx_PyUnicode_ConcatInPlaceImpl(&left, right, unsafe_shared, __pyx_refnanny)
    #else
        #define __Pyx_PyUnicode_ConcatInPlace(left, right, unsafe_shared) __Pyx_PyUnicode_ConcatInPlaceImpl(&left, right, unsafe_shared)
    #endif
    #define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_DefinitelyUniqueInPlace(left, right) __Pyx_PyUnicode_ConcatInPlace(left, right, __Pyx_ReferenceSharing_DefinitelyUnique)
    #define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlace(left, right) __Pyx_PyUnicode_ConcatInPlace(left, right, __Pyx_ReferenceSharing_OwnStrongReference)
    #define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_FunctionArgumentInPlace(left, right) __Pyx_PyUnicode_ConcatInPlace(left, right, __Pyx_ReferenceSharing_DefinitelyUnique)
    #define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_SharedReferenceInPlace(left, right) __Pyx_PyUnicode_ConcatInPlace(left, right, __Pyx_ReferenceSharing_SharedReference)
    static CYTHON_INLINE PyObject *__Pyx_PyUnicode_ConcatInPlaceImpl(PyObject **p_left, PyObject *right, int unsafe_shared
        #if CYTHON_REFNANNY
        , void* __pyx_refnanny
        #endif
    );
#else
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_DefinitelyUniqueInPlace __Pyx_PyUnicode_Concat
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlace __Pyx_PyUnicode_Concat
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_FunctionArgumentInPlace __Pyx_PyUnicode_Concat
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_SharedReferenceInPlace __Pyx_PyUnicode_Concat
#endif
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_DefinitelyUniqueInPlaceSafe(left, right)\
    ((unlikely((left) == Py_None) || unlikely((right) == Py_None)) ?\
    PyNumber_InPlaceAdd(left, right) : __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_DefinitelyUniqueInPlace(left, right))
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlaceSafe(left, right)\
    ((unlikely((left) == Py_None) || unlikely((right) == Py_None)) ?\
    PyNumber_InPlaceAdd(left, right) : __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlace(left, right))
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_FunctionArgumentInPlaceSafe(left, right)\
    ((unlikely((left) == Py_None) || unlikely((right) == Py_None)) ?\
    PyNumber_InPlaceAdd(left, right) : __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_FunctionArgumentInPlace(left, right))
#define __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_SharedReferenceInPlaceSafe(left, right)\
    ((unlikely((left) == Py_None) || unlikely((right) == Py_None)) ?\
    PyNumber_InPlaceAdd(left, right) : __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_SharedReferenceInPlace(left, right))

/* ExtTypeTest.proto */
static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type);

/* PyTypeError_Check.proto */
#define __Pyx_PyExc_TypeError_Check(obj)  __Pyx_TypeCheck(obj, PyExc_TypeError)

/* PyObjectLookupSpecial.proto */
#if CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS
#define __Pyx_PyObject_LookupSpecialNoError(obj, attr_name)  __Pyx__PyObject_LookupSpecial(obj, attr_name, 0)
#define __Pyx_PyObject_LookupSpecial(obj, attr_name)  __Pyx__PyObject_LookupSpecial(obj, attr_name, 1)
static CYTHON_INLINE PyObject* __Pyx__PyObject_LookupSpecial(PyObject* obj, PyObject* attr_name, int with_error);
#else
#define __Pyx_PyObject_LookupSpecialNoError(o,n) __Pyx_PyObject_GetAttrStrNoError(o,n)
#define __Pyx_PyObject_LookupSpecial(o,n) __Pyx_PyObject_GetAttrStr(o,n)
#endif

/* PyFloatBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_PyFloat_SubtractObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyFloat_SubtractObjC(op1, op2, floatval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceSubtract(op1, op2) : PyNumber_Subtract(op1, op2))
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_SubtractCObj(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceSubtract(op1, op2) : PyNumber_Subtract(op1, op2))
#endif

/* PyLongBinop.proto */
#if !CYTHON_COMPILING_IN_PYPY
static CYTHON_INLINE PyObject* __Pyx_PyLong_FloorDivideObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check);
#else
#define __Pyx_PyLong_FloorDivideObjC(op1, op2, intval, inplace, zerodivision_check)\
    (inplace ? PyNumber_InPlaceFloorDivide(op1, op2) : PyNumber_FloorDivide(op1, op2))
#endif

/* PyUnicode_Substring.proto */
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring(
            PyObject* text, Py_ssize_t start, Py_ssize_t stop);

/* BuildPyUnicode.proto (used by COrdinalToPyUnicode) */
static PyObject* __Pyx_PyUnicode_BuildFromAscii(Py_ssize_t ulength, const char* chars, int clength,
                                                int prepend_sign, char padding_char);

/* COrdinalToPyUnicode.proto (used by CIntToPyUnicode) */
static CYTHON_INLINE int __Pyx_CheckUnicodeValue(int value);
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromOrdinal_Padded(int value, Py_ssize_t width, char padding_char);

/* GCCDiagnostics.proto (used by CIntToPyUnicode) */
#if !defined(__INTEL_COMPILER) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))
#define __Pyx_HAS_GCC_DIAGNOSTIC
#endif

/* IncludeStdlibH.proto (used by CIntToPyUnicode) */
#include <stdlib.h>

/* CIntToPyUnicode.proto */
#define __Pyx_PyUnicode_From_int(value, width, padding_char, format_char) (\
    ((format_char) == ('c')) ?\
        __Pyx_uchar___Pyx_PyUnicode_From_int(value, width, padding_char) :\
        __Pyx____Pyx_PyUnicode_From_int(value, width, padding_char, format_char)\
    )
static CYTHON_INLINE PyObject* __Pyx_uchar___Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char);
static CYTHON_INLINE PyObject* __Pyx____Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char, char format_char);

/* DivInt[long].proto */
static CYTHON_INLINE long __Pyx_div_long(long, long, int b_is_constant);

/* ModInt[long].proto */
static CYTHON_INLINE long __Pyx_mod_long(long, long, int b_is_constant);

/* AllocateExtensionType.proto */
static PyObject *__Pyx_AllocateExtensionType(PyTypeObject *t, int is_final);

/* CallTypeTraverse.proto */
#if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000)
#define __Pyx_call_type_traverse(o, always_call, visit, arg) 0
#else
static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg);
#endif

/* CheckTypeForFreelists.proto */
#if CYTHON_USE_FREELISTS
#if CYTHON_USE_TYPE_SPECS
#define __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(t, expected_tp, expected_size) ((int) ((t) == (expected_tp)))
#define __PYX_CHECK_TYPE_FOR_FREELIST_FLAGS  Py_TPFLAGS_IS_ABSTRACT
#else
#define __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(t, expected_tp, expected_size) ((int) ((t)->tp_basicsize == (expected_size)))
#define __PYX_CHECK_TYPE_FOR_FREELIST_FLAGS  (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE)
#endif
#define __PYX_CHECK_TYPE_FOR_FREELISTS(t, expected_tp, expected_size)\
    (__PYX_CHECK_FINAL_TYPE_FOR_FREELISTS((t), (expected_tp), (expected_size)) &\
     (int) (!__Pyx_PyType_HasFeature((t), __PYX_CHECK_TYPE_FOR_FREELIST_FLAGS)))
#endif

/* LimitedApiGetTypeDict.proto (used by SetItemOnTypeDict) */
#if CYTHON_COMPILING_IN_LIMITED_API
static PyObject *__Pyx_GetTypeDict(PyTypeObject *tp);
#endif

/* SetItemOnTypeDict.proto (used by FixUpExtensionType) */
static int __Pyx__SetItemOnTypeDict(PyTypeObject *tp, PyObject *k, PyObject *v);
#define __Pyx_SetItemOnTypeDict(tp, k, v) __Pyx__SetItemOnTypeDict((PyTypeObject*)tp, k, v)

/* FixUpExtensionType.proto */
static CYTHON_INLINE int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type);

/* ValidateBasesTuple.proto (used by PyType_Ready) */
#if CYTHON_COMPILING_IN_CPYTHON || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_USE_TYPE_SPECS
static int __Pyx_validate_bases_tuple(const char *type_name, Py_ssize_t dictoffset, PyObject *bases);
#endif

/* PyType_Ready.proto */
CYTHON_UNUSED static int __Pyx_PyType_Ready(PyTypeObject *t);

/* SetVTable.proto */
static int __Pyx_SetVtable(PyTypeObject* typeptr , void* vtable);

/* GetVTable.proto (used by MergeVTables) */
static void* __Pyx_GetVtable(PyTypeObject *type);

/* MergeVTables.proto */
static int __Pyx_MergeVtables(PyTypeObject *type);

/* TypeImport.proto */
#ifndef __PYX_HAVE_RT_ImportType_proto_3_2_4
#define __PYX_HAVE_RT_ImportType_proto_3_2_4
#if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L
#include <stdalign.h>
#endif
#if (defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L) || __cplusplus >= 201103L
#define __PYX_GET_STRUCT_ALIGNMENT_3_2_4(s) alignof(s)
#else
#define __PYX_GET_STRUCT_ALIGNMENT_3_2_4(s) sizeof(void*)
#endif
enum __Pyx_ImportType_CheckSize_3_2_4 {
   __Pyx_ImportType_CheckSize_Error_3_2_4 = 0,
   __Pyx_ImportType_CheckSize_Warn_3_2_4 = 1,
   __Pyx_ImportType_CheckSize_Ignore_3_2_4 = 2
};
static PyTypeObject *__Pyx_ImportType_3_2_4(PyObject* module, const char *module_name, const char *class_name, size_t size, size_t alignment, enum __Pyx_ImportType_CheckSize_3_2_4 check_size);
#endif

/* ImportFrom.proto */
static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name);

/* ListPack.proto */
static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...);

/* Py3UpdateBases.proto */
static PyObject* __Pyx_PEP560_update_bases(PyObject *bases);

/* CalculateMetaclass.proto */
static PyObject *__Pyx_CalculateMetaclass(PyTypeObject *metaclass, PyObject *bases);

/* dict_setdefault.proto (used by FetchCommonType) */
static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value);

/* AddModuleRef.proto (used by FetchSharedCythonModule) */
#if ((CYTHON_COMPILING_IN_CPYTHON_FREETHREADING ) ||\
     __PYX_LIMITED_VERSION_HEX < 0x030d0000)
  static PyObject *__Pyx_PyImport_AddModuleRef(const char *name);
#else
  #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name)
#endif

/* FetchSharedCythonModule.proto (used by FetchCommonType) */
static PyObject *__Pyx_FetchSharedCythonABIModule(void);

/* FetchCommonType.proto (used by CommonTypesMetaclass) */
static PyTypeObject* __Pyx_FetchCommonTypeFromSpec(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases);

/* CommonTypesMetaclass.proto (used by CythonFunctionShared) */
static int __pyx_CommonTypesMetaclass_init(PyObject *module);
#define __Pyx_CommonTypesMetaclass_USED

/* PyMethodNew.proto (used by CythonFunctionShared) */
static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ);

/* PyVectorcallFastCallDict.proto (used by CythonFunctionShared) */
#if CYTHON_METH_FASTCALL && CYTHON_VECTORCALL
static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw);
#endif

/* CythonFunctionShared.proto (used by CythonFunction) */
#define __Pyx_CyFunction_USED
#define __Pyx_CYFUNCTION_STATICMETHOD  0x01
#define __Pyx_CYFUNCTION_CLASSMETHOD   0x02
#define __Pyx_CYFUNCTION_CCLASS        0x04
#define __Pyx_CYFUNCTION_COROUTINE     0x08
#define __Pyx_CyFunction_GetClosure(f)\
    (((__pyx_CyFunctionObject *) (f))->func_closure)
#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API
  #define __Pyx_CyFunction_GetClassObj(f)\
      (((__pyx_CyFunctionObject *) (f))->func_classobj)
#else
  #define __Pyx_CyFunction_GetClassObj(f)\
      ((PyObject*) ((PyCMethodObject *) (f))->mm_class)
#endif
#define __Pyx_CyFunction_SetClassObj(f, classobj)\
    __Pyx__CyFunction_SetClassObj((__pyx_CyFunctionObject *) (f), (classobj))
#define __Pyx_CyFunction_Defaults(type, f)\
    ((type *)(((__pyx_CyFunctionObject *) (f))->defaults))
#define __Pyx_CyFunction_SetDefaultsGetter(f, g)\
    ((__pyx_CyFunctionObject *) (f))->defaults_getter = (g)
typedef struct {
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject_HEAD
    PyObject *func;
#elif PY_VERSION_HEX < 0x030900B1
    PyCFunctionObject func;
#else
    PyCMethodObject func;
#endif
#if CYTHON_COMPILING_IN_LIMITED_API && CYTHON_METH_FASTCALL
    __pyx_vectorcallfunc func_vectorcall;
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *func_weakreflist;
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    PyObject *func_dict;
#endif
    PyObject *func_name;
    PyObject *func_qualname;
    PyObject *func_doc;
    PyObject *func_globals;
    PyObject *func_code;
    PyObject *func_closure;
#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API
    PyObject *func_classobj;
#endif
    PyObject *defaults;
    int flags;
    PyObject *defaults_tuple;
    PyObject *defaults_kwdict;
    PyObject *(*defaults_getter)(PyObject *);
    PyObject *func_annotations;
    PyObject *func_is_coroutine;
} __pyx_CyFunctionObject;
#undef __Pyx_CyOrPyCFunction_Check
#define __Pyx_CyFunction_Check(obj)  __Pyx_TypeCheck(obj, __pyx_mstate_global->__pyx_CyFunctionType)
#define __Pyx_CyOrPyCFunction_Check(obj)  __Pyx_TypeCheck2(obj, __pyx_mstate_global->__pyx_CyFunctionType, &PyCFunction_Type)
#define __Pyx_CyFunction_CheckExact(obj)  __Pyx_IS_TYPE(obj, __pyx_mstate_global->__pyx_CyFunctionType)
static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void));
#undef __Pyx_IsSameCFunction
#define __Pyx_IsSameCFunction(func, cfunc)   __Pyx__IsSameCyOrCFunction(func, cfunc)
static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject* op, PyMethodDef *ml,
                                      int flags, PyObject* qualname,
                                      PyObject *closure,
                                      PyObject *module, PyObject *globals,
                                      PyObject* code);
static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj);
static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func,
                                                         PyTypeObject *defaults_type);
static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *m,
                                                            PyObject *tuple);
static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *m,
                                                             PyObject *dict);
static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *m,
                                                              PyObject *dict);
static int __pyx_CyFunction_init(PyObject *module);
#if CYTHON_METH_FASTCALL
static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
#if CYTHON_COMPILING_IN_LIMITED_API
#define __Pyx_CyFunction_func_vectorcall(f) (((__pyx_CyFunctionObject*)f)->func_vectorcall)
#else
#define __Pyx_CyFunction_func_vectorcall(f) (((PyCFunctionObject*)f)->vectorcall)
#endif
#endif

/* CythonFunction.proto */
static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml,
                                      int flags, PyObject* qualname,
                                      PyObject *closure,
                                      PyObject *module, PyObject *globals,
                                      PyObject* code);

/* SetNameInClass.proto */
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030d0000
#define __Pyx_SetNameInClass(ns, name, value)\
    (likely(PyDict_CheckExact(ns)) ? _PyDict_SetItem_KnownHash(ns, name, value, ((PyASCIIObject *) name)->hash) : PyObject_SetItem(ns, name, value))
#elif CYTHON_COMPILING_IN_CPYTHON
#define __Pyx_SetNameInClass(ns, name, value)\
    (likely(PyDict_CheckExact(ns)) ? PyDict_SetItem(ns, name, value) : PyObject_SetItem(ns, name, value))
#else
#define __Pyx_SetNameInClass(ns, name, value)  PyObject_SetItem(ns, name, value)
#endif

/* Py3ClassCreate.proto */
static PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObject *name, PyObject *qualname,
                                           PyObject *mkw, PyObject *modname, PyObject *doc);
static PyObject *__Pyx_Py3ClassCreate(PyObject *metaclass, PyObject *name, PyObject *bases, PyObject *dict,
                                      PyObject *mkw, int calculate_metaclass, int allow_py2_metaclass);

/* PyUserWarning_Check.proto */
#define __Pyx_PyExc_UserWarning_Check(obj)  __Pyx_TypeCheck(obj, PyExc_UserWarning)

/* GetNameInClass.proto */
#define __Pyx_GetNameInClass(var, nmspace, name)  (var) = __Pyx__GetNameInClass(nmspace, name)
static PyObject *__Pyx__GetNameInClass(PyObject *nmspace, PyObject *name);

/* CLineInTraceback.proto (used by AddTraceback) */
#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME
static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line);
#else
#define __Pyx_CLineForTraceback(tstate, c_line)  (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0)
#endif

/* CodeObjectCache.proto (used by AddTraceback) */
#if CYTHON_COMPILING_IN_LIMITED_API
typedef PyObject __Pyx_CachedCodeObjectType;
#else
typedef PyCodeObject __Pyx_CachedCodeObjectType;
#endif
typedef struct {
    __Pyx_CachedCodeObjectType* code_object;
    int code_line;
} __Pyx_CodeObjectCacheEntry;
struct __Pyx_CodeObjectCache {
    int count;
    int max_count;
    __Pyx_CodeObjectCacheEntry* entries;
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    __pyx_atomic_int_type accessor_count;
  #endif
};
static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line);
static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line);
static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object);

/* AddTraceback.proto */
static void __Pyx_AddTraceback(const char *funcname, int c_line,
                               int py_line, const char *filename);

/* RealImag.proto */
#if CYTHON_CCOMPLEX
  #ifdef __cplusplus
    #define __Pyx_CREAL(z) ((z).real())
    #define __Pyx_CIMAG(z) ((z).imag())
  #else
    #define __Pyx_CREAL(z) (__real__(z))
    #define __Pyx_CIMAG(z) (__imag__(z))
  #endif
#else
    #define __Pyx_CREAL(z) ((z).real)
    #define __Pyx_CIMAG(z) ((z).imag)
#endif
#if defined(__cplusplus) && CYTHON_CCOMPLEX\
        && (defined(_WIN32) || defined(__clang__) || (defined(__GNUC__) && (__GNUC__ >= 5 || __GNUC__ == 4 && __GNUC_MINOR__ >= 4 )) || __cplusplus >= 201103)
    #define __Pyx_SET_CREAL(z,x) ((z).real(x))
    #define __Pyx_SET_CIMAG(z,y) ((z).imag(y))
#else
    #define __Pyx_SET_CREAL(z,x) __Pyx_CREAL(z) = (x)
    #define __Pyx_SET_CIMAG(z,y) __Pyx_CIMAG(z) = (y)
#endif

/* Arithmetic.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
    #define __Pyx_c_eq_float(a, b)   ((a)==(b))
    #define __Pyx_c_sum_float(a, b)  ((a)+(b))
    #define __Pyx_c_diff_float(a, b) ((a)-(b))
    #define __Pyx_c_prod_float(a, b) ((a)*(b))
    #define __Pyx_c_quot_float(a, b) ((a)/(b))
    #define __Pyx_c_neg_float(a)     (-(a))
  #ifdef __cplusplus
    #define __Pyx_c_is_zero_float(z) ((z)==(float)0)
    #define __Pyx_c_conj_float(z)    (::std::conj(z))
    #if 1
        #define __Pyx_c_abs_float(z)     (::std::abs(z))
        #define __Pyx_c_pow_float(a, b)  (::std::pow(a, b))
    #endif
  #else
    #define __Pyx_c_is_zero_float(z) ((z)==0)
    #define __Pyx_c_conj_float(z)    (conjf(z))
    #if 1
        #define __Pyx_c_abs_float(z)     (cabsf(z))
        #define __Pyx_c_pow_float(a, b)  (cpowf(a, b))
    #endif
 #endif
#else
    static CYTHON_INLINE int __Pyx_c_eq_float(__pyx_t_float_complex, __pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_sum_float(__pyx_t_float_complex, __pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_diff_float(__pyx_t_float_complex, __pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_prod_float(__pyx_t_float_complex, __pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_quot_float(__pyx_t_float_complex, __pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_neg_float(__pyx_t_float_complex);
    static CYTHON_INLINE int __Pyx_c_is_zero_float(__pyx_t_float_complex);
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_conj_float(__pyx_t_float_complex);
    #if 1
        static CYTHON_INLINE float __Pyx_c_abs_float(__pyx_t_float_complex);
        static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_pow_float(__pyx_t_float_complex, __pyx_t_float_complex);
    #endif
#endif

/* Arithmetic.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
    #define __Pyx_c_eq_double(a, b)   ((a)==(b))
    #define __Pyx_c_sum_double(a, b)  ((a)+(b))
    #define __Pyx_c_diff_double(a, b) ((a)-(b))
    #define __Pyx_c_prod_double(a, b) ((a)*(b))
    #define __Pyx_c_quot_double(a, b) ((a)/(b))
    #define __Pyx_c_neg_double(a)     (-(a))
  #ifdef __cplusplus
    #define __Pyx_c_is_zero_double(z) ((z)==(double)0)
    #define __Pyx_c_conj_double(z)    (::std::conj(z))
    #if 1
        #define __Pyx_c_abs_double(z)     (::std::abs(z))
        #define __Pyx_c_pow_double(a, b)  (::std::pow(a, b))
    #endif
  #else
    #define __Pyx_c_is_zero_double(z) ((z)==0)
    #define __Pyx_c_conj_double(z)    (conj(z))
    #if 1
        #define __Pyx_c_abs_double(z)     (cabs(z))
        #define __Pyx_c_pow_double(a, b)  (cpow(a, b))
    #endif
 #endif
#else
    static CYTHON_INLINE int __Pyx_c_eq_double(__pyx_t_double_complex, __pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_sum_double(__pyx_t_double_complex, __pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_diff_double(__pyx_t_double_complex, __pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_prod_double(__pyx_t_double_complex, __pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_quot_double(__pyx_t_double_complex, __pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_neg_double(__pyx_t_double_complex);
    static CYTHON_INLINE int __Pyx_c_is_zero_double(__pyx_t_double_complex);
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_conj_double(__pyx_t_double_complex);
    #if 1
        static CYTHON_INLINE double __Pyx_c_abs_double(__pyx_t_double_complex);
        static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_pow_double(__pyx_t_double_complex, __pyx_t_double_complex);
    #endif
#endif

/* Arithmetic.proto */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
    #define __Pyx_c_eq_long__double(a, b)   ((a)==(b))
    #define __Pyx_c_sum_long__double(a, b)  ((a)+(b))
    #define __Pyx_c_diff_long__double(a, b) ((a)-(b))
    #define __Pyx_c_prod_long__double(a, b) ((a)*(b))
    #define __Pyx_c_quot_long__double(a, b) ((a)/(b))
    #define __Pyx_c_neg_long__double(a)     (-(a))
  #ifdef __cplusplus
    #define __Pyx_c_is_zero_long__double(z) ((z)==(long double)0)
    #define __Pyx_c_conj_long__double(z)    (::std::conj(z))
    #if 1
        #define __Pyx_c_abs_long__double(z)     (::std::abs(z))
        #define __Pyx_c_pow_long__double(a, b)  (::std::pow(a, b))
    #endif
  #else
    #define __Pyx_c_is_zero_long__double(z) ((z)==0)
    #define __Pyx_c_conj_long__double(z)    (conjl(z))
    #if 1
        #define __Pyx_c_abs_long__double(z)     (cabsl(z))
        #define __Pyx_c_pow_long__double(a, b)  (cpowl(a, b))
    #endif
 #endif
#else
    static CYTHON_INLINE int __Pyx_c_eq_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_sum_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_diff_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_prod_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_quot_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_neg_long__double(__pyx_t_long_double_complex);
    static CYTHON_INLINE int __Pyx_c_is_zero_long__double(__pyx_t_long_double_complex);
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_conj_long__double(__pyx_t_long_double_complex);
    #if 1
        static CYTHON_INLINE long double __Pyx_c_abs_long__double(__pyx_t_long_double_complex);
        static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_pow_long__double(__pyx_t_long_double_complex, __pyx_t_long_double_complex);
    #endif
#endif

/* CIntFromPy.proto */
static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *);

/* CIntToPy.proto */
static CYTHON_INLINE PyObject* __Pyx_PyLong_From_int(int value);

/* CIntToPy.proto */
static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value);

/* FormatTypeName.proto */
#if CYTHON_COMPILING_IN_LIMITED_API
typedef PyObject *__Pyx_TypeName;
#define __Pyx_FMT_TYPENAME "%U"
#define __Pyx_DECREF_TypeName(obj) Py_XDECREF(obj)
#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
#define __Pyx_PyType_GetFullyQualifiedName PyType_GetFullyQualifiedName
#else
static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp);
#endif
#else  // !LIMITED_API
typedef const char *__Pyx_TypeName;
#define __Pyx_FMT_TYPENAME "%.200s"
#define __Pyx_PyType_GetFullyQualifiedName(tp) ((tp)->tp_name)
#define __Pyx_DECREF_TypeName(obj)
#endif

/* CIntFromPy.proto */
static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *);

/* FastTypeChecks.proto */
#if CYTHON_COMPILING_IN_CPYTHON
#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type)
#define __Pyx_TypeCheck2(obj, type1, type2) __Pyx_IsAnySubtype2(Py_TYPE(obj), (PyTypeObject *)type1, (PyTypeObject *)type2)
static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b);
static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b);
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject *type);
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2);
#else
#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type)
#define __Pyx_TypeCheck2(obj, type1, type2) (PyObject_TypeCheck(obj, (PyTypeObject *)type1) || PyObject_TypeCheck(obj, (PyTypeObject *)type2))
#define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type)
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2) {
    return PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2);
}
#endif
#define __Pyx_PyErr_ExceptionMatches2(err1, err2)  __Pyx_PyErr_GivenExceptionMatches2(__Pyx_PyErr_CurrentExceptionType(), err1, err2)
#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception)
#ifdef PyExceptionInstance_Check
  #define __Pyx_PyBaseException_Check(obj) PyExceptionInstance_Check(obj)
#else
  #define __Pyx_PyBaseException_Check(obj) __Pyx_TypeCheck(obj, PyExc_BaseException)
#endif

/* GetRuntimeVersion.proto */
#if __PYX_LIMITED_VERSION_HEX < 0x030b0000
static unsigned long __Pyx_cached_runtime_version = 0;
static void __Pyx_init_runtime_version(void);
#else
#define __Pyx_init_runtime_version()
#endif
static unsigned long __Pyx_get_runtime_version(void);

/* IterNextPlain.proto (used by CoroutineBase) */
static CYTHON_INLINE PyObject *__Pyx_PyIter_Next_Plain(PyObject *iterator);
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
static PyObject *__Pyx_GetBuiltinNext_LimitedAPI(void);
#endif

/* ReturnWithStopIteration.proto (used by CoroutineBase) */
static CYTHON_INLINE void __Pyx_ReturnWithStopIteration(PyObject* value, int async, int iternext);

/* CoroutineBase.proto (used by Generator) */
struct __pyx_CoroutineObject;
typedef PyObject *(*__pyx_coroutine_body_t)(struct __pyx_CoroutineObject *, PyThreadState *, PyObject *);
#if CYTHON_USE_EXC_INFO_STACK
#define __Pyx_ExcInfoStruct  _PyErr_StackItem
#else
typedef struct {
    PyObject *exc_type;
    PyObject *exc_value;
    PyObject *exc_traceback;
} __Pyx_ExcInfoStruct;
#endif
typedef struct __pyx_CoroutineObject {
    PyObject_HEAD
    __pyx_coroutine_body_t body;
    PyObject *closure;
    __Pyx_ExcInfoStruct gi_exc_state;
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    PyObject *gi_weakreflist;
#endif
    PyObject *classobj;
    PyObject *yieldfrom;
    __Pyx_pyiter_sendfunc yieldfrom_am_send;
    PyObject *gi_name;
    PyObject *gi_qualname;
    PyObject *gi_modulename;
    PyObject *gi_code;
    PyObject *gi_frame;
#if CYTHON_USE_SYS_MONITORING && (CYTHON_PROFILE || CYTHON_TRACE)
    PyMonitoringState __pyx_pymonitoring_state[__Pyx_MonitoringEventTypes_CyGen_count];
    uint64_t __pyx_pymonitoring_version;
#endif
    int resume_label;
    char is_running;
} __pyx_CoroutineObject;
static __pyx_CoroutineObject *__Pyx__Coroutine_New(
    PyTypeObject *type, __pyx_coroutine_body_t body, PyObject *code, PyObject *closure,
    PyObject *name, PyObject *qualname, PyObject *module_name);
static __pyx_CoroutineObject *__Pyx__Coroutine_NewInit(
            __pyx_CoroutineObject *gen, __pyx_coroutine_body_t body, PyObject *code, PyObject *closure,
            PyObject *name, PyObject *qualname, PyObject *module_name);
static CYTHON_INLINE void __Pyx_Coroutine_ExceptionClear(__Pyx_ExcInfoStruct *self);
static int __Pyx_Coroutine_clear(PyObject *self);
static __Pyx_PySendResult __Pyx_Coroutine_AmSend(PyObject *self, PyObject *value, PyObject **retval);
static PyObject *__Pyx_Coroutine_Send(PyObject *self, PyObject *value);
static __Pyx_PySendResult __Pyx_Coroutine_Close(PyObject *self, PyObject **retval);
static PyObject *__Pyx_Coroutine_Throw(PyObject *gen, PyObject *args);
#if CYTHON_USE_EXC_INFO_STACK
#define __Pyx_Coroutine_SwapException(self)
#define __Pyx_Coroutine_ResetAndClearException(self)  __Pyx_Coroutine_ExceptionClear(&(self)->gi_exc_state)
#else
#define __Pyx_Coroutine_SwapException(self) {\
    __Pyx_ExceptionSwap(&(self)->gi_exc_state.exc_type, &(self)->gi_exc_state.exc_value, &(self)->gi_exc_state.exc_traceback);\
    __Pyx_Coroutine_ResetFrameBackpointer(&(self)->gi_exc_state);\
    }
#define __Pyx_Coroutine_ResetAndClearException(self) {\
    __Pyx_ExceptionReset((self)->gi_exc_state.exc_type, (self)->gi_exc_state.exc_value, (self)->gi_exc_state.exc_traceback);\
    (self)->gi_exc_state.exc_type = (self)->gi_exc_state.exc_value = (self)->gi_exc_state.exc_traceback = NULL;\
    }
#endif
#if CYTHON_FAST_THREAD_STATE
#define __Pyx_PyGen_FetchStopIterationValue(pvalue)\
    __Pyx_PyGen__FetchStopIterationValue(__pyx_tstate, pvalue)
#else
#define __Pyx_PyGen_FetchStopIterationValue(pvalue)\
    __Pyx_PyGen__FetchStopIterationValue(__Pyx_PyThreadState_Current, pvalue)
#endif
static int __Pyx_PyGen__FetchStopIterationValue(PyThreadState *tstate, PyObject **pvalue);
static CYTHON_INLINE void __Pyx_Coroutine_ResetFrameBackpointer(__Pyx_ExcInfoStruct *exc_state);
static char __Pyx_Coroutine_test_and_set_is_running(__pyx_CoroutineObject *gen);
static void __Pyx_Coroutine_unset_is_running(__pyx_CoroutineObject *gen);
static char __Pyx_Coroutine_get_is_running(__pyx_CoroutineObject *gen);
static PyObject *__Pyx_Coroutine_get_is_running_getter(PyObject *gen, void *closure);
#if __PYX_HAS_PY_AM_SEND == 2
static void __Pyx_SetBackportTypeAmSend(PyTypeObject *type, __Pyx_PyAsyncMethodsStruct *static_amsend_methods, __Pyx_pyiter_sendfunc am_send);
#endif
static PyObject *__Pyx_Coroutine_fail_reduce_ex(PyObject *self, PyObject *arg);

/* Generator.proto */
#define __Pyx_Generator_USED
#define __Pyx_Generator_CheckExact(obj) __Pyx_IS_TYPE(obj, __pyx_mstate_global->__pyx_GeneratorType)
#define __Pyx_Generator_New(body, code, closure, name, qualname, module_name)\
    __Pyx__Coroutine_New(__pyx_mstate_global->__pyx_GeneratorType, body, code, closure, name, qualname, module_name)
static PyObject *__Pyx_Generator_Next(PyObject *self);
static int __pyx_Generator_init(PyObject *module);
static CYTHON_INLINE PyObject *__Pyx_Generator_GetInlinedResult(PyObject *self);

/* CheckBinaryVersion.proto */
static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer);

/* DecompressString.proto */
static PyObject *__Pyx_DecompressString(const char *s, Py_ssize_t length, int algo);

/* MultiPhaseInitModuleState.proto */
#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE
static PyObject *__Pyx_State_FindModule(void*);
static int __Pyx_State_AddModule(PyObject* module, void*);
static int __Pyx_State_RemoveModule(void*);
#elif CYTHON_USE_MODULE_STATE
#define __Pyx_State_FindModule PyState_FindModule
#define __Pyx_State_AddModule PyState_AddModule
#define __Pyx_State_RemoveModule PyState_RemoveModule
#endif

/* #### Code section: module_declarations ### */
/* CythonABIVersion.proto */
#if CYTHON_COMPILING_IN_LIMITED_API
    #if CYTHON_METH_FASTCALL
        #define __PYX_FASTCALL_ABI_SUFFIX  "_fastcall"
    #else
        #define __PYX_FASTCALL_ABI_SUFFIX
    #endif
    #define __PYX_LIMITED_ABI_SUFFIX "limited" __PYX_FASTCALL_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX
#else
    #define __PYX_LIMITED_ABI_SUFFIX
#endif
#if __PYX_HAS_PY_AM_SEND == 1
    #define __PYX_AM_SEND_ABI_SUFFIX
#elif __PYX_HAS_PY_AM_SEND == 2
    #define __PYX_AM_SEND_ABI_SUFFIX "amsendbackport"
#else
    #define __PYX_AM_SEND_ABI_SUFFIX "noamsend"
#endif
#ifndef __PYX_MONITORING_ABI_SUFFIX
    #define __PYX_MONITORING_ABI_SUFFIX
#endif
#if CYTHON_USE_TP_FINALIZE
    #define __PYX_TP_FINALIZE_ABI_SUFFIX
#else
    #define __PYX_TP_FINALIZE_ABI_SUFFIX "nofinalize"
#endif
#if CYTHON_USE_FREELISTS || !defined(__Pyx_AsyncGen_USED)
    #define __PYX_FREELISTS_ABI_SUFFIX
#else
    #define __PYX_FREELISTS_ABI_SUFFIX "nofreelists"
#endif
#define CYTHON_ABI  __PYX_ABI_VERSION __PYX_LIMITED_ABI_SUFFIX __PYX_MONITORING_ABI_SUFFIX __PYX_TP_FINALIZE_ABI_SUFFIX __PYX_FREELISTS_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX
#define __PYX_ABI_MODULE_NAME "_cython_" CYTHON_ABI
#define __PYX_TYPE_MODULE_PREFIX __PYX_ABI_MODULE_NAME "."

static CYTHON_INLINE npy_intp __pyx_f_5numpy_5dtype_8itemsize_itemsize(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp __pyx_f_5numpy_5dtype_9alignment_alignment(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE PyObject *__pyx_f_5numpy_5dtype_6fields_fields(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE PyObject *__pyx_f_5numpy_5dtype_5names_names(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE PyArray_ArrayDescr *__pyx_f_5numpy_5dtype_8subarray_subarray(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_uint64 __pyx_f_5numpy_5dtype_5flags_flags(PyArray_Descr *__pyx_v_self); /* proto*/
static CYTHON_INLINE int __pyx_f_5numpy_9broadcast_7numiter_numiter(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp __pyx_f_5numpy_9broadcast_4size_size(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp __pyx_f_5numpy_9broadcast_5index_index(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE int __pyx_f_5numpy_9broadcast_2nd_nd(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp *__pyx_f_5numpy_9broadcast_10dimensions_dimensions(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE void **__pyx_f_5numpy_9broadcast_5iters_iters(PyArrayMultiIterObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE PyObject *__pyx_f_5numpy_7ndarray_4base_base(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE PyArray_Descr *__pyx_f_5numpy_7ndarray_5descr_descr(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE int __pyx_f_5numpy_7ndarray_4ndim_ndim(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp *__pyx_f_5numpy_7ndarray_5shape_shape(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp *__pyx_f_5numpy_7ndarray_7strides_strides(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE npy_intp __pyx_f_5numpy_7ndarray_4size_size(PyArrayObject *__pyx_v_self); /* proto*/
static CYTHON_INLINE char *__pyx_f_5numpy_7ndarray_4data_data(PyArrayObject *__pyx_v_self); /* proto*/
static PyObject *__pyx_f_6cftime_7_cftime_8datetime__to_real_datetime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/
static PyObject *__pyx_f_6cftime_7_cftime_8datetime__getstate(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto*/
static PyObject *__pyx_f_6cftime_7_cftime_8datetime__add_timedelta(CYTHON_UNUSED struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_other); /* proto*/

/* Module declarations from "libc.string" */

/* Module declarations from "libc.stdio" */

/* Module declarations from "__builtin__" */

/* Module declarations from "cpython.type" */

/* Module declarations from "cpython" */

/* Module declarations from "cpython.object" */

/* Module declarations from "cpython.ref" */

/* Module declarations from "numpy" */

/* Module declarations from "numpy" */
static CYTHON_INLINE int __pyx_f_5numpy_import_array(void); /*proto*/

/* Module declarations from "cython" */

/* Module declarations from "cftime._cftime" */
static int __pyx_v_6cftime_7_cftime__dayspermonth[12];
static int __pyx_v_6cftime_7_cftime__dayspermonth_leap[12];
static int __pyx_v_6cftime_7_cftime__cumdayspermonth[13];
static int __pyx_v_6cftime_7_cftime__cumdayspermonth_leap[13];
static PyObject *__pyx_f_6cftime_7_cftime__parse_timezone(PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__parse_date(PyObject *, int __pyx_skip_dispatch); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__check_index(PyObject *, PyObject *, PyObject *, PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__toscalar(PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__year_zero_defaults(PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__findall(PyObject *, PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__strftime(struct __pyx_obj_6cftime_7_cftime_datetime *, PyObject *); /*proto*/
static int __pyx_f_6cftime_7_cftime_is_leap_julian(int, int); /*proto*/
static int __pyx_f_6cftime_7_cftime_is_leap_proleptic_gregorian(int, int); /*proto*/
static int __pyx_f_6cftime_7_cftime_is_leap_gregorian(int, int); /*proto*/
static int __pyx_f_6cftime_7_cftime_all_leap(int, int); /*proto*/
static int __pyx_f_6cftime_7_cftime_no_leap(int, int); /*proto*/
static int *__pyx_f_6cftime_7_cftime_month_lengths(int (*)(int, int), int, int); /*proto*/
static void __pyx_f_6cftime_7_cftime_assert_valid_date(struct __pyx_obj_6cftime_7_cftime_datetime *, int (*)(int, int), int, struct __pyx_opt_args_6cftime_7_cftime_assert_valid_date *__pyx_optional_args); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime_add_timedelta(struct __pyx_obj_6cftime_7_cftime_datetime *, PyObject *, int (*)(int, int), int, int); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime_add_timedelta_360_day(struct __pyx_obj_6cftime_7_cftime_datetime *, PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__is_leap(int, PyObject *, struct __pyx_opt_args_6cftime_7_cftime__is_leap *__pyx_optional_args); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__check_calendar(PyObject *); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__IntJulianDayFromDate(int, int, int, PyObject *, struct __pyx_opt_args_6cftime_7_cftime__IntJulianDayFromDate *__pyx_optional_args); /*proto*/
/* #### Code section: typeinfo ### */
/* #### Code section: before_global_var ### */
#define __Pyx_MODULE_NAME "cftime._cftime"
extern int __pyx_module_is_main_cftime___cftime;
int __pyx_module_is_main_cftime___cftime = 0;

/* Implementation of "cftime._cftime" */
/* #### Code section: global_var ### */
static PyObject *__pyx_builtin_property;
static PyObject *__pyx_builtin_staticmethod;
static PyObject *__pyx_builtin_enumerate;
static PyObject *__pyx_builtin_round;
static PyObject *__pyx_builtin_NotImplemented;
static PyObject *__pyx_builtin_super;
/* #### Code section: string_decls ### */
static const char __pyx_k_Performs_conversions_of_netCDF[] = "\nPerforms conversions of netCDF time coordinate data to/from datetime objects.\n";
/* #### Code section: decls ### */
static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_dayofwk(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_2dayofyr(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_4daysinmonth(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime__datesplit(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_timestr); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_2_dateparse(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_timestr, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_4_can_use_python_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_date, PyObject *__pyx_v_calendar); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_6date2num(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero, PyObject *__pyx_v_longdouble); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8num2pydate(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_10to_calendar_specific_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dt, PyObject *__pyx_v_calendar, PyObject *__pyx_v_use_python_datetime, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_12cast_to_int(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num, PyObject *__pyx_v_units); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_14upcast_times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_16scale_times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num, PyObject *__pyx_v_factor); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_18decode_date_from_scalar(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_time_in_microseconds, PyObject *__pyx_v_basedate); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_20decode_dates_from_array(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times_in_microseconds, PyObject *__pyx_v_basedate); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_22num2date(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar, PyObject *__pyx_v_only_use_cftime_datetimes, PyObject *__pyx_v_only_use_python_datetimes, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_24date2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_26_parse_date(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_datestring); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_28_date2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_30time2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_32to_tuple(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dt); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_34_create_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_date_type, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_8datetime___init__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, int __pyx_v_year, int __pyx_v_month, int __pyx_v_day, int __pyx_v_hour, int __pyx_v_minute, int __pyx_v_second, int __pyx_v_microsecond, int __pyx_v_dayofwk, int __pyx_v_dayofyr, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6format___get__(CYTHON_UNUSED struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_7dayofwk___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_7dayofyr___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_11daysinmonth___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_2strftime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_format); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8strptime_genexpr(PyObject *__pyx_self, PyObject *__pyx_genexpr_arg_0); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4strptime(PyObject *__pyx_v_datestring, PyObject *__pyx_v_format, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6__format__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_format); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8replace(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_kwargs); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_10timetuple(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_12_to_real_datetime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_14__repr__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_16__str__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_18isoformat(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_sep, PyObject *__pyx_v_timespec); /* proto */
static Py_hash_t __pyx_pf_6cftime_7_cftime_8datetime_20__hash__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_22to_tuple(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_24__richcmp__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_other, int __pyx_v_op); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_26__reduce__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_28fromordinal(PyObject *__pyx_v_jday, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_30toordinal(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_fractional); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_32change_calendar(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_34__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_other); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_36__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_other); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4year___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_5month___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_3day___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4hour___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6minute___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6second___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_11microsecond___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8calendar___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8_dayofwk___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8_dayofyr___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_13has_year_zero___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6tzinfo___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_19datetime_compatible___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self); /* proto */
static PyObject *__pyx_pf_6cftime_7_cftime_36is_leap_year(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_year, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero); /* proto */
static int __pyx_pf_6cftime_7_cftime_14DatetimeNoLeap___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_15DatetimeAllLeap___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_14Datetime360Day___init__(struct __pyx_obj_6cftime_7_cftime_Datetime360Day *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_14DatetimeJulian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeJulian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_17DatetimeGregorian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static int __pyx_pf_6cftime_7_cftime_26DatetimeProlepticGregorian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs); /* proto */
static PyObject *__pyx_tp_new_6cftime_7_cftime_datetime(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeNoLeap(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeAllLeap(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_Datetime360Day(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeJulian(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeGregorian(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeProlepticGregorian(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct__strptime(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
static PyObject *__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct_1_genexpr(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/
/* #### Code section: late_includes ### */
/* #### Code section: module_state ### */
/* SmallCodeConfig */
#ifndef CYTHON_SMALL_CODE
#if defined(__clang__)
    #define CYTHON_SMALL_CODE
#elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3))
    #define CYTHON_SMALL_CODE __attribute__((cold))
#else
    #define CYTHON_SMALL_CODE
#endif
#endif

typedef struct {
  PyObject *__pyx_d;
  PyObject *__pyx_b;
  PyObject *__pyx_cython_runtime;
  PyObject *__pyx_empty_tuple;
  PyObject *__pyx_empty_bytes;
  PyObject *__pyx_empty_unicode;
  PyTypeObject *__pyx_ptype_7cpython_4type_type;
  PyTypeObject *__pyx_ptype_5numpy_dtype;
  PyTypeObject *__pyx_ptype_5numpy_flatiter;
  PyTypeObject *__pyx_ptype_5numpy_broadcast;
  PyTypeObject *__pyx_ptype_5numpy_ndarray;
  PyTypeObject *__pyx_ptype_5numpy_generic;
  PyTypeObject *__pyx_ptype_5numpy_number;
  PyTypeObject *__pyx_ptype_5numpy_integer;
  PyTypeObject *__pyx_ptype_5numpy_signedinteger;
  PyTypeObject *__pyx_ptype_5numpy_unsignedinteger;
  PyTypeObject *__pyx_ptype_5numpy_inexact;
  PyTypeObject *__pyx_ptype_5numpy_floating;
  PyTypeObject *__pyx_ptype_5numpy_complexfloating;
  PyTypeObject *__pyx_ptype_5numpy_flexible;
  PyTypeObject *__pyx_ptype_5numpy_character;
  PyTypeObject *__pyx_ptype_5numpy_ufunc;
  PyObject *__pyx_type_6cftime_7_cftime_datetime;
  PyObject *__pyx_type_6cftime_7_cftime_DatetimeNoLeap;
  PyObject *__pyx_type_6cftime_7_cftime_DatetimeAllLeap;
  PyObject *__pyx_type_6cftime_7_cftime_Datetime360Day;
  PyObject *__pyx_type_6cftime_7_cftime_DatetimeJulian;
  PyObject *__pyx_type_6cftime_7_cftime_DatetimeGregorian;
  PyObject *__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian;
  PyObject *__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime;
  PyObject *__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_datetime;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_Datetime360Day;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_DatetimeJulian;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_DatetimeGregorian;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime;
  PyTypeObject *__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr;
  __Pyx_CachedCFunction __pyx_umethod_PyDict_Type_items;
  __Pyx_CachedCFunction __pyx_umethod_PyDict_Type_pop;
  __Pyx_CachedCFunction __pyx_umethod_PyDict_Type_values;
  PyObject *__pyx_slice[4];
  PyObject *__pyx_tuple[13];
  PyObject *__pyx_codeobj_tab[35];
  PyObject *__pyx_string_tab[480];
  PyObject *__pyx_number_tab[36];
/* #### Code section: module_state_contents ### */

#if CYTHON_USE_FREELISTS
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *__pyx_freelist_6cftime_7_cftime___pyx_scope_struct__strptime[8];
int __pyx_freecount_6cftime_7_cftime___pyx_scope_struct__strptime;
#endif

#if CYTHON_USE_FREELISTS
struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *__pyx_freelist_6cftime_7_cftime___pyx_scope_struct_1_genexpr[8];
int __pyx_freecount_6cftime_7_cftime___pyx_scope_struct_1_genexpr;
#endif
/* CommonTypesMetaclass.module_state_decls */
PyTypeObject *__pyx_CommonTypesMetaclassType;

/* CachedMethodType.module_state_decls */
#if CYTHON_COMPILING_IN_LIMITED_API
PyObject *__Pyx_CachedMethodType;
#endif

/* CythonFunctionShared.module_state_decls */
PyTypeObject *__pyx_CyFunctionType;

/* CodeObjectCache.module_state_decls */
struct __Pyx_CodeObjectCache __pyx_code_cache;

/* IterNextPlain.module_state_decls */
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
PyObject *__Pyx_GetBuiltinNext_LimitedAPI_cache;
#endif

/* Generator.module_state_decls */
PyTypeObject *__pyx_GeneratorType;

/* #### Code section: module_state_end ### */
} __pyx_mstatetype;

#if CYTHON_USE_MODULE_STATE
#ifdef __cplusplus
namespace {
extern struct PyModuleDef __pyx_moduledef;
} /* anonymous namespace */
#else
static struct PyModuleDef __pyx_moduledef;
#endif

#define __pyx_mstate_global (__Pyx_PyModule_GetState(__Pyx_State_FindModule(&__pyx_moduledef)))

#define __pyx_m (__Pyx_State_FindModule(&__pyx_moduledef))
#else
static __pyx_mstatetype __pyx_mstate_global_static =
#ifdef __cplusplus
    {};
#else
    {0};
#endif
static __pyx_mstatetype * const __pyx_mstate_global = &__pyx_mstate_global_static;
#endif
/* #### Code section: constant_name_defines ### */
#define __pyx_kp_u_ __pyx_string_tab[0]
#define __pyx_kp_u_02d __pyx_string_tab[1]
#define __pyx_kp_u_02d_2 __pyx_string_tab[2]
#define __pyx_kp_u_03d __pyx_string_tab[3]
#define __pyx_kp_u_04d __pyx_string_tab[4]
#define __pyx_kp_u_04d_02d_02d __pyx_string_tab[5]
#define __pyx_kp_u_05d __pyx_string_tab[6]
#define __pyx_kp_u_05d_02d_02d __pyx_string_tab[7]
#define __pyx_kp_u_06d __pyx_string_tab[8]
#define __pyx_kp_u_0_1_2_3_4_5_6_7_8_calendar_9_ha __pyx_string_tab[9]
#define __pyx_kp_u_0_1_2_3_4_5_6_7_8_calendar_9_ha_2 __pyx_string_tab[10]
#define __pyx_kp_u_0_1_2_3_4_5_6_7_8_has_year_zero __pyx_string_tab[11]
#define __pyx_kp_u_0_r_is_not_present_in_the_mixed __pyx_string_tab[12]
#define __pyx_kp_u_0_s __pyx_string_tab[13]
#define __pyx_kp_u_360_day __pyx_string_tab[14]
#define __pyx_kp_u_365_day __pyx_string_tab[15]
#define __pyx_kp_u_366_day __pyx_string_tab[16]
#define __pyx_kp_u_Cannot_compute_the_time_differe __pyx_string_tab[17]
#define __pyx_kp_u_Expecting_a_string_r __pyx_string_tab[18]
#define __pyx_kp_u_If_f_is_used_for_microseconds_it __pyx_string_tab[19]
#define __pyx_kp_u_In_general_units_must_be_one_of __pyx_string_tab[20]
#define __pyx_kp_u_Incorrectly_formatted_CF_date_ti __pyx_string_tab[21]
#define __pyx_kp_u_OverflowError_in_datetime_possib __pyx_string_tab[22]
#define __pyx_kp_u_P_prefix_P_hours_0_9_2_P_minute __pyx_string_tab[23]
#define __pyx_kp_u_P_year_0_9_P_month_0_9_1_2_P_da __pyx_string_tab[24]
#define __pyx_kp_u_Replacing_the_calendar_of_a_date __pyx_string_tab[25]
#define __pyx_kp_u_Replacing_the_dayofyr_or_dayofwk __pyx_string_tab[26]
#define __pyx_kp_u_Some_of_the_times_given_are_afte __pyx_string_tab[27]
#define __pyx_kp_u_Some_of_the_times_given_are_befo __pyx_string_tab[28]
#define __pyx_kp_u_Some_of_the_times_specified_were __pyx_string_tab[29]
#define __pyx_kp_u_This_strftime_implementation_doe __pyx_string_tab[30]
#define __pyx_kp_u_Unable_to_parse_date_string_r __pyx_string_tab[31]
#define __pyx_kp_u_Units_of_months_only_valid_for_3 __pyx_string_tab[32]
#define __pyx_kp_u_Unsupported_time_units_provided __pyx_string_tab[33]
#define __pyx_kp_u_Y_m_d_H_M_S __pyx_string_tab[34]
#define __pyx_kp_u__2 __pyx_string_tab[35]
#define __pyx_kp_u__3 __pyx_string_tab[36]
#define __pyx_kp_u__4 __pyx_string_tab[37]
#define __pyx_kp_u__5 __pyx_string_tab[38]
#define __pyx_kp_u__6 __pyx_string_tab[39]
#define __pyx_kp_u__7 __pyx_string_tab[40]
#define __pyx_kp_u_add_dayofwk_dayofyr_daysinmonth __pyx_string_tab[41]
#define __pyx_kp_u_calendar_2 __pyx_string_tab[42]
#define __pyx_kp_u_calendar_must_be_one_of __pyx_string_tab[43]
#define __pyx_kp_u_cannot_compare_0_r_and_1_r __pyx_string_tab[44]
#define __pyx_kp_u_cannot_compare_0_r_and_1_r_diffe __pyx_string_tab[45]
#define __pyx_kp_u_cannot_compute_the_time_differen __pyx_string_tab[46]
#define __pyx_kp_u_cannot_compute_the_time_differen_2 __pyx_string_tab[47]
#define __pyx_kp_u_cannot_compute_the_time_differen_3 __pyx_string_tab[48]
#define __pyx_kp_u_cannot_specify_a_leap_day_as_the __pyx_string_tab[49]
#define __pyx_kp_u_cftime__strptime __pyx_string_tab[50]
#define __pyx_kp_u_change_calendar_only_works_for_r __pyx_string_tab[51]
#define __pyx_kp_u_date_2 __pyx_string_tab[52]
#define __pyx_kp_u_days_since_0_1_1_12 __pyx_string_tab[53]
#define __pyx_kp_u_days_since_4712_1_1_12 __pyx_string_tab[54]
#define __pyx_kp_u_days_since_4713_11_24_12 __pyx_string_tab[55]
#define __pyx_kp_u_days_since_4713_1_1_12 __pyx_string_tab[56]
#define __pyx_kp_u_days_since_4714_11_24_12 __pyx_string_tab[57]
#define __pyx_kp_u_disable __pyx_string_tab[58]
#define __pyx_kp_u_does_not_exist_in_the __pyx_string_tab[59]
#define __pyx_kp_u_enable __pyx_string_tab[60]
#define __pyx_kp_u_f_2 __pyx_string_tab[61]
#define __pyx_kp_u_f_3 __pyx_string_tab[62]
#define __pyx_kp_u_gc __pyx_string_tab[63]
#define __pyx_kp_u_got __pyx_string_tab[64]
#define __pyx_kp_u_has_year_zero_kwarg_ignored_for __pyx_string_tab[65]
#define __pyx_kp_u_has_year_zero_not_specified __pyx_string_tab[66]
#define __pyx_kp_u_illegal_calendar_or_reference_da __pyx_string_tab[67]
#define __pyx_kp_u_illegal_timespec __pyx_string_tab[68]
#define __pyx_kp_u_invalid_date_in_mixed_calendar __pyx_string_tab[69]
#define __pyx_kp_u_invalid_day_number_provided_in_0 __pyx_string_tab[70]
#define __pyx_kp_u_invalid_hour_provided_in_0_r __pyx_string_tab[71]
#define __pyx_kp_u_invalid_microsecond_provided_in __pyx_string_tab[72]
#define __pyx_kp_u_invalid_minute_provided_in_0_r __pyx_string_tab[73]
#define __pyx_kp_u_invalid_month_provided_in_0_r __pyx_string_tab[74]
#define __pyx_kp_u_invalid_second_provided_in_0_r __pyx_string_tab[75]
#define __pyx_kp_u_invalid_year_provided_in_0_r __pyx_string_tab[76]
#define __pyx_kp_u_isenabled __pyx_string_tab[77]
#define __pyx_kp_u_months_since_units_only_allowed __pyx_string_tab[78]
#define __pyx_kp_u_netcdf_time_variable_is_missing __pyx_string_tab[79]
#define __pyx_kp_u_no_calendar_specified __pyx_string_tab[80]
#define __pyx_kp_u_no_leap_days_in_365_day_calendar __pyx_string_tab[81]
#define __pyx_kp_u_no_since_in_unit_string __pyx_string_tab[82]
#define __pyx_kp_u_numpy__core_multiarray_failed_to __pyx_string_tab[83]
#define __pyx_kp_u_numpy__core_umath_failed_to_impo __pyx_string_tab[84]
#define __pyx_kp_u_one_of_the_supplied_format_direc __pyx_string_tab[85]
#define __pyx_kp_u_s_02d __pyx_string_tab[86]
#define __pyx_kp_u_s_02d_02d __pyx_string_tab[87]
#define __pyx_kp_u_s_02d_02d_02d __pyx_string_tab[88]
#define __pyx_kp_u_s_02d_02d_s __pyx_string_tab[89]
#define __pyx_kp_u_s_2 __pyx_string_tab[90]
#define __pyx_kp_u_s_is_not_a_leap_year __pyx_string_tab[91]
#define __pyx_kp_u_s_is_not_an_option_for_the_sele __pyx_string_tab[92]
#define __pyx_kp_u_s_units_only_allowed_for_365_da __pyx_string_tab[93]
#define __pyx_kp_u_src_cftime__cftime_pyx __pyx_string_tab[94]
#define __pyx_kp_u_there_are_only_30_days_in_every __pyx_string_tab[95]
#define __pyx_kp_u_this_date_calendar_year_zero_con __pyx_string_tab[96]
#define __pyx_kp_u_time_values_outside_range_of_64 __pyx_string_tab[97]
#define __pyx_kp_u_timedelta64_us __pyx_string_tab[98]
#define __pyx_kp_u_unsupported_calendar __pyx_string_tab[99]
#define __pyx_kp_u_year_0_was_specified_this_date_c __pyx_string_tab[100]
#define __pyx_kp_u_year_zero_does_not_exist_in_the __pyx_string_tab[101]
#define __pyx_kp_u_year_zero_requested_but_has_year __pyx_string_tab[102]
#define __pyx_kp_u_zero_not_allowed_as_a_reference __pyx_string_tab[103]
#define __pyx_kp_u_zero_not_allowed_as_a_reference_2 __pyx_string_tab[104]
#define __pyx_kp_u_zero_not_allowed_as_a_reference_3 __pyx_string_tab[105]
#define __pyx_n_u_A __pyx_string_tab[106]
#define __pyx_n_u_CFWarning __pyx_string_tab[107]
#define __pyx_n_u_DATE_TYPES __pyx_string_tab[108]
#define __pyx_n_u_Datetime360Day __pyx_string_tab[109]
#define __pyx_n_u_DatetimeAllLeap __pyx_string_tab[110]
#define __pyx_n_u_DatetimeGregorian __pyx_string_tab[111]
#define __pyx_n_u_DatetimeJulian __pyx_string_tab[112]
#define __pyx_n_u_DatetimeNoLeap __pyx_string_tab[113]
#define __pyx_n_u_DatetimeProlepticGregorian __pyx_string_tab[114]
#define __pyx_n_u_G __pyx_string_tab[115]
#define __pyx_n_u_ISO8601_REGEX __pyx_string_tab[116]
#define __pyx_n_u_MAXYEAR __pyx_string_tab[117]
#define __pyx_n_u_MAX_INT64 __pyx_string_tab[118]
#define __pyx_n_u_MINYEAR __pyx_string_tab[119]
#define __pyx_n_u_MIN_INT64 __pyx_string_tab[120]
#define __pyx_n_u_MaskedArray __pyx_string_tab[121]
#define __pyx_n_u_N __pyx_string_tab[122]
#define __pyx_n_u_NotImplemented __pyx_string_tab[123]
#define __pyx_n_u_O __pyx_string_tab[124]
#define __pyx_n_u_Pyx_PyDict_NextRef __pyx_string_tab[125]
#define __pyx_n_u_T __pyx_string_tab[126]
#define __pyx_n_u_TIMEZONE_REGEX __pyx_string_tab[127]
#define __pyx_n_u_U __pyx_string_tab[128]
#define __pyx_n_u_UNIT_CONVERSION_FACTORS __pyx_string_tab[129]
#define __pyx_n_u_V __pyx_string_tab[130]
#define __pyx_n_u_W __pyx_string_tab[131]
#define __pyx_n_u_Z __pyx_string_tab[132]
#define __pyx_n_u_a __pyx_string_tab[133]
#define __pyx_n_u_abs __pyx_string_tab[134]
#define __pyx_n_u_after __pyx_string_tab[135]
#define __pyx_n_u_all __pyx_string_tab[136]
#define __pyx_n_u_all_leap __pyx_string_tab[137]
#define __pyx_n_u_all_python_datetimes __pyx_string_tab[138]
#define __pyx_n_u_any __pyx_string_tab[139]
#define __pyx_n_u_append __pyx_string_tab[140]
#define __pyx_n_u_args __pyx_string_tab[141]
#define __pyx_n_u_argsort __pyx_string_tab[142]
#define __pyx_n_u_around __pyx_string_tab[143]
#define __pyx_n_u_array __pyx_string_tab[144]
#define __pyx_n_u_asanyarray __pyx_string_tab[145]
#define __pyx_n_u_astype __pyx_string_tab[146]
#define __pyx_n_u_asyncio_coroutines __pyx_string_tab[147]
#define __pyx_n_u_atleast_1d __pyx_string_tab[148]
#define __pyx_n_u_auto __pyx_string_tab[149]
#define __pyx_n_u_basedate __pyx_string_tab[150]
#define __pyx_n_u_before __pyx_string_tab[151]
#define __pyx_n_u_bisect __pyx_string_tab[152]
#define __pyx_n_u_bisect_left __pyx_string_tab[153]
#define __pyx_n_u_bisect_right __pyx_string_tab[154]
#define __pyx_n_u_calendar __pyx_string_tab[155]
#define __pyx_n_u_calendars __pyx_string_tab[156]
#define __pyx_n_u_can_use_python_basedatetime __pyx_string_tab[157]
#define __pyx_n_u_can_use_python_datetime __pyx_string_tab[158]
#define __pyx_n_u_can_use_python_datetime_2 __pyx_string_tab[159]
#define __pyx_n_u_cast_to_int __pyx_string_tab[160]
#define __pyx_n_u_casting __pyx_string_tab[161]
#define __pyx_n_u_catch_warnings __pyx_string_tab[162]
#define __pyx_n_u_category __pyx_string_tab[163]
#define __pyx_n_u_ceil __pyx_string_tab[164]
#define __pyx_n_u_cftime __pyx_string_tab[165]
#define __pyx_n_u_cftime__cftime __pyx_string_tab[166]
#define __pyx_n_u_cfwarnmsg __pyx_string_tab[167]
#define __pyx_n_u_change_calendar __pyx_string_tab[168]
#define __pyx_n_u_class __pyx_string_tab[169]
#define __pyx_n_u_class_getitem __pyx_string_tab[170]
#define __pyx_n_u_cline_in_traceback __pyx_string_tab[171]
#define __pyx_n_u_clip __pyx_string_tab[172]
#define __pyx_n_u_close __pyx_string_tab[173]
#define __pyx_n_u_common_year __pyx_string_tab[174]
#define __pyx_n_u_common_years __pyx_string_tab[175]
#define __pyx_n_u_compatible_date __pyx_string_tab[176]
#define __pyx_n_u_compile __pyx_string_tab[177]
#define __pyx_n_u_core __pyx_string_tab[178]
#define __pyx_n_u_create_datetime __pyx_string_tab[179]
#define __pyx_n_u_d __pyx_string_tab[180]
#define __pyx_n_u_d0 __pyx_string_tab[181]
#define __pyx_n_u_date __pyx_string_tab[182]
#define __pyx_n_u_date2index __pyx_string_tab[183]
#define __pyx_n_u_date2index_2 __pyx_string_tab[184]
#define __pyx_n_u_date2num __pyx_string_tab[185]
#define __pyx_n_u_date_type __pyx_string_tab[186]
#define __pyx_n_u_dateparse __pyx_string_tab[187]
#define __pyx_n_u_dates __pyx_string_tab[188]
#define __pyx_n_u_dates_test __pyx_string_tab[189]
#define __pyx_n_u_datesplit __pyx_string_tab[190]
#define __pyx_n_u_datestring __pyx_string_tab[191]
#define __pyx_n_u_datetime __pyx_string_tab[192]
#define __pyx_n_u_datetime___format __pyx_string_tab[193]
#define __pyx_n_u_datetime___reduce __pyx_string_tab[194]
#define __pyx_n_u_datetime__to_real_datetime __pyx_string_tab[195]
#define __pyx_n_u_datetime_change_calendar __pyx_string_tab[196]
#define __pyx_n_u_datetime_compatible __pyx_string_tab[197]
#define __pyx_n_u_datetime_fromordinal __pyx_string_tab[198]
#define __pyx_n_u_datetime_isoformat __pyx_string_tab[199]
#define __pyx_n_u_datetime_python __pyx_string_tab[200]
#define __pyx_n_u_datetime_replace __pyx_string_tab[201]
#define __pyx_n_u_datetime_strftime __pyx_string_tab[202]
#define __pyx_n_u_datetime_strptime __pyx_string_tab[203]
#define __pyx_n_u_datetime_timetuple __pyx_string_tab[204]
#define __pyx_n_u_datetime_to_tuple __pyx_string_tab[205]
#define __pyx_n_u_datetime_toordinal __pyx_string_tab[206]
#define __pyx_n_u_day __pyx_string_tab[207]
#define __pyx_n_u_day_units __pyx_string_tab[208]
#define __pyx_n_u_dayofwk __pyx_string_tab[209]
#define __pyx_n_u_dayofyr __pyx_string_tab[210]
#define __pyx_n_u_days __pyx_string_tab[211]
#define __pyx_n_u_daysinmonth __pyx_string_tab[212]
#define __pyx_n_u_decode_date_from_scalar __pyx_string_tab[213]
#define __pyx_n_u_decode_dates_from_array __pyx_string_tab[214]
#define __pyx_n_u_delta __pyx_string_tab[215]
#define __pyx_n_u_deltas __pyx_string_tab[216]
#define __pyx_n_u_dict __pyx_string_tab[217]
#define __pyx_n_u_diff __pyx_string_tab[218]
#define __pyx_n_u_differential_deltas __pyx_string_tab[219]
#define __pyx_n_u_doc __pyx_string_tab[220]
#define __pyx_n_u_dt __pyx_string_tab[221]
#define __pyx_n_u_dtype __pyx_string_tab[222]
#define __pyx_n_u_e __pyx_string_tab[223]
#define __pyx_n_u_empty __pyx_string_tab[224]
#define __pyx_n_u_endswith __pyx_string_tab[225]
#define __pyx_n_u_enter __pyx_string_tab[226]
#define __pyx_n_u_enumerate __pyx_string_tab[227]
#define __pyx_n_u_exact __pyx_string_tab[228]
#define __pyx_n_u_exit __pyx_string_tab[229]
#define __pyx_n_u_f __pyx_string_tab[230]
#define __pyx_n_u_factor __pyx_string_tab[231]
#define __pyx_n_u_fd __pyx_string_tab[232]
#define __pyx_n_u_filled __pyx_string_tab[233]
#define __pyx_n_u_find __pyx_string_tab[234]
#define __pyx_n_u_flat __pyx_string_tab[235]
#define __pyx_n_u_floor __pyx_string_tab[236]
#define __pyx_n_u_form __pyx_string_tab[237]
#define __pyx_n_u_form0 __pyx_string_tab[238]
#define __pyx_n_u_format __pyx_string_tab[239]
#define __pyx_n_u_format_2 __pyx_string_tab[240]
#define __pyx_n_u_fracday __pyx_string_tab[241]
#define __pyx_n_u_fraction __pyx_string_tab[242]
#define __pyx_n_u_fractional __pyx_string_tab[243]
#define __pyx_n_u_fromordinal __pyx_string_tab[244]
#define __pyx_n_u_func __pyx_string_tab[245]
#define __pyx_n_u_genexpr __pyx_string_tab[246]
#define __pyx_n_u_getmask __pyx_string_tab[247]
#define __pyx_n_u_greater __pyx_string_tab[248]
#define __pyx_n_u_gregorian __pyx_string_tab[249]
#define __pyx_n_u_groupdict __pyx_string_tab[250]
#define __pyx_n_u_groups __pyx_string_tab[251]
#define __pyx_n_u_h __pyx_string_tab[252]
#define __pyx_n_u_has_year_zero __pyx_string_tab[253]
#define __pyx_n_u_hour __pyx_string_tab[254]
#define __pyx_n_u_hours __pyx_string_tab[255]
#define __pyx_n_u_hr __pyx_string_tab[256]
#define __pyx_n_u_hr_units __pyx_string_tab[257]
#define __pyx_n_u_hrs __pyx_string_tab[258]
#define __pyx_n_u_i __pyx_string_tab[259]
#define __pyx_n_u_idealized_calendars __pyx_string_tab[260]
#define __pyx_n_u_ignore __pyx_string_tab[261]
#define __pyx_n_u_iinfo __pyx_string_tab[262]
#define __pyx_n_u_ijd __pyx_string_tab[263]
#define __pyx_n_u_illegal_s __pyx_string_tab[264]
#define __pyx_n_u_index __pyx_string_tab[265]
#define __pyx_n_u_init __pyx_string_tab[266]
#define __pyx_n_u_int64 __pyx_string_tab[267]
#define __pyx_n_u_int_num __pyx_string_tab[268]
#define __pyx_n_u_isMA __pyx_string_tab[269]
#define __pyx_n_u_is_coroutine __pyx_string_tab[270]
#define __pyx_n_u_is_leap_year __pyx_string_tab[271]
#define __pyx_n_u_is_masked __pyx_string_tab[272]
#define __pyx_n_u_isfinite __pyx_string_tab[273]
#define __pyx_n_u_ismasked __pyx_string_tab[274]
#define __pyx_n_u_isoformat __pyx_string_tab[275]
#define __pyx_n_u_isostring __pyx_string_tab[276]
#define __pyx_n_u_isscalar __pyx_string_tab[277]
#define __pyx_n_u_item __pyx_string_tab[278]
#define __pyx_n_u_items __pyx_string_tab[279]
#define __pyx_n_u_iu __pyx_string_tab[280]
#define __pyx_n_u_j __pyx_string_tab[281]
#define __pyx_n_u_jd __pyx_string_tab[282]
#define __pyx_n_u_jday __pyx_string_tab[283]
#define __pyx_n_u_julian __pyx_string_tab[284]
#define __pyx_n_u_kind __pyx_string_tab[285]
#define __pyx_n_u_kwargs __pyx_string_tab[286]
#define __pyx_n_u_less __pyx_string_tab[287]
#define __pyx_n_u_longdouble __pyx_string_tab[288]
#define __pyx_n_u_lower __pyx_string_tab[289]
#define __pyx_n_u_ma __pyx_string_tab[290]
#define __pyx_n_u_main __pyx_string_tab[291]
#define __pyx_n_u_mask __pyx_string_tab[292]
#define __pyx_n_u_masked_array __pyx_string_tab[293]
#define __pyx_n_u_masked_invalid __pyx_string_tab[294]
#define __pyx_n_u_match __pyx_string_tab[295]
#define __pyx_n_u_max __pyx_string_tab[296]
#define __pyx_n_u_maximum __pyx_string_tab[297]
#define __pyx_n_u_metaclass __pyx_string_tab[298]
#define __pyx_n_u_microsec __pyx_string_tab[299]
#define __pyx_n_u_microsec_units __pyx_string_tab[300]
#define __pyx_n_u_microsecond __pyx_string_tab[301]
#define __pyx_n_u_microseconds __pyx_string_tab[302]
#define __pyx_n_u_microsecs __pyx_string_tab[303]
#define __pyx_n_u_millisec __pyx_string_tab[304]
#define __pyx_n_u_millisec_units __pyx_string_tab[305]
#define __pyx_n_u_millisecond __pyx_string_tab[306]
#define __pyx_n_u_milliseconds __pyx_string_tab[307]
#define __pyx_n_u_millisecs __pyx_string_tab[308]
#define __pyx_n_u_min __pyx_string_tab[309]
#define __pyx_n_u_min_units __pyx_string_tab[310]
#define __pyx_n_u_minimum __pyx_string_tab[311]
#define __pyx_n_u_mins __pyx_string_tab[312]
#define __pyx_n_u_minute __pyx_string_tab[313]
#define __pyx_n_u_minutes __pyx_string_tab[314]
#define __pyx_n_u_mismatch __pyx_string_tab[315]
#define __pyx_n_u_module __pyx_string_tab[316]
#define __pyx_n_u_month __pyx_string_tab[317]
#define __pyx_n_u_month_units __pyx_string_tab[318]
#define __pyx_n_u_months __pyx_string_tab[319]
#define __pyx_n_u_mro_entries __pyx_string_tab[320]
#define __pyx_n_u_ms __pyx_string_tab[321]
#define __pyx_n_u_msec __pyx_string_tab[322]
#define __pyx_n_u_msecs __pyx_string_tab[323]
#define __pyx_n_u_msg __pyx_string_tab[324]
#define __pyx_n_u_mtd __pyx_string_tab[325]
#define __pyx_n_u_munit __pyx_string_tab[326]
#define __pyx_n_u_n __pyx_string_tab[327]
#define __pyx_n_u_name __pyx_string_tab[328]
#define __pyx_n_u_name_2 __pyx_string_tab[329]
#define __pyx_n_u_nanosecond __pyx_string_tab[330]
#define __pyx_n_u_ncnum __pyx_string_tab[331]
#define __pyx_n_u_nctime __pyx_string_tab[332]
#define __pyx_n_u_ndim __pyx_string_tab[333]
#define __pyx_n_u_nearest __pyx_string_tab[334]
#define __pyx_n_u_nearest_to_left __pyx_string_tab[335]
#define __pyx_n_u_next __pyx_string_tab[336]
#define __pyx_n_u_noleap __pyx_string_tab[337]
#define __pyx_n_u_nonzero __pyx_string_tab[338]
#define __pyx_n_u_np __pyx_string_tab[339]
#define __pyx_n_u_num __pyx_string_tab[340]
#define __pyx_n_u_num2date __pyx_string_tab[341]
#define __pyx_n_u_num2pydate __pyx_string_tab[342]
#define __pyx_n_u_numpy __pyx_string_tab[343]
#define __pyx_n_u_only_use_cftime_datetimes __pyx_string_tab[344]
#define __pyx_n_u_only_use_python_datetimes __pyx_string_tab[345]
#define __pyx_n_u_original_mask __pyx_string_tab[346]
#define __pyx_n_u_original_shape __pyx_string_tab[347]
#define __pyx_n_u_parse_date __pyx_string_tab[348]
#define __pyx_n_u_pop __pyx_string_tab[349]
#define __pyx_n_u_prepare __pyx_string_tab[350]
#define __pyx_n_u_proleptic_gregorian __pyx_string_tab[351]
#define __pyx_n_u_property __pyx_string_tab[352]
#define __pyx_n_u_pydatetime __pyx_string_tab[353]
#define __pyx_n_u_pyx_vtable __pyx_string_tab[354]
#define __pyx_n_u_qualname __pyx_string_tab[355]
#define __pyx_n_u_quotient __pyx_string_tab[356]
#define __pyx_n_u_ravel __pyx_string_tab[357]
#define __pyx_n_u_re __pyx_string_tab[358]
#define __pyx_n_u_real_datetime __pyx_string_tab[359]
#define __pyx_n_u_real_datetime_dayofwk __pyx_string_tab[360]
#define __pyx_n_u_real_datetime_dayofyr __pyx_string_tab[361]
#define __pyx_n_u_real_datetime_daysinmonth __pyx_string_tab[362]
#define __pyx_n_u_reduce __pyx_string_tab[363]
#define __pyx_n_u_remainder __pyx_string_tab[364]
#define __pyx_n_u_replace __pyx_string_tab[365]
#define __pyx_n_u_reshape __pyx_string_tab[366]
#define __pyx_n_u_rint __pyx_string_tab[367]
#define __pyx_n_u_round __pyx_string_tab[368]
#define __pyx_n_u_s __pyx_string_tab[369]
#define __pyx_n_u_same_kind __pyx_string_tab[370]
#define __pyx_n_u_scale_times __pyx_string_tab[371]
#define __pyx_n_u_scaled_times __pyx_string_tab[372]
#define __pyx_n_u_search __pyx_string_tab[373]
#define __pyx_n_u_sec __pyx_string_tab[374]
#define __pyx_n_u_sec_units __pyx_string_tab[375]
#define __pyx_n_u_second __pyx_string_tab[376]
#define __pyx_n_u_seconds __pyx_string_tab[377]
#define __pyx_n_u_secs __pyx_string_tab[378]
#define __pyx_n_u_select __pyx_string_tab[379]
#define __pyx_n_u_self __pyx_string_tab[380]
#define __pyx_n_u_send __pyx_string_tab[381]
#define __pyx_n_u_sep __pyx_string_tab[382]
#define __pyx_n_u_set_name __pyx_string_tab[383]
#define __pyx_n_u_setdefault __pyx_string_tab[384]
#define __pyx_n_u_shape __pyx_string_tab[385]
#define __pyx_n_u_simplefilter __pyx_string_tab[386]
#define __pyx_n_u_since __pyx_string_tab[387]
#define __pyx_n_u_sincestring __pyx_string_tab[388]
#define __pyx_n_u_size __pyx_string_tab[389]
#define __pyx_n_u_sort_indices __pyx_string_tab[390]
#define __pyx_n_u_special_fd __pyx_string_tab[391]
#define __pyx_n_u_split __pyx_string_tab[392]
#define __pyx_n_u_squeeze __pyx_string_tab[393]
#define __pyx_n_u_standard __pyx_string_tab[394]
#define __pyx_n_u_staticmethod __pyx_string_tab[395]
#define __pyx_n_u_strftime __pyx_string_tab[396]
#define __pyx_n_u_strip __pyx_string_tab[397]
#define __pyx_n_u_strptime __pyx_string_tab[398]
#define __pyx_n_u_strptime_2 __pyx_string_tab[399]
#define __pyx_n_u_strptime_locals_genexpr __pyx_string_tab[400]
#define __pyx_n_u_struct_time __pyx_string_tab[401]
#define __pyx_n_u_super __pyx_string_tab[402]
#define __pyx_n_u_t0 __pyx_string_tab[403]
#define __pyx_n_u_t1 __pyx_string_tab[404]
#define __pyx_n_u_td __pyx_string_tab[405]
#define __pyx_n_u_test __pyx_string_tab[406]
#define __pyx_n_u_throw __pyx_string_tab[407]
#define __pyx_n_u_time __pyx_string_tab[408]
#define __pyx_n_u_time2index __pyx_string_tab[409]
#define __pyx_n_u_time_in_microseconds __pyx_string_tab[410]
#define __pyx_n_u_timedelta __pyx_string_tab[411]
#define __pyx_n_u_times __pyx_string_tab[412]
#define __pyx_n_u_times_in_microseconds __pyx_string_tab[413]
#define __pyx_n_u_timespec __pyx_string_tab[414]
#define __pyx_n_u_timestr __pyx_string_tab[415]
#define __pyx_n_u_timetuple __pyx_string_tab[416]
#define __pyx_n_u_timezone __pyx_string_tab[417]
#define __pyx_n_u_tm_yday __pyx_string_tab[418]
#define __pyx_n_u_to_calendar_specific_datetime __pyx_string_tab[419]
#define __pyx_n_u_to_real_datetime __pyx_string_tab[420]
#define __pyx_n_u_to_tuple __pyx_string_tab[421]
#define __pyx_n_u_toordinal __pyx_string_tab[422]
#define __pyx_n_u_tzinfo __pyx_string_tab[423]
#define __pyx_n_u_u __pyx_string_tab[424]
#define __pyx_n_u_unit __pyx_string_tab[425]
#define __pyx_n_u_unit_timedelta __pyx_string_tab[426]
#define __pyx_n_u_units __pyx_string_tab[427]
#define __pyx_n_u_units_2 __pyx_string_tab[428]
#define __pyx_n_u_unsort_indices __pyx_string_tab[429]
#define __pyx_n_u_upcast_times __pyx_string_tab[430]
#define __pyx_n_u_use_python_datetime __pyx_string_tab[431]
#define __pyx_n_u_utc_offset __pyx_string_tab[432]
#define __pyx_n_u_utcoffset __pyx_string_tab[433]
#define __pyx_n_u_value __pyx_string_tab[434]
#define __pyx_n_u_values __pyx_string_tab[435]
#define __pyx_n_u_w __pyx_string_tab[436]
#define __pyx_n_u_warn __pyx_string_tab[437]
#define __pyx_n_u_warnings __pyx_string_tab[438]
#define __pyx_n_u_weekday __pyx_string_tab[439]
#define __pyx_n_u_where __pyx_string_tab[440]
#define __pyx_n_u_x __pyx_string_tab[441]
#define __pyx_n_u_y __pyx_string_tab[442]
#define __pyx_n_u_year __pyx_string_tab[443]
#define __pyx_n_u_year_units __pyx_string_tab[444]
#define __pyx_kp_b_iso88591_1D_t84vT_34q_1_d_F_4r_a_BfAWBm1 __pyx_string_tab[445]
#define __pyx_kp_b_iso88591_1_q_2XQa_Rxq_1_E_BfA_Qe9BfARwaq __pyx_string_tab[446]
#define __pyx_kp_b_iso88591_4A_9C_Ct_S_AQ_t_q_Ja __pyx_string_tab[447]
#define __pyx_kp_b_iso88591_81F_2 __pyx_string_tab[448]
#define __pyx_kp_b_iso88591_81F_C6Iccd __pyx_string_tab[449]
#define __pyx_kp_b_iso88591_A_1_86_A_q_9D_9A_q_q_q_c_q_A__A __pyx_string_tab[450]
#define __pyx_kp_b_iso88591_A_7_Q_Q_t9AQ __pyx_string_tab[451]
#define __pyx_kp_b_iso88591_A_81D_a_Qd_V1A __pyx_string_tab[452]
#define __pyx_kp_b_iso88591_A_AT_HD_IT __pyx_string_tab[453]
#define __pyx_kp_b_iso88591_A_A_Q_t1_A_a_a_t1_Q_D_S_s_Cq_AQ __pyx_string_tab[454]
#define __pyx_kp_b_iso88591_A_G4xt6_WD_IT __pyx_string_tab[455]
#define __pyx_kp_b_iso88591_A_H_Qaq_4uF_c_Qe5_U_uE_a_a_wa_9F __pyx_string_tab[456]
#define __pyx_kp_b_iso88591_A_it_Q_D_fA __pyx_string_tab[457]
#define __pyx_kp_b_iso88591_A_t81 __pyx_string_tab[458]
#define __pyx_kp_b_iso88591_A_t_Rq __pyx_string_tab[459]
#define __pyx_kp_b_iso88591_A_t_r_WD_F_a_IT_j_Kq __pyx_string_tab[460]
#define __pyx_kp_b_iso88591_BgRxr_r_ir __pyx_string_tab[461]
#define __pyx_kp_b_iso88591_DA_q_A_Jaq_y_q __pyx_string_tab[462]
#define __pyx_kp_b_iso88591_N_4vRq_A_A_9Cq_1_4wat7_hd_c_6_1 __pyx_string_tab[463]
#define __pyx_kp_b_iso88591_Q __pyx_string_tab[464]
#define __pyx_kp_b_iso88591_Q0_a_nAQ_y_1_7_8_q_wc_Jawhiz_wc __pyx_string_tab[465]
#define __pyx_kp_b_iso88591_QT_a_nAQ_aq_S_9Cq_5_z_Q_Ba_A_C4 __pyx_string_tab[466]
#define __pyx_kp_b_iso88591_Q_s_c_q_2T_E_k_s_D_8STTXXcckkl __pyx_string_tab[467]
#define __pyx_kp_b_iso88591_Yc_t4vS_DPVVYYbbc_t_4t6_IURVV_c __pyx_string_tab[468]
#define __pyx_kp_b_iso88591_aN_a_nAQ_HAV6_QgXYj_q __pyx_string_tab[469]
#define __pyx_kp_b_iso88591_a_7_Q_T_y_q __pyx_string_tab[470]
#define __pyx_kp_b_iso88591_ap_q_Qa_4q_2V1CvQ_q_q_r_E_Rs_AQ __pyx_string_tab[471]
#define __pyx_kp_b_iso88591_q_Q_j_3a_j_5_d __pyx_string_tab[472]
#define __pyx_kp_b_iso88591_q_y_j __pyx_string_tab[473]
#define __pyx_kp_b_iso88591_s_c_s_A_s_A __pyx_string_tab[474]
#define __pyx_kp_b_iso88591_s_c_wb_3fCq_1_D_U_Rq_D_U_Rq_82 __pyx_string_tab[475]
#define __pyx_kp_b_iso88591_t_Ql_t4z_a_j_1_1_V1JfA_t1_j_A_Q __pyx_string_tab[476]
#define __pyx_kp_b_iso88591_wir __pyx_string_tab[477]
#define __pyx_kp_b_iso88591_xvQ_S_1A_M_1A_vV3l_hb_4vS_SWW_d __pyx_string_tab[478]
#define __pyx_kp_b_iso88591_z_xvQ_S_1A_z_4AYa_t_T_4q_AQ_Qa __pyx_string_tab[479]
#define __pyx_float_1_ __pyx_number_tab[0]
#define __pyx_float_2_ __pyx_number_tab[1]
#define __pyx_float_0_5 __pyx_number_tab[2]
#define __pyx_float_24_ __pyx_number_tab[3]
#define __pyx_float_60_ __pyx_number_tab[4]
#define __pyx_float_1_e6 __pyx_number_tab[5]
#define __pyx_float_1440_ __pyx_number_tab[6]
#define __pyx_float_1440_0 __pyx_number_tab[7]
#define __pyx_float_86400_0 __pyx_number_tab[8]
#define __pyx_int_0 __pyx_number_tab[9]
#define __pyx_int_neg_1 __pyx_number_tab[10]
#define __pyx_int_1 __pyx_number_tab[11]
#define __pyx_int_2 __pyx_number_tab[12]
#define __pyx_int_neg_3 __pyx_number_tab[13]
#define __pyx_int_4 __pyx_number_tab[14]
#define __pyx_int_6 __pyx_number_tab[15]
#define __pyx_int_7 __pyx_number_tab[16]
#define __pyx_int_10 __pyx_number_tab[17]
#define __pyx_int_15 __pyx_number_tab[18]
#define __pyx_int_28 __pyx_number_tab[19]
#define __pyx_int_29 __pyx_number_tab[20]
#define __pyx_int_30 __pyx_number_tab[21]
#define __pyx_int_60 __pyx_number_tab[22]
#define __pyx_int_100 __pyx_number_tab[23]
#define __pyx_int_400 __pyx_number_tab[24]
#define __pyx_int_1000 __pyx_number_tab[25]
#define __pyx_int_1582 __pyx_number_tab[26]
#define __pyx_int_2000 __pyx_number_tab[27]
#define __pyx_int_3600 __pyx_number_tab[28]
#define __pyx_int_999999 __pyx_number_tab[29]
#define __pyx_int_1000000 __pyx_number_tab[30]
#define __pyx_int_60000000 __pyx_number_tab[31]
#define __pyx_int_3600000000 __pyx_number_tab[32]
#define __pyx_int_86400000000 __pyx_number_tab[33]
#define __pyx_int_2592000000000 __pyx_number_tab[34]
#define __pyx_int_0x1cae8c13e000 __pyx_number_tab[35]
/* #### Code section: module_state_clear ### */
#if CYTHON_USE_MODULE_STATE
static CYTHON_SMALL_CODE int __pyx_m_clear(PyObject *m) {
  __pyx_mstatetype *clear_module_state = __Pyx_PyModule_GetState(m);
  if (!clear_module_state) return 0;
  Py_CLEAR(clear_module_state->__pyx_d);
  Py_CLEAR(clear_module_state->__pyx_b);
  Py_CLEAR(clear_module_state->__pyx_cython_runtime);
  Py_CLEAR(clear_module_state->__pyx_empty_tuple);
  Py_CLEAR(clear_module_state->__pyx_empty_bytes);
  Py_CLEAR(clear_module_state->__pyx_empty_unicode);
  #if CYTHON_PEP489_MULTI_PHASE_INIT
  __Pyx_State_RemoveModule(NULL);
  #endif
  Py_CLEAR(clear_module_state->__pyx_ptype_7cpython_4type_type);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_dtype);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_flatiter);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_broadcast);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_ndarray);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_generic);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_number);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_integer);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_signedinteger);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_unsignedinteger);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_inexact);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_floating);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_complexfloating);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_flexible);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_character);
  Py_CLEAR(clear_module_state->__pyx_ptype_5numpy_ufunc);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_datetime);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_datetime);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_DatetimeNoLeap);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_DatetimeAllLeap);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_Datetime360Day);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_Datetime360Day);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeJulian);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_DatetimeJulian);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_DatetimeGregorian);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime);
  Py_CLEAR(clear_module_state->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr);
  Py_CLEAR(clear_module_state->__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr);
  for (int i=0; i<4; ++i) { Py_CLEAR(clear_module_state->__pyx_slice[i]); }
  for (int i=0; i<13; ++i) { Py_CLEAR(clear_module_state->__pyx_tuple[i]); }
  for (int i=0; i<35; ++i) { Py_CLEAR(clear_module_state->__pyx_codeobj_tab[i]); }
  for (int i=0; i<480; ++i) { Py_CLEAR(clear_module_state->__pyx_string_tab[i]); }
  for (int i=0; i<36; ++i) { Py_CLEAR(clear_module_state->__pyx_number_tab[i]); }
/* #### Code section: module_state_clear_contents ### */
/* CommonTypesMetaclass.module_state_clear */
Py_CLEAR(clear_module_state->__pyx_CommonTypesMetaclassType);

/* CythonFunctionShared.module_state_clear */
Py_CLEAR(clear_module_state->__pyx_CyFunctionType);

/* Generator.module_state_clear */
Py_CLEAR(clear_module_state->__pyx_GeneratorType);

/* #### Code section: module_state_clear_end ### */
return 0;
}
#endif
/* #### Code section: module_state_traverse ### */
#if CYTHON_USE_MODULE_STATE
static CYTHON_SMALL_CODE int __pyx_m_traverse(PyObject *m, visitproc visit, void *arg) {
  __pyx_mstatetype *traverse_module_state = __Pyx_PyModule_GetState(m);
  if (!traverse_module_state) return 0;
  Py_VISIT(traverse_module_state->__pyx_d);
  Py_VISIT(traverse_module_state->__pyx_b);
  Py_VISIT(traverse_module_state->__pyx_cython_runtime);
  __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_tuple);
  __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_bytes);
  __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_unicode);
  Py_VISIT(traverse_module_state->__pyx_ptype_7cpython_4type_type);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_dtype);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_flatiter);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_broadcast);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_ndarray);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_generic);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_number);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_integer);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_signedinteger);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_unsignedinteger);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_inexact);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_floating);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_complexfloating);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_flexible);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_character);
  Py_VISIT(traverse_module_state->__pyx_ptype_5numpy_ufunc);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_datetime);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_datetime);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_DatetimeNoLeap);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_DatetimeAllLeap);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_Datetime360Day);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_Datetime360Day);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeJulian);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_DatetimeJulian);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_DatetimeGregorian);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime);
  Py_VISIT(traverse_module_state->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr);
  Py_VISIT(traverse_module_state->__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr);
  for (int i=0; i<4; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_slice[i]); }
  for (int i=0; i<13; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_tuple[i]); }
  for (int i=0; i<35; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_codeobj_tab[i]); }
  for (int i=0; i<480; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_string_tab[i]); }
  for (int i=0; i<36; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_number_tab[i]); }
/* #### Code section: module_state_traverse_contents ### */
/* CommonTypesMetaclass.module_state_traverse */
Py_VISIT(traverse_module_state->__pyx_CommonTypesMetaclassType);

/* CythonFunctionShared.module_state_traverse */
Py_VISIT(traverse_module_state->__pyx_CyFunctionType);

/* Generator.module_state_traverse */
Py_VISIT(traverse_module_state->__pyx_GeneratorType);

/* #### Code section: module_state_traverse_end ### */
return 0;
}
#endif
/* #### Code section: module_code ### */

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":243
 *         cdef int type_num
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp itemsize(self) noexcept nogil:
 *             return PyDataType_ELSIZE(self)
*/

static CYTHON_INLINE npy_intp __pyx_f_5numpy_5dtype_8itemsize_itemsize(PyArray_Descr *__pyx_v_self) {
  npy_intp __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":245
 *         @property
 *         cdef inline npy_intp itemsize(self) noexcept nogil:
 *             return PyDataType_ELSIZE(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyDataType_ELSIZE(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":243
 *         cdef int type_num
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp itemsize(self) noexcept nogil:
 *             return PyDataType_ELSIZE(self)
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":247
 *             return PyDataType_ELSIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp alignment(self) noexcept nogil:
 *             return PyDataType_ALIGNMENT(self)
*/

static CYTHON_INLINE npy_intp __pyx_f_5numpy_5dtype_9alignment_alignment(PyArray_Descr *__pyx_v_self) {
  npy_intp __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":249
 *         @property
 *         cdef inline npy_intp alignment(self) noexcept nogil:
 *             return PyDataType_ALIGNMENT(self)             # <<<<<<<<<<<<<<
 * 
 *         # Use fields/names with care as they may be NULL.  You must check
*/
  __pyx_r = PyDataType_ALIGNMENT(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":247
 *             return PyDataType_ELSIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp alignment(self) noexcept nogil:
 *             return PyDataType_ALIGNMENT(self)
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":253
 *         # Use fields/names with care as they may be NULL.  You must check
 *         # for this using PyDataType_HASFIELDS.
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline object fields(self):
 *             return <object>PyDataType_FIELDS(self)
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_5dtype_6fields_fields(PyArray_Descr *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1;
  __Pyx_RefNannySetupContext("fields", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":255
 *         @property
 *         cdef inline object fields(self):
 *             return <object>PyDataType_FIELDS(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyDataType_FIELDS(__pyx_v_self);
  __Pyx_INCREF(((PyObject *)__pyx_t_1));
  __pyx_r = ((PyObject *)__pyx_t_1);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":253
 *         # Use fields/names with care as they may be NULL.  You must check
 *         # for this using PyDataType_HASFIELDS.
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline object fields(self):
 *             return <object>PyDataType_FIELDS(self)
*/

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

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":257
 *             return <object>PyDataType_FIELDS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline tuple names(self):
 *             return <tuple>PyDataType_NAMES(self)
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_5dtype_5names_names(PyArray_Descr *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1;
  __Pyx_RefNannySetupContext("names", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":259
 *         @property
 *         cdef inline tuple names(self):
 *             return <tuple>PyDataType_NAMES(self)             # <<<<<<<<<<<<<<
 * 
 *         # Use PyDataType_HASSUBARRAY to test whether this field is
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyDataType_NAMES(__pyx_v_self);
  __Pyx_INCREF(((PyObject*)__pyx_t_1));
  __pyx_r = ((PyObject*)__pyx_t_1);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":257
 *             return <object>PyDataType_FIELDS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline tuple names(self):
 *             return <tuple>PyDataType_NAMES(self)
*/

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

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":264
 *         # valid (the pointer can be NULL). Most users should access
 *         # this field via the inline helper method PyDataType_SHAPE.
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline PyArray_ArrayDescr* subarray(self) noexcept nogil:
 *             return PyDataType_SUBARRAY(self)
*/

static CYTHON_INLINE PyArray_ArrayDescr *__pyx_f_5numpy_5dtype_8subarray_subarray(PyArray_Descr *__pyx_v_self) {
  PyArray_ArrayDescr *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":266
 *         @property
 *         cdef inline PyArray_ArrayDescr* subarray(self) noexcept nogil:
 *             return PyDataType_SUBARRAY(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyDataType_SUBARRAY(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":264
 *         # valid (the pointer can be NULL). Most users should access
 *         # this field via the inline helper method PyDataType_SHAPE.
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline PyArray_ArrayDescr* subarray(self) noexcept nogil:
 *             return PyDataType_SUBARRAY(self)
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":268
 *             return PyDataType_SUBARRAY(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_uint64 flags(self) noexcept nogil:
 *             """The data types flags."""
*/

static CYTHON_INLINE npy_uint64 __pyx_f_5numpy_5dtype_5flags_flags(PyArray_Descr *__pyx_v_self) {
  npy_uint64 __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":271
 *         cdef inline npy_uint64 flags(self) noexcept nogil:
 *             """The data types flags."""
 *             return PyDataType_FLAGS(self)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = PyDataType_FLAGS(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":268
 *             return PyDataType_SUBARRAY(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_uint64 flags(self) noexcept nogil:
 *             """The data types flags."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":280
 *     ctypedef class numpy.broadcast [object PyArrayMultiIterObject, check_size ignore]:
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int numiter(self) noexcept nogil:
 *             """The number of arrays that need to be broadcast to the same shape."""
*/

static CYTHON_INLINE int __pyx_f_5numpy_9broadcast_7numiter_numiter(PyArrayMultiIterObject *__pyx_v_self) {
  int __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":283
 *         cdef inline int numiter(self) noexcept nogil:
 *             """The number of arrays that need to be broadcast to the same shape."""
 *             return PyArray_MultiIter_NUMITER(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_MultiIter_NUMITER(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":280
 *     ctypedef class numpy.broadcast [object PyArrayMultiIterObject, check_size ignore]:
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int numiter(self) noexcept nogil:
 *             """The number of arrays that need to be broadcast to the same shape."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":285
 *             return PyArray_MultiIter_NUMITER(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp size(self) noexcept nogil:
 *             """The total broadcasted size."""
*/

static CYTHON_INLINE npy_intp __pyx_f_5numpy_9broadcast_4size_size(PyArrayMultiIterObject *__pyx_v_self) {
  npy_intp __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":288
 *         cdef inline npy_intp size(self) noexcept nogil:
 *             """The total broadcasted size."""
 *             return PyArray_MultiIter_SIZE(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_MultiIter_SIZE(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":285
 *             return PyArray_MultiIter_NUMITER(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp size(self) noexcept nogil:
 *             """The total broadcasted size."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":290
 *             return PyArray_MultiIter_SIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp index(self) noexcept nogil:
 *             """The current (1-d) index into the broadcasted result."""
*/

static CYTHON_INLINE npy_intp __pyx_f_5numpy_9broadcast_5index_index(PyArrayMultiIterObject *__pyx_v_self) {
  npy_intp __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":293
 *         cdef inline npy_intp index(self) noexcept nogil:
 *             """The current (1-d) index into the broadcasted result."""
 *             return PyArray_MultiIter_INDEX(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_MultiIter_INDEX(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":290
 *             return PyArray_MultiIter_SIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp index(self) noexcept nogil:
 *             """The current (1-d) index into the broadcasted result."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":295
 *             return PyArray_MultiIter_INDEX(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int nd(self) noexcept nogil:
 *             """The number of dimensions in the broadcasted result."""
*/

static CYTHON_INLINE int __pyx_f_5numpy_9broadcast_2nd_nd(PyArrayMultiIterObject *__pyx_v_self) {
  int __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":298
 *         cdef inline int nd(self) noexcept nogil:
 *             """The number of dimensions in the broadcasted result."""
 *             return PyArray_MultiIter_NDIM(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_MultiIter_NDIM(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":295
 *             return PyArray_MultiIter_INDEX(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int nd(self) noexcept nogil:
 *             """The number of dimensions in the broadcasted result."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":300
 *             return PyArray_MultiIter_NDIM(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp* dimensions(self) noexcept nogil:
 *             """The shape of the broadcasted result."""
*/

static CYTHON_INLINE npy_intp *__pyx_f_5numpy_9broadcast_10dimensions_dimensions(PyArrayMultiIterObject *__pyx_v_self) {
  npy_intp *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":303
 *         cdef inline npy_intp* dimensions(self) noexcept nogil:
 *             """The shape of the broadcasted result."""
 *             return PyArray_MultiIter_DIMS(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_MultiIter_DIMS(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":300
 *             return PyArray_MultiIter_NDIM(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp* dimensions(self) noexcept nogil:
 *             """The shape of the broadcasted result."""
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":305
 *             return PyArray_MultiIter_DIMS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline void** iters(self) noexcept nogil:
 *             """An array of iterator objects that holds the iterators for the arrays to be broadcast together.
*/

static CYTHON_INLINE void **__pyx_f_5numpy_9broadcast_5iters_iters(PyArrayMultiIterObject *__pyx_v_self) {
  void **__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":309
 *             """An array of iterator objects that holds the iterators for the arrays to be broadcast together.
 *             On return, the iterators are adjusted for broadcasting."""
 *             return PyArray_MultiIter_ITERS(self)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = PyArray_MultiIter_ITERS(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":305
 *             return PyArray_MultiIter_DIMS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline void** iters(self) noexcept nogil:
 *             """An array of iterator objects that holds the iterators for the arrays to be broadcast together.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":323
 *         # Instead, we use properties that map to the corresponding C-API functions.
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline PyObject* base(self) noexcept nogil:
 *             """Returns a borrowed reference to the object owning the data/memory.
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_7ndarray_4base_base(PyArrayObject *__pyx_v_self) {
  PyObject *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":327
 *             """Returns a borrowed reference to the object owning the data/memory.
 *             """
 *             return PyArray_BASE(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_BASE(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":323
 *         # Instead, we use properties that map to the corresponding C-API functions.
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline PyObject* base(self) noexcept nogil:
 *             """Returns a borrowed reference to the object owning the data/memory.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":329
 *             return PyArray_BASE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline dtype descr(self):
 *             """Returns an owned reference to the dtype of the array.
*/

static CYTHON_INLINE PyArray_Descr *__pyx_f_5numpy_7ndarray_5descr_descr(PyArrayObject *__pyx_v_self) {
  PyArray_Descr *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyArray_Descr *__pyx_t_1;
  __Pyx_RefNannySetupContext("descr", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":333
 *             """Returns an owned reference to the dtype of the array.
 *             """
 *             return <dtype>PyArray_DESCR(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __Pyx_XDECREF((PyObject *)__pyx_r);
  __pyx_t_1 = PyArray_DESCR(__pyx_v_self);
  __Pyx_INCREF((PyObject *)((PyArray_Descr *)__pyx_t_1));
  __pyx_r = ((PyArray_Descr *)__pyx_t_1);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":329
 *             return PyArray_BASE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline dtype descr(self):
 *             """Returns an owned reference to the dtype of the array.
*/

  /* function exit code */
  __pyx_L0:;
  __Pyx_XGIVEREF((PyObject *)__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":335
 *             return <dtype>PyArray_DESCR(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int ndim(self) noexcept nogil:
 *             """Returns the number of dimensions in the array.
*/

static CYTHON_INLINE int __pyx_f_5numpy_7ndarray_4ndim_ndim(PyArrayObject *__pyx_v_self) {
  int __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":339
 *             """Returns the number of dimensions in the array.
 *             """
 *             return PyArray_NDIM(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_NDIM(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":335
 *             return <dtype>PyArray_DESCR(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline int ndim(self) noexcept nogil:
 *             """Returns the number of dimensions in the array.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":341
 *             return PyArray_NDIM(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp *shape(self) noexcept nogil:
 *             """Returns a pointer to the dimensions/shape of the array.
*/

static CYTHON_INLINE npy_intp *__pyx_f_5numpy_7ndarray_5shape_shape(PyArrayObject *__pyx_v_self) {
  npy_intp *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":347
 *             Can return NULL for 0-dimensional arrays.
 *             """
 *             return PyArray_DIMS(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_DIMS(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":341
 *             return PyArray_NDIM(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp *shape(self) noexcept nogil:
 *             """Returns a pointer to the dimensions/shape of the array.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":349
 *             return PyArray_DIMS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp *strides(self) noexcept nogil:
 *             """Returns a pointer to the strides of the array.
*/

static CYTHON_INLINE npy_intp *__pyx_f_5numpy_7ndarray_7strides_strides(PyArrayObject *__pyx_v_self) {
  npy_intp *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":354
 *             The number of elements matches the number of dimensions of the array (ndim).
 *             """
 *             return PyArray_STRIDES(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_STRIDES(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":349
 *             return PyArray_DIMS(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp *strides(self) noexcept nogil:
 *             """Returns a pointer to the strides of the array.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":356
 *             return PyArray_STRIDES(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp size(self) noexcept nogil:
 *             """Returns the total size (in number of elements) of the array.
*/

static CYTHON_INLINE npy_intp __pyx_f_5numpy_7ndarray_4size_size(PyArrayObject *__pyx_v_self) {
  npy_intp __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":360
 *             """Returns the total size (in number of elements) of the array.
 *             """
 *             return PyArray_SIZE(self)             # <<<<<<<<<<<<<<
 * 
 *         @property
*/
  __pyx_r = PyArray_SIZE(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":356
 *             return PyArray_STRIDES(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline npy_intp size(self) noexcept nogil:
 *             """Returns the total size (in number of elements) of the array.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":362
 *             return PyArray_SIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline char* data(self) noexcept nogil:
 *             """The pointer to the data buffer as a char*.
*/

static CYTHON_INLINE char *__pyx_f_5numpy_7ndarray_4data_data(PyArrayObject *__pyx_v_self) {
  char *__pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":369
 *             of `PyArray_DATA()` instead, which returns a 'void*'.
 *             """
 *             return PyArray_BYTES(self)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = PyArray_BYTES(__pyx_v_self);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":362
 *             return PyArray_SIZE(self)
 * 
 *         @property             # <<<<<<<<<<<<<<
 *         cdef inline char* data(self) noexcept nogil:
 *             """The pointer to the data buffer as a char*.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":777
 * ctypedef long double complex clongdouble_t
 * 
 * cdef inline object PyArray_MultiIterNew1(a):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(1, <void*>a)
 * 
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew1(PyObject *__pyx_v_a) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("PyArray_MultiIterNew1", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":778
 * 
 * cdef inline object PyArray_MultiIterNew1(a):
 *     return PyArray_MultiIterNew(1, <void*>a)             # <<<<<<<<<<<<<<
 * 
 * cdef inline object PyArray_MultiIterNew2(a, b):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyArray_MultiIterNew(1, ((void *)__pyx_v_a)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 778, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":777
 * ctypedef long double complex clongdouble_t
 * 
 * cdef inline object PyArray_MultiIterNew1(a):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(1, <void*>a)
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("numpy.PyArray_MultiIterNew1", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":780
 *     return PyArray_MultiIterNew(1, <void*>a)
 * 
 * cdef inline object PyArray_MultiIterNew2(a, b):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(2, <void*>a, <void*>b)
 * 
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew2(PyObject *__pyx_v_a, PyObject *__pyx_v_b) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("PyArray_MultiIterNew2", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":781
 * 
 * cdef inline object PyArray_MultiIterNew2(a, b):
 *     return PyArray_MultiIterNew(2, <void*>a, <void*>b)             # <<<<<<<<<<<<<<
 * 
 * cdef inline object PyArray_MultiIterNew3(a, b, c):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyArray_MultiIterNew(2, ((void *)__pyx_v_a), ((void *)__pyx_v_b)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 781, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":780
 *     return PyArray_MultiIterNew(1, <void*>a)
 * 
 * cdef inline object PyArray_MultiIterNew2(a, b):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(2, <void*>a, <void*>b)
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("numpy.PyArray_MultiIterNew2", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":783
 *     return PyArray_MultiIterNew(2, <void*>a, <void*>b)
 * 
 * cdef inline object PyArray_MultiIterNew3(a, b, c):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(3, <void*>a, <void*>b, <void*> c)
 * 
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew3(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("PyArray_MultiIterNew3", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":784
 * 
 * cdef inline object PyArray_MultiIterNew3(a, b, c):
 *     return PyArray_MultiIterNew(3, <void*>a, <void*>b, <void*> c)             # <<<<<<<<<<<<<<
 * 
 * cdef inline object PyArray_MultiIterNew4(a, b, c, d):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyArray_MultiIterNew(3, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 784, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":783
 *     return PyArray_MultiIterNew(2, <void*>a, <void*>b)
 * 
 * cdef inline object PyArray_MultiIterNew3(a, b, c):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(3, <void*>a, <void*>b, <void*> c)
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("numpy.PyArray_MultiIterNew3", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":786
 *     return PyArray_MultiIterNew(3, <void*>a, <void*>b, <void*> c)
 * 
 * cdef inline object PyArray_MultiIterNew4(a, b, c, d):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(4, <void*>a, <void*>b, <void*>c, <void*> d)
 * 
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew4(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c, PyObject *__pyx_v_d) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("PyArray_MultiIterNew4", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":787
 * 
 * cdef inline object PyArray_MultiIterNew4(a, b, c, d):
 *     return PyArray_MultiIterNew(4, <void*>a, <void*>b, <void*>c, <void*> d)             # <<<<<<<<<<<<<<
 * 
 * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyArray_MultiIterNew(4, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c), ((void *)__pyx_v_d)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 787, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":786
 *     return PyArray_MultiIterNew(3, <void*>a, <void*>b, <void*> c)
 * 
 * cdef inline object PyArray_MultiIterNew4(a, b, c, d):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(4, <void*>a, <void*>b, <void*>c, <void*> d)
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("numpy.PyArray_MultiIterNew4", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":789
 *     return PyArray_MultiIterNew(4, <void*>a, <void*>b, <void*>c, <void*> d)
 * 
 * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(5, <void*>a, <void*>b, <void*>c, <void*> d, <void*> e)
 * 
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew5(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c, PyObject *__pyx_v_d, PyObject *__pyx_v_e) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("PyArray_MultiIterNew5", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":790
 * 
 * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e):
 *     return PyArray_MultiIterNew(5, <void*>a, <void*>b, <void*>c, <void*> d, <void*> e)             # <<<<<<<<<<<<<<
 * 
 * cdef inline tuple PyDataType_SHAPE(dtype d):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = PyArray_MultiIterNew(5, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c), ((void *)__pyx_v_d), ((void *)__pyx_v_e)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":789
 *     return PyArray_MultiIterNew(4, <void*>a, <void*>b, <void*>c, <void*> d)
 * 
 * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e):             # <<<<<<<<<<<<<<
 *     return PyArray_MultiIterNew(5, <void*>a, <void*>b, <void*>c, <void*> d, <void*> e)
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_AddTraceback("numpy.PyArray_MultiIterNew5", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":792
 *     return PyArray_MultiIterNew(5, <void*>a, <void*>b, <void*>c, <void*> d, <void*> e)
 * 
 * cdef inline tuple PyDataType_SHAPE(dtype d):             # <<<<<<<<<<<<<<
 *     if PyDataType_HASSUBARRAY(d):
 *         return <tuple>d.subarray.shape
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyDataType_SHAPE(PyArray_Descr *__pyx_v_d) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2;
  __Pyx_RefNannySetupContext("PyDataType_SHAPE", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":793
 * 
 * cdef inline tuple PyDataType_SHAPE(dtype d):
 *     if PyDataType_HASSUBARRAY(d):             # <<<<<<<<<<<<<<
 *         return <tuple>d.subarray.shape
 *     else:
*/
  __pyx_t_1 = PyDataType_HASSUBARRAY(__pyx_v_d);
  if (__pyx_t_1) {

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":794
 * cdef inline tuple PyDataType_SHAPE(dtype d):
 *     if PyDataType_HASSUBARRAY(d):
 *         return <tuple>d.subarray.shape             # <<<<<<<<<<<<<<
 *     else:
 *         return ()
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_2 = __pyx_f_5numpy_5dtype_8subarray_subarray(__pyx_v_d)->shape;
    __Pyx_INCREF(((PyObject*)__pyx_t_2));
    __pyx_r = ((PyObject*)__pyx_t_2);
    goto __pyx_L0;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":793
 * 
 * cdef inline tuple PyDataType_SHAPE(dtype d):
 *     if PyDataType_HASSUBARRAY(d):             # <<<<<<<<<<<<<<
 *         return <tuple>d.subarray.shape
 *     else:
*/
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":796
 *         return <tuple>d.subarray.shape
 *     else:
 *         return ()             # <<<<<<<<<<<<<<
 * 
 * 
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_mstate_global->__pyx_empty_tuple);
    __pyx_r = __pyx_mstate_global->__pyx_empty_tuple;
    goto __pyx_L0;
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":792
 *     return PyArray_MultiIterNew(5, <void*>a, <void*>b, <void*>c, <void*> d, <void*> e)
 * 
 * cdef inline tuple PyDataType_SHAPE(dtype d):             # <<<<<<<<<<<<<<
 *     if PyDataType_HASSUBARRAY(d):
 *         return <tuple>d.subarray.shape
*/

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

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":995
 *     int _import_umath() except -1
 * 
 * cdef inline void set_array_base(ndarray arr, object base) except *:             # <<<<<<<<<<<<<<
 *     Py_INCREF(base) # important to do this before stealing the reference below!
 *     PyArray_SetBaseObject(arr, base)
*/

static CYTHON_INLINE void __pyx_f_5numpy_set_array_base(PyArrayObject *__pyx_v_arr, PyObject *__pyx_v_base) {
  int __pyx_t_1;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":996
 * 
 * cdef inline void set_array_base(ndarray arr, object base) except *:
 *     Py_INCREF(base) # important to do this before stealing the reference below!             # <<<<<<<<<<<<<<
 *     PyArray_SetBaseObject(arr, base)
 * 
*/
  Py_INCREF(__pyx_v_base);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":997
 * cdef inline void set_array_base(ndarray arr, object base) except *:
 *     Py_INCREF(base) # important to do this before stealing the reference below!
 *     PyArray_SetBaseObject(arr, base)             # <<<<<<<<<<<<<<
 * 
 * cdef inline object get_array_base(ndarray arr):
*/
  __pyx_t_1 = PyArray_SetBaseObject(__pyx_v_arr, __pyx_v_base); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(1, 997, __pyx_L1_error)

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":995
 *     int _import_umath() except -1
 * 
 * cdef inline void set_array_base(ndarray arr, object base) except *:             # <<<<<<<<<<<<<<
 *     Py_INCREF(base) # important to do this before stealing the reference below!
 *     PyArray_SetBaseObject(arr, base)
*/

  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_AddTraceback("numpy.set_array_base", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_L0:;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":999
 *     PyArray_SetBaseObject(arr, base)
 * 
 * cdef inline object get_array_base(ndarray arr):             # <<<<<<<<<<<<<<
 *     base = PyArray_BASE(arr)
 *     if base is NULL:
*/

static CYTHON_INLINE PyObject *__pyx_f_5numpy_get_array_base(PyArrayObject *__pyx_v_arr) {
  PyObject *__pyx_v_base;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  __Pyx_RefNannySetupContext("get_array_base", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1000
 * 
 * cdef inline object get_array_base(ndarray arr):
 *     base = PyArray_BASE(arr)             # <<<<<<<<<<<<<<
 *     if base is NULL:
 *         return None
*/
  __pyx_v_base = PyArray_BASE(__pyx_v_arr);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1001
 * cdef inline object get_array_base(ndarray arr):
 *     base = PyArray_BASE(arr)
 *     if base is NULL:             # <<<<<<<<<<<<<<
 *         return None
 *     return <object>base
*/
  __pyx_t_1 = (__pyx_v_base == NULL);
  if (__pyx_t_1) {

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1002
 *     base = PyArray_BASE(arr)
 *     if base is NULL:
 *         return None             # <<<<<<<<<<<<<<
 *     return <object>base
 * 
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_r = Py_None; __Pyx_INCREF(Py_None);
    goto __pyx_L0;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1001
 * cdef inline object get_array_base(ndarray arr):
 *     base = PyArray_BASE(arr)
 *     if base is NULL:             # <<<<<<<<<<<<<<
 *         return None
 *     return <object>base
*/
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1003
 *     if base is NULL:
 *         return None
 *     return <object>base             # <<<<<<<<<<<<<<
 * 
 * # Versions of the import_* functions which are more suitable for
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(((PyObject *)__pyx_v_base));
  __pyx_r = ((PyObject *)__pyx_v_base);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":999
 *     PyArray_SetBaseObject(arr, base)
 * 
 * cdef inline object get_array_base(ndarray arr):             # <<<<<<<<<<<<<<
 *     base = PyArray_BASE(arr)
 *     if base is NULL:
*/

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

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1007
 * # Versions of the import_* functions which are more suitable for
 * # Cython code.
 * cdef inline int import_array() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         __pyx_import_array()
*/

static CYTHON_INLINE int __pyx_f_5numpy_import_array(void) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("import_array", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1008
 * # Cython code.
 * cdef inline int import_array() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         __pyx_import_array()
 *     except Exception:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1009
 * cdef inline int import_array() except -1:
 *     try:
 *         __pyx_import_array()             # <<<<<<<<<<<<<<
 *     except Exception:
 *         raise ImportError("numpy._core.multiarray failed to import")
*/
      __pyx_t_4 = _import_array(); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1009, __pyx_L3_error)

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1008
 * # Cython code.
 * cdef inline int import_array() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         __pyx_import_array()
 *     except Exception:
*/
    }
    __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:;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1010
 *     try:
 *         __pyx_import_array()
 *     except Exception:             # <<<<<<<<<<<<<<
 *         raise ImportError("numpy._core.multiarray failed to import")
 * 
*/
    __pyx_t_4 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_Exception))));
    if (__pyx_t_4) {
      __Pyx_AddTraceback("numpy.import_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(1, 1010, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1011
 *         __pyx_import_array()
 *     except Exception:
 *         raise ImportError("numpy._core.multiarray failed to import")             # <<<<<<<<<<<<<<
 * 
 * cdef inline int import_umath() except -1:
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_numpy__core_multiarray_failed_to};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ImportError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 1011, __pyx_L5_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, 1011, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1008
 * # Cython code.
 * cdef inline int import_array() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         __pyx_import_array()
 *     except Exception:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1007
 * # Versions of the import_* functions which are more suitable for
 * # Cython code.
 * cdef inline int import_array() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         __pyx_import_array()
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __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_AddTraceback("numpy.import_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1013
 *         raise ImportError("numpy._core.multiarray failed to import")
 * 
 * cdef inline int import_umath() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         _import_umath()
*/

static CYTHON_INLINE int __pyx_f_5numpy_import_umath(void) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("import_umath", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1014
 * 
 * cdef inline int import_umath() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1015
 * cdef inline int import_umath() except -1:
 *     try:
 *         _import_umath()             # <<<<<<<<<<<<<<
 *     except Exception:
 *         raise ImportError("numpy._core.umath failed to import")
*/
      __pyx_t_4 = _import_umath(); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1015, __pyx_L3_error)

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1014
 * 
 * cdef inline int import_umath() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
    }
    __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:;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1016
 *     try:
 *         _import_umath()
 *     except Exception:             # <<<<<<<<<<<<<<
 *         raise ImportError("numpy._core.umath failed to import")
 * 
*/
    __pyx_t_4 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_Exception))));
    if (__pyx_t_4) {
      __Pyx_AddTraceback("numpy.import_umath", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(1, 1016, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1017
 *         _import_umath()
 *     except Exception:
 *         raise ImportError("numpy._core.umath failed to import")             # <<<<<<<<<<<<<<
 * 
 * cdef inline int import_ufunc() except -1:
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_numpy__core_umath_failed_to_impo};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ImportError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 1017, __pyx_L5_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, 1017, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1014
 * 
 * cdef inline int import_umath() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1013
 *         raise ImportError("numpy._core.multiarray failed to import")
 * 
 * cdef inline int import_umath() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         _import_umath()
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __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_AddTraceback("numpy.import_umath", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1019
 *         raise ImportError("numpy._core.umath failed to import")
 * 
 * cdef inline int import_ufunc() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         _import_umath()
*/

static CYTHON_INLINE int __pyx_f_5numpy_import_ufunc(void) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("import_ufunc", 0);

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1020
 * 
 * cdef inline int import_ufunc() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1021
 * cdef inline int import_ufunc() except -1:
 *     try:
 *         _import_umath()             # <<<<<<<<<<<<<<
 *     except Exception:
 *         raise ImportError("numpy._core.umath failed to import")
*/
      __pyx_t_4 = _import_umath(); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 1021, __pyx_L3_error)

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1020
 * 
 * cdef inline int import_ufunc() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
    }
    __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:;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1022
 *     try:
 *         _import_umath()
 *     except Exception:             # <<<<<<<<<<<<<<
 *         raise ImportError("numpy._core.umath failed to import")
 * 
*/
    __pyx_t_4 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_Exception))));
    if (__pyx_t_4) {
      __Pyx_AddTraceback("numpy.import_ufunc", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(1, 1022, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1023
 *         _import_umath()
 *     except Exception:
 *         raise ImportError("numpy._core.umath failed to import")             # <<<<<<<<<<<<<<
 * 
 * 
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_numpy__core_umath_failed_to_impo};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ImportError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 1023, __pyx_L5_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, 1023, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1020
 * 
 * cdef inline int import_ufunc() except -1:
 *     try:             # <<<<<<<<<<<<<<
 *         _import_umath()
 *     except Exception:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1019
 *         raise ImportError("numpy._core.umath failed to import")
 * 
 * cdef inline int import_ufunc() except -1:             # <<<<<<<<<<<<<<
 *     try:
 *         _import_umath()
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __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_AddTraceback("numpy.import_ufunc", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1026
 * 
 * 
 * cdef inline bint is_timedelta64_object(object obj) noexcept:             # <<<<<<<<<<<<<<
 *     """
 *     Cython equivalent of `isinstance(obj, np.timedelta64)`
*/

static CYTHON_INLINE int __pyx_f_5numpy_is_timedelta64_object(PyObject *__pyx_v_obj) {
  int __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1038
 *     bool
 *     """
 *     return PyObject_TypeCheck(obj, &PyTimedeltaArrType_Type)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = PyObject_TypeCheck(__pyx_v_obj, (&PyTimedeltaArrType_Type));
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1026
 * 
 * 
 * cdef inline bint is_timedelta64_object(object obj) noexcept:             # <<<<<<<<<<<<<<
 *     """
 *     Cython equivalent of `isinstance(obj, np.timedelta64)`
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1041
 * 
 * 
 * cdef inline bint is_datetime64_object(object obj) noexcept:             # <<<<<<<<<<<<<<
 *     """
 *     Cython equivalent of `isinstance(obj, np.datetime64)`
*/

static CYTHON_INLINE int __pyx_f_5numpy_is_datetime64_object(PyObject *__pyx_v_obj) {
  int __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1053
 *     bool
 *     """
 *     return PyObject_TypeCheck(obj, &PyDatetimeArrType_Type)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = PyObject_TypeCheck(__pyx_v_obj, (&PyDatetimeArrType_Type));
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1041
 * 
 * 
 * cdef inline bint is_datetime64_object(object obj) noexcept:             # <<<<<<<<<<<<<<
 *     """
 *     Cython equivalent of `isinstance(obj, np.datetime64)`
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1056
 * 
 * 
 * cdef inline npy_datetime get_datetime64_value(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the int64 value underlying scalar numpy datetime64 object
*/

static CYTHON_INLINE npy_datetime __pyx_f_5numpy_get_datetime64_value(PyObject *__pyx_v_obj) {
  npy_datetime __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1063
 *     also needed.  That can be found using `get_datetime64_unit`.
 *     """
 *     return (<PyDatetimeScalarObject*>obj).obval             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = ((PyDatetimeScalarObject *)__pyx_v_obj)->obval;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1056
 * 
 * 
 * cdef inline npy_datetime get_datetime64_value(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the int64 value underlying scalar numpy datetime64 object
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1066
 * 
 * 
 * cdef inline npy_timedelta get_timedelta64_value(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the int64 value underlying scalar numpy timedelta64 object
*/

static CYTHON_INLINE npy_timedelta __pyx_f_5numpy_get_timedelta64_value(PyObject *__pyx_v_obj) {
  npy_timedelta __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1070
 *     returns the int64 value underlying scalar numpy timedelta64 object
 *     """
 *     return (<PyTimedeltaScalarObject*>obj).obval             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = ((PyTimedeltaScalarObject *)__pyx_v_obj)->obval;
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1066
 * 
 * 
 * cdef inline npy_timedelta get_timedelta64_value(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the int64 value underlying scalar numpy timedelta64 object
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1073
 * 
 * 
 * cdef inline NPY_DATETIMEUNIT get_datetime64_unit(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the unit part of the dtype for a numpy datetime64 object.
*/

static CYTHON_INLINE NPY_DATETIMEUNIT __pyx_f_5numpy_get_datetime64_unit(PyObject *__pyx_v_obj) {
  NPY_DATETIMEUNIT __pyx_r;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1077
 *     returns the unit part of the dtype for a numpy datetime64 object.
 *     """
 *     return <NPY_DATETIMEUNIT>(<PyDatetimeScalarObject*>obj).obmeta.base             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_r = ((NPY_DATETIMEUNIT)((PyDatetimeScalarObject *)__pyx_v_obj)->obmeta.base);
  goto __pyx_L0;

  /* "../_h_env_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_placehold_plac/lib/python3.11/site-packages/numpy/__init__.cython-30.pxd":1073
 * 
 * 
 * cdef inline NPY_DATETIMEUNIT get_datetime64_unit(object obj) noexcept nogil:             # <<<<<<<<<<<<<<
 *     """
 *     returns the unit part of the dtype for a numpy datetime64 object.
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "cftime/_cftime.pyx":57
 * class real_datetime(datetime_python):
 *     """add dayofwk, dayofyr, daysinmonth attributes to python datetime instance"""
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofwk(self):
 *         # 0=Monday, 6=Sunday
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_1dayofwk(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_13real_datetime_1dayofwk = {"dayofwk", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_13real_datetime_1dayofwk, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_1dayofwk(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_self = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dayofwk (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 57, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 57, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dayofwk", 0) < (0)) __PYX_ERR(0, 57, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dayofwk", 1, 1, 1, i); __PYX_ERR(0, 57, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 57, __pyx_L3_error)
    }
    __pyx_v_self = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dayofwk", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 57, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.real_datetime.dayofwk", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_13real_datetime_dayofwk(__pyx_self, __pyx_v_self);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_dayofwk(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("dayofwk", 0);

  /* "cftime/_cftime.pyx":60
 *     def dayofwk(self):
 *         # 0=Monday, 6=Sunday
 *         return self.weekday()             # <<<<<<<<<<<<<<
 *     @property
 *     def dayofyr(self):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = __pyx_v_self;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_weekday, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 60, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":57
 * class real_datetime(datetime_python):
 *     """add dayofwk, dayofyr, daysinmonth attributes to python datetime instance"""
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofwk(self):
 *         # 0=Monday, 6=Sunday
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.real_datetime.dayofwk", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":61
 *         # 0=Monday, 6=Sunday
 *         return self.weekday()
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_3dayofyr(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_13real_datetime_3dayofyr = {"dayofyr", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_13real_datetime_3dayofyr, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_3dayofyr(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_self = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("dayofyr (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 61, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 61, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "dayofyr", 0) < (0)) __PYX_ERR(0, 61, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("dayofyr", 1, 1, 1, i); __PYX_ERR(0, 61, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 61, __pyx_L3_error)
    }
    __pyx_v_self = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("dayofyr", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 61, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.real_datetime.dayofyr", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_13real_datetime_2dayofyr(__pyx_self, __pyx_v_self);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_2dayofyr(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("dayofyr", 0);

  /* "cftime/_cftime.pyx":63
 *     @property
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday             # <<<<<<<<<<<<<<
 *     @property
 *     def daysinmonth(self):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = __pyx_v_self;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_timetuple, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 63, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_tm_yday); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 63, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":61
 *         # 0=Monday, 6=Sunday
 *         return self.weekday()
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.real_datetime.dayofyr", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":64
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
 *     @property             # <<<<<<<<<<<<<<
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_5daysinmonth(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_13real_datetime_5daysinmonth = {"daysinmonth", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_13real_datetime_5daysinmonth, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_13real_datetime_5daysinmonth(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_self = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("daysinmonth (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_self,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 64, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 64, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "daysinmonth", 0) < (0)) __PYX_ERR(0, 64, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("daysinmonth", 1, 1, 1, i); __PYX_ERR(0, 64, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 64, __pyx_L3_error)
    }
    __pyx_v_self = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("daysinmonth", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 64, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.real_datetime.daysinmonth", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_13real_datetime_4daysinmonth(__pyx_self, __pyx_v_self);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_13real_datetime_4daysinmonth(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  Py_ssize_t __pyx_t_5;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("daysinmonth", 0);

  /* "cftime/_cftime.pyx":66
 *     @property
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):             # <<<<<<<<<<<<<<
 *             return _dayspermonth_leap[self.month-1]
 *         else:
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 66, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 66, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 66, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 66, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":67
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):
 *             return _dayspermonth_leap[self.month-1]             # <<<<<<<<<<<<<<
 *         else:
 *             return _dayspermonth[self.month-1]
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 67, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyLong_SubtractObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 67, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = __Pyx_PyIndex_AsSsize_t(__pyx_t_4); if (unlikely((__pyx_t_5 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(0, 67, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = __Pyx_PyLong_From_int((__pyx_v_6cftime_7_cftime__dayspermonth_leap[__pyx_t_5])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 67, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":66
 *     @property
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):             # <<<<<<<<<<<<<<
 *             return _dayspermonth_leap[self.month-1]
 *         else:
*/
  }

  /* "cftime/_cftime.pyx":69
 *             return _dayspermonth_leap[self.month-1]
 *         else:
 *             return _dayspermonth[self.month-1]             # <<<<<<<<<<<<<<
 *     nanosecond = 0 # workaround for pandas bug (cftime issue #77)
 * 
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 69, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_1 = __Pyx_PyLong_SubtractObjC(__pyx_t_4, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 69, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_5 = __Pyx_PyIndex_AsSsize_t(__pyx_t_1); if (unlikely((__pyx_t_5 == (Py_ssize_t)-1) && PyErr_Occurred())) __PYX_ERR(0, 69, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = __Pyx_PyLong_From_int((__pyx_v_6cftime_7_cftime__dayspermonth[__pyx_t_5])); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 69, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_r = __pyx_t_1;
    __pyx_t_1 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":64
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
 *     @property             # <<<<<<<<<<<<<<
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.real_datetime.daysinmonth", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":72
 *     nanosecond = 0 # workaround for pandas bug (cftime issue #77)
 * 
 * def _datesplit(timestr):             # <<<<<<<<<<<<<<
 *     """split a time string into two components, units and the remainder
 *     after 'since'
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_1_datesplit(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime__datesplit, "split a time string into two components, units and the remainder\n    after 'since'\n    ");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_1_datesplit = {"_datesplit", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_1_datesplit, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime__datesplit};
static PyObject *__pyx_pw_6cftime_7_cftime_1_datesplit(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_timestr = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_datesplit (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_timestr,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 72, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 72, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_datesplit", 0) < (0)) __PYX_ERR(0, 72, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_datesplit", 1, 1, 1, i); __PYX_ERR(0, 72, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 72, __pyx_L3_error)
    }
    __pyx_v_timestr = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_datesplit", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 72, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._datesplit", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime__datesplit(__pyx_self, __pyx_v_timestr);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime__datesplit(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_timestr) {
  PyObject *__pyx_v_units = NULL;
  PyObject *__pyx_v_sincestring = NULL;
  PyObject *__pyx_v_remainder = NULL;
  CYTHON_UNUSED PyObject *__pyx_v_e = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *(*__pyx_t_9)(PyObject *);
  int __pyx_t_10;
  size_t __pyx_t_11;
  int __pyx_t_12;
  char const *__pyx_t_13;
  PyObject *__pyx_t_14 = NULL;
  PyObject *__pyx_t_15 = NULL;
  PyObject *__pyx_t_16 = NULL;
  PyObject *__pyx_t_17 = NULL;
  PyObject *__pyx_t_18 = NULL;
  PyObject *__pyx_t_19 = NULL;
  int __pyx_t_20;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_datesplit", 0);

  /* "cftime/_cftime.pyx":76
 *     after 'since'
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":77
 *     """
 *     try:
 *         (units, sincestring, remainder) = timestr.split(None,2)             # <<<<<<<<<<<<<<
 *     except ValueError as e:
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
*/
      __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_timestr, __pyx_mstate_global->__pyx_n_u_split); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 77, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_5 = __Pyx_PyObject_Call(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[0], NULL); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 77, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 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 != 3)) {
          if (size > 3) __Pyx_RaiseTooManyValuesError(3);
          else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
          __PYX_ERR(0, 77, __pyx_L3_error)
        }
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        if (likely(PyTuple_CheckExact(sequence))) {
          __pyx_t_4 = PyTuple_GET_ITEM(sequence, 0);
          __Pyx_INCREF(__pyx_t_4);
          __pyx_t_6 = PyTuple_GET_ITEM(sequence, 1);
          __Pyx_INCREF(__pyx_t_6);
          __pyx_t_7 = PyTuple_GET_ITEM(sequence, 2);
          __Pyx_INCREF(__pyx_t_7);
        } else {
          __pyx_t_4 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 77, __pyx_L3_error)
          __Pyx_XGOTREF(__pyx_t_4);
          __pyx_t_6 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 77, __pyx_L3_error)
          __Pyx_XGOTREF(__pyx_t_6);
          __pyx_t_7 = __Pyx_PyList_GetItemRefFast(sequence, 2, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 77, __pyx_L3_error)
          __Pyx_XGOTREF(__pyx_t_7);
        }
        #else
        __pyx_t_4 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 77, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_4);
        __pyx_t_6 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 77, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_7 = __Pyx_PySequence_ITEM(sequence, 2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 77, __pyx_L3_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(0, 77, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_8);
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_8);
        index = 0; __pyx_t_4 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_4)) goto __pyx_L9_unpacking_failed;
        __Pyx_GOTREF(__pyx_t_4);
        index = 1; __pyx_t_6 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L9_unpacking_failed;
        __Pyx_GOTREF(__pyx_t_6);
        index = 2; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L9_unpacking_failed;
        __Pyx_GOTREF(__pyx_t_7);
        if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 3) < (0)) __PYX_ERR(0, 77, __pyx_L3_error)
        __pyx_t_9 = NULL;
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        goto __pyx_L10_unpacking_done;
        __pyx_L9_unpacking_failed:;
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __pyx_t_9 = NULL;
        if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
        __PYX_ERR(0, 77, __pyx_L3_error)
        __pyx_L10_unpacking_done:;
      }
      __pyx_v_units = __pyx_t_4;
      __pyx_t_4 = 0;
      __pyx_v_sincestring = __pyx_t_6;
      __pyx_t_6 = 0;
      __pyx_v_remainder = __pyx_t_7;
      __pyx_t_7 = 0;

      /* "cftime/_cftime.pyx":76
 *     after 'since'
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:
*/
    }
    __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_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;

    /* "cftime/_cftime.pyx":78
 *     try:
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:             # <<<<<<<<<<<<<<
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
 * 
*/
    __pyx_t_10 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_ValueError))));
    if (__pyx_t_10) {
      __Pyx_AddTraceback("cftime._cftime._datesplit", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_7, &__pyx_t_6) < 0) __PYX_ERR(0, 78, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __Pyx_XGOTREF(__pyx_t_7);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_7);
      __pyx_v_e = __pyx_t_7;
      /*try:*/ {

        /* "cftime/_cftime.pyx":79
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')             # <<<<<<<<<<<<<<
 * 
 *     if sincestring.lower() != 'since':
*/
        __pyx_t_8 = NULL;
        __pyx_t_11 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_mstate_global->__pyx_kp_u_Incorrectly_formatted_CF_date_ti};
          __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
          if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 79, __pyx_L16_error)
          __Pyx_GOTREF(__pyx_t_4);
        }
        __Pyx_Raise(__pyx_t_4, 0, 0, 0);
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __PYX_ERR(0, 79, __pyx_L16_error)
      }

      /* "cftime/_cftime.pyx":78
 *     try:
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:             # <<<<<<<<<<<<<<
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
 * 
*/
      /*finally:*/ {
        __pyx_L16_error:;
        /*exception exit:*/{
          __Pyx_PyThreadState_declare
          __Pyx_PyThreadState_assign
          __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_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
          __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
           __Pyx_ExceptionSwap(&__pyx_t_17, &__pyx_t_18, &__pyx_t_19);
          if ( unlikely(__Pyx_GetException(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16) < 0)) __Pyx_ErrFetch(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16);
          __Pyx_XGOTREF(__pyx_t_14);
          __Pyx_XGOTREF(__pyx_t_15);
          __Pyx_XGOTREF(__pyx_t_16);
          __Pyx_XGOTREF(__pyx_t_17);
          __Pyx_XGOTREF(__pyx_t_18);
          __Pyx_XGOTREF(__pyx_t_19);
          __pyx_t_10 = __pyx_lineno; __pyx_t_12 = __pyx_clineno; __pyx_t_13 = __pyx_filename;
          {
            __Pyx_DECREF(__pyx_v_e); __pyx_v_e = 0;
          }
          __Pyx_XGIVEREF(__pyx_t_17);
          __Pyx_XGIVEREF(__pyx_t_18);
          __Pyx_XGIVEREF(__pyx_t_19);
          __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19);
          __Pyx_XGIVEREF(__pyx_t_14);
          __Pyx_XGIVEREF(__pyx_t_15);
          __Pyx_XGIVEREF(__pyx_t_16);
          __Pyx_ErrRestore(__pyx_t_14, __pyx_t_15, __pyx_t_16);
          __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_lineno = __pyx_t_10; __pyx_clineno = __pyx_t_12; __pyx_filename = __pyx_t_13;
          goto __pyx_L5_except_error;
        }
      }
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":76
 *     after 'since'
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         (units, sincestring, remainder) = timestr.split(None,2)
 *     except ValueError as e:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "cftime/_cftime.pyx":81
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
 * 
 *     if sincestring.lower() != 'since':             # <<<<<<<<<<<<<<
 *         raise ValueError("no 'since' in unit_string")
 * 
*/
  __pyx_t_7 = __pyx_v_sincestring;
  __Pyx_INCREF(__pyx_t_7);
  __pyx_t_11 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_7, NULL};
    __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_11, (1-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 81, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __pyx_t_20 = (__Pyx_PyUnicode_Equals(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_since, Py_NE)); if (unlikely((__pyx_t_20 < 0))) __PYX_ERR(0, 81, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if (unlikely(__pyx_t_20)) {

    /* "cftime/_cftime.pyx":82
 * 
 *     if sincestring.lower() != 'since':
 *         raise ValueError("no 'since' in unit_string")             # <<<<<<<<<<<<<<
 * 
 *     return units.lower(), remainder
*/
    __pyx_t_7 = NULL;
    __pyx_t_11 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_no_since_in_unit_string};
      __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_11, (2-__pyx_t_11) | (__pyx_t_11*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 82, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
    }
    __Pyx_Raise(__pyx_t_6, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __PYX_ERR(0, 82, __pyx_L1_error)

    /* "cftime/_cftime.pyx":81
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
 * 
 *     if sincestring.lower() != 'since':             # <<<<<<<<<<<<<<
 *         raise ValueError("no 'since' in unit_string")
 * 
*/
  }

  /* "cftime/_cftime.pyx":84
 *         raise ValueError("no 'since' in unit_string")
 * 
 *     return units.lower(), remainder             # <<<<<<<<<<<<<<
 * 
 * def _dateparse(timestr,calendar,has_year_zero=None):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_7 = __pyx_v_units;
  __Pyx_INCREF(__pyx_t_7);
  __pyx_t_11 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_7, NULL};
    __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_11, (1-__pyx_t_11) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 84, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __pyx_t_7 = PyTuple_New(2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 84, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_7, 0, __pyx_t_6) != (0)) __PYX_ERR(0, 84, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_remainder);
  __Pyx_GIVEREF(__pyx_v_remainder);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_7, 1, __pyx_v_remainder) != (0)) __PYX_ERR(0, 84, __pyx_L1_error);
  __pyx_t_6 = 0;
  __pyx_r = __pyx_t_7;
  __pyx_t_7 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":72
 *     nanosecond = 0 # workaround for pandas bug (cftime issue #77)
 * 
 * def _datesplit(timestr):             # <<<<<<<<<<<<<<
 *     """split a time string into two components, units and the remainder
 *     after 'since'
*/

  /* 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_AddTraceback("cftime._cftime._datesplit", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_units);
  __Pyx_XDECREF(__pyx_v_sincestring);
  __Pyx_XDECREF(__pyx_v_remainder);
  __Pyx_XDECREF(__pyx_v_e);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":86
 *     return units.lower(), remainder
 * 
 * def _dateparse(timestr,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """parse a string of the form time-units since yyyy-mm-dd hh:mm:ss,
 *     return a datetime instance"""
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_3_dateparse(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_2_dateparse, "parse a string of the form time-units since yyyy-mm-dd hh:mm:ss,\n    return a datetime instance");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_3_dateparse = {"_dateparse", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_3_dateparse, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_2_dateparse};
static PyObject *__pyx_pw_6cftime_7_cftime_3_dateparse(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_timestr = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[3] = {0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_dateparse (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_timestr,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 86, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 86, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 86, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 86, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_dateparse", 0) < (0)) __PYX_ERR(0, 86, __pyx_L3_error)
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_dateparse", 0, 2, 3, i); __PYX_ERR(0, 86, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 86, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 86, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 86, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_timestr = values[0];
    __pyx_v_calendar = values[1];
    __pyx_v_has_year_zero = values[2];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_dateparse", 0, 2, 3, __pyx_nargs); __PYX_ERR(0, 86, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._dateparse", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_2_dateparse(__pyx_self, __pyx_v_timestr, __pyx_v_calendar, __pyx_v_has_year_zero);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_2_dateparse(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_timestr, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_units = NULL;
  PyObject *__pyx_v_isostring = NULL;
  PyObject *__pyx_v_year = NULL;
  PyObject *__pyx_v_month = NULL;
  PyObject *__pyx_v_day = NULL;
  PyObject *__pyx_v_hour = NULL;
  PyObject *__pyx_v_minute = NULL;
  PyObject *__pyx_v_second = NULL;
  PyObject *__pyx_v_microsecond = NULL;
  PyObject *__pyx_v_utc_offset = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_v_basedate = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *(*__pyx_t_7)(PyObject *);
  int __pyx_t_8;
  int __pyx_t_9;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  PyObject *__pyx_t_13 = NULL;
  PyObject *__pyx_t_14 = NULL;
  PyObject *__pyx_t_15 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_dateparse", 0);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":92
 *     # python datetime instance with the utc_offset included.
 * 
 *     calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
*/
  __pyx_t_2 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 92, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":94
 *     calendar = calendar.lower()
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     (units, isostring) = _datesplit(timestr)
*/
  __pyx_t_4 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":95
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *     (units, isostring) = _datesplit(timestr)
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):
*/
    __pyx_t_1 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 95, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_1);
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":94
 *     calendar = calendar.lower()
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     (units, isostring) = _datesplit(timestr)
*/
  }

  /* "cftime/_cftime.pyx":96
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     (units, isostring) = _datesplit(timestr)             # <<<<<<<<<<<<<<
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):
 *         if units in month_units and calendar != '360_day':
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_datesplit); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 96, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_timestr};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 96, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  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(0, 96, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 0);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_t_2 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_2);
    } else {
      __pyx_t_5 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 96, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __pyx_t_2 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 96, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_2);
    }
    #else
    __pyx_t_5 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 96, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_2 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 96, __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_6 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 96, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_7 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6);
    index = 0; __pyx_t_5 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_5)) goto __pyx_L4_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_5);
    index = 1; __pyx_t_2 = __pyx_t_7(__pyx_t_6); if (unlikely(!__pyx_t_2)) goto __pyx_L4_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_2);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_7(__pyx_t_6), 2) < (0)) __PYX_ERR(0, 96, __pyx_L1_error)
    __pyx_t_7 = NULL;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L5_unpacking_done;
    __pyx_L4_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_7 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(0, 96, __pyx_L1_error)
    __pyx_L5_unpacking_done:;
  }
  __pyx_v_units = __pyx_t_5;
  __pyx_t_5 = 0;
  __pyx_v_isostring = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":97
 *         has_year_zero = _year_zero_defaults(calendar)
 *     (units, isostring) = _datesplit(timestr)
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):             # <<<<<<<<<<<<<<
 *         if units in month_units and calendar != '360_day':
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
*/
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_month_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_8 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (!__pyx_t_8) {
    goto __pyx_L8_next_or;
  } else {
  }
  __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  if (!__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L7_bool_binop_done;
  }
  __pyx_L8_next_or:;
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_year_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_8 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (!__pyx_t_8) {
    goto __pyx_L10_next_or;
  } else {
  }
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_1 = __pyx_v_calendar;
  __pyx_t_9 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_kp_u_365_day, Py_EQ)); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  if (!__pyx_t_9) {
  } else {
    __pyx_t_8 = __pyx_t_9;
    goto __pyx_L12_bool_binop_done;
  }
  __pyx_t_9 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  __pyx_t_8 = __pyx_t_9;
  __pyx_L12_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_9 = __pyx_t_8;
  if (!__pyx_t_9) {
  } else {
    __pyx_t_4 = __pyx_t_9;
    goto __pyx_L7_bool_binop_done;
  }
  __pyx_L10_next_or:;
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_9 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_EQ)); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 97, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __pyx_t_9;
  __pyx_L7_bool_binop_done:;
  __pyx_t_9 = (!__pyx_t_4);
  if (__pyx_t_9) {

    /* "cftime/_cftime.pyx":98
 *     (units, isostring) = _datesplit(timestr)
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):
 *         if units in month_units and calendar != '360_day':             # <<<<<<<<<<<<<<
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:
*/
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_month_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 98, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 98, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (__pyx_t_4) {
    } else {
      __pyx_t_9 = __pyx_t_4;
      goto __pyx_L15_bool_binop_done;
    }
    __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_NE)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 98, __pyx_L1_error)
    __pyx_t_9 = __pyx_t_4;
    __pyx_L15_bool_binop_done:;
    if (unlikely(__pyx_t_9)) {

      /* "cftime/_cftime.pyx":99
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):
 *         if units in month_units and calendar != '360_day':
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")             # <<<<<<<<<<<<<<
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:
 *             raise ValueError("'%s' units only allowed for '365_day' and 'noleap' calendars" % units)
*/
      __pyx_t_2 = NULL;
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_months_since_units_only_allowed};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 99, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 99, __pyx_L1_error)

      /* "cftime/_cftime.pyx":98
 *     (units, isostring) = _datesplit(timestr)
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):
 *         if units in month_units and calendar != '360_day':             # <<<<<<<<<<<<<<
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:
*/
    }

    /* "cftime/_cftime.pyx":100
 *         if units in month_units and calendar != '360_day':
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:             # <<<<<<<<<<<<<<
 *             raise ValueError("'%s' units only allowed for '365_day' and 'noleap' calendars" % units)
 *         else:
*/
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_year_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 100, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 100, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (__pyx_t_4) {
    } else {
      __pyx_t_9 = __pyx_t_4;
      goto __pyx_L18_bool_binop_done;
    }
    __Pyx_INCREF(__pyx_v_calendar);
    __pyx_t_1 = __pyx_v_calendar;
    __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_kp_u_365_day, Py_NE)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 100, __pyx_L1_error)
    if (__pyx_t_8) {
    } else {
      __pyx_t_4 = __pyx_t_8;
      goto __pyx_L20_bool_binop_done;
    }
    __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_noleap, Py_NE)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 100, __pyx_L1_error)
    __pyx_t_4 = __pyx_t_8;
    __pyx_L20_bool_binop_done:;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_8 = __pyx_t_4;
    __pyx_t_9 = __pyx_t_8;
    __pyx_L18_bool_binop_done:;
    if (unlikely(__pyx_t_9)) {

      /* "cftime/_cftime.pyx":101
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:
 *             raise ValueError("'%s' units only allowed for '365_day' and 'noleap' calendars" % units)             # <<<<<<<<<<<<<<
 *         else:
 *             raise ValueError(
*/
      __pyx_t_2 = NULL;
      __pyx_t_5 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_s_units_only_allowed_for_365_da, __pyx_v_units); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 101, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_5};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 101, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 101, __pyx_L1_error)

      /* "cftime/_cftime.pyx":100
 *         if units in month_units and calendar != '360_day':
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
 *         if units in year_units and calendar not in {'365_day', 'noleap'}:             # <<<<<<<<<<<<<<
 *             raise ValueError("'%s' units only allowed for '365_day' and 'noleap' calendars" % units)
 *         else:
*/
    }

    /* "cftime/_cftime.pyx":103
 *             raise ValueError("'%s' units only allowed for '365_day' and 'noleap' calendars" % units)
 *         else:
 *             raise ValueError(             # <<<<<<<<<<<<<<
 *             "In general, units must be one of 'microseconds', 'milliseconds', "
 *             "'seconds', 'minutes', 'hours', or 'days' (or select abbreviated "
*/
    /*else*/ {
      __pyx_t_5 = NULL;

      /* "cftime/_cftime.pyx":108
 *             "versions of these).  For the '360_day' calendar, "
 *             "'months' can also be used, or for the 'noleap' calendar 'common_years' "
 *             "can also be used. Got '%s' instead, which are not recognized." % units)             # <<<<<<<<<<<<<<
 *     # parse the date string.
 *     year, month, day, hour, minute, second, microsecond, utc_offset =\
*/
      __pyx_t_2 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_In_general_units_must_be_one_of, __pyx_v_units); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 108, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_2};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 103, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 103, __pyx_L1_error)
    }

    /* "cftime/_cftime.pyx":97
 *         has_year_zero = _year_zero_defaults(calendar)
 *     (units, isostring) = _datesplit(timestr)
 *     if not ((units in month_units and calendar=='360_day') or (units in year_units and calendar in {'365_day', 'noleap'}) or units in _units):             # <<<<<<<<<<<<<<
 *         if units in month_units and calendar != '360_day':
 *             raise ValueError("'months since' units only allowed for '360_day' calendar")
*/
  }

  /* "cftime/_cftime.pyx":111
 *     # parse the date string.
 *     year, month, day, hour, minute, second, microsecond, utc_offset =\
 *         _parse_date( isostring.strip() )             # <<<<<<<<<<<<<<
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:
 *         msg='zero not allowed as a reference year when has_year_zero=False'
*/
  __pyx_t_2 = __pyx_v_isostring;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_strip, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 111, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__parse_date(__pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 111, __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 != 8)) {
      if (size > 8) __Pyx_RaiseTooManyValuesError(8);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(0, 110, __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_INCREF(__pyx_t_1);
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_t_6 = PyTuple_GET_ITEM(sequence, 2);
      __Pyx_INCREF(__pyx_t_6);
      __pyx_t_10 = PyTuple_GET_ITEM(sequence, 3);
      __Pyx_INCREF(__pyx_t_10);
      __pyx_t_11 = PyTuple_GET_ITEM(sequence, 4);
      __Pyx_INCREF(__pyx_t_11);
      __pyx_t_12 = PyTuple_GET_ITEM(sequence, 5);
      __Pyx_INCREF(__pyx_t_12);
      __pyx_t_13 = PyTuple_GET_ITEM(sequence, 6);
      __Pyx_INCREF(__pyx_t_13);
      __pyx_t_14 = PyTuple_GET_ITEM(sequence, 7);
      __Pyx_INCREF(__pyx_t_14);
    } else {
      __pyx_t_1 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_1);
      __pyx_t_5 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __pyx_t_6 = __Pyx_PyList_GetItemRefFast(sequence, 2, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_6);
      __pyx_t_10 = __Pyx_PyList_GetItemRefFast(sequence, 3, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_10);
      __pyx_t_11 = __Pyx_PyList_GetItemRefFast(sequence, 4, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_11);
      __pyx_t_12 = __Pyx_PyList_GetItemRefFast(sequence, 5, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_12);
      __pyx_t_13 = __Pyx_PyList_GetItemRefFast(sequence, 6, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_13);
      __pyx_t_14 = __Pyx_PyList_GetItemRefFast(sequence, 7, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 110, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_14);
    }
    #else
    {
      Py_ssize_t i;
      PyObject** temps[8] = {&__pyx_t_1,&__pyx_t_5,&__pyx_t_6,&__pyx_t_10,&__pyx_t_11,&__pyx_t_12,&__pyx_t_13,&__pyx_t_14};
      for (i=0; i < 8; i++) {
        PyObject* item = __Pyx_PySequence_ITEM(sequence, i); if (unlikely(!item)) __PYX_ERR(0, 110, __pyx_L1_error)
        __Pyx_GOTREF(item);
        *(temps[i]) = item;
      }
    }
    #endif
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    Py_ssize_t index = -1;
    PyObject** temps[8] = {&__pyx_t_1,&__pyx_t_5,&__pyx_t_6,&__pyx_t_10,&__pyx_t_11,&__pyx_t_12,&__pyx_t_13,&__pyx_t_14};
    __pyx_t_15 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 110, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_15);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_7 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_15);
    for (index=0; index < 8; index++) {
      PyObject* item = __pyx_t_7(__pyx_t_15); if (unlikely(!item)) goto __pyx_L22_unpacking_failed;
      __Pyx_GOTREF(item);
      *(temps[index]) = item;
    }
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_7(__pyx_t_15), 8) < (0)) __PYX_ERR(0, 110, __pyx_L1_error)
    __pyx_t_7 = NULL;
    __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
    goto __pyx_L23_unpacking_done;
    __pyx_L22_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
    __pyx_t_7 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(0, 110, __pyx_L1_error)
    __pyx_L23_unpacking_done:;
  }

  /* "cftime/_cftime.pyx":110
 *             "can also be used. Got '%s' instead, which are not recognized." % units)
 *     # parse the date string.
 *     year, month, day, hour, minute, second, microsecond, utc_offset =\             # <<<<<<<<<<<<<<
 *         _parse_date( isostring.strip() )
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:
*/
  __pyx_v_year = __pyx_t_1;
  __pyx_t_1 = 0;
  __pyx_v_month = __pyx_t_5;
  __pyx_t_5 = 0;
  __pyx_v_day = __pyx_t_6;
  __pyx_t_6 = 0;
  __pyx_v_hour = __pyx_t_10;
  __pyx_t_10 = 0;
  __pyx_v_minute = __pyx_t_11;
  __pyx_t_11 = 0;
  __pyx_v_second = __pyx_t_12;
  __pyx_t_12 = 0;
  __pyx_v_microsecond = __pyx_t_13;
  __pyx_t_13 = 0;
  __pyx_v_utc_offset = __pyx_t_14;
  __pyx_t_14 = 0;

  /* "cftime/_cftime.pyx":112
 *     year, month, day, hour, minute, second, microsecond, utc_offset =\
 *         _parse_date( isostring.strip() )
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:             # <<<<<<<<<<<<<<
 *         msg='zero not allowed as a reference year when has_year_zero=False'
 *         raise ValueError(msg)
*/
  __pyx_t_8 = (__Pyx_PyLong_BoolEqObjC(__pyx_v_year, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  if (__pyx_t_8) {
  } else {
    __pyx_t_9 = __pyx_t_8;
    goto __pyx_L25_bool_binop_done;
  }
  __pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  __pyx_t_4 = (!__pyx_t_8);
  if (__pyx_t_4) {
  } else {
    __pyx_t_9 = __pyx_t_4;
    goto __pyx_L25_bool_binop_done;
  }
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  if (!__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L28_bool_binop_done;
  }
  __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  if (!__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L28_bool_binop_done;
  }
  __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  if (!__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L28_bool_binop_done;
  }
  __pyx_t_8 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 112, __pyx_L1_error)
  __pyx_t_4 = __pyx_t_8;
  __pyx_L28_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_8 = __pyx_t_4;
  __pyx_t_9 = __pyx_t_8;
  __pyx_L25_bool_binop_done:;
  if (unlikely(__pyx_t_9)) {

    /* "cftime/_cftime.pyx":113
 *         _parse_date( isostring.strip() )
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:
 *         msg='zero not allowed as a reference year when has_year_zero=False'             # <<<<<<<<<<<<<<
 *         raise ValueError(msg)
 *     if calendar in ['noleap', '365_day'] and month == 2 and day == 29:
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference);
    __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference;

    /* "cftime/_cftime.pyx":114
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:
 *         msg='zero not allowed as a reference year when has_year_zero=False'
 *         raise ValueError(msg)             # <<<<<<<<<<<<<<
 *     if calendar in ['noleap', '365_day'] and month == 2 and day == 29:
 *         raise ValueError(
*/
    __pyx_t_14 = NULL;
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_v_msg};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 114, __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(0, 114, __pyx_L1_error)

    /* "cftime/_cftime.pyx":112
 *     year, month, day, hour, minute, second, microsecond, utc_offset =\
 *         _parse_date( isostring.strip() )
 *     if year == 0 and not has_year_zero and calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian']:             # <<<<<<<<<<<<<<
 *         msg='zero not allowed as a reference year when has_year_zero=False'
 *         raise ValueError(msg)
*/
  }

  /* "cftime/_cftime.pyx":115
 *         msg='zero not allowed as a reference year when has_year_zero=False'
 *         raise ValueError(msg)
 *     if calendar in ['noleap', '365_day'] and month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *         raise ValueError(
 *             'cannot specify a leap day as the reference time with the noleap calendar')
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 115, __pyx_L1_error)
  if (!__pyx_t_4) {
  } else {
    __pyx_t_8 = __pyx_t_4;
    goto __pyx_L35_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_365_day, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 115, __pyx_L1_error)
  __pyx_t_8 = __pyx_t_4;
  __pyx_L35_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_4 = __pyx_t_8;
  if (__pyx_t_4) {
  } else {
    __pyx_t_9 = __pyx_t_4;
    goto __pyx_L33_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyLong_BoolEqObjC(__pyx_v_month, __pyx_mstate_global->__pyx_int_2, 2, 0)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 115, __pyx_L1_error)
  if (__pyx_t_4) {
  } else {
    __pyx_t_9 = __pyx_t_4;
    goto __pyx_L33_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyLong_BoolEqObjC(__pyx_v_day, __pyx_mstate_global->__pyx_int_29, 29, 0)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 115, __pyx_L1_error)
  __pyx_t_9 = __pyx_t_4;
  __pyx_L33_bool_binop_done:;
  if (unlikely(__pyx_t_9)) {

    /* "cftime/_cftime.pyx":116
 *         raise ValueError(msg)
 *     if calendar in ['noleap', '365_day'] and month == 2 and day == 29:
 *         raise ValueError(             # <<<<<<<<<<<<<<
 *             'cannot specify a leap day as the reference time with the noleap calendar')
 *     if calendar == '360_day' and day > 30:
*/
    __pyx_t_14 = NULL;
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_mstate_global->__pyx_kp_u_cannot_specify_a_leap_day_as_the};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 116, __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(0, 116, __pyx_L1_error)

    /* "cftime/_cftime.pyx":115
 *         msg='zero not allowed as a reference year when has_year_zero=False'
 *         raise ValueError(msg)
 *     if calendar in ['noleap', '365_day'] and month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *         raise ValueError(
 *             'cannot specify a leap day as the reference time with the noleap calendar')
*/
  }

  /* "cftime/_cftime.pyx":118
 *         raise ValueError(
 *             'cannot specify a leap day as the reference time with the noleap calendar')
 *     if calendar == '360_day' and day > 30:             # <<<<<<<<<<<<<<
 *         raise ValueError(
 *             'there are only 30 days in every month with the 360_day calendar')
*/
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 118, __pyx_L1_error)
  if (__pyx_t_4) {
  } else {
    __pyx_t_9 = __pyx_t_4;
    goto __pyx_L39_bool_binop_done;
  }
  __pyx_t_2 = PyObject_RichCompare(__pyx_v_day, __pyx_mstate_global->__pyx_int_30, Py_GT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 118, __pyx_L1_error)
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 118, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_9 = __pyx_t_4;
  __pyx_L39_bool_binop_done:;
  if (unlikely(__pyx_t_9)) {

    /* "cftime/_cftime.pyx":119
 *             'cannot specify a leap day as the reference time with the noleap calendar')
 *     if calendar == '360_day' and day > 30:
 *         raise ValueError(             # <<<<<<<<<<<<<<
 *             'there are only 30 days in every month with the 360_day calendar')
 *     basedate = datetime(year, month, day, hour, minute, second,
*/
    __pyx_t_14 = NULL;
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_mstate_global->__pyx_kp_u_there_are_only_30_days_in_every};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 119, __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(0, 119, __pyx_L1_error)

    /* "cftime/_cftime.pyx":118
 *         raise ValueError(
 *             'cannot specify a leap day as the reference time with the noleap calendar')
 *     if calendar == '360_day' and day > 30:             # <<<<<<<<<<<<<<
 *         raise ValueError(
 *             'there are only 30 days in every month with the 360_day calendar')
*/
  }

  /* "cftime/_cftime.pyx":121
 *         raise ValueError(
 *             'there are only 30 days in every month with the 360_day calendar')
 *     basedate = datetime(year, month, day, hour, minute, second,             # <<<<<<<<<<<<<<
 *                         microsecond,calendar=calendar,has_year_zero=has_year_zero)
 *     # subtract utc_offset from basedate time instance (which is timezone naive)
*/
  __pyx_t_14 = NULL;

  /* "cftime/_cftime.pyx":122
 *             'there are only 30 days in every month with the 360_day calendar')
 *     basedate = datetime(year, month, day, hour, minute, second,
 *                         microsecond,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     # subtract utc_offset from basedate time instance (which is timezone naive)
 *     if utc_offset:
*/
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[8 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_14, __pyx_v_year, __pyx_v_month, __pyx_v_day, __pyx_v_hour, __pyx_v_minute, __pyx_v_second, __pyx_v_microsecond};
    __pyx_t_13 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 121, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_13);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_13, __pyx_callargs+8, 0) < (0)) __PYX_ERR(0, 121, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_13, __pyx_callargs+8, 1) < (0)) __PYX_ERR(0, 121, __pyx_L1_error)
    __pyx_t_2 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_callargs+__pyx_t_3, (8-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_13);
    __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 121, __pyx_L1_error)
    __Pyx_GOTREF((PyObject *)__pyx_t_2);
  }
  __pyx_v_basedate = ((PyObject *)__pyx_t_2);
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":124
 *                         microsecond,calendar=calendar,has_year_zero=has_year_zero)
 *     # subtract utc_offset from basedate time instance (which is timezone naive)
 *     if utc_offset:             # <<<<<<<<<<<<<<
 *         basedate -= timedelta(days=utc_offset/1440.)
 *     return basedate
*/
  __pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_v_utc_offset); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 124, __pyx_L1_error)
  if (__pyx_t_9) {

    /* "cftime/_cftime.pyx":125
 *     # subtract utc_offset from basedate time instance (which is timezone naive)
 *     if utc_offset:
 *         basedate -= timedelta(days=utc_offset/1440.)             # <<<<<<<<<<<<<<
 *     return basedate
 * 
*/
    __pyx_t_13 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 125, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    __pyx_t_12 = __Pyx_PyFloat_TrueDivideObjC(__pyx_v_utc_offset, __pyx_mstate_global->__pyx_float_1440_, 1440., 0, 0); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 125, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_3 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_14))) {
      __pyx_t_13 = PyMethod_GET_SELF(__pyx_t_14);
      assert(__pyx_t_13);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14);
      __Pyx_INCREF(__pyx_t_13);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_14, __pyx__function);
      __pyx_t_3 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_13, NULL};
      __pyx_t_11 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 125, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_days, __pyx_t_12, __pyx_t_11, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 125, __pyx_L1_error)
      __pyx_t_2 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_14, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_11);
      __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 125, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_14 = PyNumber_InPlaceSubtract(__pyx_v_basedate, __pyx_t_2); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 125, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF_SET(__pyx_v_basedate, __pyx_t_14);
    __pyx_t_14 = 0;

    /* "cftime/_cftime.pyx":124
 *                         microsecond,calendar=calendar,has_year_zero=has_year_zero)
 *     # subtract utc_offset from basedate time instance (which is timezone naive)
 *     if utc_offset:             # <<<<<<<<<<<<<<
 *         basedate -= timedelta(days=utc_offset/1440.)
 *     return basedate
*/
  }

  /* "cftime/_cftime.pyx":126
 *     if utc_offset:
 *         basedate -= timedelta(days=utc_offset/1440.)
 *     return basedate             # <<<<<<<<<<<<<<
 * 
 * def _can_use_python_datetime(date,calendar):
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_basedate);
  __pyx_r = __pyx_v_basedate;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":86
 *     return units.lower(), remainder
 * 
 * def _dateparse(timestr,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """parse a string of the form time-units since yyyy-mm-dd hh:mm:ss,
 *     return a datetime instance"""
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __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_XDECREF(__pyx_t_15);
  __Pyx_AddTraceback("cftime._cftime._dateparse", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_units);
  __Pyx_XDECREF(__pyx_v_isostring);
  __Pyx_XDECREF(__pyx_v_year);
  __Pyx_XDECREF(__pyx_v_month);
  __Pyx_XDECREF(__pyx_v_day);
  __Pyx_XDECREF(__pyx_v_hour);
  __Pyx_XDECREF(__pyx_v_minute);
  __Pyx_XDECREF(__pyx_v_second);
  __Pyx_XDECREF(__pyx_v_microsecond);
  __Pyx_XDECREF(__pyx_v_utc_offset);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_basedate);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":128
 *     return basedate
 * 
 * def _can_use_python_datetime(date,calendar):             # <<<<<<<<<<<<<<
 *     #gregorian = datetime(1582,10,15,calendar=calendar,has_year_zero=date.has_year_zero)
 *     #return ((calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_5_can_use_python_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_5_can_use_python_datetime = {"_can_use_python_datetime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_5_can_use_python_datetime, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_5_can_use_python_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_date = 0;
  PyObject *__pyx_v_calendar = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_can_use_python_datetime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_date,&__pyx_mstate_global->__pyx_n_u_calendar,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 128, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 128, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 128, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_can_use_python_datetime", 0) < (0)) __PYX_ERR(0, 128, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_can_use_python_datetime", 1, 2, 2, i); __PYX_ERR(0, 128, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 2)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 128, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 128, __pyx_L3_error)
    }
    __pyx_v_date = values[0];
    __pyx_v_calendar = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_can_use_python_datetime", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 128, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._can_use_python_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_4_can_use_python_datetime(__pyx_self, __pyx_v_date, __pyx_v_calendar);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_4_can_use_python_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_date, PyObject *__pyx_v_calendar) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  int __pyx_t_6;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_can_use_python_datetime", 0);

  /* "cftime/_cftime.pyx":132
 *     #return ((calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
 *     #       (calendar in ['gregorian','standard'] and date > gregorian and date.year <= MAXYEAR))
 *     return  (calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \             # <<<<<<<<<<<<<<
 *             ((calendar in ['gregorian','standard'] and date.year <= MAXYEAR) and (date.year > 1582 or \
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = PyObject_RichCompare(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 132, __pyx_L1_error)
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (!__pyx_t_3) {
    goto __pyx_L4_next_or;
  } else {
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_MINYEAR); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyObject_RichCompare(__pyx_t_2, __pyx_t_4, Py_GE); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (!__pyx_t_3) {
    goto __pyx_L4_next_or;
  } else {
  }
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_MAXYEAR); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = PyObject_RichCompare(__pyx_t_5, __pyx_t_4, Py_LE); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 132, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 132, __pyx_L1_error)
  if (!__pyx_t_3) {
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_2);
    __pyx_t_1 = __pyx_t_2;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    goto __pyx_L3_bool_binop_done;
  }
  __pyx_L4_next_or:;

  /* "cftime/_cftime.pyx":133
 *     #       (calendar in ['gregorian','standard'] and date > gregorian and date.year <= MAXYEAR))
 *     return  (calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
 *             ((calendar in ['gregorian','standard'] and date.year <= MAXYEAR) and (date.year > 1582 or \             # <<<<<<<<<<<<<<
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 133, __pyx_L1_error)
  if (!__pyx_t_6) {
  } else {
    __pyx_t_3 = __pyx_t_6;
    goto __pyx_L9_bool_binop_done;
  }
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 133, __pyx_L1_error)
  __pyx_t_3 = __pyx_t_6;
  __pyx_L9_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6 = __pyx_t_3;
  if (__pyx_t_6) {
  } else {
    __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 133, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L3_bool_binop_done;
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_MAXYEAR); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyObject_RichCompare(__pyx_t_2, __pyx_t_4, Py_LE); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 133, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 133, __pyx_L1_error)
  if (__pyx_t_6) {
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_1 = __pyx_t_5;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L3_bool_binop_done;
  }
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = PyObject_RichCompare(__pyx_t_5, __pyx_mstate_global->__pyx_int_1582, Py_GT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 133, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 133, __pyx_L1_error)
  if (!__pyx_t_6) {
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_1 = __pyx_t_4;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L3_bool_binop_done;
  }

  /* "cftime/_cftime.pyx":134
 *     return  (calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
 *             ((calendar in ['gregorian','standard'] and date.year <= MAXYEAR) and (date.year > 1582 or \
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyLong_EqObjC(__pyx_t_4, __pyx_mstate_global->__pyx_int_1582, 0x62E, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 134, __pyx_L1_error)
  if (__pyx_t_6) {
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_1 = __pyx_t_5;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    goto __pyx_L3_bool_binop_done;
  }
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = PyObject_RichCompare(__pyx_t_5, __pyx_mstate_global->__pyx_int_10, Py_GE); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 134, __pyx_L1_error)
  if (__pyx_t_6) {
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_1 = __pyx_t_4;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L3_bool_binop_done;
  }
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = PyObject_RichCompare(__pyx_t_4, __pyx_mstate_global->__pyx_int_15, Py_GT); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 134, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_INCREF(__pyx_t_5);
  __pyx_t_1 = __pyx_t_5;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_L3_bool_binop_done:;
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":128
 *     return basedate
 * 
 * def _can_use_python_datetime(date,calendar):             # <<<<<<<<<<<<<<
 *     #gregorian = datetime(1582,10,15,calendar=calendar,has_year_zero=date.has_year_zero)
 *     #return ((calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("cftime._cftime._can_use_python_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":136
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):
 *     """
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_7date2num(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_6date2num, "date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False)\n\nReturn numeric time values given datetime objects. The units\nof the numeric time values are described by the **units** argument\nand the **calendar** keyword. The datetime objects must\nbe in UTC with no time-zone offset.  If there is a\ntime-zone offset in **units**, it will be applied to the\nreturned numeric values.\n\n**dates**: A datetime object or a sequence of datetime objects.\nThe datetime objects should not include a time-zone offset. They\ncan be either native python datetime instances (which use\nthe proleptic gregorian calendar) or cftime.datetime instances.\n\n**units**: a string of the form **<time units> since <reference time>**\ndescribing the time units. **<time units>** can be days, hours, minutes,\nseconds, milliseconds or microseconds. **<reference time>** is the time\norigin. **months since** is allowed *only* for the **360_day** calendar\nand **common_years since** is allowed *only* for the **365_day** calendar.\n\n**calendar**: describes the calendar to be used in the time calculations.\nAll the values currently defined in the\n`CF metadata convention <http://cfconventions.org/cf-conventions/cf-conventions#calendar>`__ are supported.\nValid calendars **'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'**.\nDefault is `None` which means the calendar associated with the first\ninput datetime instance will be used.\n\n**has_year_zero**: If set to True, astronomical year numbering\nis used and the year zero exists.  If set to False for real-world\ncalendars, then historical year numbering is used and the year 1 is\npreceded by year -1 and no year zero exists.\nThe defaults are set to conform with\nCF version 1.9 conventions (False for 'julian', 'gregorian'/'standard', True\nfor 'proleptic_gregorian' (ISO 8601) and True for the idealized\ncalendars 'noleap'/'365_day', '360_day', 366_day'/'all_leap')\nNote tha""t CF v1.9 does not specifically mention whether year zero\nis allowed in the proleptic_gregorian calendar, but ISO-8601 has\na year zero so we have adopted this as the default.\nThe defaults can only be over-ridden for the real-world calendars,\nfor the the idealized calendars the year zero \nalways exists and the has_year_zero kwarg is ignored.\nThis kwarg is not needed to define calendar systems allowed by CF\n(the calendar-specific defaults do this).\n\n**longdouble**: If set True, output is in the long double float type\n(numpy.float128) instead of float (numpy.float64), allowing microsecond\naccuracy when converting a time value to a date and back again. Otherwise\nthis is only possible if the discretization of the time variable is an\ninteger multiple of the units.\n\nreturns a numeric time value, or an array of numeric time values\nwith approximately 1 microsecond accuracy.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_7date2num = {"date2num", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_7date2num, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_6date2num};
static PyObject *__pyx_pw_6cftime_7_cftime_7date2num(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_dates = 0;
  PyObject *__pyx_v_units = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  PyObject *__pyx_v_longdouble = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[5] = {0,0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("date2num (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_dates,&__pyx_mstate_global->__pyx_n_u_units_2,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,&__pyx_mstate_global->__pyx_n_u_longdouble,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 136, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "date2num", 0) < (0)) __PYX_ERR(0, 136, __pyx_L3_error)

      /* "cftime/_cftime.pyx":137
 * 
 * @cython.embedsignature(True)
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):             # <<<<<<<<<<<<<<
 *     """
 *     Return numeric time values given datetime objects. The units
*/
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_False)));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("date2num", 0, 2, 5, i); __PYX_ERR(0, 136, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 136, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 136, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 136, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_False)));
    }
    __pyx_v_dates = values[0];
    __pyx_v_units = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_has_year_zero = values[3];
    __pyx_v_longdouble = values[4];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("date2num", 0, 2, 5, __pyx_nargs); __PYX_ERR(0, 136, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.date2num", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_6date2num(__pyx_self, __pyx_v_dates, __pyx_v_units, __pyx_v_calendar, __pyx_v_has_year_zero, __pyx_v_longdouble);

  /* "cftime/_cftime.pyx":136
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):
 *     """
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_6date2num(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero, PyObject *__pyx_v_longdouble) {
  int __pyx_v_isscalar;
  int __pyx_v_ismasked;
  PyObject *__pyx_v_mask = NULL;
  PyObject *__pyx_v_shape = NULL;
  int __pyx_v_all_python_datetimes;
  PyObject *__pyx_v_date = NULL;
  PyObject *__pyx_v_d0 = NULL;
  PyObject *__pyx_v_basedate = NULL;
  PyObject *__pyx_v_unit = NULL;
  CYTHON_UNUSED PyObject *__pyx_v_isostring = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_v_unit_timedelta = NULL;
  PyObject *__pyx_v_can_use_python_basedatetime = NULL;
  int __pyx_v_use_python_datetime;
  PyObject *__pyx_v_times = NULL;
  PyObject *__pyx_v_n = NULL;
  PyObject *__pyx_v_td = NULL;
  PyObject *__pyx_v_quotient = NULL;
  PyObject *__pyx_v_mtd = NULL;
  PyObject *__pyx_v_munit = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  int __pyx_t_7;
  int __pyx_t_8;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  size_t __pyx_t_13;
  PyObject *__pyx_t_14 = NULL;
  Py_ssize_t __pyx_t_15;
  PyObject *(*__pyx_t_16)(PyObject *);
  int __pyx_t_17;
  PyObject *(*__pyx_t_18)(PyObject *);
  int __pyx_t_19;
  PyObject *__pyx_t_20 = NULL;
  PyObject *__pyx_t_21 = NULL;
  int __pyx_t_22;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("date2num", 0);
  __Pyx_INCREF(__pyx_v_dates);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":193
 * 
 *     # input a scale or array-like?
 *     isscalar = False             # <<<<<<<<<<<<<<
 *     try:
 *         dates[0]
*/
  __pyx_v_isscalar = 0;

  /* "cftime/_cftime.pyx":194
 *     # input a scale or array-like?
 *     isscalar = False
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0]
 *     except:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":195
 *     isscalar = False
 *     try:
 *         dates[0]             # <<<<<<<<<<<<<<
 *     except:
 *         if not dates:
*/
      __pyx_t_4 = __Pyx_GetItemInt(__pyx_v_dates, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_FunctionArgument); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 195, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":194
 *     # input a scale or array-like?
 *     isscalar = False
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0]
 *     except:
*/
    }
    __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;

    /* "cftime/_cftime.pyx":196
 *     try:
 *         dates[0]
 *     except:             # <<<<<<<<<<<<<<
 *         if not dates:
 *             # if empty list or array input, return empty array (issue #315)
*/
    /*except:*/ {
      __Pyx_AddTraceback("cftime._cftime.date2num", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_5, &__pyx_t_6) < 0) __PYX_ERR(0, 196, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_5);
      __Pyx_XGOTREF(__pyx_t_6);

      /* "cftime/_cftime.pyx":197
 *         dates[0]
 *     except:
 *         if not dates:             # <<<<<<<<<<<<<<
 *             # if empty list or array input, return empty array (issue #315)
 *             return np.array([],dtype=float)
*/
      __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_dates); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 197, __pyx_L5_except_error)
      __pyx_t_8 = (!__pyx_t_7);
      if (__pyx_t_8) {

        /* "cftime/_cftime.pyx":199
 *         if not dates:
 *             # if empty list or array input, return empty array (issue #315)
 *             return np.array([],dtype=float)             # <<<<<<<<<<<<<<
 *         else:
 *             isscalar = True
*/
        __Pyx_XDECREF(__pyx_r);
        __pyx_t_10 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 199, __pyx_L5_except_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 199, __pyx_L5_except_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __pyx_t_11 = PyList_New(0); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 199, __pyx_L5_except_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_13 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_12))) {
          __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_12);
          assert(__pyx_t_10);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
          __Pyx_INCREF(__pyx_t_10);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
          __pyx_t_13 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_10, __pyx_t_11};
          __pyx_t_14 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 199, __pyx_L5_except_error)
          __Pyx_GOTREF(__pyx_t_14);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, ((PyObject *)(&PyFloat_Type)), __pyx_t_14, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 199, __pyx_L5_except_error)
          __pyx_t_9 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_14);
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 199, __pyx_L5_except_error)
          __Pyx_GOTREF(__pyx_t_9);
        }
        __pyx_r = __pyx_t_9;
        __pyx_t_9 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        goto __pyx_L6_except_return;

        /* "cftime/_cftime.pyx":197
 *         dates[0]
 *     except:
 *         if not dates:             # <<<<<<<<<<<<<<
 *             # if empty list or array input, return empty array (issue #315)
 *             return np.array([],dtype=float)
*/
      }

      /* "cftime/_cftime.pyx":201
 *             return np.array([],dtype=float)
 *         else:
 *             isscalar = True             # <<<<<<<<<<<<<<
 * 
 *     # masked array input?
*/
      /*else*/ {
        __pyx_v_isscalar = 1;
      }
      __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_L4_exception_handled;
    }

    /* "cftime/_cftime.pyx":194
 *     # input a scale or array-like?
 *     isscalar = False
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0]
 *     except:
*/
    __pyx_L5_except_error:;
    __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_L6_except_return:;
    __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_L0;
    __pyx_L4_exception_handled:;
    __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);
    __pyx_L8_try_end:;
  }

  /* "cftime/_cftime.pyx":204
 * 
 *     # masked array input?
 *     ismasked = False             # <<<<<<<<<<<<<<
 *     if np.ma.isMA(dates) and np.ma.is_masked(dates):
 *         mask = dates.mask
*/
  __pyx_v_ismasked = 0;

  /* "cftime/_cftime.pyx":205
 *     # masked array input?
 *     ismasked = False
 *     if np.ma.isMA(dates) and np.ma.is_masked(dates):             # <<<<<<<<<<<<<<
 *         mask = dates.mask
 *         ismasked = True
*/
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_5 = __pyx_t_9;
  __Pyx_INCREF(__pyx_t_5);
  __pyx_t_13 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_dates};
    __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_isMA, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 205, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if (__pyx_t_7) {
  } else {
    __pyx_t_8 = __pyx_t_7;
    goto __pyx_L13_bool_binop_done;
  }
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_9 = __pyx_t_4;
  __Pyx_INCREF(__pyx_t_9);
  __pyx_t_13 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_v_dates};
    __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_is_masked, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 205, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 205, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_8 = __pyx_t_7;
  __pyx_L13_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":206
 *     ismasked = False
 *     if np.ma.isMA(dates) and np.ma.is_masked(dates):
 *         mask = dates.mask             # <<<<<<<<<<<<<<
 *         ismasked = True
 * 
*/
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dates, __pyx_mstate_global->__pyx_n_u_mask); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 206, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_v_mask = __pyx_t_6;
    __pyx_t_6 = 0;

    /* "cftime/_cftime.pyx":207
 *     if np.ma.isMA(dates) and np.ma.is_masked(dates):
 *         mask = dates.mask
 *         ismasked = True             # <<<<<<<<<<<<<<
 * 
 *     # are all input dates 'real' python datetime objects?
*/
    __pyx_v_ismasked = 1;

    /* "cftime/_cftime.pyx":205
 *     # masked array input?
 *     ismasked = False
 *     if np.ma.isMA(dates) and np.ma.is_masked(dates):             # <<<<<<<<<<<<<<
 *         mask = dates.mask
 *         ismasked = True
*/
  }

  /* "cftime/_cftime.pyx":210
 * 
 *     # are all input dates 'real' python datetime objects?
 *     dates = np.asanyarray(dates) # convert to numpy array             # <<<<<<<<<<<<<<
 *     shape = dates.shape # save shape of input
 *     all_python_datetimes = True
*/
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 210, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_asanyarray); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 210, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_4);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_dates};
    __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 210, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __Pyx_DECREF_SET(__pyx_v_dates, __pyx_t_6);
  __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":211
 *     # are all input dates 'real' python datetime objects?
 *     dates = np.asanyarray(dates) # convert to numpy array
 *     shape = dates.shape # save shape of input             # <<<<<<<<<<<<<<
 *     all_python_datetimes = True
 *     for date in dates.flat:
*/
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dates, __pyx_mstate_global->__pyx_n_u_shape); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 211, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_v_shape = __pyx_t_6;
  __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":212
 *     dates = np.asanyarray(dates) # convert to numpy array
 *     shape = dates.shape # save shape of input
 *     all_python_datetimes = True             # <<<<<<<<<<<<<<
 *     for date in dates.flat:
 *         if not isinstance(date,datetime_python):
*/
  __pyx_v_all_python_datetimes = 1;

  /* "cftime/_cftime.pyx":213
 *     shape = dates.shape # save shape of input
 *     all_python_datetimes = True
 *     for date in dates.flat:             # <<<<<<<<<<<<<<
 *         if not isinstance(date,datetime_python):
 *            all_python_datetimes = False
*/
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dates, __pyx_mstate_global->__pyx_n_u_flat); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 213, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (likely(PyList_CheckExact(__pyx_t_6)) || PyTuple_CheckExact(__pyx_t_6)) {
    __pyx_t_5 = __pyx_t_6; __Pyx_INCREF(__pyx_t_5);
    __pyx_t_15 = 0;
    __pyx_t_16 = NULL;
  } else {
    __pyx_t_15 = -1; __pyx_t_5 = PyObject_GetIter(__pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 213, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_16 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_5); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 213, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  for (;;) {
    if (likely(!__pyx_t_16)) {
      if (likely(PyList_CheckExact(__pyx_t_5))) {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_5);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 213, __pyx_L1_error)
          #endif
          if (__pyx_t_15 >= __pyx_temp) break;
        }
        __pyx_t_6 = __Pyx_PyList_GetItemRefFast(__pyx_t_5, __pyx_t_15, __Pyx_ReferenceSharing_OwnStrongReference);
        ++__pyx_t_15;
      } else {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_5);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 213, __pyx_L1_error)
          #endif
          if (__pyx_t_15 >= __pyx_temp) break;
        }
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_5, __pyx_t_15));
        #else
        __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_5, __pyx_t_15);
        #endif
        ++__pyx_t_15;
      }
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 213, __pyx_L1_error)
    } else {
      __pyx_t_6 = __pyx_t_16(__pyx_t_5);
      if (unlikely(!__pyx_t_6)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 213, __pyx_L1_error)
          PyErr_Clear();
        }
        break;
      }
    }
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_XDECREF_SET(__pyx_v_date, __pyx_t_6);
    __pyx_t_6 = 0;

    /* "cftime/_cftime.pyx":214
 *     all_python_datetimes = True
 *     for date in dates.flat:
 *         if not isinstance(date,datetime_python):             # <<<<<<<<<<<<<<
 *            all_python_datetimes = False
 *            break
*/
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 214, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_8 = PyObject_IsInstance(__pyx_v_date, __pyx_t_6); if (unlikely(__pyx_t_8 == ((int)-1))) __PYX_ERR(0, 214, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_7 = (!__pyx_t_8);
    if (__pyx_t_7) {

      /* "cftime/_cftime.pyx":215
 *     for date in dates.flat:
 *         if not isinstance(date,datetime_python):
 *            all_python_datetimes = False             # <<<<<<<<<<<<<<
 *            break
 * 
*/
      __pyx_v_all_python_datetimes = 0;

      /* "cftime/_cftime.pyx":216
 *         if not isinstance(date,datetime_python):
 *            all_python_datetimes = False
 *            break             # <<<<<<<<<<<<<<
 * 
 *     # if has_year_zero is None and calendar is None, use first input cftime.datetime instance
*/
      goto __pyx_L16_break;

      /* "cftime/_cftime.pyx":214
 *     all_python_datetimes = True
 *     for date in dates.flat:
 *         if not isinstance(date,datetime_python):             # <<<<<<<<<<<<<<
 *            all_python_datetimes = False
 *            break
*/
    }

    /* "cftime/_cftime.pyx":213
 *     shape = dates.shape # save shape of input
 *     all_python_datetimes = True
 *     for date in dates.flat:             # <<<<<<<<<<<<<<
 *         if not isinstance(date,datetime_python):
 *            all_python_datetimes = False
*/
  }
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  goto __pyx_L18_for_end;
  __pyx_L16_break:;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  goto __pyx_L18_for_end;
  __pyx_L18_for_end:;

  /* "cftime/_cftime.pyx":221
 *     # to determine if year zero is to be included.
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         if calendar is None:
 *             d0 = dates.item(0)
*/
  __pyx_t_7 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_7) {

    /* "cftime/_cftime.pyx":222
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:
 *         if calendar is None:             # <<<<<<<<<<<<<<
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):
*/
    __pyx_t_7 = (__pyx_v_calendar == Py_None);
    if (__pyx_t_7) {

      /* "cftime/_cftime.pyx":223
 *     if has_year_zero is None:
 *         if calendar is None:
 *             d0 = dates.item(0)             # <<<<<<<<<<<<<<
 *             if isinstance(d0,datetime_python):
 *                 has_year_zero = False
*/
      __pyx_t_6 = __pyx_v_dates;
      __Pyx_INCREF(__pyx_t_6);
      __pyx_t_13 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_int_0};
        __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 223, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __pyx_v_d0 = __pyx_t_5;
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":224
 *         if calendar is None:
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 has_year_zero = False
 *             else:
*/
      __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 224, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_7 = PyObject_IsInstance(__pyx_v_d0, __pyx_t_5); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 224, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (__pyx_t_7) {

        /* "cftime/_cftime.pyx":225
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):
 *                 has_year_zero = False             # <<<<<<<<<<<<<<
 *             else:
 *                 try:
*/
        __Pyx_INCREF(Py_False);
        __Pyx_DECREF_SET(__pyx_v_has_year_zero, Py_False);

        /* "cftime/_cftime.pyx":224
 *         if calendar is None:
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 has_year_zero = False
 *             else:
*/
        goto __pyx_L21;
      }

      /* "cftime/_cftime.pyx":227
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
      /*else*/ {
        {
          __Pyx_PyThreadState_declare
          __Pyx_PyThreadState_assign
          __Pyx_ExceptionSave(&__pyx_t_3, &__pyx_t_2, &__pyx_t_1);
          __Pyx_XGOTREF(__pyx_t_3);
          __Pyx_XGOTREF(__pyx_t_2);
          __Pyx_XGOTREF(__pyx_t_1);
          /*try:*/ {

            /* "cftime/_cftime.pyx":228
 *             else:
 *                 try:
 *                     has_year_zero = d0.has_year_zero             # <<<<<<<<<<<<<<
 *                 except AttributeError:
 *                     raise ValueError('has_year_zero not specified',type(d0))
*/
            __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_d0, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 228, __pyx_L22_error)
            __Pyx_GOTREF(__pyx_t_5);
            __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_5);
            __pyx_t_5 = 0;

            /* "cftime/_cftime.pyx":227
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
          }
          __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_L27_try_end;
          __pyx_L22_error:;
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 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_XDECREF(__pyx_t_9); __pyx_t_9 = 0;

          /* "cftime/_cftime.pyx":229
 *                 try:
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:             # <<<<<<<<<<<<<<
 *                     raise ValueError('has_year_zero not specified',type(d0))
 *         else:
*/
          __pyx_t_17 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
          if (__pyx_t_17) {
            __Pyx_AddTraceback("cftime._cftime.date2num", __pyx_clineno, __pyx_lineno, __pyx_filename);
            if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_6, &__pyx_t_4) < 0) __PYX_ERR(0, 229, __pyx_L24_except_error)
            __Pyx_XGOTREF(__pyx_t_5);
            __Pyx_XGOTREF(__pyx_t_6);
            __Pyx_XGOTREF(__pyx_t_4);

            /* "cftime/_cftime.pyx":230
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
 *                     raise ValueError('has_year_zero not specified',type(d0))             # <<<<<<<<<<<<<<
 *         else:
 *             has_year_zero = _year_zero_defaults(calendar)
*/
            __pyx_t_12 = NULL;
            __pyx_t_13 = 1;
            {
              PyObject *__pyx_callargs[3] = {__pyx_t_12, __pyx_mstate_global->__pyx_kp_u_has_year_zero_not_specified, ((PyObject *)Py_TYPE(__pyx_v_d0))};
              __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_13, (3-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
              __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
              if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 230, __pyx_L24_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(0, 230, __pyx_L24_except_error)
          }
          goto __pyx_L24_except_error;

          /* "cftime/_cftime.pyx":227
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
          __pyx_L24_except_error:;
          __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_L27_try_end:;
        }
      }
      __pyx_L21:;

      /* "cftime/_cftime.pyx":222
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:
 *         if calendar is None:             # <<<<<<<<<<<<<<
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):
*/
      goto __pyx_L20;
    }

    /* "cftime/_cftime.pyx":232
 *                     raise ValueError('has_year_zero not specified',type(d0))
 *         else:
 *             has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 * 
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
*/
    /*else*/ {
      __pyx_t_4 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 232, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_4);
      __pyx_t_4 = 0;
    }
    __pyx_L20:;

    /* "cftime/_cftime.pyx":221
 *     # to determine if year zero is to be included.
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         if calendar is None:
 *             d0 = dates.item(0)
*/
  }

  /* "cftime/_cftime.pyx":236
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:             # <<<<<<<<<<<<<<
 *         if all_python_datetimes:
 *             calendar = 'proleptic_gregorian'
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_calendar); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 236, __pyx_L1_error)
  __pyx_t_8 = (!__pyx_t_7);
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":237
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:
 *         if all_python_datetimes:             # <<<<<<<<<<<<<<
 *             calendar = 'proleptic_gregorian'
 *         else:
*/
    if (__pyx_v_all_python_datetimes) {

      /* "cftime/_cftime.pyx":238
 *     if not calendar:
 *         if all_python_datetimes:
 *             calendar = 'proleptic_gregorian'             # <<<<<<<<<<<<<<
 *         else:
 *             d0 = dates.item(0)
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_proleptic_gregorian);
      __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian);

      /* "cftime/_cftime.pyx":237
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:
 *         if all_python_datetimes:             # <<<<<<<<<<<<<<
 *             calendar = 'proleptic_gregorian'
 *         else:
*/
      goto __pyx_L31;
    }

    /* "cftime/_cftime.pyx":240
 *             calendar = 'proleptic_gregorian'
 *         else:
 *             d0 = dates.item(0)             # <<<<<<<<<<<<<<
 *             if isinstance(d0,datetime_python):
 *                 calendar = 'proleptic_gregorian'
*/
    /*else*/ {
      __pyx_t_6 = __pyx_v_dates;
      __Pyx_INCREF(__pyx_t_6);
      __pyx_t_13 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_int_0};
        __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 240, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __Pyx_XDECREF_SET(__pyx_v_d0, __pyx_t_4);
      __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":241
 *         else:
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 calendar = 'proleptic_gregorian'
 *             else:
*/
      __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 241, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_8 = PyObject_IsInstance(__pyx_v_d0, __pyx_t_4); if (unlikely(__pyx_t_8 == ((int)-1))) __PYX_ERR(0, 241, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (__pyx_t_8) {

        /* "cftime/_cftime.pyx":242
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):
 *                 calendar = 'proleptic_gregorian'             # <<<<<<<<<<<<<<
 *             else:
 *                 try:
*/
        __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_proleptic_gregorian);
        __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian);

        /* "cftime/_cftime.pyx":241
 *         else:
 *             d0 = dates.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 calendar = 'proleptic_gregorian'
 *             else:
*/
        goto __pyx_L32;
      }

      /* "cftime/_cftime.pyx":244
 *                 calendar = 'proleptic_gregorian'
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     calendar = d0.calendar
 *                 except AttributeError:
*/
      /*else*/ {
        {
          __Pyx_PyThreadState_declare
          __Pyx_PyThreadState_assign
          __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
          __Pyx_XGOTREF(__pyx_t_1);
          __Pyx_XGOTREF(__pyx_t_2);
          __Pyx_XGOTREF(__pyx_t_3);
          /*try:*/ {

            /* "cftime/_cftime.pyx":245
 *             else:
 *                 try:
 *                     calendar = d0.calendar             # <<<<<<<<<<<<<<
 *                 except AttributeError:
 *                     raise ValueError('no calendar specified',type(d0))
*/
            __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_d0, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 245, __pyx_L33_error)
            __Pyx_GOTREF(__pyx_t_4);
            __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_4);
            __pyx_t_4 = 0;

            /* "cftime/_cftime.pyx":244
 *                 calendar = 'proleptic_gregorian'
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     calendar = d0.calendar
 *                 except AttributeError:
*/
          }
          __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_L38_try_end;
          __pyx_L33_error:;
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 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_XDECREF(__pyx_t_9); __pyx_t_9 = 0;

          /* "cftime/_cftime.pyx":246
 *                 try:
 *                     calendar = d0.calendar
 *                 except AttributeError:             # <<<<<<<<<<<<<<
 *                     raise ValueError('no calendar specified',type(d0))
 * 
*/
          __pyx_t_17 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
          if (__pyx_t_17) {
            __Pyx_AddTraceback("cftime._cftime.date2num", __pyx_clineno, __pyx_lineno, __pyx_filename);
            if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_5) < 0) __PYX_ERR(0, 246, __pyx_L35_except_error)
            __Pyx_XGOTREF(__pyx_t_4);
            __Pyx_XGOTREF(__pyx_t_6);
            __Pyx_XGOTREF(__pyx_t_5);

            /* "cftime/_cftime.pyx":247
 *                     calendar = d0.calendar
 *                 except AttributeError:
 *                     raise ValueError('no calendar specified',type(d0))             # <<<<<<<<<<<<<<
 * 
 *     calendar = calendar.lower()
*/
            __pyx_t_12 = NULL;
            __pyx_t_13 = 1;
            {
              PyObject *__pyx_callargs[3] = {__pyx_t_12, __pyx_mstate_global->__pyx_kp_u_no_calendar_specified, ((PyObject *)Py_TYPE(__pyx_v_d0))};
              __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_13, (3-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
              __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
              if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 247, __pyx_L35_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(0, 247, __pyx_L35_except_error)
          }
          goto __pyx_L35_except_error;

          /* "cftime/_cftime.pyx":244
 *                 calendar = 'proleptic_gregorian'
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     calendar = d0.calendar
 *                 except AttributeError:
*/
          __pyx_L35_except_error:;
          __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_L38_try_end:;
        }
      }
      __pyx_L32:;
    }
    __pyx_L31:;

    /* "cftime/_cftime.pyx":236
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:             # <<<<<<<<<<<<<<
 *         if all_python_datetimes:
 *             calendar = 'proleptic_gregorian'
*/
  }

  /* "cftime/_cftime.pyx":249
 *                     raise ValueError('no calendar specified',type(d0))
 * 
 *     calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
 *     (unit, isostring) = _datesplit(units)
*/
  __pyx_t_6 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_6);
  __pyx_t_13 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL};
    __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_13, (1-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 249, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_5);
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":250
 * 
 *     calendar = calendar.lower()
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     (unit, isostring) = _datesplit(units)
 *     # real-world calendars cannot have zero as a reference year.
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dateparse); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 250, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_6, __pyx_v_units};
    __pyx_t_9 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 250, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_9, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 250, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_9, __pyx_callargs+2, 1) < (0)) __PYX_ERR(0, 250, __pyx_L1_error)
    __pyx_t_5 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_9);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 250, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  __pyx_v_basedate = __pyx_t_5;
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":251
 *     calendar = calendar.lower()
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
 *     (unit, isostring) = _datesplit(units)             # <<<<<<<<<<<<<<
 *     # real-world calendars cannot have zero as a reference year.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
*/
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_datesplit); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 251, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_9))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_9);
    assert(__pyx_t_4);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_9, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_units};
    __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_9, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  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(0, 251, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_9 = PyTuple_GET_ITEM(sequence, 0);
      __Pyx_INCREF(__pyx_t_9);
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_4);
    } else {
      __pyx_t_9 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 251, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_9);
      __pyx_t_4 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 251, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_4);
    }
    #else
    __pyx_t_9 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_4 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    #endif
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_6 = PyObject_GetIter(__pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 251, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_18 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6);
    index = 0; __pyx_t_9 = __pyx_t_18(__pyx_t_6); if (unlikely(!__pyx_t_9)) goto __pyx_L41_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_9);
    index = 1; __pyx_t_4 = __pyx_t_18(__pyx_t_6); if (unlikely(!__pyx_t_4)) goto __pyx_L41_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_4);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_18(__pyx_t_6), 2) < (0)) __PYX_ERR(0, 251, __pyx_L1_error)
    __pyx_t_18 = NULL;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    goto __pyx_L42_unpacking_done;
    __pyx_L41_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_18 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(0, 251, __pyx_L1_error)
    __pyx_L42_unpacking_done:;
  }
  __pyx_v_unit = __pyx_t_9;
  __pyx_t_9 = 0;
  __pyx_v_isostring = __pyx_t_4;
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":253
 *     (unit, isostring) = _datesplit(units)
 *     # real-world calendars cannot have zero as a reference year.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_5 = __pyx_v_calendar;
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 253, __pyx_L1_error)
  if (!__pyx_t_19) {
  } else {
    __pyx_t_7 = __pyx_t_19;
    goto __pyx_L46_bool_binop_done;
  }
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 253, __pyx_L1_error)
  if (!__pyx_t_19) {
  } else {
    __pyx_t_7 = __pyx_t_19;
    goto __pyx_L46_bool_binop_done;
  }
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 253, __pyx_L1_error)
  if (!__pyx_t_19) {
  } else {
    __pyx_t_7 = __pyx_t_19;
    goto __pyx_L46_bool_binop_done;
  }
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 253, __pyx_L1_error)
  __pyx_t_7 = __pyx_t_19;
  __pyx_L46_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_19 = __pyx_t_7;
  if (__pyx_t_19) {
  } else {
    __pyx_t_8 = __pyx_t_19;
    goto __pyx_L44_bool_binop_done;
  }
  __pyx_t_19 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 253, __pyx_L1_error)
  __pyx_t_7 = (!__pyx_t_19);
  __pyx_t_8 = __pyx_t_7;
  __pyx_L44_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":254
 *     # real-world calendars cannot have zero as a reference year.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
*/
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 254, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_8 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_5, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 254, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(__pyx_t_8)) {

      /* "cftime/_cftime.pyx":255
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'             # <<<<<<<<<<<<<<
 *             raise ValueError(msg)
 *     if unit not in UNIT_CONVERSION_FACTORS:
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_2);
      __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_2;

      /* "cftime/_cftime.pyx":256
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)             # <<<<<<<<<<<<<<
 *     if unit not in UNIT_CONVERSION_FACTORS:
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
*/
      __pyx_t_4 = NULL;
      __pyx_t_13 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_msg};
        __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 256, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __Pyx_Raise(__pyx_t_5, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __PYX_ERR(0, 256, __pyx_L1_error)

      /* "cftime/_cftime.pyx":254
 *     # real-world calendars cannot have zero as a reference year.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
*/
    }

    /* "cftime/_cftime.pyx":253
 *     (unit, isostring) = _datesplit(units)
 *     # real-world calendars cannot have zero as a reference year.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
*/
  }

  /* "cftime/_cftime.pyx":257
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
 *     if unit not in UNIT_CONVERSION_FACTORS:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 *     if unit in ["months", "month"] and calendar != "360_day":
*/
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_UNIT_CONVERSION_FACTORS); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 257, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_8 = (__Pyx_PySequence_ContainsTF(__pyx_v_unit, __pyx_t_5, Py_NE)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 257, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (unlikely(__pyx_t_8)) {

    /* "cftime/_cftime.pyx":258
 *             raise ValueError(msg)
 *     if unit not in UNIT_CONVERSION_FACTORS:
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))             # <<<<<<<<<<<<<<
 *     if unit in ["months", "month"] and calendar != "360_day":
 *         raise ValueError("Units of months only valid for 360_day calendar.")
*/
    __pyx_t_4 = NULL;
    __pyx_t_6 = __pyx_mstate_global->__pyx_kp_u_Unsupported_time_units_provided;
    __Pyx_INCREF(__pyx_t_6);
    __pyx_t_13 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_unit};
      __pyx_t_9 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 258, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
    }
    __pyx_t_13 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_9};
      __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 258, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __Pyx_Raise(__pyx_t_5, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __PYX_ERR(0, 258, __pyx_L1_error)

    /* "cftime/_cftime.pyx":257
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
 *     if unit not in UNIT_CONVERSION_FACTORS:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 *     if unit in ["months", "month"] and calendar != "360_day":
*/
  }

  /* "cftime/_cftime.pyx":259
 *     if unit not in UNIT_CONVERSION_FACTORS:
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 *     if unit in ["months", "month"] and calendar != "360_day":             # <<<<<<<<<<<<<<
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 *     unit_timedelta = timedelta(microseconds=UNIT_CONVERSION_FACTORS[unit])
*/
  __Pyx_INCREF(__pyx_v_unit);
  __pyx_t_5 = __pyx_v_unit;
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_months, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 259, __pyx_L1_error)
  if (!__pyx_t_19) {
  } else {
    __pyx_t_7 = __pyx_t_19;
    goto __pyx_L55_bool_binop_done;
  }
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_month, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 259, __pyx_L1_error)
  __pyx_t_7 = __pyx_t_19;
  __pyx_L55_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_19 = __pyx_t_7;
  if (__pyx_t_19) {
  } else {
    __pyx_t_8 = __pyx_t_19;
    goto __pyx_L53_bool_binop_done;
  }
  __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_NE)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 259, __pyx_L1_error)
  __pyx_t_8 = __pyx_t_19;
  __pyx_L53_bool_binop_done:;
  if (unlikely(__pyx_t_8)) {

    /* "cftime/_cftime.pyx":260
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 *     if unit in ["months", "month"] and calendar != "360_day":
 *         raise ValueError("Units of months only valid for 360_day calendar.")             # <<<<<<<<<<<<<<
 *     unit_timedelta = timedelta(microseconds=UNIT_CONVERSION_FACTORS[unit])
 *     can_use_python_basedatetime = calendar=='proleptic_gregorian' and _can_use_python_datetime(basedate,calendar)
*/
    __pyx_t_9 = NULL;
    __pyx_t_13 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_Units_of_months_only_valid_for_3};
      __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 260, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __Pyx_Raise(__pyx_t_5, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __PYX_ERR(0, 260, __pyx_L1_error)

    /* "cftime/_cftime.pyx":259
 *     if unit not in UNIT_CONVERSION_FACTORS:
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 *     if unit in ["months", "month"] and calendar != "360_day":             # <<<<<<<<<<<<<<
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 *     unit_timedelta = timedelta(microseconds=UNIT_CONVERSION_FACTORS[unit])
*/
  }

  /* "cftime/_cftime.pyx":261
 *     if unit in ["months", "month"] and calendar != "360_day":
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 *     unit_timedelta = timedelta(microseconds=UNIT_CONVERSION_FACTORS[unit])             # <<<<<<<<<<<<<<
 *     can_use_python_basedatetime = calendar=='proleptic_gregorian' and _can_use_python_datetime(basedate,calendar)
 * 
*/
  __pyx_t_9 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 261, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_UNIT_CONVERSION_FACTORS); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 261, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_12 = __Pyx_PyObject_GetItem(__pyx_t_6, __pyx_v_unit); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 261, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_9);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_9);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_9, NULL};
    __pyx_t_6 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 261, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_microseconds, __pyx_t_12, __pyx_t_6, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 261, __pyx_L1_error)
    __pyx_t_5 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_13, (1-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_6);
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 261, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  __pyx_v_unit_timedelta = __pyx_t_5;
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":262
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 *     unit_timedelta = timedelta(microseconds=UNIT_CONVERSION_FACTORS[unit])
 *     can_use_python_basedatetime = calendar=='proleptic_gregorian' and _can_use_python_datetime(basedate,calendar)             # <<<<<<<<<<<<<<
 * 
 *     if can_use_python_basedatetime and all_python_datetimes:
*/
  __pyx_t_4 = PyObject_RichCompare(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 262, __pyx_L1_error)
  __pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 262, __pyx_L1_error)
  if (__pyx_t_8) {
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  } else {
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_5 = __pyx_t_4;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    goto __pyx_L57_bool_binop_done;
  }
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_can_use_python_datetime); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 262, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_12))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_12);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_6, __pyx_v_basedate, __pyx_v_calendar};
    __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (3-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 262, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
  }
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_5 = __pyx_t_4;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_L57_bool_binop_done:;
  __pyx_v_can_use_python_basedatetime = __pyx_t_5;
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":264
 *     can_use_python_basedatetime = calendar=='proleptic_gregorian' and _can_use_python_datetime(basedate,calendar)
 * 
 *     if can_use_python_basedatetime and all_python_datetimes:             # <<<<<<<<<<<<<<
 *         use_python_datetime = True
 *         if not isinstance(basedate, datetime_python):
*/
  __pyx_t_19 = __Pyx_PyObject_IsTrue(__pyx_v_can_use_python_basedatetime); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 264, __pyx_L1_error)
  if (__pyx_t_19) {
  } else {
    __pyx_t_8 = __pyx_t_19;
    goto __pyx_L60_bool_binop_done;
  }
  __pyx_t_8 = __pyx_v_all_python_datetimes;
  __pyx_L60_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":265
 * 
 *     if can_use_python_basedatetime and all_python_datetimes:
 *         use_python_datetime = True             # <<<<<<<<<<<<<<
 *         if not isinstance(basedate, datetime_python):
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,
*/
    __pyx_v_use_python_datetime = 1;

    /* "cftime/_cftime.pyx":266
 *     if can_use_python_basedatetime and all_python_datetimes:
 *         use_python_datetime = True
 *         if not isinstance(basedate, datetime_python):             # <<<<<<<<<<<<<<
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,
 *                        basedate.hour, basedate.minute, basedate.second,
*/
    __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 266, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_8 = PyObject_IsInstance(__pyx_v_basedate, __pyx_t_5); if (unlikely(__pyx_t_8 == ((int)-1))) __PYX_ERR(0, 266, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_19 = (!__pyx_t_8);
    if (__pyx_t_19) {

      /* "cftime/_cftime.pyx":267
 *         use_python_datetime = True
 *         if not isinstance(basedate, datetime_python):
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,             # <<<<<<<<<<<<<<
 *                        basedate.hour, basedate.minute, basedate.second,
 *                        basedate.microsecond)
*/
      __pyx_t_4 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_real_datetime); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 267, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 267, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 267, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
      __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 267, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_14);

      /* "cftime/_cftime.pyx":268
 *         if not isinstance(basedate, datetime_python):
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,
 *                        basedate.hour, basedate.minute, basedate.second,             # <<<<<<<<<<<<<<
 *                        basedate.microsecond)
 *     else:
*/
      __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 268, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 268, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_20 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 268, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_20);

      /* "cftime/_cftime.pyx":269
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,
 *                        basedate.hour, basedate.minute, basedate.second,
 *                        basedate.microsecond)             # <<<<<<<<<<<<<<
 *     else:
 *         use_python_datetime = False
*/
      __pyx_t_21 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 269, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_21);
      __pyx_t_13 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_12))) {
        __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_12);
        assert(__pyx_t_4);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
        __pyx_t_13 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[8] = {__pyx_t_4, __pyx_t_6, __pyx_t_9, __pyx_t_14, __pyx_t_11, __pyx_t_10, __pyx_t_20, __pyx_t_21};
        __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (8-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__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_DECREF(__pyx_t_14); __pyx_t_14 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 267, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __Pyx_DECREF_SET(__pyx_v_basedate, __pyx_t_5);
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":266
 *     if can_use_python_basedatetime and all_python_datetimes:
 *         use_python_datetime = True
 *         if not isinstance(basedate, datetime_python):             # <<<<<<<<<<<<<<
 *             basedate = real_datetime(basedate.year, basedate.month, basedate.day,
 *                        basedate.hour, basedate.minute, basedate.second,
*/
    }

    /* "cftime/_cftime.pyx":264
 *     can_use_python_basedatetime = calendar=='proleptic_gregorian' and _can_use_python_datetime(basedate,calendar)
 * 
 *     if can_use_python_basedatetime and all_python_datetimes:             # <<<<<<<<<<<<<<
 *         use_python_datetime = True
 *         if not isinstance(basedate, datetime_python):
*/
    goto __pyx_L59;
  }

  /* "cftime/_cftime.pyx":271
 *                        basedate.microsecond)
 *     else:
 *         use_python_datetime = False             # <<<<<<<<<<<<<<
 *         # convert basedate to specified calendar
 *         basedate =  to_calendar_specific_datetime(basedate, calendar, False, has_year_zero=has_year_zero)
*/
  /*else*/ {
    __pyx_v_use_python_datetime = 0;

    /* "cftime/_cftime.pyx":273
 *         use_python_datetime = False
 *         # convert basedate to specified calendar
 *         basedate =  to_calendar_specific_datetime(basedate, calendar, False, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     times = []
 *     for n, date in enumerate(dates.flat):
*/
    __pyx_t_12 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_21, __pyx_mstate_global->__pyx_n_u_to_calendar_specific_datetime); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 273, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    __pyx_t_13 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_21))) {
      __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_21);
      assert(__pyx_t_12);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_21);
      __Pyx_INCREF(__pyx_t_12);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_21, __pyx__function);
      __pyx_t_13 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[4 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_12, __pyx_v_basedate, __pyx_v_calendar, Py_False};
      __pyx_t_20 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 273, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_20);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_20, __pyx_callargs+4, 0) < (0)) __PYX_ERR(0, 273, __pyx_L1_error)
      __pyx_t_5 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_21, __pyx_callargs+__pyx_t_13, (4-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_20);
      __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
      __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
      __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 273, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __Pyx_DECREF_SET(__pyx_v_basedate, __pyx_t_5);
    __pyx_t_5 = 0;
  }
  __pyx_L59:;

  /* "cftime/_cftime.pyx":274
 *         # convert basedate to specified calendar
 *         basedate =  to_calendar_specific_datetime(basedate, calendar, False, has_year_zero=has_year_zero)
 *     times = []             # <<<<<<<<<<<<<<
 *     for n, date in enumerate(dates.flat):
 *         if ismasked and mask.flat[n]:
*/
  __pyx_t_5 = PyList_New(0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 274, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_v_times = __pyx_t_5;
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":275
 *         basedate =  to_calendar_specific_datetime(basedate, calendar, False, has_year_zero=has_year_zero)
 *     times = []
 *     for n, date in enumerate(dates.flat):             # <<<<<<<<<<<<<<
 *         if ismasked and mask.flat[n]:
 *             times.append(None)
*/
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_0);
  __pyx_t_5 = __pyx_mstate_global->__pyx_int_0;
  __pyx_t_21 = __Pyx_PyObject_GetAttrStr(__pyx_v_dates, __pyx_mstate_global->__pyx_n_u_flat); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 275, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_21);
  if (likely(PyList_CheckExact(__pyx_t_21)) || PyTuple_CheckExact(__pyx_t_21)) {
    __pyx_t_20 = __pyx_t_21; __Pyx_INCREF(__pyx_t_20);
    __pyx_t_15 = 0;
    __pyx_t_16 = NULL;
  } else {
    __pyx_t_15 = -1; __pyx_t_20 = PyObject_GetIter(__pyx_t_21); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 275, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_20);
    __pyx_t_16 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_20); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 275, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
  for (;;) {
    if (likely(!__pyx_t_16)) {
      if (likely(PyList_CheckExact(__pyx_t_20))) {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_20);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 275, __pyx_L1_error)
          #endif
          if (__pyx_t_15 >= __pyx_temp) break;
        }
        __pyx_t_21 = __Pyx_PyList_GetItemRefFast(__pyx_t_20, __pyx_t_15, __Pyx_ReferenceSharing_OwnStrongReference);
        ++__pyx_t_15;
      } else {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_20);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 275, __pyx_L1_error)
          #endif
          if (__pyx_t_15 >= __pyx_temp) break;
        }
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_21 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_20, __pyx_t_15));
        #else
        __pyx_t_21 = __Pyx_PySequence_ITEM(__pyx_t_20, __pyx_t_15);
        #endif
        ++__pyx_t_15;
      }
      if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 275, __pyx_L1_error)
    } else {
      __pyx_t_21 = __pyx_t_16(__pyx_t_20);
      if (unlikely(!__pyx_t_21)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 275, __pyx_L1_error)
          PyErr_Clear();
        }
        break;
      }
    }
    __Pyx_GOTREF(__pyx_t_21);
    __Pyx_XDECREF_SET(__pyx_v_date, __pyx_t_21);
    __pyx_t_21 = 0;
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_XDECREF_SET(__pyx_v_n, __pyx_t_5);
    __pyx_t_21 = __Pyx_PyLong_AddObjC(__pyx_t_5, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 275, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    __Pyx_DECREF(__pyx_t_5);
    __pyx_t_5 = __pyx_t_21;
    __pyx_t_21 = 0;

    /* "cftime/_cftime.pyx":276
 *     times = []
 *     for n, date in enumerate(dates.flat):
 *         if ismasked and mask.flat[n]:             # <<<<<<<<<<<<<<
 *             times.append(None)
 *             continue
*/
    if (__pyx_v_ismasked) {
    } else {
      __pyx_t_19 = __pyx_v_ismasked;
      goto __pyx_L66_bool_binop_done;
    }
    if (unlikely(!__pyx_v_mask)) { __Pyx_RaiseUnboundLocalError("mask"); __PYX_ERR(0, 276, __pyx_L1_error) }
    __pyx_t_21 = __Pyx_PyObject_GetAttrStr(__pyx_v_mask, __pyx_mstate_global->__pyx_n_u_flat); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 276, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    __pyx_t_12 = __Pyx_PyObject_GetItem(__pyx_t_21, __pyx_v_n); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 276, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
    __pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_t_12); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 276, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __pyx_t_19 = __pyx_t_8;
    __pyx_L66_bool_binop_done:;
    if (__pyx_t_19) {

      /* "cftime/_cftime.pyx":277
 *     for n, date in enumerate(dates.flat):
 *         if ismasked and mask.flat[n]:
 *             times.append(None)             # <<<<<<<<<<<<<<
 *             continue
 * 
*/
      __pyx_t_22 = __Pyx_PyObject_Append(__pyx_v_times, Py_None); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 277, __pyx_L1_error)

      /* "cftime/_cftime.pyx":278
 *         if ismasked and mask.flat[n]:
 *             times.append(None)
 *             continue             # <<<<<<<<<<<<<<
 * 
 *         # use python datetime if possible.
*/
      goto __pyx_L63_continue;

      /* "cftime/_cftime.pyx":276
 *     times = []
 *     for n, date in enumerate(dates.flat):
 *         if ismasked and mask.flat[n]:             # <<<<<<<<<<<<<<
 *             times.append(None)
 *             continue
*/
    }

    /* "cftime/_cftime.pyx":281
 * 
 *         # use python datetime if possible.
 *         if use_python_datetime:             # <<<<<<<<<<<<<<
 *             # remove time zone offset
 *             if getattr(date, 'tzinfo',None) is not None:
*/
    if (__pyx_v_use_python_datetime) {

      /* "cftime/_cftime.pyx":283
 *         if use_python_datetime:
 *             # remove time zone offset
 *             if getattr(date, 'tzinfo',None) is not None:             # <<<<<<<<<<<<<<
 *                 date = date.replace(tzinfo=None) - date.utcoffset()
 *         else: # convert date to same calendar specific cftime.datetime instance
*/
      __pyx_t_12 = __Pyx_GetAttr3(__pyx_v_date, __pyx_mstate_global->__pyx_n_u_tzinfo, Py_None); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 283, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __pyx_t_19 = (__pyx_t_12 != Py_None);
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      if (__pyx_t_19) {

        /* "cftime/_cftime.pyx":284
 *             # remove time zone offset
 *             if getattr(date, 'tzinfo',None) is not None:
 *                 date = date.replace(tzinfo=None) - date.utcoffset()             # <<<<<<<<<<<<<<
 *         else: # convert date to same calendar specific cftime.datetime instance
 *             date = to_calendar_specific_datetime(date, calendar, False, has_year_zero=has_year_zero)
*/
        __pyx_t_21 = __pyx_v_date;
        __Pyx_INCREF(__pyx_t_21);
        __pyx_t_13 = 0;
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_21, NULL};
          __pyx_t_10 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 284, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_tzinfo, Py_None, __pyx_t_10, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 284, __pyx_L1_error)
          __pyx_t_12 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_replace, __pyx_callargs+__pyx_t_13, (1-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_10);
          __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 284, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_12);
        }
        __pyx_t_21 = __pyx_v_date;
        __Pyx_INCREF(__pyx_t_21);
        __pyx_t_13 = 0;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_21, NULL};
          __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_utcoffset, __pyx_callargs+__pyx_t_13, (1-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
          if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 284, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
        }
        __pyx_t_21 = PyNumber_Subtract(__pyx_t_12, __pyx_t_10); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 284, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF_SET(__pyx_v_date, __pyx_t_21);
        __pyx_t_21 = 0;

        /* "cftime/_cftime.pyx":283
 *         if use_python_datetime:
 *             # remove time zone offset
 *             if getattr(date, 'tzinfo',None) is not None:             # <<<<<<<<<<<<<<
 *                 date = date.replace(tzinfo=None) - date.utcoffset()
 *         else: # convert date to same calendar specific cftime.datetime instance
*/
      }

      /* "cftime/_cftime.pyx":281
 * 
 *         # use python datetime if possible.
 *         if use_python_datetime:             # <<<<<<<<<<<<<<
 *             # remove time zone offset
 *             if getattr(date, 'tzinfo',None) is not None:
*/
      goto __pyx_L68;
    }

    /* "cftime/_cftime.pyx":286
 *                 date = date.replace(tzinfo=None) - date.utcoffset()
 *         else: # convert date to same calendar specific cftime.datetime instance
 *             date = to_calendar_specific_datetime(date, calendar, False, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *         td = date - basedate
*/
    /*else*/ {
      __pyx_t_10 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_to_calendar_specific_datetime); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 286, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __pyx_t_13 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_12))) {
        __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_12);
        assert(__pyx_t_10);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
        __Pyx_INCREF(__pyx_t_10);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
        __pyx_t_13 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[4 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_10, __pyx_v_date, __pyx_v_calendar, Py_False};
        __pyx_t_11 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 286, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_11, __pyx_callargs+4, 0) < (0)) __PYX_ERR(0, 286, __pyx_L1_error)
        __pyx_t_21 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (4-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_11);
        __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 286, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);
      }
      __Pyx_DECREF_SET(__pyx_v_date, __pyx_t_21);
      __pyx_t_21 = 0;
    }
    __pyx_L68:;

    /* "cftime/_cftime.pyx":288
 *             date = to_calendar_specific_datetime(date, calendar, False, has_year_zero=has_year_zero)
 * 
 *         td = date - basedate             # <<<<<<<<<<<<<<
 *         if td % unit_timedelta == timedelta(0):
 *             # Explicitly cast result to np.int64 for Windows compatibility
*/
    __pyx_t_21 = PyNumber_Subtract(__pyx_v_date, __pyx_v_basedate); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 288, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    __Pyx_XDECREF_SET(__pyx_v_td, __pyx_t_21);
    __pyx_t_21 = 0;

    /* "cftime/_cftime.pyx":289
 * 
 *         td = date - basedate
 *         if td % unit_timedelta == timedelta(0):             # <<<<<<<<<<<<<<
 *             # Explicitly cast result to np.int64 for Windows compatibility
 *             quotient = np.int64(td // unit_timedelta)
*/
    __pyx_t_21 = PyNumber_Remainder(__pyx_v_td, __pyx_v_unit_timedelta); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 289, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_21);
    __pyx_t_11 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 289, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_13 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_10);
      assert(__pyx_t_11);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_11);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
      __pyx_t_13 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_mstate_global->__pyx_int_0};
      __pyx_t_12 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 289, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
    }
    __pyx_t_10 = PyObject_RichCompare(__pyx_t_21, __pyx_t_12, Py_EQ); __Pyx_XGOTREF(__pyx_t_10); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 289, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __pyx_t_19 = __Pyx_PyObject_IsTrue(__pyx_t_10); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 289, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    if (__pyx_t_19) {

      /* "cftime/_cftime.pyx":291
 *         if td % unit_timedelta == timedelta(0):
 *             # Explicitly cast result to np.int64 for Windows compatibility
 *             quotient = np.int64(td // unit_timedelta)             # <<<<<<<<<<<<<<
 *             times.append(quotient)
 *         else:
*/
      __pyx_t_12 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_21, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 291, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_21);
      __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_21, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 291, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
      __pyx_t_21 = PyNumber_FloorDivide(__pyx_v_td, __pyx_v_unit_timedelta); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 291, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_21);
      __pyx_t_13 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_11))) {
        __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_11);
        assert(__pyx_t_12);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
        __Pyx_INCREF(__pyx_t_12);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
        __pyx_t_13 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_t_21};
        __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 291, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __Pyx_XDECREF_SET(__pyx_v_quotient, __pyx_t_10);
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":292
 *             # Explicitly cast result to np.int64 for Windows compatibility
 *             quotient = np.int64(td // unit_timedelta)
 *             times.append(quotient)             # <<<<<<<<<<<<<<
 *         else:
 *             if longdouble:
*/
      __pyx_t_22 = __Pyx_PyObject_Append(__pyx_v_times, __pyx_v_quotient); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 292, __pyx_L1_error)

      /* "cftime/_cftime.pyx":289
 * 
 *         td = date - basedate
 *         if td % unit_timedelta == timedelta(0):             # <<<<<<<<<<<<<<
 *             # Explicitly cast result to np.int64 for Windows compatibility
 *             quotient = np.int64(td // unit_timedelta)
*/
      goto __pyx_L70;
    }

    /* "cftime/_cftime.pyx":294
 *             times.append(quotient)
 *         else:
 *             if longdouble:             # <<<<<<<<<<<<<<
 *                 # Division of timedelta's is in float64 precision,
 *                 # i.e. losing microsecond precision.
*/
    /*else*/ {
      __pyx_t_19 = __Pyx_PyObject_IsTrue(__pyx_v_longdouble); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 294, __pyx_L1_error)
      if (__pyx_t_19) {

        /* "cftime/_cftime.pyx":302
 *                 #               np.longdouble(unit_timedelta.total_seconds()))
 *                 # -> Convert to (64-bit) integers of microseconds
 *                 mtd = (td.days * 86400000000 +             # <<<<<<<<<<<<<<
 *                        td.seconds * 1000000 +
 *                        td.microseconds)
*/
        __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_td, __pyx_mstate_global->__pyx_n_u_days); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 302, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_11 = PyNumber_Multiply(__pyx_t_10, __pyx_mstate_global->__pyx_int_86400000000); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 302, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":303
 *                 # -> Convert to (64-bit) integers of microseconds
 *                 mtd = (td.days * 86400000000 +
 *                        td.seconds * 1000000 +             # <<<<<<<<<<<<<<
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +
*/
        __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_td, __pyx_mstate_global->__pyx_n_u_seconds); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 303, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_21 = __Pyx_PyLong_MultiplyObjC(__pyx_t_10, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 303, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":302
 *                 #               np.longdouble(unit_timedelta.total_seconds()))
 *                 # -> Convert to (64-bit) integers of microseconds
 *                 mtd = (td.days * 86400000000 +             # <<<<<<<<<<<<<<
 *                        td.seconds * 1000000 +
 *                        td.microseconds)
*/
        __pyx_t_10 = PyNumber_Add(__pyx_t_11, __pyx_t_21); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 302, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;

        /* "cftime/_cftime.pyx":304
 *                 mtd = (td.days * 86400000000 +
 *                        td.seconds * 1000000 +
 *                        td.microseconds)             # <<<<<<<<<<<<<<
 *                 munit = (unit_timedelta.days * 86400000000 +
 *                          unit_timedelta.seconds * 1000000 +
*/
        __pyx_t_21 = __Pyx_PyObject_GetAttrStr(__pyx_v_td, __pyx_mstate_global->__pyx_n_u_microseconds); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 304, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);

        /* "cftime/_cftime.pyx":303
 *                 # -> Convert to (64-bit) integers of microseconds
 *                 mtd = (td.days * 86400000000 +
 *                        td.seconds * 1000000 +             # <<<<<<<<<<<<<<
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +
*/
        __pyx_t_11 = PyNumber_Add(__pyx_t_10, __pyx_t_21); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 303, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_XDECREF_SET(__pyx_v_mtd, __pyx_t_11);
        __pyx_t_11 = 0;

        /* "cftime/_cftime.pyx":305
 *                        td.seconds * 1000000 +
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +             # <<<<<<<<<<<<<<
 *                          unit_timedelta.seconds * 1000000 +
 *                          unit_timedelta.microseconds)
*/
        __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_unit_timedelta, __pyx_mstate_global->__pyx_n_u_days); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 305, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_21 = PyNumber_Multiply(__pyx_t_11, __pyx_mstate_global->__pyx_int_86400000000); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 305, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;

        /* "cftime/_cftime.pyx":306
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +
 *                          unit_timedelta.seconds * 1000000 +             # <<<<<<<<<<<<<<
 *                          unit_timedelta.microseconds)
 *                 quotient = np.longdouble(mtd) / np.longdouble(munit)
*/
        __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_unit_timedelta, __pyx_mstate_global->__pyx_n_u_seconds); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 306, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_10 = __Pyx_PyLong_MultiplyObjC(__pyx_t_11, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 306, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;

        /* "cftime/_cftime.pyx":305
 *                        td.seconds * 1000000 +
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +             # <<<<<<<<<<<<<<
 *                          unit_timedelta.seconds * 1000000 +
 *                          unit_timedelta.microseconds)
*/
        __pyx_t_11 = PyNumber_Add(__pyx_t_21, __pyx_t_10); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 305, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":307
 *                 munit = (unit_timedelta.days * 86400000000 +
 *                          unit_timedelta.seconds * 1000000 +
 *                          unit_timedelta.microseconds)             # <<<<<<<<<<<<<<
 *                 quotient = np.longdouble(mtd) / np.longdouble(munit)
 *             else:
*/
        __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_unit_timedelta, __pyx_mstate_global->__pyx_n_u_microseconds); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 307, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);

        /* "cftime/_cftime.pyx":306
 *                        td.microseconds)
 *                 munit = (unit_timedelta.days * 86400000000 +
 *                          unit_timedelta.seconds * 1000000 +             # <<<<<<<<<<<<<<
 *                          unit_timedelta.microseconds)
 *                 quotient = np.longdouble(mtd) / np.longdouble(munit)
*/
        __pyx_t_21 = PyNumber_Add(__pyx_t_11, __pyx_t_10); if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 306, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_21);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_XDECREF_SET(__pyx_v_munit, __pyx_t_21);
        __pyx_t_21 = 0;

        /* "cftime/_cftime.pyx":308
 *                          unit_timedelta.seconds * 1000000 +
 *                          unit_timedelta.microseconds)
 *                 quotient = np.longdouble(mtd) / np.longdouble(munit)             # <<<<<<<<<<<<<<
 *             else:
 *                 quotient = td / unit_timedelta
*/
        __pyx_t_10 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 308, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 308, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __pyx_t_13 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_12))) {
          __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_12);
          assert(__pyx_t_10);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
          __Pyx_INCREF(__pyx_t_10);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
          __pyx_t_13 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_mtd};
          __pyx_t_21 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 308, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_21);
        }
        __pyx_t_10 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 308, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_11);
        __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 308, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        __pyx_t_13 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_14))) {
          __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_14);
          assert(__pyx_t_10);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14);
          __Pyx_INCREF(__pyx_t_10);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_14, __pyx__function);
          __pyx_t_13 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_v_munit};
          __pyx_t_12 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_14, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 308, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_12);
        }
        __pyx_t_14 = __Pyx_PyNumber_Divide(__pyx_t_21, __pyx_t_12); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 308, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        __Pyx_XDECREF_SET(__pyx_v_quotient, __pyx_t_14);
        __pyx_t_14 = 0;

        /* "cftime/_cftime.pyx":294
 *             times.append(quotient)
 *         else:
 *             if longdouble:             # <<<<<<<<<<<<<<
 *                 # Division of timedelta's is in float64 precision,
 *                 # i.e. losing microsecond precision.
*/
        goto __pyx_L71;
      }

      /* "cftime/_cftime.pyx":310
 *                 quotient = np.longdouble(mtd) / np.longdouble(munit)
 *             else:
 *                 quotient = td / unit_timedelta             # <<<<<<<<<<<<<<
 *             times.append(quotient)
 * 
*/
      /*else*/ {
        __pyx_t_14 = __Pyx_PyNumber_Divide(__pyx_v_td, __pyx_v_unit_timedelta); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 310, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_XDECREF_SET(__pyx_v_quotient, __pyx_t_14);
        __pyx_t_14 = 0;
      }
      __pyx_L71:;

      /* "cftime/_cftime.pyx":311
 *             else:
 *                 quotient = td / unit_timedelta
 *             times.append(quotient)             # <<<<<<<<<<<<<<
 * 
 *     if ismasked: # convert to masked array if input was masked array
*/
      __pyx_t_22 = __Pyx_PyObject_Append(__pyx_v_times, __pyx_v_quotient); if (unlikely(__pyx_t_22 == ((int)-1))) __PYX_ERR(0, 311, __pyx_L1_error)
    }
    __pyx_L70:;

    /* "cftime/_cftime.pyx":275
 *         basedate =  to_calendar_specific_datetime(basedate, calendar, False, has_year_zero=has_year_zero)
 *     times = []
 *     for n, date in enumerate(dates.flat):             # <<<<<<<<<<<<<<
 *         if ismasked and mask.flat[n]:
 *             times.append(None)
*/
    __pyx_L63_continue:;
  }
  __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":313
 *             times.append(quotient)
 * 
 *     if ismasked: # convert to masked array if input was masked array             # <<<<<<<<<<<<<<
 *         times = np.array(times, dtype=float)  # None -> nan
 *         times = np.ma.masked_invalid(times)
*/
  if (__pyx_v_ismasked) {

    /* "cftime/_cftime.pyx":314
 * 
 *     if ismasked: # convert to masked array if input was masked array
 *         times = np.array(times, dtype=float)  # None -> nan             # <<<<<<<<<<<<<<
 *         times = np.ma.masked_invalid(times)
 *         if isscalar:
*/
    __pyx_t_20 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 314, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 314, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __pyx_t_13 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_12))) {
      __pyx_t_20 = PyMethod_GET_SELF(__pyx_t_12);
      assert(__pyx_t_20);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
      __Pyx_INCREF(__pyx_t_20);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
      __pyx_t_13 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_20, __pyx_v_times};
      __pyx_t_14 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 314, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_14);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, ((PyObject *)(&PyFloat_Type)), __pyx_t_14, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 314, __pyx_L1_error)
      __pyx_t_5 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_14);
      __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
      __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 314, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __Pyx_DECREF_SET(__pyx_v_times, __pyx_t_5);
    __pyx_t_5 = 0;

    /* "cftime/_cftime.pyx":315
 *     if ismasked: # convert to masked array if input was masked array
 *         times = np.array(times, dtype=float)  # None -> nan
 *         times = np.ma.masked_invalid(times)             # <<<<<<<<<<<<<<
 *         if isscalar:
 *             return times[0]
*/
    __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 315, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_14);
    __pyx_t_20 = __Pyx_PyObject_GetAttrStr(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 315, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_20);
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    __pyx_t_12 = __pyx_t_20;
    __Pyx_INCREF(__pyx_t_12);
    __pyx_t_13 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_times};
      __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_masked_invalid, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
      __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 315, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __Pyx_DECREF_SET(__pyx_v_times, __pyx_t_5);
    __pyx_t_5 = 0;

    /* "cftime/_cftime.pyx":316
 *         times = np.array(times, dtype=float)  # None -> nan
 *         times = np.ma.masked_invalid(times)
 *         if isscalar:             # <<<<<<<<<<<<<<
 *             return times[0]
 *         else:
*/
    if (__pyx_v_isscalar) {

      /* "cftime/_cftime.pyx":317
 *         times = np.ma.masked_invalid(times)
 *         if isscalar:
 *             return times[0]             # <<<<<<<<<<<<<<
 *         else:
 *             return np.reshape(times, shape)
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_5 = __Pyx_GetItemInt(__pyx_v_times, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 317, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_r = __pyx_t_5;
      __pyx_t_5 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":316
 *         times = np.array(times, dtype=float)  # None -> nan
 *         times = np.ma.masked_invalid(times)
 *         if isscalar:             # <<<<<<<<<<<<<<
 *             return times[0]
 *         else:
*/
    }

    /* "cftime/_cftime.pyx":319
 *             return times[0]
 *         else:
 *             return np.reshape(times, shape)             # <<<<<<<<<<<<<<
 *     if isscalar:
 *         return times[0]
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_20 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 319, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_reshape); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 319, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_14);
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      __pyx_t_13 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_14))) {
        __pyx_t_20 = PyMethod_GET_SELF(__pyx_t_14);
        assert(__pyx_t_20);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14);
        __Pyx_INCREF(__pyx_t_20);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_14, __pyx__function);
        __pyx_t_13 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_20, __pyx_v_times, __pyx_v_shape};
        __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_14, __pyx_callargs+__pyx_t_13, (3-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0;
        __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 319, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __pyx_r = __pyx_t_5;
      __pyx_t_5 = 0;
      goto __pyx_L0;
    }

    /* "cftime/_cftime.pyx":313
 *             times.append(quotient)
 * 
 *     if ismasked: # convert to masked array if input was masked array             # <<<<<<<<<<<<<<
 *         times = np.array(times, dtype=float)  # None -> nan
 *         times = np.ma.masked_invalid(times)
*/
  }

  /* "cftime/_cftime.pyx":320
 *         else:
 *             return np.reshape(times, shape)
 *     if isscalar:             # <<<<<<<<<<<<<<
 *         return times[0]
 *     else:
*/
  if (__pyx_v_isscalar) {

    /* "cftime/_cftime.pyx":321
 *             return np.reshape(times, shape)
 *     if isscalar:
 *         return times[0]             # <<<<<<<<<<<<<<
 *     else:
 *         return np.reshape(np.array(times), shape)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_5 = __Pyx_GetItemInt(__pyx_v_times, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 321, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":320
 *         else:
 *             return np.reshape(times, shape)
 *     if isscalar:             # <<<<<<<<<<<<<<
 *         return times[0]
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":323
 *         return times[0]
 *     else:
 *         return np.reshape(np.array(times), shape)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_14 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_20, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_20);
    __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_20, __pyx_mstate_global->__pyx_n_u_reshape); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
    __pyx_t_21 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 323, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __pyx_t_13 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_21 = PyMethod_GET_SELF(__pyx_t_11);
      assert(__pyx_t_21);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
      __Pyx_INCREF(__pyx_t_21);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
      __pyx_t_13 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_21, __pyx_v_times};
      __pyx_t_20 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 323, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_20);
    }
    __pyx_t_13 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_12))) {
      __pyx_t_14 = PyMethod_GET_SELF(__pyx_t_12);
      assert(__pyx_t_14);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
      __Pyx_INCREF(__pyx_t_14);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
      __pyx_t_13 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_14, __pyx_t_20, __pyx_v_shape};
      __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_13, (3-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
      __Pyx_DECREF(__pyx_t_20); __pyx_t_20 = 0;
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 323, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
    }
    __pyx_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":136
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):
 *     """
*/

  /* 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_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_XDECREF(__pyx_t_20);
  __Pyx_XDECREF(__pyx_t_21);
  __Pyx_AddTraceback("cftime._cftime.date2num", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_mask);
  __Pyx_XDECREF(__pyx_v_shape);
  __Pyx_XDECREF(__pyx_v_date);
  __Pyx_XDECREF(__pyx_v_d0);
  __Pyx_XDECREF(__pyx_v_basedate);
  __Pyx_XDECREF(__pyx_v_unit);
  __Pyx_XDECREF(__pyx_v_isostring);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_unit_timedelta);
  __Pyx_XDECREF(__pyx_v_can_use_python_basedatetime);
  __Pyx_XDECREF(__pyx_v_times);
  __Pyx_XDECREF(__pyx_v_n);
  __Pyx_XDECREF(__pyx_v_td);
  __Pyx_XDECREF(__pyx_v_quotient);
  __Pyx_XDECREF(__pyx_v_mtd);
  __Pyx_XDECREF(__pyx_v_munit);
  __Pyx_XDECREF(__pyx_v_dates);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":326
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2pydate(times,units,calendar='standard'):
 *     """
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_9num2pydate(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8num2pydate, "num2pydate(times, units, calendar='standard')\n\nAlways returns python datetime.datetime\nobjects and raise an error if this is not possible.\n\nSame as\nnum2date(times,units,calendar,only_use_cftime_datetimes=False,only_use_python_datetimes=True)");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_9num2pydate = {"num2pydate", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_9num2pydate, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8num2pydate};
static PyObject *__pyx_pw_6cftime_7_cftime_9num2pydate(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_times = 0;
  PyObject *__pyx_v_units = 0;
  PyObject *__pyx_v_calendar = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[3] = {0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("num2pydate (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_times,&__pyx_mstate_global->__pyx_n_u_units_2,&__pyx_mstate_global->__pyx_n_u_calendar,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 326, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 326, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 326, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 326, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "num2pydate", 0) < (0)) __PYX_ERR(0, 326, __pyx_L3_error)
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_standard)));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("num2pydate", 0, 2, 3, i); __PYX_ERR(0, 326, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 326, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 326, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 326, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_standard)));
    }
    __pyx_v_times = values[0];
    __pyx_v_units = values[1];
    __pyx_v_calendar = values[2];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("num2pydate", 0, 2, 3, __pyx_nargs); __PYX_ERR(0, 326, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.num2pydate", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8num2pydate(__pyx_self, __pyx_v_times, __pyx_v_units, __pyx_v_calendar);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8num2pydate(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("num2pydate", 0);

  /* "cftime/_cftime.pyx":335
 *     num2date(times,units,calendar,only_use_cftime_datetimes=False,only_use_python_datetimes=True)
 *     """
 *     return num2date(times,units,calendar,only_use_cftime_datetimes=False,only_use_python_datetimes=True)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_num2date); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 335, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_3, __pyx__function);
    __pyx_t_4 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[4 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_2, __pyx_v_times, __pyx_v_units, __pyx_v_calendar};
    __pyx_t_5 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 335, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_only_use_cftime_datetimes, Py_False, __pyx_t_5, __pyx_callargs+4, 0) < (0)) __PYX_ERR(0, 335, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_only_use_python_datetimes, Py_True, __pyx_t_5, __pyx_callargs+4, 1) < (0)) __PYX_ERR(0, 335, __pyx_L1_error)
    __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_3, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_5);
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 335, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":326
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2pydate(times,units,calendar='standard'):
 *     """
*/

  /* 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_5);
  __Pyx_AddTraceback("cftime._cftime.num2pydate", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":386
 *  }
 * 
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     if use_python_datetime:
 *         return real_datetime(
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_11to_calendar_specific_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_11to_calendar_specific_datetime = {"to_calendar_specific_datetime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_11to_calendar_specific_datetime, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_11to_calendar_specific_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_dt = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_use_python_datetime = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[4] = {0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("to_calendar_specific_datetime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_dt,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_use_python_datetime,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 386, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 386, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 386, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 386, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 386, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "to_calendar_specific_datetime", 0) < (0)) __PYX_ERR(0, 386, __pyx_L3_error)
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 3; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("to_calendar_specific_datetime", 0, 3, 4, i); __PYX_ERR(0, 386, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 386, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 386, __pyx_L3_error)
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 386, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 386, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_dt = values[0];
    __pyx_v_calendar = values[1];
    __pyx_v_use_python_datetime = values[2];
    __pyx_v_has_year_zero = values[3];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("to_calendar_specific_datetime", 0, 3, 4, __pyx_nargs); __PYX_ERR(0, 386, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.to_calendar_specific_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_10to_calendar_specific_datetime(__pyx_self, __pyx_v_dt, __pyx_v_calendar, __pyx_v_use_python_datetime, __pyx_v_has_year_zero);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_10to_calendar_specific_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dt, PyObject *__pyx_v_calendar, PyObject *__pyx_v_use_python_datetime, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_date_type = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  size_t __pyx_t_12;
  PyObject *__pyx_t_13 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("to_calendar_specific_datetime", 0);

  /* "cftime/_cftime.pyx":387
 * 
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):
 *     if use_python_datetime:             # <<<<<<<<<<<<<<
 *         return real_datetime(
 *                dt.year,
*/
  __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_use_python_datetime); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 387, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":388
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):
 *     if use_python_datetime:
 *         return real_datetime(             # <<<<<<<<<<<<<<
 *                dt.year,
 *                dt.month,
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_3 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_real_datetime); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);

    /* "cftime/_cftime.pyx":389
 *     if use_python_datetime:
 *         return real_datetime(
 *                dt.year,             # <<<<<<<<<<<<<<
 *                dt.month,
 *                dt.day,
*/
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 389, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);

    /* "cftime/_cftime.pyx":390
 *         return real_datetime(
 *                dt.year,
 *                dt.month,             # <<<<<<<<<<<<<<
 *                dt.day,
 *                dt.hour,
*/
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 390, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);

    /* "cftime/_cftime.pyx":391
 *                dt.year,
 *                dt.month,
 *                dt.day,             # <<<<<<<<<<<<<<
 *                dt.hour,
 *                dt.minute,
*/
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);

    /* "cftime/_cftime.pyx":392
 *                dt.month,
 *                dt.day,
 *                dt.hour,             # <<<<<<<<<<<<<<
 *                dt.minute,
 *                dt.second,
*/
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 392, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);

    /* "cftime/_cftime.pyx":393
 *                dt.day,
 *                dt.hour,
 *                dt.minute,             # <<<<<<<<<<<<<<
 *                dt.second,
 *                dt.microsecond)
*/
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 393, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);

    /* "cftime/_cftime.pyx":394
 *                dt.hour,
 *                dt.minute,
 *                dt.second,             # <<<<<<<<<<<<<<
 *                dt.microsecond)
 *     else:
*/
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 394, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);

    /* "cftime/_cftime.pyx":395
 *                dt.minute,
 *                dt.second,
 *                dt.microsecond)             # <<<<<<<<<<<<<<
 *     else:
 *         date_type = DATE_TYPES[calendar]
*/
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 395, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_12 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
      assert(__pyx_t_3);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
      __pyx_t_12 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[8] = {__pyx_t_3, __pyx_t_5, __pyx_t_6, __pyx_t_7, __pyx_t_8, __pyx_t_9, __pyx_t_10, __pyx_t_11};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_12, (8-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __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_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 388, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":387
 * 
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):
 *     if use_python_datetime:             # <<<<<<<<<<<<<<
 *         return real_datetime(
 *                dt.year,
*/
  }

  /* "cftime/_cftime.pyx":397
 *                dt.microsecond)
 *     else:
 *         date_type = DATE_TYPES[calendar]             # <<<<<<<<<<<<<<
 *         return date_type(
 *                dt.year,
*/
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_DATE_TYPES); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 397, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_4 = __Pyx_PyObject_GetItem(__pyx_t_2, __pyx_v_calendar); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 397, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_date_type = __pyx_t_4;
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":398
 *     else:
 *         date_type = DATE_TYPES[calendar]
 *         return date_type(             # <<<<<<<<<<<<<<
 *                dt.year,
 *                dt.month,
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_2 = NULL;
    __Pyx_INCREF(__pyx_v_date_type);
    __pyx_t_11 = __pyx_v_date_type; 

    /* "cftime/_cftime.pyx":399
 *         date_type = DATE_TYPES[calendar]
 *         return date_type(
 *                dt.year,             # <<<<<<<<<<<<<<
 *                dt.month,
 *                dt.day,
*/
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 399, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);

    /* "cftime/_cftime.pyx":400
 *         return date_type(
 *                dt.year,
 *                dt.month,             # <<<<<<<<<<<<<<
 *                dt.day,
 *                dt.hour,
*/
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 400, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);

    /* "cftime/_cftime.pyx":401
 *                dt.year,
 *                dt.month,
 *                dt.day,             # <<<<<<<<<<<<<<
 *                dt.hour,
 *                dt.minute,
*/
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 401, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);

    /* "cftime/_cftime.pyx":402
 *                dt.month,
 *                dt.day,
 *                dt.hour,             # <<<<<<<<<<<<<<
 *                dt.minute,
 *                dt.second,
*/
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 402, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);

    /* "cftime/_cftime.pyx":403
 *                dt.day,
 *                dt.hour,
 *                dt.minute,             # <<<<<<<<<<<<<<
 *                dt.second,
 *                dt.microsecond,
*/
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 403, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);

    /* "cftime/_cftime.pyx":404
 *                dt.hour,
 *                dt.minute,
 *                dt.second,             # <<<<<<<<<<<<<<
 *                dt.microsecond,
 *                calendar=calendar,has_year_zero=has_year_zero)
*/
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 404, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);

    /* "cftime/_cftime.pyx":405
 *                dt.minute,
 *                dt.second,
 *                dt.microsecond,             # <<<<<<<<<<<<<<
 *                calendar=calendar,has_year_zero=has_year_zero)
 * 
*/
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 405, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);

    /* "cftime/_cftime.pyx":406
 *                dt.second,
 *                dt.microsecond,
 *                calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * _MAX_INT64 = np.iinfo("int64").max
*/
    __pyx_t_12 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_11);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
      __pyx_t_12 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[8 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_2, __pyx_t_10, __pyx_t_9, __pyx_t_8, __pyx_t_7, __pyx_t_6, __pyx_t_5, __pyx_t_3};
      __pyx_t_13 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 398, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_13, __pyx_callargs+8, 0) < (0)) __PYX_ERR(0, 398, __pyx_L1_error)
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_13, __pyx_callargs+8, 1) < (0)) __PYX_ERR(0, 398, __pyx_L1_error)
      __pyx_t_4 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_12, (8-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_13);
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __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_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 398, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":386
 *  }
 * 
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     if use_python_datetime:
 *         return real_datetime(
*/

  /* 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_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_AddTraceback("cftime._cftime.to_calendar_specific_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_date_type);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":412
 * 
 * 
 * def cast_to_int(num, units=None):             # <<<<<<<<<<<<<<
 *     if num.dtype.kind in "iu":
 *         return num
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_13cast_to_int(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_13cast_to_int = {"cast_to_int", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_13cast_to_int, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_13cast_to_int(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_num = 0;
  PyObject *__pyx_v_units = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("cast_to_int (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_num,&__pyx_mstate_global->__pyx_n_u_units_2,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 412, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 412, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 412, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "cast_to_int", 0) < (0)) __PYX_ERR(0, 412, __pyx_L3_error)
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("cast_to_int", 0, 1, 2, i); __PYX_ERR(0, 412, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 412, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 412, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_num = values[0];
    __pyx_v_units = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("cast_to_int", 0, 1, 2, __pyx_nargs); __PYX_ERR(0, 412, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.cast_to_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_12cast_to_int(__pyx_self, __pyx_v_num, __pyx_v_units);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_12cast_to_int(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num, PyObject *__pyx_v_units) {
  PyObject *__pyx_v_int_num = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  size_t __pyx_t_9;
  PyObject *__pyx_t_10 = NULL;
  int __pyx_t_11;
  PyObject *__pyx_t_12 = NULL;
  PyObject *__pyx_t_13 = NULL;
  PyObject *__pyx_t_14 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("cast_to_int", 0);

  /* "cftime/_cftime.pyx":413
 * 
 * def cast_to_int(num, units=None):
 *     if num.dtype.kind in "iu":             # <<<<<<<<<<<<<<
 *         return num
 *     else:
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_num, __pyx_mstate_global->__pyx_n_u_dtype); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 413, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_kind); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 413, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = (__Pyx_PyUnicode_ContainsTF(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_iu, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 413, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":414
 * def cast_to_int(num, units=None):
 *     if num.dtype.kind in "iu":
 *         return num             # <<<<<<<<<<<<<<
 *     else:
 *         #if np.any(num < _MIN_INT64) or np.any(num > _MAX_INT64):
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_num);
    __pyx_r = __pyx_v_num;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":413
 * 
 * def cast_to_int(num, units=None):
 *     if num.dtype.kind in "iu":             # <<<<<<<<<<<<<<
 *         return num
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":418
 *         #if np.any(num < _MIN_INT64) or np.any(num > _MAX_INT64):
 *         # use this instead to avoid test failures on windows with numpy 1.23.0 (issue #279)
 *         if np.any(np.less(num,_MIN_INT64,casting='same_kind')) or np.any(np.greater(num,_MAX_INT64,casting='same_kind')):             # <<<<<<<<<<<<<<
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         if isinstance(num, np.ma.core.MaskedArray):
*/
  /*else*/ {
    __pyx_t_1 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_any); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_6 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_less); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_MIN_INT64); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_6);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_6, __pyx_v_num, __pyx_t_7};
      __pyx_t_10 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_casting, __pyx_mstate_global->__pyx_n_u_same_kind, __pyx_t_10, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 418, __pyx_L1_error)
      __pyx_t_4 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_10);
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_5))) {
      __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_5);
      assert(__pyx_t_1);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__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;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (!__pyx_t_11) {
    } else {
      __pyx_t_3 = __pyx_t_11;
      goto __pyx_L5_bool_binop_done;
    }
    __pyx_t_5 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_any); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_greater); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_MAX_INT64); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_8, __pyx_v_num, __pyx_t_10};
      __pyx_t_6 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_casting, __pyx_mstate_global->__pyx_n_u_same_kind, __pyx_t_6, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 418, __pyx_L1_error)
      __pyx_t_4 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_6);
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_1);
      assert(__pyx_t_5);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 418, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 418, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_3 = __pyx_t_11;
    __pyx_L5_bool_binop_done:;
    if (unlikely(__pyx_t_3)) {

      /* "cftime/_cftime.pyx":419
 *         # use this instead to avoid test failures on windows with numpy 1.23.0 (issue #279)
 *         if np.any(np.less(num,_MIN_INT64,casting='same_kind')) or np.any(np.greater(num,_MAX_INT64,casting='same_kind')):
 *             raise OverflowError('time values outside range of 64 bit signed integers')             # <<<<<<<<<<<<<<
 *         if isinstance(num, np.ma.core.MaskedArray):
 *             int_num = np.ma.masked_array(np.rint(num), dtype=np.int64)
*/
      __pyx_t_1 = NULL;
      __pyx_t_9 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_mstate_global->__pyx_kp_u_time_values_outside_range_of_64};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_OverflowError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 419, __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(0, 419, __pyx_L1_error)

      /* "cftime/_cftime.pyx":418
 *         #if np.any(num < _MIN_INT64) or np.any(num > _MAX_INT64):
 *         # use this instead to avoid test failures on windows with numpy 1.23.0 (issue #279)
 *         if np.any(np.less(num,_MIN_INT64,casting='same_kind')) or np.any(np.greater(num,_MAX_INT64,casting='same_kind')):             # <<<<<<<<<<<<<<
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         if isinstance(num, np.ma.core.MaskedArray):
*/
    }

    /* "cftime/_cftime.pyx":420
 *         if np.any(np.less(num,_MIN_INT64,casting='same_kind')) or np.any(np.greater(num,_MAX_INT64,casting='same_kind')):
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         if isinstance(num, np.ma.core.MaskedArray):             # <<<<<<<<<<<<<<
 *             int_num = np.ma.masked_array(np.rint(num), dtype=np.int64)
 *             # use ceil instead of rint if 1 microsec less than a second
*/
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 420, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 420, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_core); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 420, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_MaskedArray); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 420, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_3 = PyObject_IsInstance(__pyx_v_num, __pyx_t_1); if (unlikely(__pyx_t_3 == ((int)-1))) __PYX_ERR(0, 420, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (__pyx_t_3) {

      /* "cftime/_cftime.pyx":421
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         if isinstance(num, np.ma.core.MaskedArray):
 *             int_num = np.ma.masked_array(np.rint(num), dtype=np.int64)             # <<<<<<<<<<<<<<
 *             # use ceil instead of rint if 1 microsec less than a second
 *             # or floor if 1 microsec greater than a second (issue #187)
*/
      __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_t_2 = __pyx_t_5;
      __Pyx_INCREF(__pyx_t_2);
      __pyx_t_7 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_rint); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __pyx_t_9 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_10))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_10);
        assert(__pyx_t_7);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
        __Pyx_INCREF(__pyx_t_7);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
        __pyx_t_9 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_num};
        __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __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(0, 421, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 421, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __pyx_t_9 = 0;
      {
        PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, __pyx_t_4};
        __pyx_t_10 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 421, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_7, __pyx_t_10, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 421, __pyx_L1_error)
        __pyx_t_1 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_masked_array, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_10);
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 421, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __pyx_v_int_num = __pyx_t_1;
      __pyx_t_1 = 0;

      /* "cftime/_cftime.pyx":424
 *             # use ceil instead of rint if 1 microsec less than a second
 *             # or floor if 1 microsec greater than a second (issue #187)
 *             if units not in microsec_units and units not in millisec_units:             # <<<<<<<<<<<<<<
 *                 int_num = np.ma.where(int_num%1000000 == 1, \
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)
*/
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_microsec_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 424, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_11 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 424, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (__pyx_t_11) {
      } else {
        __pyx_t_3 = __pyx_t_11;
        goto __pyx_L9_bool_binop_done;
      }
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_millisec_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 424, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_11 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 424, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_3 = __pyx_t_11;
      __pyx_L9_bool_binop_done:;
      if (__pyx_t_3) {

        /* "cftime/_cftime.pyx":425
 *             # or floor if 1 microsec greater than a second (issue #187)
 *             if units not in microsec_units and units not in millisec_units:
 *                 int_num = np.ma.where(int_num%1000000 == 1, \             # <<<<<<<<<<<<<<
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.ma.where(int_num%1000000 == 999999, \
*/
        __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 425, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 425, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __pyx_t_5 = __pyx_t_7;
        __Pyx_INCREF(__pyx_t_5);
        __pyx_t_10 = __Pyx_PyLong_RemainderObjC(__pyx_v_int_num, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 425, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_4 = __Pyx_PyLong_EqObjC(__pyx_t_10, __pyx_mstate_global->__pyx_int_1, 1, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 425, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":426
 *             if units not in microsec_units and units not in millisec_units:
 *                 int_num = np.ma.where(int_num%1000000 == 1, \
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)             # <<<<<<<<<<<<<<
 *                 int_num = np.ma.where(int_num%1000000 == 999999, \
 *                           np.ma.masked_array(np.ceil(num),dtype=np.int64), int_num)
*/
        __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        __pyx_t_2 = __pyx_t_8;
        __Pyx_INCREF(__pyx_t_2);
        __pyx_t_12 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_floor); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_14))) {
          __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_14);
          assert(__pyx_t_12);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14);
          __Pyx_INCREF(__pyx_t_12);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_14, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_num};
          __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_14, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 426, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_6);
        }
        __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 426, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
        __pyx_t_9 = 0;
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, __pyx_t_6};
          __pyx_t_14 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 426, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_14);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_12, __pyx_t_14, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 426, __pyx_L1_error)
          __pyx_t_10 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_masked_array, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_14);
          __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
          __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 426, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
        }
        __pyx_t_9 = 0;
        {
          PyObject *__pyx_callargs[4] = {__pyx_t_5, __pyx_t_4, __pyx_t_10, __pyx_v_int_num};
          __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_where, __pyx_callargs+__pyx_t_9, (4-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 425, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __Pyx_DECREF_SET(__pyx_v_int_num, __pyx_t_1);
        __pyx_t_1 = 0;

        /* "cftime/_cftime.pyx":427
 *                 int_num = np.ma.where(int_num%1000000 == 1, \
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.ma.where(int_num%1000000 == 999999, \             # <<<<<<<<<<<<<<
 *                           np.ma.masked_array(np.ceil(num),dtype=np.int64), int_num)
 *         else:
*/
        __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __pyx_t_7 = __pyx_t_4;
        __Pyx_INCREF(__pyx_t_7);
        __pyx_t_10 = __Pyx_PyLong_RemainderObjC(__pyx_v_int_num, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_5 = __Pyx_PyLong_EqObjC(__pyx_t_10, __pyx_mstate_global->__pyx_int_999999, 0xF423F, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":428
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.ma.where(int_num%1000000 == 999999, \
 *                           np.ma.masked_array(np.ceil(num),dtype=np.int64), int_num)             # <<<<<<<<<<<<<<
 *         else:
 *             int_num = np.array(np.rint(num), dtype=np.int64)
*/
        __Pyx_GetModuleGlobalName(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_14, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
        __pyx_t_8 = __pyx_t_12;
        __Pyx_INCREF(__pyx_t_8);
        __pyx_t_6 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ceil); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_13))) {
          __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_13);
          assert(__pyx_t_6);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13);
          __Pyx_INCREF(__pyx_t_6);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_13, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_num};
          __pyx_t_14 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_13, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 428, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_14);
        }
        __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 428, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        __pyx_t_9 = 0;
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_8, __pyx_t_14};
          __pyx_t_13 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 428, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_6, __pyx_t_13, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 428, __pyx_L1_error)
          __pyx_t_10 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_masked_array, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_13);
          __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 428, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_10);
        }
        __pyx_t_9 = 0;
        {
          PyObject *__pyx_callargs[4] = {__pyx_t_7, __pyx_t_5, __pyx_t_10, __pyx_v_int_num};
          __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_where, __pyx_callargs+__pyx_t_9, (4-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 427, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __Pyx_DECREF_SET(__pyx_v_int_num, __pyx_t_1);
        __pyx_t_1 = 0;

        /* "cftime/_cftime.pyx":424
 *             # use ceil instead of rint if 1 microsec less than a second
 *             # or floor if 1 microsec greater than a second (issue #187)
 *             if units not in microsec_units and units not in millisec_units:             # <<<<<<<<<<<<<<
 *                 int_num = np.ma.where(int_num%1000000 == 1, \
 *                           np.ma.masked_array(np.floor(num),dtype=np.int64), int_num)
*/
      }

      /* "cftime/_cftime.pyx":420
 *         if np.any(np.less(num,_MIN_INT64,casting='same_kind')) or np.any(np.greater(num,_MAX_INT64,casting='same_kind')):
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         if isinstance(num, np.ma.core.MaskedArray):             # <<<<<<<<<<<<<<
 *             int_num = np.ma.masked_array(np.rint(num), dtype=np.int64)
 *             # use ceil instead of rint if 1 microsec less than a second
*/
      goto __pyx_L7;
    }

    /* "cftime/_cftime.pyx":430
 *                           np.ma.masked_array(np.ceil(num),dtype=np.int64), int_num)
 *         else:
 *             int_num = np.array(np.rint(num), dtype=np.int64)             # <<<<<<<<<<<<<<
 *             if units not in microsec_units and units not in millisec_units:
 *                 int_num = np.where(int_num%1000000 == 1, \
*/
    /*else*/ {
      __pyx_t_4 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __pyx_t_7 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_12);
      __pyx_t_13 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_rint); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      __pyx_t_9 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_13))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_13);
        assert(__pyx_t_7);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_13);
        __Pyx_INCREF(__pyx_t_7);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_13, __pyx__function);
        __pyx_t_9 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_num};
        __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_13, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 430, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_13);
      __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
      __pyx_t_9 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_5))) {
        __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_5);
        assert(__pyx_t_4);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
        __Pyx_INCREF(__pyx_t_4);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
        __pyx_t_9 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_4, __pyx_t_10};
        __pyx_t_13 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 430, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_7, __pyx_t_13, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 430, __pyx_L1_error)
        __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_13);
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 430, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __pyx_v_int_num = __pyx_t_1;
      __pyx_t_1 = 0;

      /* "cftime/_cftime.pyx":431
 *         else:
 *             int_num = np.array(np.rint(num), dtype=np.int64)
 *             if units not in microsec_units and units not in millisec_units:             # <<<<<<<<<<<<<<
 *                 int_num = np.where(int_num%1000000 == 1, \
 *                           np.array(np.floor(num),dtype=np.int64), int_num)
*/
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_microsec_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 431, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_11 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 431, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (__pyx_t_11) {
      } else {
        __pyx_t_3 = __pyx_t_11;
        goto __pyx_L12_bool_binop_done;
      }
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_millisec_units); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 431, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_11 = (__Pyx_PySequence_ContainsTF(__pyx_v_units, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 431, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_3 = __pyx_t_11;
      __pyx_L12_bool_binop_done:;
      if (__pyx_t_3) {

        /* "cftime/_cftime.pyx":432
 *             int_num = np.array(np.rint(num), dtype=np.int64)
 *             if units not in microsec_units and units not in millisec_units:
 *                 int_num = np.where(int_num%1000000 == 1, \             # <<<<<<<<<<<<<<
 *                           np.array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.where(int_num%1000000 == 999999, \
*/
        __pyx_t_5 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 432, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_where); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 432, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        __pyx_t_13 = __Pyx_PyLong_RemainderObjC(__pyx_v_int_num, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 432, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_10 = __Pyx_PyLong_EqObjC(__pyx_t_13, __pyx_mstate_global->__pyx_int_1, 1, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 432, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;

        /* "cftime/_cftime.pyx":433
 *             if units not in microsec_units and units not in millisec_units:
 *                 int_num = np.where(int_num%1000000 == 1, \
 *                           np.array(np.floor(num),dtype=np.int64), int_num)             # <<<<<<<<<<<<<<
 *                 int_num = np.where(int_num%1000000 == 999999, \
 *                           np.array(np.ceil(num),dtype=np.int64), int_num)
*/
        __pyx_t_4 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
        __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
        __pyx_t_14 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_floor); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_2))) {
          __pyx_t_14 = PyMethod_GET_SELF(__pyx_t_2);
          assert(__pyx_t_14);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
          __Pyx_INCREF(__pyx_t_14);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_v_num};
          __pyx_t_12 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 433, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_12);
        }
        __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_6))) {
          __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6);
          assert(__pyx_t_4);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
          __Pyx_INCREF(__pyx_t_4);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_4, __pyx_t_12};
          __pyx_t_2 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 433, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_2);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_14, __pyx_t_2, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 433, __pyx_L1_error)
          __pyx_t_13 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_2);
          __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
          if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 433, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
        }
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_7))) {
          __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_7);
          assert(__pyx_t_5);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
          __Pyx_INCREF(__pyx_t_5);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[4] = {__pyx_t_5, __pyx_t_10, __pyx_t_13, __pyx_v_int_num};
          __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_9, (4-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 432, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __Pyx_DECREF_SET(__pyx_v_int_num, __pyx_t_1);
        __pyx_t_1 = 0;

        /* "cftime/_cftime.pyx":434
 *                 int_num = np.where(int_num%1000000 == 1, \
 *                           np.array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.where(int_num%1000000 == 999999, \             # <<<<<<<<<<<<<<
 *                           np.array(np.ceil(num),dtype=np.int64), int_num)
 *         return int_num
*/
        __pyx_t_7 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_13, __pyx_mstate_global->__pyx_n_u_where); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
        __pyx_t_13 = __Pyx_PyLong_RemainderObjC(__pyx_v_int_num, __pyx_mstate_global->__pyx_int_1000000, 0xF4240, 0, 0); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_13);
        __pyx_t_5 = __Pyx_PyLong_EqObjC(__pyx_t_13, __pyx_mstate_global->__pyx_int_999999, 0xF423F, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;

        /* "cftime/_cftime.pyx":435
 *                           np.array(np.floor(num),dtype=np.int64), int_num)
 *                 int_num = np.where(int_num%1000000 == 999999, \
 *                           np.array(np.ceil(num),dtype=np.int64), int_num)             # <<<<<<<<<<<<<<
 *         return int_num
 * 
*/
        __pyx_t_6 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_14);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __pyx_t_12 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
        __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_ceil); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_8))) {
          __pyx_t_12 = PyMethod_GET_SELF(__pyx_t_8);
          assert(__pyx_t_12);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
          __Pyx_INCREF(__pyx_t_12);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_v_num};
          __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 435, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_2);
        }
        __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __pyx_t_12 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 435, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_12);
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_14))) {
          __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_14);
          assert(__pyx_t_6);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14);
          __Pyx_INCREF(__pyx_t_6);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_14, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_6, __pyx_t_2};
          __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 435, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_8);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_t_12, __pyx_t_8, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 435, __pyx_L1_error)
          __pyx_t_13 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_14, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
          if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 435, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_13);
        }
        __pyx_t_9 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_10))) {
          __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_10);
          assert(__pyx_t_7);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
          __Pyx_INCREF(__pyx_t_7);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
          __pyx_t_9 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[4] = {__pyx_t_7, __pyx_t_5, __pyx_t_13, __pyx_v_int_num};
          __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_9, (4-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 434, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __Pyx_DECREF_SET(__pyx_v_int_num, __pyx_t_1);
        __pyx_t_1 = 0;

        /* "cftime/_cftime.pyx":431
 *         else:
 *             int_num = np.array(np.rint(num), dtype=np.int64)
 *             if units not in microsec_units and units not in millisec_units:             # <<<<<<<<<<<<<<
 *                 int_num = np.where(int_num%1000000 == 1, \
 *                           np.array(np.floor(num),dtype=np.int64), int_num)
*/
      }
    }
    __pyx_L7:;

    /* "cftime/_cftime.pyx":436
 *                 int_num = np.where(int_num%1000000 == 999999, \
 *                           np.array(np.ceil(num),dtype=np.int64), int_num)
 *         return int_num             # <<<<<<<<<<<<<<
 * 
 * 
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_int_num);
    __pyx_r = __pyx_v_int_num;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":412
 * 
 * 
 * def cast_to_int(num, units=None):             # <<<<<<<<<<<<<<
 *     if num.dtype.kind in "iu":
 *         return num
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __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_XDECREF(__pyx_t_12);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_AddTraceback("cftime._cftime.cast_to_int", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_int_num);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":439
 * 
 * 
 * def upcast_times(num):             # <<<<<<<<<<<<<<
 *     """Cast times array to larger float or integer dtype before scaling
 *     to units of microseconds.
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_15upcast_times(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_14upcast_times, "Cast times array to larger float or integer dtype before scaling\n    to units of microseconds.\n    ");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_15upcast_times = {"upcast_times", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_15upcast_times, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_14upcast_times};
static PyObject *__pyx_pw_6cftime_7_cftime_15upcast_times(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_num = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("upcast_times (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_num,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 439, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 439, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "upcast_times", 0) < (0)) __PYX_ERR(0, 439, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("upcast_times", 1, 1, 1, i); __PYX_ERR(0, 439, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 439, __pyx_L3_error)
    }
    __pyx_v_num = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("upcast_times", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 439, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.upcast_times", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_14upcast_times(__pyx_self, __pyx_v_num);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_14upcast_times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  size_t __pyx_t_6;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("upcast_times", 0);

  /* "cftime/_cftime.pyx":443
 *     to units of microseconds.
 *     """
 *     if num.dtype.kind == "f":             # <<<<<<<<<<<<<<
 *         return num.astype(np.longdouble)
 *     else:
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_num, __pyx_mstate_global->__pyx_n_u_dtype); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 443, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_kind); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 443, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_f, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 443, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":444
 *     """
 *     if num.dtype.kind == "f":
 *         return num.astype(np.longdouble)             # <<<<<<<<<<<<<<
 *     else:
 *         return num.astype(np.int64)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = __pyx_v_num;
    __Pyx_INCREF(__pyx_t_1);
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 444, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 444, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_5};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 444, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":443
 *     to units of microseconds.
 *     """
 *     if num.dtype.kind == "f":             # <<<<<<<<<<<<<<
 *         return num.astype(np.longdouble)
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":446
 *         return num.astype(np.longdouble)
 *     else:
 *         return num.astype(np.int64)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_5 = __pyx_v_num;
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 446, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_int64); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 446, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 446, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":439
 * 
 * 
 * def upcast_times(num):             # <<<<<<<<<<<<<<
 *     """Cast times array to larger float or integer dtype before scaling
 *     to units of microseconds.
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("cftime._cftime.upcast_times", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":449
 * 
 * 
 * def scale_times(num, factor):             # <<<<<<<<<<<<<<
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_17scale_times(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_16scale_times, "Scale times by a factor, raise an error if values will not fit in np.int64");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_17scale_times = {"scale_times", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_17scale_times, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_16scale_times};
static PyObject *__pyx_pw_6cftime_7_cftime_17scale_times(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_num = 0;
  PyObject *__pyx_v_factor = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("scale_times (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_num,&__pyx_mstate_global->__pyx_n_u_factor,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 449, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 449, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 449, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "scale_times", 0) < (0)) __PYX_ERR(0, 449, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("scale_times", 1, 2, 2, i); __PYX_ERR(0, 449, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 2)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 449, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 449, __pyx_L3_error)
    }
    __pyx_v_num = values[0];
    __pyx_v_factor = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("scale_times", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 449, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.scale_times", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_16scale_times(__pyx_self, __pyx_v_num, __pyx_v_factor);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_16scale_times(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_num, PyObject *__pyx_v_factor) {
  PyObject *__pyx_v_minimum = NULL;
  PyObject *__pyx_v_maximum = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  size_t __pyx_t_8;
  int __pyx_t_9;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("scale_times", 0);

  /* "cftime/_cftime.pyx":451
 * def scale_times(num, factor):
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":             # <<<<<<<<<<<<<<
 *         return factor * num
 *     else:
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_num, __pyx_mstate_global->__pyx_n_u_dtype); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 451, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_kind); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 451, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_f, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 451, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":452
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":
 *         return factor * num             # <<<<<<<<<<<<<<
 *     else:
 *         if num.size == 0: # empty array (issue #287)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_2 = PyNumber_Multiply(__pyx_v_factor, __pyx_v_num); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 452, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":451
 * def scale_times(num, factor):
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":             # <<<<<<<<<<<<<<
 *         return factor * num
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":454
 *         return factor * num
 *     else:
 *         if num.size == 0: # empty array (issue #287)             # <<<<<<<<<<<<<<
 *             return num
 *         # Python integers have arbitrary precision, so convert min and max
*/
  /*else*/ {
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_num, __pyx_mstate_global->__pyx_n_u_size); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 454, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_2, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 454, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (__pyx_t_3) {

      /* "cftime/_cftime.pyx":455
 *     else:
 *         if num.size == 0: # empty array (issue #287)
 *             return num             # <<<<<<<<<<<<<<
 *         # Python integers have arbitrary precision, so convert min and max
 *         # returned by NumPy functions through item, prior to multiplying by
*/
      __Pyx_XDECREF(__pyx_r);
      __Pyx_INCREF(__pyx_v_num);
      __pyx_r = __pyx_v_num;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":454
 *         return factor * num
 *     else:
 *         if num.size == 0: # empty array (issue #287)             # <<<<<<<<<<<<<<
 *             return num
 *         # Python integers have arbitrary precision, so convert min and max
*/
    }

    /* "cftime/_cftime.pyx":459
 *         # returned by NumPy functions through item, prior to multiplying by
 *         # factor.
 *         minimum = np.min(num).item() * factor             # <<<<<<<<<<<<<<
 *         maximum = np.max(num).item() * factor
 *         if minimum < _MIN_INT64 or maximum > _MAX_INT64:
*/
    __pyx_t_5 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 459, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_min); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 459, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_8 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_5);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_5);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_8 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_num};
      __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 459, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_1 = __pyx_t_4;
    __Pyx_INCREF(__pyx_t_1);
    __pyx_t_8 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 459, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_4 = PyNumber_Multiply(__pyx_t_2, __pyx_v_factor); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 459, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_minimum = __pyx_t_4;
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":460
 *         # factor.
 *         minimum = np.min(num).item() * factor
 *         maximum = np.max(num).item() * factor             # <<<<<<<<<<<<<<
 *         if minimum < _MIN_INT64 or maximum > _MAX_INT64:
 *             # allowable time range = 292,471 years
*/
    __pyx_t_7 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 460, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_max); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 460, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_8 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_7);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_8 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_num};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 460, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_2 = __pyx_t_1;
    __Pyx_INCREF(__pyx_t_2);
    __pyx_t_8 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
      __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_8, (1-__pyx_t_8) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 460, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_1 = PyNumber_Multiply(__pyx_t_4, __pyx_v_factor); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 460, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_v_maximum = __pyx_t_1;
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":461
 *         minimum = np.min(num).item() * factor
 *         maximum = np.max(num).item() * factor
 *         if minimum < _MIN_INT64 or maximum > _MAX_INT64:             # <<<<<<<<<<<<<<
 *             # allowable time range = 292,471 years
 *             raise OverflowError('time values outside range of 64 bit signed integers')
*/
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_MIN_INT64); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = PyObject_RichCompare(__pyx_v_minimum, __pyx_t_1, Py_LT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (!__pyx_t_9) {
    } else {
      __pyx_t_3 = __pyx_t_9;
      goto __pyx_L6_bool_binop_done;
    }
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_MAX_INT64); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_1 = PyObject_RichCompare(__pyx_v_maximum, __pyx_t_4, Py_GT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_9 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_9 < 0))) __PYX_ERR(0, 461, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_3 = __pyx_t_9;
    __pyx_L6_bool_binop_done:;
    if (unlikely(__pyx_t_3)) {

      /* "cftime/_cftime.pyx":463
 *         if minimum < _MIN_INT64 or maximum > _MAX_INT64:
 *             # allowable time range = 292,471 years
 *             raise OverflowError('time values outside range of 64 bit signed integers')             # <<<<<<<<<<<<<<
 *         else:
 *             return num * factor
*/
      __pyx_t_4 = NULL;
      __pyx_t_8 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_time_values_outside_range_of_64};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_OverflowError)), __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 463, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 463, __pyx_L1_error)

      /* "cftime/_cftime.pyx":461
 *         minimum = np.min(num).item() * factor
 *         maximum = np.max(num).item() * factor
 *         if minimum < _MIN_INT64 or maximum > _MAX_INT64:             # <<<<<<<<<<<<<<
 *             # allowable time range = 292,471 years
 *             raise OverflowError('time values outside range of 64 bit signed integers')
*/
    }

    /* "cftime/_cftime.pyx":465
 *             raise OverflowError('time values outside range of 64 bit signed integers')
 *         else:
 *             return num * factor             # <<<<<<<<<<<<<<
 * 
 * 
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_1 = PyNumber_Multiply(__pyx_v_num, __pyx_v_factor); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 465, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_r = __pyx_t_1;
      __pyx_t_1 = 0;
      goto __pyx_L0;
    }
  }

  /* "cftime/_cftime.pyx":449
 * 
 * 
 * def scale_times(num, factor):             # <<<<<<<<<<<<<<
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_AddTraceback("cftime._cftime.scale_times", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_minimum);
  __Pyx_XDECREF(__pyx_v_maximum);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":468
 * 
 * 
 * def decode_date_from_scalar(time_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_19decode_date_from_scalar(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_18decode_date_from_scalar, "Decode a date from a scalar input.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_19decode_date_from_scalar = {"decode_date_from_scalar", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_19decode_date_from_scalar, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_18decode_date_from_scalar};
static PyObject *__pyx_pw_6cftime_7_cftime_19decode_date_from_scalar(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_time_in_microseconds = 0;
  PyObject *__pyx_v_basedate = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("decode_date_from_scalar (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_time_in_microseconds,&__pyx_mstate_global->__pyx_n_u_basedate,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 468, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 468, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 468, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "decode_date_from_scalar", 0) < (0)) __PYX_ERR(0, 468, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("decode_date_from_scalar", 1, 2, 2, i); __PYX_ERR(0, 468, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 2)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 468, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 468, __pyx_L3_error)
    }
    __pyx_v_time_in_microseconds = values[0];
    __pyx_v_basedate = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("decode_date_from_scalar", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 468, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.decode_date_from_scalar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_18decode_date_from_scalar(__pyx_self, __pyx_v_time_in_microseconds, __pyx_v_basedate);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_18decode_date_from_scalar(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_time_in_microseconds, PyObject *__pyx_v_basedate) {
  PyObject *__pyx_v_delta = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  int __pyx_t_9;
  PyObject *__pyx_t_10 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("decode_date_from_scalar", 0);

  /* "cftime/_cftime.pyx":470
 * def decode_date_from_scalar(time_in_microseconds, basedate):
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)             # <<<<<<<<<<<<<<
 *     try:
 *         return basedate + delta
*/
  __pyx_t_4 = __pyx_v_time_in_microseconds;
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_5 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_timedelta64_us};
    __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 470, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
  }
  __pyx_t_2 = __pyx_t_3;
  __Pyx_INCREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 470, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_4};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 470, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_delta = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":471
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
 *     try:             # <<<<<<<<<<<<<<
 *         return basedate + delta
 *     except OverflowError:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8);
    __Pyx_XGOTREF(__pyx_t_6);
    __Pyx_XGOTREF(__pyx_t_7);
    __Pyx_XGOTREF(__pyx_t_8);
    /*try:*/ {

      /* "cftime/_cftime.pyx":472
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
 *     try:
 *         return basedate + delta             # <<<<<<<<<<<<<<
 *     except OverflowError:
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_1 = PyNumber_Add(__pyx_v_basedate, __pyx_v_delta); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 472, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_r = __pyx_t_1;
      __pyx_t_1 = 0;
      goto __pyx_L7_try_return;

      /* "cftime/_cftime.pyx":471
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
 *     try:             # <<<<<<<<<<<<<<
 *         return basedate + delta
 *     except OverflowError:
*/
    }
    __pyx_L3_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_4); __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":473
 *     try:
 *         return basedate + delta
 *     except OverflowError:             # <<<<<<<<<<<<<<
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")
 * 
*/
    __pyx_t_9 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_OverflowError))));
    if (__pyx_t_9) {
      __Pyx_AddTraceback("cftime._cftime.decode_date_from_scalar", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_1, &__pyx_t_3, &__pyx_t_4) < 0) __PYX_ERR(0, 473, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_1);
      __Pyx_XGOTREF(__pyx_t_3);
      __Pyx_XGOTREF(__pyx_t_4);

      /* "cftime/_cftime.pyx":474
 *         return basedate + delta
 *     except OverflowError:
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")             # <<<<<<<<<<<<<<
 * 
 * 
*/
      __pyx_t_10 = NULL;
      __pyx_t_5 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_mstate_global->__pyx_kp_u_OverflowError_in_datetime_possib};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 474, __pyx_L5_except_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(0, 474, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":471
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
 *     try:             # <<<<<<<<<<<<<<
 *         return basedate + delta
 *     except OverflowError:
*/
    __pyx_L5_except_error:;
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_XGIVEREF(__pyx_t_7);
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8);
    goto __pyx_L1_error;
    __pyx_L7_try_return:;
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_XGIVEREF(__pyx_t_7);
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8);
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":468
 * 
 * 
 * def decode_date_from_scalar(time_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
*/

  /* 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_10);
  __Pyx_AddTraceback("cftime._cftime.decode_date_from_scalar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_delta);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":477
 * 
 * 
 * def decode_dates_from_array(times_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode values encoded by an integer array in units of microseconds to dates.
 * 
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_21decode_dates_from_array(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_20decode_dates_from_array, "Decode values encoded by an integer array in units of microseconds to dates.\n    \n    This is an optimized algorithm that operates by flattening and sorting the input\n    array of integers, decoding the first date using the original base date, and then\n    incrementally adding timedeltas to decode the rest of the dates in the array.  This\n    is an optimal approach, because it minimizes the length of the timedeltas used in\n    each addition operation required to decode the times (timedelta addition is the rate\n    limiting step in the process).  The original order of the elements and shape of the\n    array are restored at the end.  The sorting and unsorting steps add only a small\n    overhead.  See discussion and timing results in GitHub issue 269.\n    ");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_21decode_dates_from_array = {"decode_dates_from_array", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_21decode_dates_from_array, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_20decode_dates_from_array};
static PyObject *__pyx_pw_6cftime_7_cftime_21decode_dates_from_array(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_times_in_microseconds = 0;
  PyObject *__pyx_v_basedate = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("decode_dates_from_array (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_times_in_microseconds,&__pyx_mstate_global->__pyx_n_u_basedate,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 477, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 477, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 477, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "decode_dates_from_array", 0) < (0)) __PYX_ERR(0, 477, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("decode_dates_from_array", 1, 2, 2, i); __PYX_ERR(0, 477, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 2)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 477, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 477, __pyx_L3_error)
    }
    __pyx_v_times_in_microseconds = values[0];
    __pyx_v_basedate = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("decode_dates_from_array", 1, 2, 2, __pyx_nargs); __PYX_ERR(0, 477, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.decode_dates_from_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_20decode_dates_from_array(__pyx_self, __pyx_v_times_in_microseconds, __pyx_v_basedate);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_20decode_dates_from_array(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times_in_microseconds, PyObject *__pyx_v_basedate) {
  PyObject *__pyx_v_original_shape = NULL;
  PyObject *__pyx_v_sort_indices = NULL;
  PyObject *__pyx_v_unsort_indices = NULL;
  PyObject *__pyx_v_deltas = NULL;
  PyObject *__pyx_v_differential_deltas = NULL;
  PyObject *__pyx_v_dates = NULL;
  PyObject *__pyx_v_i = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  Py_ssize_t __pyx_t_11;
  PyObject *(*__pyx_t_12)(PyObject *);
  int __pyx_t_13;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("decode_dates_from_array", 0);
  __Pyx_INCREF(__pyx_v_times_in_microseconds);

  /* "cftime/_cftime.pyx":489
 *     overhead.  See discussion and timing results in GitHub issue 269.
 *     """
 *     original_shape = times_in_microseconds.shape             # <<<<<<<<<<<<<<
 *     times_in_microseconds = times_in_microseconds.ravel()
 * 
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_times_in_microseconds, __pyx_mstate_global->__pyx_n_u_shape); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 489, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_original_shape = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":490
 *     """
 *     original_shape = times_in_microseconds.shape
 *     times_in_microseconds = times_in_microseconds.ravel()             # <<<<<<<<<<<<<<
 * 
 *     sort_indices = np.argsort(times_in_microseconds)
*/
  __pyx_t_2 = __pyx_v_times_in_microseconds;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_ravel, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 490, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_times_in_microseconds, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":492
 *     times_in_microseconds = times_in_microseconds.ravel()
 * 
 *     sort_indices = np.argsort(times_in_microseconds)             # <<<<<<<<<<<<<<
 *     unsort_indices = np.argsort(sort_indices)
 *     times_in_microseconds = times_in_microseconds[sort_indices]
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 492, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_argsort); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 492, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_times_in_microseconds};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 492, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_sort_indices = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":493
 * 
 *     sort_indices = np.argsort(times_in_microseconds)
 *     unsort_indices = np.argsort(sort_indices)             # <<<<<<<<<<<<<<
 *     times_in_microseconds = times_in_microseconds[sort_indices]
 * 
*/
  __pyx_t_5 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 493, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_argsort); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 493, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_5);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_sort_indices};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 493, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_unsort_indices = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":494
 *     sort_indices = np.argsort(times_in_microseconds)
 *     unsort_indices = np.argsort(sort_indices)
 *     times_in_microseconds = times_in_microseconds[sort_indices]             # <<<<<<<<<<<<<<
 * 
 *     # We first cast to the np.timedelta64[us] dtype out of convenience, but ultimately
*/
  __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_times_in_microseconds, __pyx_v_sort_indices); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 494, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF_SET(__pyx_v_times_in_microseconds, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":499
 *     # cast to datetime.timedelta objects for operations with cftime objects (we cannot
 *     # cast from integers to datetime.timedelta objects directly).
 *     deltas = times_in_microseconds.astype("timedelta64[us]")             # <<<<<<<<<<<<<<
 *     differential_deltas = np.diff(deltas).astype(timedelta)
 * 
*/
  __pyx_t_4 = __pyx_v_times_in_microseconds;
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_timedelta64_us};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 499, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_deltas = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":500
 *     # cast from integers to datetime.timedelta objects directly).
 *     deltas = times_in_microseconds.astype("timedelta64[us]")
 *     differential_deltas = np.diff(deltas).astype(timedelta)             # <<<<<<<<<<<<<<
 * 
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 500, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_diff); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 500, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_7))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_7);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_deltas};
    __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 500, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  __pyx_t_4 = __pyx_t_5;
  __Pyx_INCREF(__pyx_t_4);
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 500, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 500, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_differential_deltas = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":502
 *     differential_deltas = np.diff(deltas).astype(timedelta)
 * 
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")             # <<<<<<<<<<<<<<
 *     try:
 *         dates[0] = basedate + deltas[0].astype(timedelta)
*/
  __pyx_t_5 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 502, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_empty); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 502, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_times_in_microseconds, __pyx_mstate_global->__pyx_n_u_shape); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 502, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_5);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_5, __pyx_t_7};
    __pyx_t_2 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 502, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_dtype, __pyx_mstate_global->__pyx_n_u_O, __pyx_t_2, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 502, __pyx_L1_error)
    __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_2);
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 502, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_dates = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":503
 * 
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_8, &__pyx_t_9, &__pyx_t_10);
    __Pyx_XGOTREF(__pyx_t_8);
    __Pyx_XGOTREF(__pyx_t_9);
    __Pyx_XGOTREF(__pyx_t_10);
    /*try:*/ {

      /* "cftime/_cftime.pyx":504
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")
 *     try:
 *         dates[0] = basedate + deltas[0].astype(timedelta)             # <<<<<<<<<<<<<<
 *         for i in range(len(differential_deltas)):
 *             dates[i + 1] = dates[i] + differential_deltas[i]
*/
      __pyx_t_2 = __Pyx_GetItemInt(__pyx_v_deltas, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 504, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_4 = __pyx_t_2;
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 504, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_3 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7};
        __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_astype, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 504, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __pyx_t_2 = PyNumber_Add(__pyx_v_basedate, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 504, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely((__Pyx_SetItemInt(__pyx_v_dates, 0, __pyx_t_2, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference) < 0))) __PYX_ERR(0, 504, __pyx_L3_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

      /* "cftime/_cftime.pyx":505
 *     try:
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):             # <<<<<<<<<<<<<<
 *             dates[i + 1] = dates[i] + differential_deltas[i]
 *     except OverflowError:
*/
      __pyx_t_1 = NULL;
      __pyx_t_11 = PyObject_Length(__pyx_v_differential_deltas); if (unlikely(__pyx_t_11 == ((Py_ssize_t)-1))) __PYX_ERR(0, 505, __pyx_L3_error)
      __pyx_t_7 = PyLong_FromSsize_t(__pyx_t_11); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 505, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_7};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(&PyRange_Type), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 505, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_2);
      }
      __pyx_t_7 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 505, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_12 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_7); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 505, __pyx_L3_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      for (;;) {
        {
          __pyx_t_2 = __pyx_t_12(__pyx_t_7);
          if (unlikely(!__pyx_t_2)) {
            PyObject* exc_type = PyErr_Occurred();
            if (exc_type) {
              if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 505, __pyx_L3_error)
              PyErr_Clear();
            }
            break;
          }
        }
        __Pyx_GOTREF(__pyx_t_2);
        __Pyx_XDECREF_SET(__pyx_v_i, __pyx_t_2);
        __pyx_t_2 = 0;

        /* "cftime/_cftime.pyx":506
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):
 *             dates[i + 1] = dates[i] + differential_deltas[i]             # <<<<<<<<<<<<<<
 *     except OverflowError:
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")
*/
        __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_v_dates, __pyx_v_i); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 506, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_differential_deltas, __pyx_v_i); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 506, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_1);
        __pyx_t_4 = PyNumber_Add(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 506, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_4);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        __pyx_t_1 = __Pyx_PyLong_AddObjC(__pyx_v_i, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 506, __pyx_L3_error)
        __Pyx_GOTREF(__pyx_t_1);
        if (unlikely((PyObject_SetItem(__pyx_v_dates, __pyx_t_1, __pyx_t_4) < 0))) __PYX_ERR(0, 506, __pyx_L3_error)
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

        /* "cftime/_cftime.pyx":505
 *     try:
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):             # <<<<<<<<<<<<<<
 *             dates[i + 1] = dates[i] + differential_deltas[i]
 *     except OverflowError:
*/
      }
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;

      /* "cftime/_cftime.pyx":503
 * 
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):
*/
    }
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
    goto __pyx_L8_try_end;
    __pyx_L3_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 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_XDECREF(__pyx_t_7); __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":507
 *         for i in range(len(differential_deltas)):
 *             dates[i + 1] = dates[i] + differential_deltas[i]
 *     except OverflowError:             # <<<<<<<<<<<<<<
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")
 * 
*/
    __pyx_t_13 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_OverflowError))));
    if (__pyx_t_13) {
      __Pyx_AddTraceback("cftime._cftime.decode_dates_from_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_4, &__pyx_t_1) < 0) __PYX_ERR(0, 507, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_7);
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_1);

      /* "cftime/_cftime.pyx":508
 *             dates[i + 1] = dates[i] + differential_deltas[i]
 *     except OverflowError:
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")             # <<<<<<<<<<<<<<
 * 
 *     return dates[unsort_indices].reshape(original_shape)
*/
      __pyx_t_5 = NULL;
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_mstate_global->__pyx_kp_u_OverflowError_in_datetime_possib};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 508, __pyx_L5_except_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(0, 508, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":503
 * 
 *     dates = np.empty(times_in_microseconds.shape, dtype="O")
 *     try:             # <<<<<<<<<<<<<<
 *         dates[0] = basedate + deltas[0].astype(timedelta)
 *         for i in range(len(differential_deltas)):
*/
    __pyx_L5_except_error:;
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_XGIVEREF(__pyx_t_9);
    __Pyx_XGIVEREF(__pyx_t_10);
    __Pyx_ExceptionReset(__pyx_t_8, __pyx_t_9, __pyx_t_10);
    goto __pyx_L1_error;
    __pyx_L8_try_end:;
  }

  /* "cftime/_cftime.pyx":510
 *         raise ValueError("OverflowError in datetime, possibly because year < datetime.MINYEAR")
 * 
 *     return dates[unsort_indices].reshape(original_shape)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_v_dates, __pyx_v_unsort_indices); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 510, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_4 = __pyx_t_7;
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_original_shape};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_reshape, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 510, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":477
 * 
 * 
 * def decode_dates_from_array(times_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode values encoded by an integer array in units of microseconds to dates.
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_AddTraceback("cftime._cftime.decode_dates_from_array", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_original_shape);
  __Pyx_XDECREF(__pyx_v_sort_indices);
  __Pyx_XDECREF(__pyx_v_unsort_indices);
  __Pyx_XDECREF(__pyx_v_deltas);
  __Pyx_XDECREF(__pyx_v_differential_deltas);
  __Pyx_XDECREF(__pyx_v_dates);
  __Pyx_XDECREF(__pyx_v_i);
  __Pyx_XDECREF(__pyx_v_times_in_microseconds);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":513
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2date(
 *     times,
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_23num2date(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_22num2date, "num2date(times, units, calendar='standard', only_use_cftime_datetimes=True, only_use_python_datetimes=False, has_year_zero=None)\n\nReturn datetime objects given numeric time values. The units\nof the numeric time values are described by the **units** argument\nand the **calendar** keyword. The returned datetime objects represent\nUTC with no time-zone offset, even if the specified\n**units** contain a time-zone offset.\n\n**times**: numeric time values.\n\n**units**: a string of the form **<time units> since <reference time>**\ndescribing the time units. **<time units>** can be days, hours, minutes,\nseconds, milliseconds or microseconds. **<reference time>** is the time\norigin. **months since** is allowed *only* for the **360_day** calendar\nand **common_years since** is allowed *only* for the **365_day** calendar.\n\n**calendar**: describes the calendar used in the time calculations.\nAll the values currently defined in the\n`CF metadata convention <http://cfconventions.org/cf-conventions/cf-conventions#calendar>`__ are supported.\nValid calendars **'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'**.\nDefault is **'standard'**, which is a mixed Julian/Gregorian calendar.\n\n**only_use_cftime_datetimes**: if False, python datetime.datetime\nobjects are returned from num2date where possible; if True dates which\nsubclass cftime.datetime are returned for all calendars. Default **True**.\n\n**only_use_python_datetimes**: always return python datetime.datetime\nobjects and raise an error if this is not possible. Ignored unless\n**only_use_cftime_datetimes=False**. Default **False**.\n\n**has_year_zero**: if set to True, astronomical year numbering\nis used and the year zero exists.  If set to False for real-world\ncalendars, then historical year numbering is used and the year 1 is\npreceded by year -1 and no year zero exists.\nThe defaults are set to conform with\nCF version 1.9 conventions (False for 'ju""lian', 'gregorian'/'standard', True\nfor 'proleptic_gregorian' (ISO 8601) and True for the idealized\ncalendars 'noleap'/'365_day', '360_day', 366_day'/'all_leap')\nThe defaults can only be over-ridden for the real-world calendars,\nfor the the idealized calendars the year zero \nalways exists and the has_year_zero kwarg is ignored.\nThis kwarg is not needed to define calendar systems allowed by CF\n(the calendar-specific defaults do this).\n\nreturns a datetime instance, or an array of datetime instances with\nmicrosecond accuracy, if possible.\n\n***Note***: If only_use_cftime_datetimes=False and\nuse_only_python_datetimes=False, the datetime instances\nreturned are 'real' python datetime\nobjects if **calendar='proleptic_gregorian'**, or\n**calendar='standard'** or **'gregorian'**\nand the date is after the breakpoint between the Julian and\nGregorian calendars (1582-10-15). Otherwise, they are ctime.datetime\nobjects which support some but not all the methods of native python\ndatetime objects. The datetime instances\ndo not contain a time-zone offset, even if the specified **units**\ncontains one.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_23num2date = {"num2date", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_23num2date, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_22num2date};
static PyObject *__pyx_pw_6cftime_7_cftime_23num2date(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_times = 0;
  PyObject *__pyx_v_units = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_only_use_cftime_datetimes = 0;
  PyObject *__pyx_v_only_use_python_datetimes = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[6] = {0,0,0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("num2date (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_times,&__pyx_mstate_global->__pyx_n_u_units_2,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_only_use_cftime_datetimes,&__pyx_mstate_global->__pyx_n_u_only_use_python_datetimes,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 513, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  6:
        values[5] = __Pyx_ArgRef_FASTCALL(__pyx_args, 5);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[5])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "num2date", 0) < (0)) __PYX_ERR(0, 513, __pyx_L3_error)
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_standard)));

      /* "cftime/_cftime.pyx":518
 *     units,
 *     calendar='standard',
 *     only_use_cftime_datetimes=True,             # <<<<<<<<<<<<<<
 *     only_use_python_datetimes=False,
 *     has_year_zero=None
*/
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_True)));

      /* "cftime/_cftime.pyx":519
 *     calendar='standard',
 *     only_use_cftime_datetimes=True,
 *     only_use_python_datetimes=False,             # <<<<<<<<<<<<<<
 *     has_year_zero=None
 * ):
*/
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_False)));

      /* "cftime/_cftime.pyx":520
 *     only_use_cftime_datetimes=True,
 *     only_use_python_datetimes=False,
 *     has_year_zero=None             # <<<<<<<<<<<<<<
 * ):
 *     """
*/
      if (!values[5]) values[5] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("num2date", 0, 2, 6, i); __PYX_ERR(0, 513, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  6:
        values[5] = __Pyx_ArgRef_FASTCALL(__pyx_args, 5);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[5])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 513, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 513, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 513, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_standard)));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_True)));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)((PyObject*)Py_False)));
      if (!values[5]) values[5] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_times = values[0];
    __pyx_v_units = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_only_use_cftime_datetimes = values[3];
    __pyx_v_only_use_python_datetimes = values[4];
    __pyx_v_has_year_zero = values[5];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("num2date", 0, 2, 6, __pyx_nargs); __PYX_ERR(0, 513, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.num2date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_22num2date(__pyx_self, __pyx_v_times, __pyx_v_units, __pyx_v_calendar, __pyx_v_only_use_cftime_datetimes, __pyx_v_only_use_python_datetimes, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":513
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2date(
 *     times,
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_22num2date(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_units, PyObject *__pyx_v_calendar, PyObject *__pyx_v_only_use_cftime_datetimes, PyObject *__pyx_v_only_use_python_datetimes, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_basedate = NULL;
  PyObject *__pyx_v_can_use_python_datetime = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_v_unit = NULL;
  CYTHON_UNUSED PyObject *__pyx_v_ignore = NULL;
  int __pyx_v_use_python_datetime;
  PyObject *__pyx_v_factor = NULL;
  PyObject *__pyx_v_scaled_times = NULL;
  PyObject *__pyx_v_original_mask = NULL;
  PyObject *__pyx_v_dates = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  int __pyx_t_7;
  int __pyx_t_8;
  PyObject *(*__pyx_t_9)(PyObject *);
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("num2date", 0);
  __Pyx_INCREF(__pyx_v_times);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":581
 *     contains one.
 *     """
 *     calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
*/
  __pyx_t_2 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 581, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":583
 *     calendar = calendar.lower()
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
*/
  __pyx_t_4 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":584
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
 * 
*/
    __pyx_t_1 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 584, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_1);
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":583
 *     calendar = calendar.lower()
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
*/
  }

  /* "cftime/_cftime.pyx":585
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_dateparse); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 585, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_2, __pyx_v_units};
    __pyx_t_6 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 585, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_6, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 585, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_6, __pyx_callargs+2, 1) < (0)) __PYX_ERR(0, 585, __pyx_L1_error)
    __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_6);
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 585, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_basedate = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":587
 *     basedate = _dateparse(units,calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)             # <<<<<<<<<<<<<<
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:
 *         if not can_use_python_datetime:
*/
  __pyx_t_5 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_can_use_python_datetime); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 587, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_6);
    assert(__pyx_t_5);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_5, __pyx_v_basedate, __pyx_v_calendar};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 587, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_v_can_use_python_datetime = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":588
 * 
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:             # <<<<<<<<<<<<<<
 *         if not can_use_python_datetime:
 *             msg='illegal calendar or reference date for python datetime'
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_cftime_datetimes); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 588, __pyx_L1_error)
  __pyx_t_8 = (!__pyx_t_7);
  if (__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_python_datetimes); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 588, __pyx_L1_error)
  __pyx_t_4 = __pyx_t_8;
  __pyx_L5_bool_binop_done:;
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":589
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:
 *         if not can_use_python_datetime:             # <<<<<<<<<<<<<<
 *             msg='illegal calendar or reference date for python datetime'
 *             raise ValueError(msg)
*/
    __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_can_use_python_datetime); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 589, __pyx_L1_error)
    __pyx_t_8 = (!__pyx_t_4);
    if (unlikely(__pyx_t_8)) {

      /* "cftime/_cftime.pyx":590
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:
 *         if not can_use_python_datetime:
 *             msg='illegal calendar or reference date for python datetime'             # <<<<<<<<<<<<<<
 *             raise ValueError(msg)
 * 
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_illegal_calendar_or_reference_da);
      __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_illegal_calendar_or_reference_da;

      /* "cftime/_cftime.pyx":591
 *         if not can_use_python_datetime:
 *             msg='illegal calendar or reference date for python datetime'
 *             raise ValueError(msg)             # <<<<<<<<<<<<<<
 * 
 *     unit, ignore = _datesplit(units)
*/
      __pyx_t_6 = NULL;
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_msg};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 591, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 591, __pyx_L1_error)

      /* "cftime/_cftime.pyx":589
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:
 *         if not can_use_python_datetime:             # <<<<<<<<<<<<<<
 *             msg='illegal calendar or reference date for python datetime'
 *             raise ValueError(msg)
*/
    }

    /* "cftime/_cftime.pyx":588
 * 
 *     can_use_python_datetime=_can_use_python_datetime(basedate,calendar)
 *     if not only_use_cftime_datetimes and only_use_python_datetimes:             # <<<<<<<<<<<<<<
 *         if not can_use_python_datetime:
 *             msg='illegal calendar or reference date for python datetime'
*/
  }

  /* "cftime/_cftime.pyx":593
 *             raise ValueError(msg)
 * 
 *     unit, ignore = _datesplit(units)             # <<<<<<<<<<<<<<
 * 
 *     # real-world calendars limited to positive reference years.
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_datesplit); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 593, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_units};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 593, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  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(0, 593, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 0);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_t_6 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_6);
    } else {
      __pyx_t_5 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 593, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __pyx_t_6 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 593, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_6);
    }
    #else
    __pyx_t_5 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 593, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 593, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    #endif
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  } else {
    Py_ssize_t index = -1;
    __pyx_t_2 = PyObject_GetIter(__pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 593, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2);
    index = 0; __pyx_t_5 = __pyx_t_9(__pyx_t_2); if (unlikely(!__pyx_t_5)) goto __pyx_L8_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_5);
    index = 1; __pyx_t_6 = __pyx_t_9(__pyx_t_2); if (unlikely(!__pyx_t_6)) goto __pyx_L8_unpacking_failed;
    __Pyx_GOTREF(__pyx_t_6);
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_2), 2) < (0)) __PYX_ERR(0, 593, __pyx_L1_error)
    __pyx_t_9 = NULL;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    goto __pyx_L9_unpacking_done;
    __pyx_L8_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_9 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(0, 593, __pyx_L1_error)
    __pyx_L9_unpacking_done:;
  }
  __pyx_v_unit = __pyx_t_5;
  __pyx_t_5 = 0;
  __pyx_v_ignore = __pyx_t_6;
  __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":596
 * 
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year unless has_year_zero=True'
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_1 = __pyx_v_calendar;
  __pyx_t_7 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 596, __pyx_L1_error)
  if (!__pyx_t_7) {
  } else {
    __pyx_t_4 = __pyx_t_7;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_7 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 596, __pyx_L1_error)
  if (!__pyx_t_7) {
  } else {
    __pyx_t_4 = __pyx_t_7;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_7 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 596, __pyx_L1_error)
  if (!__pyx_t_7) {
  } else {
    __pyx_t_4 = __pyx_t_7;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_7 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 596, __pyx_L1_error)
  __pyx_t_4 = __pyx_t_7;
  __pyx_L13_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_7 = __pyx_t_4;
  if (__pyx_t_7) {
  } else {
    __pyx_t_8 = __pyx_t_7;
    goto __pyx_L11_bool_binop_done;
  }
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 596, __pyx_L1_error)
  __pyx_t_4 = (!__pyx_t_7);
  __pyx_t_8 = __pyx_t_4;
  __pyx_L11_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":597
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year unless has_year_zero=True'
 *             raise ValueError(msg)
*/
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 597, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_8 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 597, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(__pyx_t_8)) {

      /* "cftime/_cftime.pyx":598
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year unless has_year_zero=True'             # <<<<<<<<<<<<<<
 *             raise ValueError(msg)
 * 
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_3);
      __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_3;

      /* "cftime/_cftime.pyx":599
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year unless has_year_zero=True'
 *             raise ValueError(msg)             # <<<<<<<<<<<<<<
 * 
 *     use_python_datetime = False
*/
      __pyx_t_6 = NULL;
      __pyx_t_3 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_msg};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 599, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 599, __pyx_L1_error)

      /* "cftime/_cftime.pyx":597
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year unless has_year_zero=True'
 *             raise ValueError(msg)
*/
    }

    /* "cftime/_cftime.pyx":596
 * 
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year unless has_year_zero=True'
*/
  }

  /* "cftime/_cftime.pyx":601
 *             raise ValueError(msg)
 * 
 *     use_python_datetime = False             # <<<<<<<<<<<<<<
 *     if only_use_python_datetimes and not only_use_cftime_datetimes:
 *         # only_use_cftime_datetimes takes precedence
*/
  __pyx_v_use_python_datetime = 0;

  /* "cftime/_cftime.pyx":602
 * 
 *     use_python_datetime = False
 *     if only_use_python_datetimes and not only_use_cftime_datetimes:             # <<<<<<<<<<<<<<
 *         # only_use_cftime_datetimes takes precedence
 *         use_python_datetime = True
*/
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_python_datetimes); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 602, __pyx_L1_error)
  if (__pyx_t_4) {
  } else {
    __pyx_t_8 = __pyx_t_4;
    goto __pyx_L19_bool_binop_done;
  }
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_cftime_datetimes); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 602, __pyx_L1_error)
  __pyx_t_7 = (!__pyx_t_4);
  __pyx_t_8 = __pyx_t_7;
  __pyx_L19_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":604
 *     if only_use_python_datetimes and not only_use_cftime_datetimes:
 *         # only_use_cftime_datetimes takes precedence
 *         use_python_datetime = True             # <<<<<<<<<<<<<<
 *     if not only_use_python_datetimes and not only_use_cftime_datetimes and can_use_python_datetime:
 *         # if only_use_cftimes_datetimes and only_use_python_datetimes are False
*/
    __pyx_v_use_python_datetime = 1;

    /* "cftime/_cftime.pyx":602
 * 
 *     use_python_datetime = False
 *     if only_use_python_datetimes and not only_use_cftime_datetimes:             # <<<<<<<<<<<<<<
 *         # only_use_cftime_datetimes takes precedence
 *         use_python_datetime = True
*/
  }

  /* "cftime/_cftime.pyx":605
 *         # only_use_cftime_datetimes takes precedence
 *         use_python_datetime = True
 *     if not only_use_python_datetimes and not only_use_cftime_datetimes and can_use_python_datetime:             # <<<<<<<<<<<<<<
 *         # if only_use_cftimes_datetimes and only_use_python_datetimes are False
 *         # return python datetime if possible.
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_python_datetimes); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 605, __pyx_L1_error)
  __pyx_t_4 = (!__pyx_t_7);
  if (__pyx_t_4) {
  } else {
    __pyx_t_8 = __pyx_t_4;
    goto __pyx_L22_bool_binop_done;
  }
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_only_use_cftime_datetimes); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 605, __pyx_L1_error)
  __pyx_t_7 = (!__pyx_t_4);
  if (__pyx_t_7) {
  } else {
    __pyx_t_8 = __pyx_t_7;
    goto __pyx_L22_bool_binop_done;
  }
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_can_use_python_datetime); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 605, __pyx_L1_error)
  __pyx_t_8 = __pyx_t_7;
  __pyx_L22_bool_binop_done:;
  if (__pyx_t_8) {

    /* "cftime/_cftime.pyx":608
 *         # if only_use_cftimes_datetimes and only_use_python_datetimes are False
 *         # return python datetime if possible.
 *         use_python_datetime = True             # <<<<<<<<<<<<<<
 * 
 *     basedate = to_calendar_specific_datetime(basedate, calendar, use_python_datetime, has_year_zero=has_year_zero)
*/
    __pyx_v_use_python_datetime = 1;

    /* "cftime/_cftime.pyx":605
 *         # only_use_cftime_datetimes takes precedence
 *         use_python_datetime = True
 *     if not only_use_python_datetimes and not only_use_cftime_datetimes and can_use_python_datetime:             # <<<<<<<<<<<<<<
 *         # if only_use_cftimes_datetimes and only_use_python_datetimes are False
 *         # return python datetime if possible.
*/
  }

  /* "cftime/_cftime.pyx":610
 *         use_python_datetime = True
 * 
 *     basedate = to_calendar_specific_datetime(basedate, calendar, use_python_datetime, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     if unit not in UNIT_CONVERSION_FACTORS:
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_to_calendar_specific_datetime); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_v_use_python_datetime); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 610, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[4 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_6, __pyx_v_basedate, __pyx_v_calendar, __pyx_t_2};
    __pyx_t_10 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 610, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_10, __pyx_callargs+4, 0) < (0)) __PYX_ERR(0, 610, __pyx_L1_error)
    __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_3, (4-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_10);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 610, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_basedate, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":612
 *     basedate = to_calendar_specific_datetime(basedate, calendar, use_python_datetime, has_year_zero=has_year_zero)
 * 
 *     if unit not in UNIT_CONVERSION_FACTORS:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 * 
*/
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_UNIT_CONVERSION_FACTORS); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 612, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_8 = (__Pyx_PySequence_ContainsTF(__pyx_v_unit, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 612, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(__pyx_t_8)) {

    /* "cftime/_cftime.pyx":613
 * 
 *     if unit not in UNIT_CONVERSION_FACTORS:
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))             # <<<<<<<<<<<<<<
 * 
 *     if unit in ["months", "month"] and calendar != "360_day":
*/
    __pyx_t_5 = NULL;
    __pyx_t_2 = __pyx_mstate_global->__pyx_kp_u_Unsupported_time_units_provided;
    __Pyx_INCREF(__pyx_t_2);
    __pyx_t_3 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_unit};
      __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 613, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_10};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 613, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 613, __pyx_L1_error)

    /* "cftime/_cftime.pyx":612
 *     basedate = to_calendar_specific_datetime(basedate, calendar, use_python_datetime, has_year_zero=has_year_zero)
 * 
 *     if unit not in UNIT_CONVERSION_FACTORS:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 * 
*/
  }

  /* "cftime/_cftime.pyx":615
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 * 
 *     if unit in ["months", "month"] and calendar != "360_day":             # <<<<<<<<<<<<<<
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 * 
*/
  __Pyx_INCREF(__pyx_v_unit);
  __pyx_t_1 = __pyx_v_unit;
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_months, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 615, __pyx_L1_error)
  if (!__pyx_t_4) {
  } else {
    __pyx_t_7 = __pyx_t_4;
    goto __pyx_L29_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_month, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 615, __pyx_L1_error)
  __pyx_t_7 = __pyx_t_4;
  __pyx_L29_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __pyx_t_7;
  if (__pyx_t_4) {
  } else {
    __pyx_t_8 = __pyx_t_4;
    goto __pyx_L27_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_NE)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 615, __pyx_L1_error)
  __pyx_t_8 = __pyx_t_4;
  __pyx_L27_bool_binop_done:;
  if (unlikely(__pyx_t_8)) {

    /* "cftime/_cftime.pyx":616
 * 
 *     if unit in ["months", "month"] and calendar != "360_day":
 *         raise ValueError("Units of months only valid for 360_day calendar.")             # <<<<<<<<<<<<<<
 * 
 *     factor = UNIT_CONVERSION_FACTORS[unit]
*/
    __pyx_t_10 = NULL;
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_mstate_global->__pyx_kp_u_Units_of_months_only_valid_for_3};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 616, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 616, __pyx_L1_error)

    /* "cftime/_cftime.pyx":615
 *         raise ValueError("Unsupported time units provided, {!r}.".format(unit))
 * 
 *     if unit in ["months", "month"] and calendar != "360_day":             # <<<<<<<<<<<<<<
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 * 
*/
  }

  /* "cftime/_cftime.pyx":618
 *         raise ValueError("Units of months only valid for 360_day calendar.")
 * 
 *     factor = UNIT_CONVERSION_FACTORS[unit]             # <<<<<<<<<<<<<<
 *     times = np.asanyarray(times)  # Allow list as input
 *     times = upcast_times(times)
*/
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_UNIT_CONVERSION_FACTORS); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_10 = __Pyx_PyObject_GetItem(__pyx_t_1, __pyx_v_unit); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 618, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_factor = __pyx_t_10;
  __pyx_t_10 = 0;

  /* "cftime/_cftime.pyx":619
 * 
 *     factor = UNIT_CONVERSION_FACTORS[unit]
 *     times = np.asanyarray(times)  # Allow list as input             # <<<<<<<<<<<<<<
 *     times = upcast_times(times)
 *     # convert to masked array if any nan or inf values present
*/
  __pyx_t_1 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 619, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_asanyarray); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 619, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_2);
    assert(__pyx_t_1);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_1);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_v_times};
    __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 619, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
  }
  __Pyx_DECREF_SET(__pyx_v_times, __pyx_t_10);
  __pyx_t_10 = 0;

  /* "cftime/_cftime.pyx":620
 *     factor = UNIT_CONVERSION_FACTORS[unit]
 *     times = np.asanyarray(times)  # Allow list as input
 *     times = upcast_times(times)             # <<<<<<<<<<<<<<
 *     # convert to masked array if any nan or inf values present
 *     if not np.isfinite(times).all():
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_upcast_times); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 620, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_1))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_times};
    __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 620, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
  }
  __Pyx_DECREF_SET(__pyx_v_times, __pyx_t_10);
  __pyx_t_10 = 0;

  /* "cftime/_cftime.pyx":622
 *     times = upcast_times(times)
 *     # convert to masked array if any nan or inf values present
 *     if not np.isfinite(times).all():             # <<<<<<<<<<<<<<
 *         times = np.ma.masked_invalid(times)
 *     scaled_times = scale_times(times, factor)
*/
  __pyx_t_5 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 622, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_isfinite); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 622, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_11))) {
    __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_11);
    assert(__pyx_t_5);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
    __Pyx_INCREF(__pyx_t_5);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_v_times};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 622, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_t_1 = __pyx_t_2;
  __Pyx_INCREF(__pyx_t_1);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL};
    __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_all, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 622, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
  }
  __pyx_t_8 = __Pyx_PyObject_IsTrue(__pyx_t_10); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 622, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_4 = (!__pyx_t_8);
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":623
 *     # convert to masked array if any nan or inf values present
 *     if not np.isfinite(times).all():
 *         times = np.ma.masked_invalid(times)             # <<<<<<<<<<<<<<
 *     scaled_times = scale_times(times, factor)
 *     scaled_times = cast_to_int(scaled_times,units=unit)
*/
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 623, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 623, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_2 = __pyx_t_11;
    __Pyx_INCREF(__pyx_t_2);
    __pyx_t_3 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_times};
      __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_masked_invalid, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 623, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __Pyx_DECREF_SET(__pyx_v_times, __pyx_t_10);
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":622
 *     times = upcast_times(times)
 *     # convert to masked array if any nan or inf values present
 *     if not np.isfinite(times).all():             # <<<<<<<<<<<<<<
 *         times = np.ma.masked_invalid(times)
 *     scaled_times = scale_times(times, factor)
*/
  }

  /* "cftime/_cftime.pyx":624
 *     if not np.isfinite(times).all():
 *         times = np.ma.masked_invalid(times)
 *     scaled_times = scale_times(times, factor)             # <<<<<<<<<<<<<<
 *     scaled_times = cast_to_int(scaled_times,units=unit)
 * 
*/
  __pyx_t_11 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_scale_times); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 624, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_2))) {
    __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_2);
    assert(__pyx_t_11);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
    __Pyx_INCREF(__pyx_t_11);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_11, __pyx_v_times, __pyx_v_factor};
    __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 624, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
  }
  __pyx_v_scaled_times = __pyx_t_10;
  __pyx_t_10 = 0;

  /* "cftime/_cftime.pyx":625
 *         times = np.ma.masked_invalid(times)
 *     scaled_times = scale_times(times, factor)
 *     scaled_times = cast_to_int(scaled_times,units=unit)             # <<<<<<<<<<<<<<
 * 
 *     if scaled_times.ndim == 0 or scaled_times.size == 0:
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_cast_to_int); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 625, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_3 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_11))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_11);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
    __pyx_t_3 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, __pyx_v_scaled_times};
    __pyx_t_1 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 625, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_units_2, __pyx_v_unit, __pyx_t_1, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 625, __pyx_L1_error)
    __pyx_t_10 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_1);
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 625, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
  }
  __Pyx_DECREF_SET(__pyx_v_scaled_times, __pyx_t_10);
  __pyx_t_10 = 0;

  /* "cftime/_cftime.pyx":627
 *     scaled_times = cast_to_int(scaled_times,units=unit)
 * 
 *     if scaled_times.ndim == 0 or scaled_times.size == 0:             # <<<<<<<<<<<<<<
 *         return decode_date_from_scalar(scaled_times, basedate)
 *     else:
*/
  __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_scaled_times, __pyx_mstate_global->__pyx_n_u_ndim); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 627, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_8 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_10, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 627, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  if (!__pyx_t_8) {
  } else {
    __pyx_t_4 = __pyx_t_8;
    goto __pyx_L33_bool_binop_done;
  }
  __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_v_scaled_times, __pyx_mstate_global->__pyx_n_u_size); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 627, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_8 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_10, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_8 < 0))) __PYX_ERR(0, 627, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
  __pyx_t_4 = __pyx_t_8;
  __pyx_L33_bool_binop_done:;
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":628
 * 
 *     if scaled_times.ndim == 0 or scaled_times.size == 0:
 *         return decode_date_from_scalar(scaled_times, basedate)             # <<<<<<<<<<<<<<
 *     else:
 *         if isinstance(scaled_times, np.ma.MaskedArray):
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_11 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_decode_date_from_scalar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 628, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_3 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_1);
      assert(__pyx_t_11);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_11);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
      __pyx_t_3 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_11, __pyx_v_scaled_times, __pyx_v_basedate};
      __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 628, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __pyx_r = __pyx_t_10;
    __pyx_t_10 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":627
 *     scaled_times = cast_to_int(scaled_times,units=unit)
 * 
 *     if scaled_times.ndim == 0 or scaled_times.size == 0:             # <<<<<<<<<<<<<<
 *         return decode_date_from_scalar(scaled_times, basedate)
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":630
 *         return decode_date_from_scalar(scaled_times, basedate)
 *     else:
 *         if isinstance(scaled_times, np.ma.MaskedArray):             # <<<<<<<<<<<<<<
 *             # The algorithm requires data be present for all values. To handle this, we fill
 *             # masked values with 0 temporarily and then restore the mask at the end.
*/
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 630, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 630, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_MaskedArray); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 630, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_4 = PyObject_IsInstance(__pyx_v_scaled_times, __pyx_t_10); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 630, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":633
 *             # The algorithm requires data be present for all values. To handle this, we fill
 *             # masked values with 0 temporarily and then restore the mask at the end.
 *             original_mask = np.ma.getmask(scaled_times)             # <<<<<<<<<<<<<<
 *             scaled_times = scaled_times.filled(0)
 *             dates = decode_dates_from_array(scaled_times, basedate)
*/
      __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 633, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 633, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __pyx_t_1 = __pyx_t_2;
      __Pyx_INCREF(__pyx_t_1);
      __pyx_t_3 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_v_scaled_times};
        __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_getmask, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 633, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __pyx_v_original_mask = __pyx_t_10;
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":634
 *             # masked values with 0 temporarily and then restore the mask at the end.
 *             original_mask = np.ma.getmask(scaled_times)
 *             scaled_times = scaled_times.filled(0)             # <<<<<<<<<<<<<<
 *             dates = decode_dates_from_array(scaled_times, basedate)
 *             return np.ma.MaskedArray(dates, mask=original_mask)
*/
      __pyx_t_2 = __pyx_v_scaled_times;
      __Pyx_INCREF(__pyx_t_2);
      __pyx_t_3 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_int_0};
        __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_filled, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 634, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __Pyx_DECREF_SET(__pyx_v_scaled_times, __pyx_t_10);
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":635
 *             original_mask = np.ma.getmask(scaled_times)
 *             scaled_times = scaled_times.filled(0)
 *             dates = decode_dates_from_array(scaled_times, basedate)             # <<<<<<<<<<<<<<
 *             return np.ma.MaskedArray(dates, mask=original_mask)
 *         else:
*/
      __pyx_t_2 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_decode_dates_from_array); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 635, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_1))) {
        __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
        assert(__pyx_t_2);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
        __Pyx_INCREF(__pyx_t_2);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
        __pyx_t_3 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_scaled_times, __pyx_v_basedate};
        __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 635, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __pyx_v_dates = __pyx_t_10;
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":636
 *             scaled_times = scaled_times.filled(0)
 *             dates = decode_dates_from_array(scaled_times, basedate)
 *             return np.ma.MaskedArray(dates, mask=original_mask)             # <<<<<<<<<<<<<<
 *         else:
 *             return decode_dates_from_array(scaled_times, basedate)
*/
      __Pyx_XDECREF(__pyx_r);
      __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 636, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_ma); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 636, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_1 = __pyx_t_11;
      __Pyx_INCREF(__pyx_t_1);
      __pyx_t_3 = 0;
      {
        PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_1, __pyx_v_dates};
        __pyx_t_2 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 636, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_mask, __pyx_v_original_mask, __pyx_t_2, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 636, __pyx_L1_error)
        __pyx_t_10 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_MaskedArray, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_2);
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 636, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __pyx_r = __pyx_t_10;
      __pyx_t_10 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":630
 *         return decode_date_from_scalar(scaled_times, basedate)
 *     else:
 *         if isinstance(scaled_times, np.ma.MaskedArray):             # <<<<<<<<<<<<<<
 *             # The algorithm requires data be present for all values. To handle this, we fill
 *             # masked values with 0 temporarily and then restore the mask at the end.
*/
    }

    /* "cftime/_cftime.pyx":638
 *             return np.ma.MaskedArray(dates, mask=original_mask)
 *         else:
 *             return decode_dates_from_array(scaled_times, basedate)             # <<<<<<<<<<<<<<
 * 
 * 
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_11 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_decode_dates_from_array); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 638, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_2))) {
        __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_2);
        assert(__pyx_t_11);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_11);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
        __pyx_t_3 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_11, __pyx_v_scaled_times, __pyx_v_basedate};
        __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 638, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __pyx_r = __pyx_t_10;
      __pyx_t_10 = 0;
      goto __pyx_L0;
    }
  }

  /* "cftime/_cftime.pyx":513
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2date(
 *     times,
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_AddTraceback("cftime._cftime.num2date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_basedate);
  __Pyx_XDECREF(__pyx_v_can_use_python_datetime);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_unit);
  __Pyx_XDECREF(__pyx_v_ignore);
  __Pyx_XDECREF(__pyx_v_factor);
  __Pyx_XDECREF(__pyx_v_scaled_times);
  __Pyx_XDECREF(__pyx_v_original_mask);
  __Pyx_XDECREF(__pyx_v_dates);
  __Pyx_XDECREF(__pyx_v_times);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":641
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):
 *     """
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_25date2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_24date2index, "date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None)\n\nReturn indices of a netCDF time variable corresponding to the given dates.\n\n**dates**: A datetime object or a sequence of datetime objects.\nThe datetime objects should not include a time-zone offset.\n\n**nctime**: A netCDF time variable object. The nctime object must have a\n**units** attribute.\n\n**calendar**: describes the calendar to be used in the time calculations.\nAll the values currently defined in the\n`CF metadata convention <http://cfconventions.org/cf-conventions/cf-conventions#calendar>`__ are supported.\nValid calendars **'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'**.\nDefault is `None` which means the calendar associated with the first\ninput datetime instance will be used.\n\n**select**: **'exact', 'before', 'after', 'nearest'**\nThe index selection method. **exact** will return the indices perfectly\nmatching the dates given. **before** and **after** will return the indices\ncorresponding to the dates just before or just after the given dates if\nan exact match cannot be found. **nearest** will return the indices that\ncorrespond to the closest dates.\n\n**has_year_zero**: if set to True, astronomical year numbering\nis used and the year zero exists.  If set to False for real-world\ncalendars, then historical year numbering is used and the year 1 is\npreceded by year -1 and no year zero exists.\nThe defaults are set to conform with\nCF version 1.9 conventions (False for 'julian', 'gregorian'/'standard', True\nfor 'proleptic_gregorian' (ISO 8601) and True for the idealized\ncalendars 'noleap'/'365_day', '360_day', 366_day'/'all_leap')\nThe defaults can only be over-ridden for the real-world calendars,\nfor the the idealized calendars the year zero \nalways exists and the has_year_zero kwarg is ignored.\nThis kwarg is not needed to define calendar systems allowed by CF\n(the calendar-specific defaults"" do this).\n\nreturns an index (indices) of the netCDF time variable corresponding\nto the given datetime object(s).");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_25date2index = {"date2index", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_25date2index, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_24date2index};
static PyObject *__pyx_pw_6cftime_7_cftime_25date2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_dates = 0;
  PyObject *__pyx_v_nctime = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_select = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[5] = {0,0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("date2index (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_dates,&__pyx_mstate_global->__pyx_n_u_nctime,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_select,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 641, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "date2index", 0) < (0)) __PYX_ERR(0, 641, __pyx_L3_error)

      /* "cftime/_cftime.pyx":642
 * 
 * @cython.embedsignature(True)
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """
 *     Return indices of a netCDF time variable corresponding to the given dates.
*/
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("date2index", 0, 2, 5, i); __PYX_ERR(0, 641, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 641, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 641, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 641, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_dates = values[0];
    __pyx_v_nctime = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_select = values[3];
    __pyx_v_has_year_zero = values[4];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("date2index", 0, 2, 5, __pyx_nargs); __PYX_ERR(0, 641, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_24date2index(__pyx_self, __pyx_v_dates, __pyx_v_nctime, __pyx_v_calendar, __pyx_v_select, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":641
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):
 *     """
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_24date2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_dates_test = NULL;
  PyObject *__pyx_v_d0 = NULL;
  PyObject *__pyx_v_basedate = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_v_times = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_t_11;
  int __pyx_t_12;
  int __pyx_t_13;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("date2index", 0);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":684
 *     to the given datetime object(s).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":685
 *     """
 *     try:
 *         nctime.units             # <<<<<<<<<<<<<<
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
*/
      __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 685, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":684
 *     to the given datetime object(s).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    }
    __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;

    /* "cftime/_cftime.pyx":686
 *     try:
 *         nctime.units
 *     except AttributeError:             # <<<<<<<<<<<<<<
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 * 
*/
    __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
    if (__pyx_t_5) {
      __Pyx_AddTraceback("cftime._cftime.date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(0, 686, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "cftime/_cftime.pyx":687
 *         nctime.units
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")             # <<<<<<<<<<<<<<
 * 
 *     dates_test = np.asanyarray(dates) # convert to numpy array
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_netcdf_time_variable_is_missing};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_AttributeError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 687, __pyx_L5_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(0, 687, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":684
 *     to the given datetime object(s).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "cftime/_cftime.pyx":689
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 * 
 *     dates_test = np.asanyarray(dates) # convert to numpy array             # <<<<<<<<<<<<<<
 * 
 *     # if has_year_zero is None and calendar is None, use first input cftime.datetime instance
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 689, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_asanyarray); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 689, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_8))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_8);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_dates};
    __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 689, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_v_dates_test = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":694
 *     # to determine if year zero is to be included.
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         if calendar is None:
 *             d0 = dates_test.item(0)
*/
  __pyx_t_11 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_11) {

    /* "cftime/_cftime.pyx":695
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:
 *         if calendar is None:             # <<<<<<<<<<<<<<
 *             d0 = dates_test.item(0)
 *             if isinstance(d0,datetime_python):
*/
    __pyx_t_11 = (__pyx_v_calendar == Py_None);
    if (__pyx_t_11) {

      /* "cftime/_cftime.pyx":696
 *     if has_year_zero is None:
 *         if calendar is None:
 *             d0 = dates_test.item(0)             # <<<<<<<<<<<<<<
 *             if isinstance(d0,datetime_python):
 *                 has_year_zero = False
*/
      __pyx_t_8 = __pyx_v_dates_test;
      __Pyx_INCREF(__pyx_t_8);
      __pyx_t_10 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_mstate_global->__pyx_int_0};
        __pyx_t_7 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
        if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 696, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
      }
      __pyx_v_d0 = __pyx_t_7;
      __pyx_t_7 = 0;

      /* "cftime/_cftime.pyx":697
 *         if calendar is None:
 *             d0 = dates_test.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 has_year_zero = False
 *             else:
*/
      __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 697, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_11 = PyObject_IsInstance(__pyx_v_d0, __pyx_t_7); if (unlikely(__pyx_t_11 == ((int)-1))) __PYX_ERR(0, 697, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (__pyx_t_11) {

        /* "cftime/_cftime.pyx":698
 *             d0 = dates_test.item(0)
 *             if isinstance(d0,datetime_python):
 *                 has_year_zero = False             # <<<<<<<<<<<<<<
 *             else:
 *                 try:
*/
        __Pyx_INCREF(Py_False);
        __Pyx_DECREF_SET(__pyx_v_has_year_zero, Py_False);

        /* "cftime/_cftime.pyx":697
 *         if calendar is None:
 *             d0 = dates_test.item(0)
 *             if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *                 has_year_zero = False
 *             else:
*/
        goto __pyx_L13;
      }

      /* "cftime/_cftime.pyx":700
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
      /*else*/ {
        {
          __Pyx_PyThreadState_declare
          __Pyx_PyThreadState_assign
          __Pyx_ExceptionSave(&__pyx_t_3, &__pyx_t_2, &__pyx_t_1);
          __Pyx_XGOTREF(__pyx_t_3);
          __Pyx_XGOTREF(__pyx_t_2);
          __Pyx_XGOTREF(__pyx_t_1);
          /*try:*/ {

            /* "cftime/_cftime.pyx":701
 *             else:
 *                 try:
 *                     has_year_zero = d0.has_year_zero             # <<<<<<<<<<<<<<
 *                 except AttributeError:
 *                     raise ValueError('has_year_zero not specified',type(d0))
*/
            __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_d0, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 701, __pyx_L14_error)
            __Pyx_GOTREF(__pyx_t_7);
            __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_7);
            __pyx_t_7 = 0;

            /* "cftime/_cftime.pyx":700
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
          }
          __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_L19_try_end;
          __pyx_L14_error:;
          __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
          __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;

          /* "cftime/_cftime.pyx":702
 *                 try:
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:             # <<<<<<<<<<<<<<
 *                     raise ValueError('has_year_zero not specified',type(d0))
 *         else:
*/
          __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
          if (__pyx_t_5) {
            __Pyx_AddTraceback("cftime._cftime.date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
            if (__Pyx_GetException(&__pyx_t_7, &__pyx_t_8, &__pyx_t_6) < 0) __PYX_ERR(0, 702, __pyx_L16_except_error)
            __Pyx_XGOTREF(__pyx_t_7);
            __Pyx_XGOTREF(__pyx_t_8);
            __Pyx_XGOTREF(__pyx_t_6);

            /* "cftime/_cftime.pyx":703
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
 *                     raise ValueError('has_year_zero not specified',type(d0))             # <<<<<<<<<<<<<<
 *         else:
 *             has_year_zero = _year_zero_defaults(calendar)
*/
            __pyx_t_9 = NULL;
            __pyx_t_10 = 1;
            {
              PyObject *__pyx_callargs[3] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_has_year_zero_not_specified, ((PyObject *)Py_TYPE(__pyx_v_d0))};
              __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
              __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
              if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 703, __pyx_L16_except_error)
              __Pyx_GOTREF(__pyx_t_4);
            }
            __Pyx_Raise(__pyx_t_4, 0, 0, 0);
            __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
            __PYX_ERR(0, 703, __pyx_L16_except_error)
          }
          goto __pyx_L16_except_error;

          /* "cftime/_cftime.pyx":700
 *                 has_year_zero = False
 *             else:
 *                 try:             # <<<<<<<<<<<<<<
 *                     has_year_zero = d0.has_year_zero
 *                 except AttributeError:
*/
          __pyx_L16_except_error:;
          __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_L19_try_end:;
        }
      }
      __pyx_L13:;

      /* "cftime/_cftime.pyx":695
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:
 *         if calendar is None:             # <<<<<<<<<<<<<<
 *             d0 = dates_test.item(0)
 *             if isinstance(d0,datetime_python):
*/
      goto __pyx_L12;
    }

    /* "cftime/_cftime.pyx":705
 *                     raise ValueError('has_year_zero not specified',type(d0))
 *         else:
 *             has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 * 
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
*/
    /*else*/ {
      __pyx_t_6 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 705, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_6);
      __pyx_t_6 = 0;
    }
    __pyx_L12:;

    /* "cftime/_cftime.pyx":694
 *     # to determine if year zero is to be included.
 *     # If calendar is specified, use calendar specific defaults
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         if calendar is None:
 *             d0 = dates_test.item(0)
*/
  }

  /* "cftime/_cftime.pyx":709
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:             # <<<<<<<<<<<<<<
 *         d0 = dates_test.item(0)
 *         if isinstance(d0,datetime_python):
*/
  __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_v_calendar); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 709, __pyx_L1_error)
  __pyx_t_12 = (!__pyx_t_11);
  if (__pyx_t_12) {

    /* "cftime/_cftime.pyx":710
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:
 *         d0 = dates_test.item(0)             # <<<<<<<<<<<<<<
 *         if isinstance(d0,datetime_python):
 *             calendar = 'proleptic_gregorian'
*/
    __pyx_t_8 = __pyx_v_dates_test;
    __Pyx_INCREF(__pyx_t_8);
    __pyx_t_10 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_mstate_global->__pyx_int_0};
      __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 710, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
    }
    __Pyx_XDECREF_SET(__pyx_v_d0, __pyx_t_6);
    __pyx_t_6 = 0;

    /* "cftime/_cftime.pyx":711
 *     if not calendar:
 *         d0 = dates_test.item(0)
 *         if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *             calendar = 'proleptic_gregorian'
 *         else:
*/
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 711, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_12 = PyObject_IsInstance(__pyx_v_d0, __pyx_t_6); if (unlikely(__pyx_t_12 == ((int)-1))) __PYX_ERR(0, 711, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (__pyx_t_12) {

      /* "cftime/_cftime.pyx":712
 *         d0 = dates_test.item(0)
 *         if isinstance(d0,datetime_python):
 *             calendar = 'proleptic_gregorian'             # <<<<<<<<<<<<<<
 *         else:
 *             try:
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_proleptic_gregorian);
      __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian);

      /* "cftime/_cftime.pyx":711
 *     if not calendar:
 *         d0 = dates_test.item(0)
 *         if isinstance(d0,datetime_python):             # <<<<<<<<<<<<<<
 *             calendar = 'proleptic_gregorian'
 *         else:
*/
      goto __pyx_L23;
    }

    /* "cftime/_cftime.pyx":714
 *             calendar = 'proleptic_gregorian'
 *         else:
 *             try:             # <<<<<<<<<<<<<<
 *                 calendar = d0.calendar
 *             except AttributeError:
*/
    /*else*/ {
      {
        __Pyx_PyThreadState_declare
        __Pyx_PyThreadState_assign
        __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
        __Pyx_XGOTREF(__pyx_t_1);
        __Pyx_XGOTREF(__pyx_t_2);
        __Pyx_XGOTREF(__pyx_t_3);
        /*try:*/ {

          /* "cftime/_cftime.pyx":715
 *         else:
 *             try:
 *                 calendar = d0.calendar             # <<<<<<<<<<<<<<
 *             except AttributeError:
 *                 raise ValueError('no calendar specified',type(d0))
*/
          __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_d0, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 715, __pyx_L24_error)
          __Pyx_GOTREF(__pyx_t_6);
          __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_6);
          __pyx_t_6 = 0;

          /* "cftime/_cftime.pyx":714
 *             calendar = 'proleptic_gregorian'
 *         else:
 *             try:             # <<<<<<<<<<<<<<
 *                 calendar = d0.calendar
 *             except AttributeError:
*/
        }
        __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_L29_try_end;
        __pyx_L24_error:;
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;

        /* "cftime/_cftime.pyx":716
 *             try:
 *                 calendar = d0.calendar
 *             except AttributeError:             # <<<<<<<<<<<<<<
 *                 raise ValueError('no calendar specified',type(d0))
 * 
*/
        __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
        if (__pyx_t_5) {
          __Pyx_AddTraceback("cftime._cftime.date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
          if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_8, &__pyx_t_7) < 0) __PYX_ERR(0, 716, __pyx_L26_except_error)
          __Pyx_XGOTREF(__pyx_t_6);
          __Pyx_XGOTREF(__pyx_t_8);
          __Pyx_XGOTREF(__pyx_t_7);

          /* "cftime/_cftime.pyx":717
 *                 calendar = d0.calendar
 *             except AttributeError:
 *                 raise ValueError('no calendar specified',type(d0))             # <<<<<<<<<<<<<<
 * 
 *     calendar = calendar.lower()
*/
          __pyx_t_9 = NULL;
          __pyx_t_10 = 1;
          {
            PyObject *__pyx_callargs[3] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_no_calendar_specified, ((PyObject *)Py_TYPE(__pyx_v_d0))};
            __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
            __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
            if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 717, __pyx_L26_except_error)
            __Pyx_GOTREF(__pyx_t_4);
          }
          __Pyx_Raise(__pyx_t_4, 0, 0, 0);
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          __PYX_ERR(0, 717, __pyx_L26_except_error)
        }
        goto __pyx_L26_except_error;

        /* "cftime/_cftime.pyx":714
 *             calendar = 'proleptic_gregorian'
 *         else:
 *             try:             # <<<<<<<<<<<<<<
 *                 calendar = d0.calendar
 *             except AttributeError:
*/
        __pyx_L26_except_error:;
        __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_L29_try_end:;
      }
    }
    __pyx_L23:;

    /* "cftime/_cftime.pyx":709
 *     # if calendar is None or '', use calendar of first input cftime.datetime instances.
 *     # if inputs are 'real' python datetime instances, use proleptic gregorian.
 *     if not calendar:             # <<<<<<<<<<<<<<
 *         d0 = dates_test.item(0)
 *         if isinstance(d0,datetime_python):
*/
  }

  /* "cftime/_cftime.pyx":719
 *                 raise ValueError('no calendar specified',type(d0))
 * 
 *     calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     basedate = _dateparse(nctime.units,calendar=calendar,has_year_zero=has_year_zero)
 *     # real-world calendars limited to positive reference years.
*/
  __pyx_t_8 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_8);
  __pyx_t_10 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_8, NULL};
    __pyx_t_7 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_10, (1-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 719, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_7);
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":720
 * 
 *     calendar = calendar.lower()
 *     basedate = _dateparse(nctime.units,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
*/
  __pyx_t_8 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_dateparse); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 720, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 720, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_6);
    assert(__pyx_t_8);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
    __Pyx_INCREF(__pyx_t_8);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_8, __pyx_t_4};
    __pyx_t_9 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 720, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_9, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 720, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_9, __pyx_callargs+2, 1) < (0)) __PYX_ERR(0, 720, __pyx_L1_error)
    __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_9);
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
    __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;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 720, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_v_basedate = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":722
 *     basedate = _dateparse(nctime.units,calendar=calendar,has_year_zero=has_year_zero)
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_7 = __pyx_v_calendar;
  __pyx_t_13 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 722, __pyx_L1_error)
  if (!__pyx_t_13) {
  } else {
    __pyx_t_11 = __pyx_t_13;
    goto __pyx_L35_bool_binop_done;
  }
  __pyx_t_13 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 722, __pyx_L1_error)
  if (!__pyx_t_13) {
  } else {
    __pyx_t_11 = __pyx_t_13;
    goto __pyx_L35_bool_binop_done;
  }
  __pyx_t_13 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 722, __pyx_L1_error)
  if (!__pyx_t_13) {
  } else {
    __pyx_t_11 = __pyx_t_13;
    goto __pyx_L35_bool_binop_done;
  }
  __pyx_t_13 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 722, __pyx_L1_error)
  __pyx_t_11 = __pyx_t_13;
  __pyx_L35_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_13 = __pyx_t_11;
  if (__pyx_t_13) {
  } else {
    __pyx_t_12 = __pyx_t_13;
    goto __pyx_L33_bool_binop_done;
  }
  __pyx_t_13 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 722, __pyx_L1_error)
  __pyx_t_11 = (!__pyx_t_13);
  __pyx_t_12 = __pyx_t_11;
  __pyx_L33_bool_binop_done:;
  if (__pyx_t_12) {

    /* "cftime/_cftime.pyx":723
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
*/
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_basedate, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 723, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_12 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_7, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 723, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    if (unlikely(__pyx_t_12)) {

      /* "cftime/_cftime.pyx":724
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'             # <<<<<<<<<<<<<<
 *             raise ValueError(msg)
 * 
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_2);
      __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_zero_not_allowed_as_a_reference_2;

      /* "cftime/_cftime.pyx":725
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)             # <<<<<<<<<<<<<<
 * 
 *     if _can_use_python_datetime(basedate,calendar):
*/
      __pyx_t_6 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_msg};
        __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 725, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
      }
      __Pyx_Raise(__pyx_t_7, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __PYX_ERR(0, 725, __pyx_L1_error)

      /* "cftime/_cftime.pyx":723
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:
 *         if basedate.year == 0:             # <<<<<<<<<<<<<<
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
 *             raise ValueError(msg)
*/
    }

    /* "cftime/_cftime.pyx":722
 *     basedate = _dateparse(nctime.units,calendar=calendar,has_year_zero=has_year_zero)
 *     # real-world calendars limited to positive reference years.
 *     if calendar in ['julian', 'standard', 'gregorian', 'proleptic_gregorian'] and not has_year_zero:             # <<<<<<<<<<<<<<
 *         if basedate.year == 0:
 *             msg='zero not allowed as a reference year, does not exist in Julian or Gregorian calendars'
*/
  }

  /* "cftime/_cftime.pyx":727
 *             raise ValueError(msg)
 * 
 *     if _can_use_python_datetime(basedate,calendar):             # <<<<<<<<<<<<<<
 *         # use python datetime
 *         times = date2num(dates,nctime.units,calendar=calendar,has_year_zero=has_year_zero)
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_can_use_python_datetime); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 727, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_9))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_9);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_9, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_6, __pyx_v_basedate, __pyx_v_calendar};
    __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_9, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 727, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_7); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 727, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (__pyx_t_12) {

    /* "cftime/_cftime.pyx":729
 *     if _can_use_python_datetime(basedate,calendar):
 *         # use python datetime
 *         times = date2num(dates,nctime.units,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         return time2index(times, nctime, calendar, select)
 *     else: # use cftime module for other cases
*/
    __pyx_t_9 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_date2num); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 729, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 729, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_9);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_9);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_9, __pyx_v_dates, __pyx_t_4};
      __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 729, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_8, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 729, __pyx_L1_error)
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_8, __pyx_callargs+3, 1) < (0)) __PYX_ERR(0, 729, __pyx_L1_error)
      __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
      __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 729, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_v_times = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":730
 *         # use python datetime
 *         times = date2num(dates,nctime.units,calendar=calendar,has_year_zero=has_year_zero)
 *         return time2index(times, nctime, calendar, select)             # <<<<<<<<<<<<<<
 *     else: # use cftime module for other cases
 *         return _date2index(dates, nctime, calendar, select, has_year_zero=has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_6 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_time2index); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 730, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_6);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[5] = {__pyx_t_6, __pyx_v_times, __pyx_v_nctime, __pyx_v_calendar, __pyx_v_select};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (5-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 730, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_r = __pyx_t_7;
    __pyx_t_7 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":727
 *             raise ValueError(msg)
 * 
 *     if _can_use_python_datetime(basedate,calendar):             # <<<<<<<<<<<<<<
 *         # use python datetime
 *         times = date2num(dates,nctime.units,calendar=calendar,has_year_zero=has_year_zero)
*/
  }

  /* "cftime/_cftime.pyx":732
 *         return time2index(times, nctime, calendar, select)
 *     else: # use cftime module for other cases
 *         return _date2index(dates, nctime, calendar, select, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_date2index); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 732, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[5 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_8, __pyx_v_dates, __pyx_v_nctime, __pyx_v_calendar, __pyx_v_select};
      __pyx_t_4 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 732, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_4, __pyx_callargs+5, 0) < (0)) __PYX_ERR(0, 732, __pyx_L1_error)
      __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (5-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_4);
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 732, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_r = __pyx_t_7;
    __pyx_t_7 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":641
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):
 *     """
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime.date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_dates_test);
  __Pyx_XDECREF(__pyx_v_d0);
  __Pyx_XDECREF(__pyx_v_basedate);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_times);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":735
 * 
 * 
 * cdef _parse_timezone(tzstring):             # <<<<<<<<<<<<<<
 *     """Parses ISO 8601 time zone specs into tzinfo offsets
 * 
*/

static PyObject *__pyx_f_6cftime_7_cftime__parse_timezone(PyObject *__pyx_v_tzstring) {
  PyObject *__pyx_v_m = NULL;
  PyObject *__pyx_v_prefix = NULL;
  PyObject *__pyx_v_hours = NULL;
  PyObject *__pyx_v_minutes1 = NULL;
  PyObject *__pyx_v_minutes2 = NULL;
  PyObject *__pyx_v_minutes = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  size_t __pyx_t_6;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *(*__pyx_t_9)(PyObject *);
  int __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_parse_timezone", 0);

  /* "cftime/_cftime.pyx":740
 *     Adapted from pyiso8601 (http://code.google.com/p/pyiso8601/)
 *     """
 *     if tzstring == "Z":             # <<<<<<<<<<<<<<
 *         return 0
 *     # This isn't strictly correct, but it's common to encounter dates without
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_tzstring, __pyx_mstate_global->__pyx_n_u_Z, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 740, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":741
 *     """
 *     if tzstring == "Z":
 *         return 0             # <<<<<<<<<<<<<<
 *     # This isn't strictly correct, but it's common to encounter dates without
 *     # time zones so I'll assume the default (which defaults to UTC).
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_mstate_global->__pyx_int_0);
    __pyx_r = __pyx_mstate_global->__pyx_int_0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":740
 *     Adapted from pyiso8601 (http://code.google.com/p/pyiso8601/)
 *     """
 *     if tzstring == "Z":             # <<<<<<<<<<<<<<
 *         return 0
 *     # This isn't strictly correct, but it's common to encounter dates without
*/
  }

  /* "cftime/_cftime.pyx":744
 *     # This isn't strictly correct, but it's common to encounter dates without
 *     # time zones so I'll assume the default (which defaults to UTC).
 *     if tzstring is None:             # <<<<<<<<<<<<<<
 *         return 0
 *     m = TIMEZONE_REGEX.match(tzstring)
*/
  __pyx_t_1 = (__pyx_v_tzstring == Py_None);
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":745
 *     # time zones so I'll assume the default (which defaults to UTC).
 *     if tzstring is None:
 *         return 0             # <<<<<<<<<<<<<<
 *     m = TIMEZONE_REGEX.match(tzstring)
 *     prefix, hours, minutes1, minutes2 = m.groups()
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_mstate_global->__pyx_int_0);
    __pyx_r = __pyx_mstate_global->__pyx_int_0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":744
 *     # This isn't strictly correct, but it's common to encounter dates without
 *     # time zones so I'll assume the default (which defaults to UTC).
 *     if tzstring is None:             # <<<<<<<<<<<<<<
 *         return 0
 *     m = TIMEZONE_REGEX.match(tzstring)
*/
  }

  /* "cftime/_cftime.pyx":746
 *     if tzstring is None:
 *         return 0
 *     m = TIMEZONE_REGEX.match(tzstring)             # <<<<<<<<<<<<<<
 *     prefix, hours, minutes1, minutes2 = m.groups()
 *     hours = int(hours)
*/
  __pyx_t_3 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_TIMEZONE_REGEX); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 746, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_match); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 746, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_6 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_5))) {
    __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_5);
    assert(__pyx_t_3);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_5);
    __Pyx_INCREF(__pyx_t_3);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_5, __pyx__function);
    __pyx_t_6 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_tzstring};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_5, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 746, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_v_m = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":747
 *         return 0
 *     m = TIMEZONE_REGEX.match(tzstring)
 *     prefix, hours, minutes1, minutes2 = m.groups()             # <<<<<<<<<<<<<<
 *     hours = int(hours)
 *     # Note: Minutes don't have to be specified in tzstring, so if the group is not found it means minutes is 0.
*/
  __pyx_t_5 = __pyx_v_m;
  __Pyx_INCREF(__pyx_t_5);
  __pyx_t_6 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL};
    __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_groups, __pyx_callargs+__pyx_t_6, (1-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 747, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  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 != 4)) {
      if (size > 4) __Pyx_RaiseTooManyValuesError(4);
      else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
      __PYX_ERR(0, 747, __pyx_L1_error)
    }
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    if (likely(PyTuple_CheckExact(sequence))) {
      __pyx_t_5 = PyTuple_GET_ITEM(sequence, 0);
      __Pyx_INCREF(__pyx_t_5);
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_4 = PyTuple_GET_ITEM(sequence, 2);
      __Pyx_INCREF(__pyx_t_4);
      __pyx_t_7 = PyTuple_GET_ITEM(sequence, 3);
      __Pyx_INCREF(__pyx_t_7);
    } else {
      __pyx_t_5 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 747, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_5);
      __pyx_t_3 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 747, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_3);
      __pyx_t_4 = __Pyx_PyList_GetItemRefFast(sequence, 2, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 747, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __pyx_t_7 = __Pyx_PyList_GetItemRefFast(sequence, 3, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 747, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_7);
    }
    #else
    {
      Py_ssize_t i;
      PyObject** temps[4] = {&__pyx_t_5,&__pyx_t_3,&__pyx_t_4,&__pyx_t_7};
      for (i=0; i < 4; i++) {
        PyObject* item = __Pyx_PySequence_ITEM(sequence, i); if (unlikely(!item)) __PYX_ERR(0, 747, __pyx_L1_error)
        __Pyx_GOTREF(item);
        *(temps[i]) = item;
      }
    }
    #endif
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  } else {
    Py_ssize_t index = -1;
    PyObject** temps[4] = {&__pyx_t_5,&__pyx_t_3,&__pyx_t_4,&__pyx_t_7};
    __pyx_t_8 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 747, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_8);
    for (index=0; index < 4; index++) {
      PyObject* item = __pyx_t_9(__pyx_t_8); if (unlikely(!item)) goto __pyx_L5_unpacking_failed;
      __Pyx_GOTREF(item);
      *(temps[index]) = item;
    }
    if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 4) < (0)) __PYX_ERR(0, 747, __pyx_L1_error)
    __pyx_t_9 = NULL;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    goto __pyx_L6_unpacking_done;
    __pyx_L5_unpacking_failed:;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_9 = NULL;
    if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
    __PYX_ERR(0, 747, __pyx_L1_error)
    __pyx_L6_unpacking_done:;
  }
  __pyx_v_prefix = __pyx_t_5;
  __pyx_t_5 = 0;
  __pyx_v_hours = __pyx_t_3;
  __pyx_t_3 = 0;
  __pyx_v_minutes1 = __pyx_t_4;
  __pyx_t_4 = 0;
  __pyx_v_minutes2 = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":748
 *     m = TIMEZONE_REGEX.match(tzstring)
 *     prefix, hours, minutes1, minutes2 = m.groups()
 *     hours = int(hours)             # <<<<<<<<<<<<<<
 *     # Note: Minutes don't have to be specified in tzstring, so if the group is not found it means minutes is 0.
 *     #       Also, due to the timezone regex definition, there are two mutually exclusive groups that might hold the minutes value, so check both.
*/
  __pyx_t_2 = __Pyx_PyNumber_Int(__pyx_v_hours); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 748, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF_SET(__pyx_v_hours, __pyx_t_2);
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":751
 *     # Note: Minutes don't have to be specified in tzstring, so if the group is not found it means minutes is 0.
 *     #       Also, due to the timezone regex definition, there are two mutually exclusive groups that might hold the minutes value, so check both.
 *     minutes = int(minutes1) if minutes1 is not None else int(minutes2) if minutes2 is not None else 0             # <<<<<<<<<<<<<<
 *     if prefix == "-":
 *         hours = -hours
*/
  __pyx_t_1 = (__pyx_v_minutes1 != Py_None);
  if (__pyx_t_1) {
    __pyx_t_7 = __Pyx_PyNumber_Int(__pyx_v_minutes1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 751, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_2 = __pyx_t_7;
    __pyx_t_7 = 0;
  } else {
    __pyx_t_10 = (__pyx_v_minutes2 != Py_None);
    if (__pyx_t_10) {
      __pyx_t_4 = __Pyx_PyNumber_Int(__pyx_v_minutes2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 751, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_7 = __pyx_t_4;
      __pyx_t_4 = 0;
    } else {
      __Pyx_INCREF(__pyx_mstate_global->__pyx_int_0);
      __pyx_t_7 = __pyx_mstate_global->__pyx_int_0;
    }
    __pyx_t_2 = __pyx_t_7;
    __pyx_t_7 = 0;
  }
  __pyx_v_minutes = ((PyObject*)__pyx_t_2);
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":752
 *     #       Also, due to the timezone regex definition, there are two mutually exclusive groups that might hold the minutes value, so check both.
 *     minutes = int(minutes1) if minutes1 is not None else int(minutes2) if minutes2 is not None else 0
 *     if prefix == "-":             # <<<<<<<<<<<<<<
 *         hours = -hours
 *         minutes = -minutes
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_prefix, __pyx_mstate_global->__pyx_kp_u_, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 752, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":753
 *     minutes = int(minutes1) if minutes1 is not None else int(minutes2) if minutes2 is not None else 0
 *     if prefix == "-":
 *         hours = -hours             # <<<<<<<<<<<<<<
 *         minutes = -minutes
 *     return minutes + hours * 60.
*/
    __pyx_t_2 = PyNumber_Negative(__pyx_v_hours); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 753, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF_SET(__pyx_v_hours, __pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":754
 *     if prefix == "-":
 *         hours = -hours
 *         minutes = -minutes             # <<<<<<<<<<<<<<
 *     return minutes + hours * 60.
 * 
*/
    __pyx_t_2 = PyNumber_Negative(__pyx_v_minutes); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 754, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    if (__Pyx_PyInt_FromNumber(&__pyx_t_2, NULL, 0) < (0)) __PYX_ERR(0, 754, __pyx_L1_error)
    __Pyx_DECREF_SET(__pyx_v_minutes, ((PyObject*)__pyx_t_2));
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":752
 *     #       Also, due to the timezone regex definition, there are two mutually exclusive groups that might hold the minutes value, so check both.
 *     minutes = int(minutes1) if minutes1 is not None else int(minutes2) if minutes2 is not None else 0
 *     if prefix == "-":             # <<<<<<<<<<<<<<
 *         hours = -hours
 *         minutes = -minutes
*/
  }

  /* "cftime/_cftime.pyx":755
 *         hours = -hours
 *         minutes = -minutes
 *     return minutes + hours * 60.             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = PyNumber_Multiply(__pyx_v_hours, __pyx_mstate_global->__pyx_float_60_); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 755, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_7 = PyNumber_Add(__pyx_v_minutes, __pyx_t_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 755, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_7;
  __pyx_t_7 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":735
 * 
 * 
 * cdef _parse_timezone(tzstring):             # <<<<<<<<<<<<<<
 *     """Parses ISO 8601 time zone specs into tzinfo offsets
 * 
*/

  /* 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_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_AddTraceback("cftime._cftime._parse_timezone", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_m);
  __Pyx_XDECREF(__pyx_v_prefix);
  __Pyx_XDECREF(__pyx_v_hours);
  __Pyx_XDECREF(__pyx_v_minutes1);
  __Pyx_XDECREF(__pyx_v_minutes2);
  __Pyx_XDECREF(__pyx_v_minutes);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":758
 * 
 * 
 * cpdef _parse_date(datestring):             # <<<<<<<<<<<<<<
 *     """Parses ISO 8601 dates into datetime objects
 * 
*/

static PyObject *__pyx_pw_6cftime_7_cftime_27_parse_date(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime__parse_date(PyObject *__pyx_v_datestring, CYTHON_UNUSED int __pyx_skip_dispatch) {
  PyObject *__pyx_v_m = NULL;
  PyObject *__pyx_v_groups = NULL;
  PyObject *__pyx_v_tzoffset_mins = NULL;
  PyObject *__pyx_v_iyear = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  int __pyx_t_2;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  size_t __pyx_t_7;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  double __pyx_t_10;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_parse_date", 0);

  /* "cftime/_cftime.pyx":771
 * 
 *     """
 *     if not isinstance(datestring, str) and not isinstance(datestring, unicode):             # <<<<<<<<<<<<<<
 *         raise ValueError("Expecting a string %r" % datestring)
 *     m = ISO8601_REGEX.match(datestring.strip())
*/
  __pyx_t_2 = PyUnicode_Check(__pyx_v_datestring); 
  __pyx_t_3 = (!__pyx_t_2);
  if (__pyx_t_3) {
  } else {
    __pyx_t_1 = __pyx_t_3;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = PyUnicode_Check(__pyx_v_datestring); 
  __pyx_t_2 = (!__pyx_t_3);
  __pyx_t_1 = __pyx_t_2;
  __pyx_L4_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":772
 *     """
 *     if not isinstance(datestring, str) and not isinstance(datestring, unicode):
 *         raise ValueError("Expecting a string %r" % datestring)             # <<<<<<<<<<<<<<
 *     m = ISO8601_REGEX.match(datestring.strip())
 *     if not m:
*/
    __pyx_t_5 = NULL;
    __pyx_t_6 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_Expecting_a_string_r, __pyx_v_datestring); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 772, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_6};
      __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 772, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __Pyx_Raise(__pyx_t_4, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __PYX_ERR(0, 772, __pyx_L1_error)

    /* "cftime/_cftime.pyx":771
 * 
 *     """
 *     if not isinstance(datestring, str) and not isinstance(datestring, unicode):             # <<<<<<<<<<<<<<
 *         raise ValueError("Expecting a string %r" % datestring)
 *     m = ISO8601_REGEX.match(datestring.strip())
*/
  }

  /* "cftime/_cftime.pyx":773
 *     if not isinstance(datestring, str) and not isinstance(datestring, unicode):
 *         raise ValueError("Expecting a string %r" % datestring)
 *     m = ISO8601_REGEX.match(datestring.strip())             # <<<<<<<<<<<<<<
 *     if not m:
 *         raise ValueError("Unable to parse date string %r" % datestring)
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_ISO8601_REGEX); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 773, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_match); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 773, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_9 = __pyx_v_datestring;
  __Pyx_INCREF(__pyx_t_9);
  __pyx_t_7 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_9, NULL};
    __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_strip, __pyx_callargs+__pyx_t_7, (1-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
    if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 773, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
  }
  __pyx_t_7 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_8))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_8);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
    __pyx_t_7 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_5};
    __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 773, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
  }
  __pyx_v_m = __pyx_t_4;
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":774
 *         raise ValueError("Expecting a string %r" % datestring)
 *     m = ISO8601_REGEX.match(datestring.strip())
 *     if not m:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unable to parse date string %r" % datestring)
 *     groups = m.groupdict()
*/
  __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_m); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 774, __pyx_L1_error)
  __pyx_t_2 = (!__pyx_t_1);
  if (unlikely(__pyx_t_2)) {

    /* "cftime/_cftime.pyx":775
 *     m = ISO8601_REGEX.match(datestring.strip())
 *     if not m:
 *         raise ValueError("Unable to parse date string %r" % datestring)             # <<<<<<<<<<<<<<
 *     groups = m.groupdict()
 *     tzoffset_mins = _parse_timezone(groups["timezone"])
*/
    __pyx_t_8 = NULL;
    __pyx_t_5 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_Unable_to_parse_date_string_r, __pyx_v_datestring); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 775, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_7 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_t_5};
      __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 775, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __Pyx_Raise(__pyx_t_4, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __PYX_ERR(0, 775, __pyx_L1_error)

    /* "cftime/_cftime.pyx":774
 *         raise ValueError("Expecting a string %r" % datestring)
 *     m = ISO8601_REGEX.match(datestring.strip())
 *     if not m:             # <<<<<<<<<<<<<<
 *         raise ValueError("Unable to parse date string %r" % datestring)
 *     groups = m.groupdict()
*/
  }

  /* "cftime/_cftime.pyx":776
 *     if not m:
 *         raise ValueError("Unable to parse date string %r" % datestring)
 *     groups = m.groupdict()             # <<<<<<<<<<<<<<
 *     tzoffset_mins = _parse_timezone(groups["timezone"])
 *     if groups["hour"] is None:
*/
  __pyx_t_5 = __pyx_v_m;
  __Pyx_INCREF(__pyx_t_5);
  __pyx_t_7 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL};
    __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_groupdict, __pyx_callargs+__pyx_t_7, (1-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
    if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 776, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
  }
  __pyx_v_groups = __pyx_t_4;
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":777
 *         raise ValueError("Unable to parse date string %r" % datestring)
 *     groups = m.groupdict()
 *     tzoffset_mins = _parse_timezone(groups["timezone"])             # <<<<<<<<<<<<<<
 *     if groups["hour"] is None:
 *         groups["hour"] = 0
*/
  __pyx_t_4 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_timezone); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 777, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __pyx_f_6cftime_7_cftime__parse_timezone(__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 777, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_tzoffset_mins = __pyx_t_5;
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":778
 *     groups = m.groupdict()
 *     tzoffset_mins = _parse_timezone(groups["timezone"])
 *     if groups["hour"] is None:             # <<<<<<<<<<<<<<
 *         groups["hour"] = 0
 *     if groups["minute"] is None:
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 778, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = (__pyx_t_5 == Py_None);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":779
 *     tzoffset_mins = _parse_timezone(groups["timezone"])
 *     if groups["hour"] is None:
 *         groups["hour"] = 0             # <<<<<<<<<<<<<<
 *     if groups["minute"] is None:
 *         groups["minute"] = 0
*/
    if (unlikely((PyObject_SetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_hour, __pyx_mstate_global->__pyx_int_0) < 0))) __PYX_ERR(0, 779, __pyx_L1_error)

    /* "cftime/_cftime.pyx":778
 *     groups = m.groupdict()
 *     tzoffset_mins = _parse_timezone(groups["timezone"])
 *     if groups["hour"] is None:             # <<<<<<<<<<<<<<
 *         groups["hour"] = 0
 *     if groups["minute"] is None:
*/
  }

  /* "cftime/_cftime.pyx":780
 *     if groups["hour"] is None:
 *         groups["hour"] = 0
 *     if groups["minute"] is None:             # <<<<<<<<<<<<<<
 *         groups["minute"] = 0
 *     if groups["second"] is None:
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 780, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = (__pyx_t_5 == Py_None);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":781
 *         groups["hour"] = 0
 *     if groups["minute"] is None:
 *         groups["minute"] = 0             # <<<<<<<<<<<<<<
 *     if groups["second"] is None:
 *         groups["second"] = 0
*/
    if (unlikely((PyObject_SetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_minute, __pyx_mstate_global->__pyx_int_0) < 0))) __PYX_ERR(0, 781, __pyx_L1_error)

    /* "cftime/_cftime.pyx":780
 *     if groups["hour"] is None:
 *         groups["hour"] = 0
 *     if groups["minute"] is None:             # <<<<<<<<<<<<<<
 *         groups["minute"] = 0
 *     if groups["second"] is None:
*/
  }

  /* "cftime/_cftime.pyx":782
 *     if groups["minute"] is None:
 *         groups["minute"] = 0
 *     if groups["second"] is None:             # <<<<<<<<<<<<<<
 *         groups["second"] = 0
 *     if groups["fraction"] is None:
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 782, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = (__pyx_t_5 == Py_None);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":783
 *         groups["minute"] = 0
 *     if groups["second"] is None:
 *         groups["second"] = 0             # <<<<<<<<<<<<<<
 *     if groups["fraction"] is None:
 *         groups["fraction"] = 0
*/
    if (unlikely((PyObject_SetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_second, __pyx_mstate_global->__pyx_int_0) < 0))) __PYX_ERR(0, 783, __pyx_L1_error)

    /* "cftime/_cftime.pyx":782
 *     if groups["minute"] is None:
 *         groups["minute"] = 0
 *     if groups["second"] is None:             # <<<<<<<<<<<<<<
 *         groups["second"] = 0
 *     if groups["fraction"] is None:
*/
  }

  /* "cftime/_cftime.pyx":784
 *     if groups["second"] is None:
 *         groups["second"] = 0
 *     if groups["fraction"] is None:             # <<<<<<<<<<<<<<
 *         groups["fraction"] = 0
 *     else:
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_fraction); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 784, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_2 = (__pyx_t_5 == Py_None);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":785
 *         groups["second"] = 0
 *     if groups["fraction"] is None:
 *         groups["fraction"] = 0             # <<<<<<<<<<<<<<
 *     else:
 *         groups["fraction"] = int(float("0.%s" % groups["fraction"]) * 1e6)
*/
    if (unlikely((PyObject_SetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_fraction, __pyx_mstate_global->__pyx_int_0) < 0))) __PYX_ERR(0, 785, __pyx_L1_error)

    /* "cftime/_cftime.pyx":784
 *     if groups["second"] is None:
 *         groups["second"] = 0
 *     if groups["fraction"] is None:             # <<<<<<<<<<<<<<
 *         groups["fraction"] = 0
 *     else:
*/
    goto __pyx_L10;
  }

  /* "cftime/_cftime.pyx":787
 *         groups["fraction"] = 0
 *     else:
 *         groups["fraction"] = int(float("0.%s" % groups["fraction"]) * 1e6)             # <<<<<<<<<<<<<<
 *     iyear = int(groups["year"])
 *     return iyear, int(groups["month"]), int(groups["day"]),\
*/
  /*else*/ {
    __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_fraction); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 787, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_0_s, __pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 787, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_10 = __Pyx_PyUnicode_AsDouble(__pyx_t_4); if (unlikely(__PYX_CHECK_FLOAT_EXCEPTION(__pyx_t_10, ((double)((double)-1))) && PyErr_Occurred())) __PYX_ERR(0, 787, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = PyLong_FromDouble((__pyx_t_10 * 1e6)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 787, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (unlikely((PyObject_SetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_fraction, __pyx_t_4) < 0))) __PYX_ERR(0, 787, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  }
  __pyx_L10:;

  /* "cftime/_cftime.pyx":788
 *     else:
 *         groups["fraction"] = int(float("0.%s" % groups["fraction"]) * 1e6)
 *     iyear = int(groups["year"])             # <<<<<<<<<<<<<<
 *     return iyear, int(groups["month"]), int(groups["day"]),\
 *         int(groups["hour"]), int(groups["minute"]), int(groups["second"]),\
*/
  __pyx_t_4 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 788, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyNumber_Int(__pyx_t_4); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 788, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_v_iyear = ((PyObject*)__pyx_t_5);
  __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":789
 *         groups["fraction"] = int(float("0.%s" % groups["fraction"]) * 1e6)
 *     iyear = int(groups["year"])
 *     return iyear, int(groups["month"]), int(groups["day"]),\             # <<<<<<<<<<<<<<
 *         int(groups["hour"]), int(groups["minute"]), int(groups["second"]),\
 *         int(groups["fraction"]),\
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 789, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_4 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 789, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 789, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_8 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 789, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":790
 *     iyear = int(groups["year"])
 *     return iyear, int(groups["month"]), int(groups["day"]),\
 *         int(groups["hour"]), int(groups["minute"]), int(groups["second"]),\             # <<<<<<<<<<<<<<
 *         int(groups["fraction"]),\
 *         tzoffset_mins
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_9 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_11 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 790, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":791
 *     return iyear, int(groups["month"]), int(groups["day"]),\
 *         int(groups["hour"]), int(groups["minute"]), int(groups["second"]),\
 *         int(groups["fraction"]),\             # <<<<<<<<<<<<<<
 *         tzoffset_mins
 * 
*/
  __pyx_t_5 = __Pyx_PyObject_Dict_GetItem(__pyx_v_groups, __pyx_mstate_global->__pyx_n_u_fraction); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 791, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_12 = __Pyx_PyNumber_Int(__pyx_t_5); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 791, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;

  /* "cftime/_cftime.pyx":789
 *         groups["fraction"] = int(float("0.%s" % groups["fraction"]) * 1e6)
 *     iyear = int(groups["year"])
 *     return iyear, int(groups["month"]), int(groups["day"]),\             # <<<<<<<<<<<<<<
 *         int(groups["hour"]), int(groups["minute"]), int(groups["second"]),\
 *         int(groups["fraction"]),\
*/
  __pyx_t_5 = PyTuple_New(8); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 789, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __Pyx_INCREF(__pyx_v_iyear);
  __Pyx_GIVEREF(__pyx_v_iyear);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v_iyear) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_4);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_4) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_8);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_t_8) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 3, __pyx_t_6) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_9);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 4, __pyx_t_9) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_11);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 5, __pyx_t_11) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_12);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 6, __pyx_t_12) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_tzoffset_mins);
  __Pyx_GIVEREF(__pyx_v_tzoffset_mins);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_5, 7, __pyx_v_tzoffset_mins) != (0)) __PYX_ERR(0, 789, __pyx_L1_error);
  __pyx_t_4 = 0;
  __pyx_t_8 = 0;
  __pyx_t_6 = 0;
  __pyx_t_9 = 0;
  __pyx_t_11 = 0;
  __pyx_t_12 = 0;
  __pyx_r = __pyx_t_5;
  __pyx_t_5 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":758
 * 
 * 
 * cpdef _parse_date(datestring):             # <<<<<<<<<<<<<<
 *     """Parses ISO 8601 dates into datetime objects
 * 
*/

  /* 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_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_AddTraceback("cftime._cftime._parse_date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_m);
  __Pyx_XDECREF(__pyx_v_groups);
  __Pyx_XDECREF(__pyx_v_tzoffset_mins);
  __Pyx_XDECREF(__pyx_v_iyear);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_27_parse_date(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_26_parse_date, "Parses ISO 8601 dates into datetime objects\n\n    The timezone is parsed from the date string, assuming UTC\n    by default.\n\n    Note that a seconds element with a fractional component\n    (e.g. 12.5) is converted into integer seconds and integer\n    microseconds.\n\n    Adapted from pyiso8601 (http://code.google.com/p/pyiso8601/)\n\n    ");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_27_parse_date = {"_parse_date", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_27_parse_date, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_26_parse_date};
static PyObject *__pyx_pw_6cftime_7_cftime_27_parse_date(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_datestring = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_parse_date (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_datestring,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 758, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 758, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_parse_date", 0) < (0)) __PYX_ERR(0, 758, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_parse_date", 1, 1, 1, i); __PYX_ERR(0, 758, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 758, __pyx_L3_error)
    }
    __pyx_v_datestring = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_parse_date", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 758, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._parse_date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_26_parse_date(__pyx_self, __pyx_v_datestring);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_26_parse_date(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_datestring) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_parse_date", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_6cftime_7_cftime__parse_date(__pyx_v_datestring, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 758, __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("cftime._cftime._parse_date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":794
 *         tzoffset_mins
 * 
 * cdef _check_index(indices, times, nctime, select):             # <<<<<<<<<<<<<<
 *     """Return True if the time indices given correspond to the given times,
 *     False otherwise.
*/

static PyObject *__pyx_f_6cftime_7_cftime__check_index(PyObject *__pyx_v_indices, PyObject *__pyx_v_times, PyObject *__pyx_v_nctime, PyObject *__pyx_v_select) {
  PyObject *__pyx_v_N = NULL;
  PyObject *__pyx_v_t = NULL;
  PyObject *__pyx_v_ta = NULL;
  PyObject *__pyx_v_tb = NULL;
  PyObject *__pyx_v_delta_after = NULL;
  PyObject *__pyx_v_delta_before = NULL;
  PyObject *__pyx_v_delta_check = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  int __pyx_t_9;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_check_index", 0);
  __Pyx_INCREF(__pyx_v_nctime);

  /* "cftime/_cftime.pyx":812
 *     Index selection method.
 *     """
 *     N = nctime.shape[0]             # <<<<<<<<<<<<<<
 *     if (indices < 0).any():
 *         return False
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_shape); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 812, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_GetItemInt(__pyx_t_1, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 812, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_N = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":813
 *     """
 *     N = nctime.shape[0]
 *     if (indices < 0).any():             # <<<<<<<<<<<<<<
 *         return False
 * 
*/
  __pyx_t_3 = PyObject_RichCompare(__pyx_v_indices, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 813, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_3;
  __Pyx_INCREF(__pyx_t_1);
  __pyx_t_4 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_1, NULL};
    __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_any, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __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(0, 813, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 813, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":814
 *     N = nctime.shape[0]
 *     if (indices < 0).any():
 *         return False             # <<<<<<<<<<<<<<
 * 
 *     if (indices >= N).any():
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_False);
    __pyx_r = Py_False;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":813
 *     """
 *     N = nctime.shape[0]
 *     if (indices < 0).any():             # <<<<<<<<<<<<<<
 *         return False
 * 
*/
  }

  /* "cftime/_cftime.pyx":816
 *         return False
 * 
 *     if (indices >= N).any():             # <<<<<<<<<<<<<<
 *         return False
 * 
*/
  __pyx_t_1 = PyObject_RichCompare(__pyx_v_indices, __pyx_v_N, Py_GE); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 816, __pyx_L1_error)
  __pyx_t_3 = __pyx_t_1;
  __Pyx_INCREF(__pyx_t_3);
  __pyx_t_4 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
    __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_any, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 816, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 816, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":817
 * 
 *     if (indices >= N).any():
 *         return False             # <<<<<<<<<<<<<<
 * 
 *     try:
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_False);
    __pyx_r = Py_False;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":816
 *         return False
 * 
 *     if (indices >= N).any():             # <<<<<<<<<<<<<<
 *         return False
 * 
*/
  }

  /* "cftime/_cftime.pyx":819
 *         return False
 * 
 *     try:             # <<<<<<<<<<<<<<
 *         t = nctime[indices]
 *         nctime = nctime
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8);
    __Pyx_XGOTREF(__pyx_t_6);
    __Pyx_XGOTREF(__pyx_t_7);
    __Pyx_XGOTREF(__pyx_t_8);
    /*try:*/ {

      /* "cftime/_cftime.pyx":820
 * 
 *     try:
 *         t = nctime[indices]             # <<<<<<<<<<<<<<
 *         nctime = nctime
 *     # WORKAROUND TO CHANGES IN SLICING BEHAVIOUR in 1.1.2
*/
      __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_v_indices); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 820, __pyx_L5_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_v_t = __pyx_t_2;
      __pyx_t_2 = 0;

      /* "cftime/_cftime.pyx":821
 *     try:
 *         t = nctime[indices]
 *         nctime = nctime             # <<<<<<<<<<<<<<
 *     # WORKAROUND TO CHANGES IN SLICING BEHAVIOUR in 1.1.2
 *     # this may be unacceptably slow...
*/
      __Pyx_INCREF(__pyx_v_nctime);
      __Pyx_DECREF_SET(__pyx_v_nctime, __pyx_v_nctime);

      /* "cftime/_cftime.pyx":819
 *         return False
 * 
 *     try:             # <<<<<<<<<<<<<<
 *         t = nctime[indices]
 *         nctime = nctime
*/
    }
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
    goto __pyx_L10_try_end;
    __pyx_L5_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;

    /* "cftime/_cftime.pyx":827
 *     # values in indices, read entire time variable into numpy
 *     # array so numpy slicing rules can be used.
 *     except IndexError:             # <<<<<<<<<<<<<<
 *         nctime = nctime[:]
 *         t = nctime[indices]
*/
    __pyx_t_9 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_IndexError))));
    if (__pyx_t_9) {
      __Pyx_AddTraceback("cftime._cftime._check_index", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_2, &__pyx_t_1, &__pyx_t_3) < 0) __PYX_ERR(0, 827, __pyx_L7_except_error)
      __Pyx_XGOTREF(__pyx_t_2);
      __Pyx_XGOTREF(__pyx_t_1);
      __Pyx_XGOTREF(__pyx_t_3);

      /* "cftime/_cftime.pyx":828
 *     # array so numpy slicing rules can be used.
 *     except IndexError:
 *         nctime = nctime[:]             # <<<<<<<<<<<<<<
 *         t = nctime[indices]
 * # if fancy indexing not available, fall back on this.
*/
      __pyx_t_10 = __Pyx_PyObject_GetSlice(__pyx_v_nctime, 0, 0, NULL, NULL, &__pyx_mstate_global->__pyx_slice[0], 0, 0, 1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 828, __pyx_L7_except_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF_SET(__pyx_v_nctime, __pyx_t_10);
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":829
 *     except IndexError:
 *         nctime = nctime[:]
 *         t = nctime[indices]             # <<<<<<<<<<<<<<
 * # if fancy indexing not available, fall back on this.
 * #   t=[]
*/
      __pyx_t_10 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_v_indices); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 829, __pyx_L7_except_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_XDECREF_SET(__pyx_v_t, __pyx_t_10);
      __pyx_t_10 = 0;
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      goto __pyx_L6_exception_handled;
    }
    goto __pyx_L7_except_error;

    /* "cftime/_cftime.pyx":819
 *         return False
 * 
 *     try:             # <<<<<<<<<<<<<<
 *         t = nctime[indices]
 *         nctime = nctime
*/
    __pyx_L7_except_error:;
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_XGIVEREF(__pyx_t_7);
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8);
    goto __pyx_L1_error;
    __pyx_L6_exception_handled:;
    __Pyx_XGIVEREF(__pyx_t_6);
    __Pyx_XGIVEREF(__pyx_t_7);
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8);
    __pyx_L10_try_end:;
  }

  /* "cftime/_cftime.pyx":835
 * #       t.append(nctime[ind])
 * 
 *     if select == 'exact':             # <<<<<<<<<<<<<<
 *         return np.all(t == times)
 * 
*/
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_exact, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 835, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":836
 * 
 *     if select == 'exact':
 *         return np.all(t == times)             # <<<<<<<<<<<<<<
 * 
 *     elif select == 'before':
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 836, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 836, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyObject_RichCompare(__pyx_v_t, __pyx_v_times, Py_EQ); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 836, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_10);
      assert(__pyx_t_1);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_2};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 836, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_r = __pyx_t_3;
    __pyx_t_3 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":835
 * #       t.append(nctime[ind])
 * 
 *     if select == 'exact':             # <<<<<<<<<<<<<<
 *         return np.all(t == times)
 * 
*/
  }

  /* "cftime/_cftime.pyx":838
 *         return np.all(t == times)
 * 
 *     elif select == 'before':             # <<<<<<<<<<<<<<
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         return np.all(t <= times) and np.all(ta > times)
*/
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_before, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 838, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":839
 * 
 *     elif select == 'before':
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]             # <<<<<<<<<<<<<<
 *         return np.all(t <= times) and np.all(ta > times)
 * 
*/
    __pyx_t_10 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 839, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_clip); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 839, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = __Pyx_PyLong_AddObjC(__pyx_v_indices, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 839, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_11 = __Pyx_PyLong_SubtractObjC(__pyx_v_N, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 839, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_1);
      assert(__pyx_t_10);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_10);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[4] = {__pyx_t_10, __pyx_t_2, __pyx_mstate_global->__pyx_int_0, __pyx_t_11};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 839, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_1 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_t_3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 839, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_ta = __pyx_t_1;
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":840
 *     elif select == 'before':
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         return np.all(t <= times) and np.all(ta > times)             # <<<<<<<<<<<<<<
 * 
 *     elif select == 'after':
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_11 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 840, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 840, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyObject_RichCompare(__pyx_v_t, __pyx_v_times, Py_LE); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 840, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_10);
      assert(__pyx_t_11);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_11);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_t_2};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 840, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 840, __pyx_L1_error)
    if (__pyx_t_5) {
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else {
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_1 = __pyx_t_3;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      goto __pyx_L14_bool_binop_done;
    }
    __pyx_t_10 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 840, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 840, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyObject_RichCompare(__pyx_v_ta, __pyx_v_times, Py_GT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 840, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_11);
      assert(__pyx_t_10);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
      __Pyx_INCREF(__pyx_t_10);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_2};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 840, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_1 = __pyx_t_3;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_L14_bool_binop_done:;
    __pyx_r = __pyx_t_1;
    __pyx_t_1 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":838
 *         return np.all(t == times)
 * 
 *     elif select == 'before':             # <<<<<<<<<<<<<<
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         return np.all(t <= times) and np.all(ta > times)
*/
  }

  /* "cftime/_cftime.pyx":842
 *         return np.all(t <= times) and np.all(ta > times)
 * 
 *     elif select == 'after':             # <<<<<<<<<<<<<<
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         return np.all(t >= times) and np.all(tb < times)
*/
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_after, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 842, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":843
 * 
 *     elif select == 'after':
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]             # <<<<<<<<<<<<<<
 *         return np.all(t >= times) and np.all(tb < times)
 * 
*/
    __pyx_t_3 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 843, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_clip); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 843, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_t_11 = __Pyx_PyLong_SubtractObjC(__pyx_v_indices, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 843, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_10 = __Pyx_PyLong_SubtractObjC(__pyx_v_N, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 843, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_2);
      assert(__pyx_t_3);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[4] = {__pyx_t_3, __pyx_t_11, __pyx_mstate_global->__pyx_int_0, __pyx_t_10};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 843, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_2 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 843, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_v_tb = __pyx_t_2;
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":844
 *     elif select == 'after':
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         return np.all(t >= times) and np.all(tb < times)             # <<<<<<<<<<<<<<
 * 
 *     elif select == 'nearest':
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_10 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 844, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 844, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_t_11 = PyObject_RichCompare(__pyx_v_t, __pyx_v_times, Py_GE); __Pyx_XGOTREF(__pyx_t_11); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 844, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_3);
      assert(__pyx_t_10);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_10);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_3, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_11};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 844, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 844, __pyx_L1_error)
    if (__pyx_t_5) {
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    } else {
      __Pyx_INCREF(__pyx_t_1);
      __pyx_t_2 = __pyx_t_1;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      goto __pyx_L16_bool_binop_done;
    }
    __pyx_t_3 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 844, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 844, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_t_11 = PyObject_RichCompare(__pyx_v_tb, __pyx_v_times, Py_LT); __Pyx_XGOTREF(__pyx_t_11); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 844, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_10);
      assert(__pyx_t_3);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_3);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_11};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 844, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_INCREF(__pyx_t_1);
    __pyx_t_2 = __pyx_t_1;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_L16_bool_binop_done:;
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":842
 *         return np.all(t <= times) and np.all(ta > times)
 * 
 *     elif select == 'after':             # <<<<<<<<<<<<<<
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         return np.all(t >= times) and np.all(tb < times)
*/
  }

  /* "cftime/_cftime.pyx":846
 *         return np.all(t >= times) and np.all(tb < times)
 * 
 *     elif select == 'nearest':             # <<<<<<<<<<<<<<
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
*/
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_nearest, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 846, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":847
 * 
 *     elif select == 'nearest':
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]             # <<<<<<<<<<<<<<
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         delta_after = ta - t
*/
    __pyx_t_1 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 847, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_clip); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 847, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __pyx_t_10 = __Pyx_PyLong_AddObjC(__pyx_v_indices, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 847, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_3 = __Pyx_PyLong_SubtractObjC(__pyx_v_N, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 847, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_11);
      assert(__pyx_t_1);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[4] = {__pyx_t_1, __pyx_t_10, __pyx_mstate_global->__pyx_int_0, __pyx_t_3};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 847, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_11 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_t_2); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 847, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_ta = __pyx_t_11;
    __pyx_t_11 = 0;

    /* "cftime/_cftime.pyx":848
 *     elif select == 'nearest':
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]             # <<<<<<<<<<<<<<
 *         delta_after = ta - t
 *         delta_before = t - tb
*/
    __pyx_t_2 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 848, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_clip); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 848, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = __Pyx_PyLong_SubtractObjC(__pyx_v_indices, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 848, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = __Pyx_PyLong_SubtractObjC(__pyx_v_N, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 848, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_10))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_10);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_10);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_10, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[4] = {__pyx_t_2, __pyx_t_3, __pyx_mstate_global->__pyx_int_0, __pyx_t_1};
      __pyx_t_11 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_10, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 848, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_11);
    }
    __pyx_t_10 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_t_11); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 848, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_v_tb = __pyx_t_10;
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":849
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         delta_after = ta - t             # <<<<<<<<<<<<<<
 *         delta_before = t - tb
 *         delta_check = np.abs(times - t)
*/
    __pyx_t_10 = PyNumber_Subtract(__pyx_v_ta, __pyx_v_t); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 849, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_v_delta_after = __pyx_t_10;
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":850
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
 *         delta_after = ta - t
 *         delta_before = t - tb             # <<<<<<<<<<<<<<
 *         delta_check = np.abs(times - t)
 *         return np.all(delta_check <= delta_after) and np.all(delta_check <= delta_before)
*/
    __pyx_t_10 = PyNumber_Subtract(__pyx_v_t, __pyx_v_tb); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 850, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_v_delta_before = __pyx_t_10;
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":851
 *         delta_after = ta - t
 *         delta_before = t - tb
 *         delta_check = np.abs(times - t)             # <<<<<<<<<<<<<<
 *         return np.all(delta_check <= delta_after) and np.all(delta_check <= delta_before)
 * 
*/
    __pyx_t_11 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 851, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_abs); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 851, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_1 = PyNumber_Subtract(__pyx_v_times, __pyx_v_t); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 851, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_3);
      assert(__pyx_t_11);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_11);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_3, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_t_1};
      __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 851, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __pyx_v_delta_check = __pyx_t_10;
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":852
 *         delta_before = t - tb
 *         delta_check = np.abs(times - t)
 *         return np.all(delta_check <= delta_after) and np.all(delta_check <= delta_before)             # <<<<<<<<<<<<<<
 * 
 * 
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 852, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 852, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_t_11 = PyObject_RichCompare(__pyx_v_delta_check, __pyx_v_delta_after, Py_LE); __Pyx_XGOTREF(__pyx_t_11); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 852, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_2);
      assert(__pyx_t_1);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_1, __pyx_t_11};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 852, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 852, __pyx_L1_error)
    if (__pyx_t_5) {
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    } else {
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_10 = __pyx_t_3;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      goto __pyx_L18_bool_binop_done;
    }
    __pyx_t_2 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 852, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_all); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 852, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_t_11 = PyObject_RichCompare(__pyx_v_delta_check, __pyx_v_delta_before, Py_LE); __Pyx_XGOTREF(__pyx_t_11); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 852, __pyx_L1_error)
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_1);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_11};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 852, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_10 = __pyx_t_3;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_L18_bool_binop_done:;
    __pyx_r = __pyx_t_10;
    __pyx_t_10 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":846
 *         return np.all(t >= times) and np.all(tb < times)
 * 
 *     elif select == 'nearest':             # <<<<<<<<<<<<<<
 *         ta = nctime[np.clip(indices + 1, 0, N - 1)]
 *         tb = nctime[np.clip(indices - 1, 0, N - 1)]
*/
  }

  /* "cftime/_cftime.pyx":794
 *         tzoffset_mins
 * 
 * cdef _check_index(indices, times, nctime, select):             # <<<<<<<<<<<<<<
 *     """Return True if the time indices given correspond to the given times,
 *     False otherwise.
*/

  /* 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_3);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_AddTraceback("cftime._cftime._check_index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_N);
  __Pyx_XDECREF(__pyx_v_t);
  __Pyx_XDECREF(__pyx_v_ta);
  __Pyx_XDECREF(__pyx_v_tb);
  __Pyx_XDECREF(__pyx_v_delta_after);
  __Pyx_XDECREF(__pyx_v_delta_before);
  __Pyx_XDECREF(__pyx_v_delta_check);
  __Pyx_XDECREF(__pyx_v_nctime);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":855
 * 
 * 
 * def _date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """
 *     Return indices of a netCDF time variable corresponding to the given dates.
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_29_date2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_28_date2index, "\n    Return indices of a netCDF time variable corresponding to the given dates.\n\n    **dates**: A datetime object or a sequence of datetime objects.\n    The datetime objects should not include a time-zone offset.\n\n    **nctime**: A netCDF time variable object. The nctime object must have a\n    `units` attribute. The entries are assumed to be stored in increasing\n    order.\n\n    **calendar**: Describes the calendar used in the time calculation.\n    Valid calendars 'standard', 'gregorian', 'proleptic_gregorian'\n    'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'.\n    Default is 'standard', which is a mixed Julian/Gregorian calendar\n    If `calendar` is None, its value is given by `nctime.calendar` or\n    `standard` if no such attribute exists.\n\n    **select**: 'exact', 'before', 'after', 'nearest'\n    The index selection method. `exact` will return the indices perfectly\n    matching the dates given. `before` and `after` will return the indices\n    corresponding to the dates just before or just after the given dates if\n    an exact match cannot be found. `nearest` will return the indices that\n    correspond to the closest dates.\n\n    **has_year_zero**: if set to True, astronomical year numbering\n    is used and the year zero exists.  If set to False for real-world\n    calendars, then historical year numbering is used and the year 1 is\n    preceded by year -1 and no year zero exists.\n    The defaults are set to conform with\n    CF version 1.9 conventions (False for 'julian', 'gregorian'/'standard', True\n    for 'proleptic_gregorian' (ISO 8601) and True for the idealized\n    calendars 'noleap'/'365_day', '360_day', 366_day'/'all_leap')\n    The defaults can only be over-ridden for the real-world calendars,\n    for the the idealized calendars the year zero \n    always exists and the has_year_zero kwarg is ignored.\n    This kwarg is not needed to define calendar systems allowed by CF\n    (the calendar-specific defaults do ""this).\n    ");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_29_date2index = {"_date2index", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_29_date2index, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_28_date2index};
static PyObject *__pyx_pw_6cftime_7_cftime_29_date2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_dates = 0;
  PyObject *__pyx_v_nctime = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_select = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[5] = {0,0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_date2index (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_dates,&__pyx_mstate_global->__pyx_n_u_nctime,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_select,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 855, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_date2index", 0) < (0)) __PYX_ERR(0, 855, __pyx_L3_error)
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_date2index", 0, 2, 5, i); __PYX_ERR(0, 855, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  5:
        values[4] = __Pyx_ArgRef_FASTCALL(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 855, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 855, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 855, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
      if (!values[4]) values[4] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_dates = values[0];
    __pyx_v_nctime = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_select = values[3];
    __pyx_v_has_year_zero = values[4];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_date2index", 0, 2, 5, __pyx_nargs); __PYX_ERR(0, 855, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_28_date2index(__pyx_self, __pyx_v_dates, __pyx_v_nctime, __pyx_v_calendar, __pyx_v_select, __pyx_v_has_year_zero);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_28_date2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dates, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_times = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_date2index", 0);

  /* "cftime/_cftime.pyx":894
 *     (the calendar-specific defaults do this).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":895
 *     """
 *     try:
 *         nctime.units             # <<<<<<<<<<<<<<
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
*/
      __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 895, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":894
 *     (the calendar-specific defaults do this).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    }
    __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;

    /* "cftime/_cftime.pyx":896
 *     try:
 *         nctime.units
 *     except AttributeError:             # <<<<<<<<<<<<<<
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     times = date2num(dates,nctime.units,calendar=calendar, has_year_zero=has_year_zero)
*/
    __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
    if (__pyx_t_5) {
      __Pyx_AddTraceback("cftime._cftime._date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(0, 896, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "cftime/_cftime.pyx":897
 *         nctime.units
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")             # <<<<<<<<<<<<<<
 *     times = date2num(dates,nctime.units,calendar=calendar, has_year_zero=has_year_zero)
 *     return time2index(times, nctime, calendar=calendar, select=select)
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_netcdf_time_variable_is_missing};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_AttributeError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 897, __pyx_L5_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(0, 897, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":894
 *     (the calendar-specific defaults do this).
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "cftime/_cftime.pyx":898
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     times = date2num(dates,nctime.units,calendar=calendar, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     return time2index(times, nctime, calendar=calendar, select=select)
 * 
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_date2num); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 898, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 898, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_6);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_6);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_6, __pyx_v_dates, __pyx_t_8};
    __pyx_t_9 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 898, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_9, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 898, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_9, __pyx_callargs+3, 1) < (0)) __PYX_ERR(0, 898, __pyx_L1_error)
    __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_9);
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 898, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_v_times = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":899
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     times = date2num(dates,nctime.units,calendar=calendar, has_year_zero=has_year_zero)
 *     return time2index(times, nctime, calendar=calendar, select=select)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_time2index); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 899, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_9))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_9);
    assert(__pyx_t_4);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_9, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_4, __pyx_v_times, __pyx_v_nctime};
    __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 899, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_8, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 899, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_select, __pyx_v_select, __pyx_t_8, __pyx_callargs+3, 1) < (0)) __PYX_ERR(0, 899, __pyx_L1_error)
    __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_9, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 899, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_r = __pyx_t_7;
  __pyx_t_7 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":855
 * 
 * 
 * def _date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """
 *     Return indices of a netCDF time variable corresponding to the given dates.
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime._date2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_times);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":902
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def time2index(times, nctime, calendar=None, select='exact'):
 *     """
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_31time2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_30time2index, "time2index(times, nctime, calendar=None, select='exact')\n\nReturn indices of a netCDF time variable corresponding to the given times.\n\n**times**: A numeric time or a sequence of numeric times.\n\n**nctime**: A netCDF time variable object. The nctime object must have a\n`units` attribute. The entries are assumed to be stored in increasing\norder.\n\n**calendar**: Describes the calendar used in the time calculation.\nValid calendars 'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'.\nDefault is `standard`, which is a mixed Julian/Gregorian calendar\nIf `calendar` is None, its value is given by `nctime.calendar` or\n`standard` if no such attribute exists.\n\n**select**: **'exact', 'before', 'after', 'nearest'**\nThe index selection method. `exact` will return the indices perfectly\nmatching the times given. `before` and `after` will return the indices\ncorresponding to the times just before or just after the given times if\nan exact match cannot be found. `nearest` will return the indices that\ncorrespond to the closest times.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_31time2index = {"time2index", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_31time2index, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_30time2index};
static PyObject *__pyx_pw_6cftime_7_cftime_31time2index(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_times = 0;
  PyObject *__pyx_v_nctime = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_select = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[4] = {0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("time2index (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_times,&__pyx_mstate_global->__pyx_n_u_nctime,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_select,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 902, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "time2index", 0) < (0)) __PYX_ERR(0, 902, __pyx_L3_error)

      /* "cftime/_cftime.pyx":903
 * 
 * @cython.embedsignature(True)
 * def time2index(times, nctime, calendar=None, select='exact'):             # <<<<<<<<<<<<<<
 *     """
 *     Return indices of a netCDF time variable corresponding to the given times.
*/
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("time2index", 0, 2, 4, i); __PYX_ERR(0, 902, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 902, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 902, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 902, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)));
    }
    __pyx_v_times = values[0];
    __pyx_v_nctime = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_select = values[3];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("time2index", 0, 2, 4, __pyx_nargs); __PYX_ERR(0, 902, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.time2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_30time2index(__pyx_self, __pyx_v_times, __pyx_v_nctime, __pyx_v_calendar, __pyx_v_select);

  /* "cftime/_cftime.pyx":902
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def time2index(times, nctime, calendar=None, select='exact'):
 *     """
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_30time2index(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_times, PyObject *__pyx_v_nctime, PyObject *__pyx_v_calendar, PyObject *__pyx_v_select) {
  PyObject *__pyx_v_index = NULL;
  PyObject *__pyx_v_num = NULL;
  PyObject *__pyx_v_N = NULL;
  PyObject *__pyx_v_t0 = NULL;
  PyObject *__pyx_v_t1 = NULL;
  PyObject *__pyx_v_dt = NULL;
  PyObject *__pyx_v_bisect = NULL;
  PyObject *__pyx_v_before = NULL;
  PyObject *__pyx_v_after = NULL;
  PyObject *__pyx_v_ncnum = NULL;
  PyObject *__pyx_v_mismatch = NULL;
  PyObject *__pyx_v_nearest_to_left = NULL;
  PyObject *__pyx_7genexpr__pyx_v_n = NULL;
  PyObject *__pyx_8genexpr1__pyx_v_n = NULL;
  PyObject *__pyx_8genexpr2__pyx_v_i = NULL;
  PyObject *__pyx_8genexpr3__pyx_v_i = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  int __pyx_t_11;
  Py_ssize_t __pyx_t_12;
  PyObject *(*__pyx_t_13)(PyObject *);
  int __pyx_t_14;
  PyObject *__pyx_t_15 = NULL;
  PyObject *__pyx_t_16 = NULL;
  PyObject *__pyx_t_17 = NULL;
  PyObject *(*__pyx_t_18)(PyObject *);
  int __pyx_t_19;
  double __pyx_t_20;
  double __pyx_t_21;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("time2index", 0);
  __Pyx_INCREF(__pyx_v_calendar);

  /* "cftime/_cftime.pyx":927
 *     correspond to the closest times.
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":928
 *     """
 *     try:
 *         nctime.units             # <<<<<<<<<<<<<<
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
*/
      __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_units_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 928, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":927
 *     correspond to the closest times.
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    }
    __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;

    /* "cftime/_cftime.pyx":929
 *     try:
 *         nctime.units
 *     except AttributeError:             # <<<<<<<<<<<<<<
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     # Setting the calendar.
*/
    __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_AttributeError))));
    if (__pyx_t_5) {
      __Pyx_AddTraceback("cftime._cftime.time2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(0, 929, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "cftime/_cftime.pyx":930
 *         nctime.units
 *     except AttributeError:
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")             # <<<<<<<<<<<<<<
 *     # Setting the calendar.
 *     if calendar == None:
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_netcdf_time_variable_is_missing};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_AttributeError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 930, __pyx_L5_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(0, 930, __pyx_L5_except_error)
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":927
 *     correspond to the closest times.
 *     """
 *     try:             # <<<<<<<<<<<<<<
 *         nctime.units
 *     except AttributeError:
*/
    __pyx_L5_except_error:;
    __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:;
  }

  /* "cftime/_cftime.pyx":932
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     # Setting the calendar.
 *     if calendar == None:             # <<<<<<<<<<<<<<
 *         calendar = getattr(nctime, 'calendar', 'standard')
 * 
*/
  __pyx_t_7 = PyObject_RichCompare(__pyx_v_calendar, Py_None, Py_EQ); __Pyx_XGOTREF(__pyx_t_7); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 932, __pyx_L1_error)
  __pyx_t_11 = __Pyx_PyObject_IsTrue(__pyx_t_7); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 932, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  if (__pyx_t_11) {

    /* "cftime/_cftime.pyx":933
 *     # Setting the calendar.
 *     if calendar == None:
 *         calendar = getattr(nctime, 'calendar', 'standard')             # <<<<<<<<<<<<<<
 * 
 *     if select != 'exact':
*/
    __pyx_t_7 = __Pyx_GetAttr3(__pyx_v_nctime, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_standard); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 933, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_7);
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":932
 *         raise AttributeError("netcdf time variable is missing a 'units' attribute")
 *     # Setting the calendar.
 *     if calendar == None:             # <<<<<<<<<<<<<<
 *         calendar = getattr(nctime, 'calendar', 'standard')
 * 
*/
  }

  /* "cftime/_cftime.pyx":935
 *         calendar = getattr(nctime, 'calendar', 'standard')
 * 
 *     if select != 'exact':             # <<<<<<<<<<<<<<
 *         # if select works, then 'nearest' == 'exact', 'before' == 'exact'-1 and
 *         # 'after' == 'exact'+1
*/
  __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_exact, Py_NE)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 935, __pyx_L1_error)
  if (__pyx_t_11) {

    /* "cftime/_cftime.pyx":938
 *         # if select works, then 'nearest' == 'exact', 'before' == 'exact'-1 and
 *         # 'after' == 'exact'+1
 *         try:             # <<<<<<<<<<<<<<
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':
*/
    {
      __Pyx_PyThreadState_declare
      __Pyx_PyThreadState_assign
      __Pyx_ExceptionSave(&__pyx_t_3, &__pyx_t_2, &__pyx_t_1);
      __Pyx_XGOTREF(__pyx_t_3);
      __Pyx_XGOTREF(__pyx_t_2);
      __Pyx_XGOTREF(__pyx_t_1);
      /*try:*/ {

        /* "cftime/_cftime.pyx":939
 *         # 'after' == 'exact'+1
 *         try:
 *             index = time2index(times, nctime, calendar=calendar, select='exact')             # <<<<<<<<<<<<<<
 *             if select == 'nearest':
 *                 return index
*/
        __pyx_t_6 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_time2index); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 939, __pyx_L13_error)
        __Pyx_GOTREF(__pyx_t_4);
        __pyx_t_10 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_4))) {
          __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_4);
          assert(__pyx_t_6);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
          __Pyx_INCREF(__pyx_t_6);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
          __pyx_t_10 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[3 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_6, __pyx_v_times, __pyx_v_nctime};
          __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 939, __pyx_L13_error)
          __Pyx_GOTREF(__pyx_t_8);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_8, __pyx_callargs+3, 0) < (0)) __PYX_ERR(0, 939, __pyx_L13_error)
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_select, __pyx_mstate_global->__pyx_n_u_exact, __pyx_t_8, __pyx_callargs+3, 1) < (0)) __PYX_ERR(0, 939, __pyx_L13_error)
          __pyx_t_7 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 939, __pyx_L13_error)
          __Pyx_GOTREF(__pyx_t_7);
        }
        __pyx_v_index = __pyx_t_7;
        __pyx_t_7 = 0;

        /* "cftime/_cftime.pyx":940
 *         try:
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':             # <<<<<<<<<<<<<<
 *                 return index
 *             elif select == 'before':
*/
        __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_nearest, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 940, __pyx_L13_error)
        if (__pyx_t_11) {

          /* "cftime/_cftime.pyx":941
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':
 *                 return index             # <<<<<<<<<<<<<<
 *             elif select == 'before':
 *                 return index-1
*/
          __Pyx_XDECREF(__pyx_r);
          __Pyx_INCREF(__pyx_v_index);
          __pyx_r = __pyx_v_index;
          goto __pyx_L17_try_return;

          /* "cftime/_cftime.pyx":940
 *         try:
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':             # <<<<<<<<<<<<<<
 *                 return index
 *             elif select == 'before':
*/
        }

        /* "cftime/_cftime.pyx":942
 *             if select == 'nearest':
 *                 return index
 *             elif select == 'before':             # <<<<<<<<<<<<<<
 *                 return index-1
 *             else:
*/
        __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_before, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 942, __pyx_L13_error)
        if (__pyx_t_11) {

          /* "cftime/_cftime.pyx":943
 *                 return index
 *             elif select == 'before':
 *                 return index-1             # <<<<<<<<<<<<<<
 *             else:
 *                 return index+1
*/
          __Pyx_XDECREF(__pyx_r);
          __pyx_t_7 = __Pyx_PyLong_SubtractObjC(__pyx_v_index, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 943, __pyx_L13_error)
          __Pyx_GOTREF(__pyx_t_7);
          __pyx_r = __pyx_t_7;
          __pyx_t_7 = 0;
          goto __pyx_L17_try_return;

          /* "cftime/_cftime.pyx":942
 *             if select == 'nearest':
 *                 return index
 *             elif select == 'before':             # <<<<<<<<<<<<<<
 *                 return index-1
 *             else:
*/
        }

        /* "cftime/_cftime.pyx":945
 *                 return index-1
 *             else:
 *                 return index+1             # <<<<<<<<<<<<<<
 *         except ValueError:
 *             pass
*/
        /*else*/ {
          __Pyx_XDECREF(__pyx_r);
          __pyx_t_7 = __Pyx_PyLong_AddObjC(__pyx_v_index, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 945, __pyx_L13_error)
          __Pyx_GOTREF(__pyx_t_7);
          __pyx_r = __pyx_t_7;
          __pyx_t_7 = 0;
          goto __pyx_L17_try_return;
        }

        /* "cftime/_cftime.pyx":938
 *         # if select works, then 'nearest' == 'exact', 'before' == 'exact'-1 and
 *         # 'after' == 'exact'+1
 *         try:             # <<<<<<<<<<<<<<
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':
*/
      }
      __pyx_L13_error:;
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;

      /* "cftime/_cftime.pyx":946
 *             else:
 *                 return index+1
 *         except ValueError:             # <<<<<<<<<<<<<<
 *             pass
 * 
*/
      __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_ValueError))));
      if (__pyx_t_5) {
        __Pyx_ErrRestore(0,0,0);
        goto __pyx_L14_exception_handled;
      }
      goto __pyx_L15_except_error;

      /* "cftime/_cftime.pyx":938
 *         # if select works, then 'nearest' == 'exact', 'before' == 'exact'-1 and
 *         # 'after' == 'exact'+1
 *         try:             # <<<<<<<<<<<<<<
 *             index = time2index(times, nctime, calendar=calendar, select='exact')
 *             if select == 'nearest':
*/
      __pyx_L15_except_error:;
      __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_L17_try_return:;
      __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_L0;
      __pyx_L14_exception_handled:;
      __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);
    }

    /* "cftime/_cftime.pyx":935
 *         calendar = getattr(nctime, 'calendar', 'standard')
 * 
 *     if select != 'exact':             # <<<<<<<<<<<<<<
 *         # if select works, then 'nearest' == 'exact', 'before' == 'exact'-1 and
 *         # 'after' == 'exact'+1
*/
  }

  /* "cftime/_cftime.pyx":949
 *             pass
 * 
 *     num = np.atleast_1d(times)             # <<<<<<<<<<<<<<
 *     N = len(nctime)
 * 
*/
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 949, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_atleast_1d); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 949, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_10 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_6))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_6);
    assert(__pyx_t_4);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
    __pyx_t_10 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_times};
    __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 949, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
  }
  __pyx_v_num = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":950
 * 
 *     num = np.atleast_1d(times)
 *     N = len(nctime)             # <<<<<<<<<<<<<<
 * 
 *     # Trying to infer the correct index from the starting time and the stride.
*/
  __pyx_t_12 = PyObject_Length(__pyx_v_nctime); if (unlikely(__pyx_t_12 == ((Py_ssize_t)-1))) __PYX_ERR(0, 950, __pyx_L1_error)
  __pyx_t_7 = PyLong_FromSsize_t(__pyx_t_12); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 950, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_v_N = __pyx_t_7;
  __pyx_t_7 = 0;

  /* "cftime/_cftime.pyx":954
 *     # Trying to infer the correct index from the starting time and the stride.
 *     # This assumes that the times are increasing uniformly.
 *     if len(nctime) >= 2:             # <<<<<<<<<<<<<<
 *         t0, t1 = nctime[:2]
 *         dt = t1 - t0
*/
  __pyx_t_12 = PyObject_Length(__pyx_v_nctime); if (unlikely(__pyx_t_12 == ((Py_ssize_t)-1))) __PYX_ERR(0, 954, __pyx_L1_error)
  __pyx_t_11 = (__pyx_t_12 >= 2);
  if (__pyx_t_11) {

    /* "cftime/_cftime.pyx":955
 *     # This assumes that the times are increasing uniformly.
 *     if len(nctime) >= 2:
 *         t0, t1 = nctime[:2]             # <<<<<<<<<<<<<<
 *         dt = t1 - t0
 *     else:
*/
    __pyx_t_7 = __Pyx_PyObject_GetSlice(__pyx_v_nctime, 0, 2, NULL, NULL, &__pyx_mstate_global->__pyx_slice[1], 0, 1, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 955, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if ((likely(PyTuple_CheckExact(__pyx_t_7))) || (PyList_CheckExact(__pyx_t_7))) {
      PyObject* sequence = __pyx_t_7;
      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(0, 955, __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_INCREF(__pyx_t_6);
        __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1);
        __Pyx_INCREF(__pyx_t_4);
      } else {
        __pyx_t_6 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
        if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 955, __pyx_L1_error)
        __Pyx_XGOTREF(__pyx_t_6);
        __pyx_t_4 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 955, __pyx_L1_error)
        __Pyx_XGOTREF(__pyx_t_4);
      }
      #else
      __pyx_t_6 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 955, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_4 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 955, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      #endif
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    } else {
      Py_ssize_t index = -1;
      __pyx_t_8 = PyObject_GetIter(__pyx_t_7); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 955, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_t_13 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_8);
      index = 0; __pyx_t_6 = __pyx_t_13(__pyx_t_8); if (unlikely(!__pyx_t_6)) goto __pyx_L23_unpacking_failed;
      __Pyx_GOTREF(__pyx_t_6);
      index = 1; __pyx_t_4 = __pyx_t_13(__pyx_t_8); if (unlikely(!__pyx_t_4)) goto __pyx_L23_unpacking_failed;
      __Pyx_GOTREF(__pyx_t_4);
      if (__Pyx_IternextUnpackEndCheck(__pyx_t_13(__pyx_t_8), 2) < (0)) __PYX_ERR(0, 955, __pyx_L1_error)
      __pyx_t_13 = NULL;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      goto __pyx_L24_unpacking_done;
      __pyx_L23_unpacking_failed:;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __pyx_t_13 = NULL;
      if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
      __PYX_ERR(0, 955, __pyx_L1_error)
      __pyx_L24_unpacking_done:;
    }
    __pyx_v_t0 = __pyx_t_6;
    __pyx_t_6 = 0;
    __pyx_v_t1 = __pyx_t_4;
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":956
 *     if len(nctime) >= 2:
 *         t0, t1 = nctime[:2]
 *         dt = t1 - t0             # <<<<<<<<<<<<<<
 *     else:
 *         t0 = nctime[0]
*/
    __pyx_t_7 = PyNumber_Subtract(__pyx_v_t1, __pyx_v_t0); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 956, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_v_dt = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":954
 *     # Trying to infer the correct index from the starting time and the stride.
 *     # This assumes that the times are increasing uniformly.
 *     if len(nctime) >= 2:             # <<<<<<<<<<<<<<
 *         t0, t1 = nctime[:2]
 *         dt = t1 - t0
*/
    goto __pyx_L22;
  }

  /* "cftime/_cftime.pyx":958
 *         dt = t1 - t0
 *     else:
 *         t0 = nctime[0]             # <<<<<<<<<<<<<<
 *         dt = 1.
 *     if select in ['exact', 'before']:
*/
  /*else*/ {
    __pyx_t_7 = __Pyx_GetItemInt(__pyx_v_nctime, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_FunctionArgument); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 958, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_v_t0 = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":959
 *     else:
 *         t0 = nctime[0]
 *         dt = 1.             # <<<<<<<<<<<<<<
 *     if select in ['exact', 'before']:
 *         index = np.array((num - t0) / dt, int)
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_float_1_);
    __pyx_v_dt = __pyx_mstate_global->__pyx_float_1_;
  }
  __pyx_L22:;

  /* "cftime/_cftime.pyx":960
 *         t0 = nctime[0]
 *         dt = 1.
 *     if select in ['exact', 'before']:             # <<<<<<<<<<<<<<
 *         index = np.array((num - t0) / dt, int)
 *     elif select == 'after':
*/
  __Pyx_INCREF(__pyx_v_select);
  __pyx_t_7 = __pyx_v_select;
  __pyx_t_14 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_exact, Py_EQ)); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 960, __pyx_L1_error)
  if (!__pyx_t_14) {
  } else {
    __pyx_t_11 = __pyx_t_14;
    goto __pyx_L26_bool_binop_done;
  }
  __pyx_t_14 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_before, Py_EQ)); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 960, __pyx_L1_error)
  __pyx_t_11 = __pyx_t_14;
  __pyx_L26_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_14 = __pyx_t_11;
  if (__pyx_t_14) {

    /* "cftime/_cftime.pyx":961
 *         dt = 1.
 *     if select in ['exact', 'before']:
 *         index = np.array((num - t0) / dt, int)             # <<<<<<<<<<<<<<
 *     elif select == 'after':
 *         index = np.array(np.ceil((num - t0) / dt), int)
*/
    __pyx_t_4 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 961, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 961, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_6 = PyNumber_Subtract(__pyx_v_num, __pyx_v_t0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 961, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_9 = __Pyx_PyNumber_Divide(__pyx_t_6, __pyx_v_dt); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 961, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_4);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_9, ((PyObject *)(&PyLong_Type))};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 961, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_XDECREF_SET(__pyx_v_index, __pyx_t_7);
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":960
 *         t0 = nctime[0]
 *         dt = 1.
 *     if select in ['exact', 'before']:             # <<<<<<<<<<<<<<
 *         index = np.array((num - t0) / dt, int)
 *     elif select == 'after':
*/
    goto __pyx_L25;
  }

  /* "cftime/_cftime.pyx":962
 *     if select in ['exact', 'before']:
 *         index = np.array((num - t0) / dt, int)
 *     elif select == 'after':             # <<<<<<<<<<<<<<
 *         index = np.array(np.ceil((num - t0) / dt), int)
 *     else:
*/
  __pyx_t_14 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_after, Py_EQ)); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 962, __pyx_L1_error)
  if (__pyx_t_14) {

    /* "cftime/_cftime.pyx":963
 *         index = np.array((num - t0) / dt, int)
 *     elif select == 'after':
 *         index = np.array(np.ceil((num - t0) / dt), int)             # <<<<<<<<<<<<<<
 *     else:
 *         index = np.array(np.around((num - t0) / dt), int)
*/
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __pyx_t_6 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_15, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_15);
    __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_t_15, __pyx_mstate_global->__pyx_n_u_ceil); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_16);
    __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
    __pyx_t_15 = PyNumber_Subtract(__pyx_v_num, __pyx_v_t0); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_15);
    __pyx_t_17 = __Pyx_PyNumber_Divide(__pyx_t_15, __pyx_v_dt); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 963, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_17);
    __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_16))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_16);
      assert(__pyx_t_6);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_16);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_16, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_17};
      __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_16, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
      __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
      if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 963, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
    }
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_4);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_8, __pyx_t_9, ((PyObject *)(&PyLong_Type))};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 963, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_XDECREF_SET(__pyx_v_index, __pyx_t_7);
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":962
 *     if select in ['exact', 'before']:
 *         index = np.array((num - t0) / dt, int)
 *     elif select == 'after':             # <<<<<<<<<<<<<<
 *         index = np.array(np.ceil((num - t0) / dt), int)
 *     else:
*/
    goto __pyx_L25;
  }

  /* "cftime/_cftime.pyx":965
 *         index = np.array(np.ceil((num - t0) / dt), int)
 *     else:
 *         index = np.array(np.around((num - t0) / dt), int)             # <<<<<<<<<<<<<<
 * 
 *     # Checking that the index really corresponds to the given time.
*/
  /*else*/ {
    __pyx_t_4 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __pyx_t_16 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_17, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_17);
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_17, __pyx_mstate_global->__pyx_n_u_around); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
    __pyx_t_17 = PyNumber_Subtract(__pyx_v_num, __pyx_v_t0); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_17);
    __pyx_t_15 = __Pyx_PyNumber_Divide(__pyx_t_17, __pyx_v_dt); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 965, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_15);
    __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_16);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_16);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_16, __pyx_t_15};
      __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
      __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 965, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
    }
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_4);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_9, ((PyObject *)(&PyLong_Type))};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 965, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_XDECREF_SET(__pyx_v_index, __pyx_t_7);
    __pyx_t_7 = 0;
  }
  __pyx_L25:;

  /* "cftime/_cftime.pyx":970
 *     # If the times do not correspond, then it means that the times
 *     # are not increasing uniformly and we try the bisection method.
 *     if not _check_index(index, times, nctime, select):             # <<<<<<<<<<<<<<
 * 
 *         # Use the bisection method. Assumes nctime is ordered.
*/
  __pyx_t_7 = __pyx_f_6cftime_7_cftime__check_index(__pyx_v_index, __pyx_v_times, __pyx_v_nctime, __pyx_v_select); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 970, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_14 = __Pyx_PyObject_IsTrue(__pyx_t_7); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 970, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
  __pyx_t_11 = (!__pyx_t_14);
  if (__pyx_t_11) {

    /* "cftime/_cftime.pyx":973
 * 
 *         # Use the bisection method. Assumes nctime is ordered.
 *         import bisect             # <<<<<<<<<<<<<<
 *         index = np.array([bisect.bisect_right(nctime, n) for n in num], int)
 *         before = index == 0
*/
    __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_bisect, 0, 0, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 973, __pyx_L1_error)
    __pyx_t_7 = __pyx_t_1;
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_v_bisect = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":974
 *         # Use the bisection method. Assumes nctime is ordered.
 *         import bisect
 *         index = np.array([bisect.bisect_right(nctime, n) for n in num], int)             # <<<<<<<<<<<<<<
 *         before = index == 0
 * 
*/
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 974, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    { /* enter inner scope */
      __pyx_t_9 = PyList_New(0); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 974, __pyx_L31_error)
      __Pyx_GOTREF(__pyx_t_9);
      if (likely(PyList_CheckExact(__pyx_v_num)) || PyTuple_CheckExact(__pyx_v_num)) {
        __pyx_t_6 = __pyx_v_num; __Pyx_INCREF(__pyx_t_6);
        __pyx_t_12 = 0;
        __pyx_t_18 = NULL;
      } else {
        __pyx_t_12 = -1; __pyx_t_6 = PyObject_GetIter(__pyx_v_num); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 974, __pyx_L31_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_18 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 974, __pyx_L31_error)
      }
      for (;;) {
        if (likely(!__pyx_t_18)) {
          if (likely(PyList_CheckExact(__pyx_t_6))) {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 974, __pyx_L31_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            __pyx_t_15 = __Pyx_PyList_GetItemRefFast(__pyx_t_6, __pyx_t_12, __Pyx_ReferenceSharing_OwnStrongReference);
            ++__pyx_t_12;
          } else {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 974, __pyx_L31_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
            __pyx_t_15 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_6, __pyx_t_12));
            #else
            __pyx_t_15 = __Pyx_PySequence_ITEM(__pyx_t_6, __pyx_t_12);
            #endif
            ++__pyx_t_12;
          }
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 974, __pyx_L31_error)
        } else {
          __pyx_t_15 = __pyx_t_18(__pyx_t_6);
          if (unlikely(!__pyx_t_15)) {
            PyObject* exc_type = PyErr_Occurred();
            if (exc_type) {
              if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 974, __pyx_L31_error)
              PyErr_Clear();
            }
            break;
          }
        }
        __Pyx_GOTREF(__pyx_t_15);
        __Pyx_XDECREF_SET(__pyx_7genexpr__pyx_v_n, __pyx_t_15);
        __pyx_t_15 = 0;
        __pyx_t_16 = __pyx_v_bisect;
        __Pyx_INCREF(__pyx_t_16);
        __pyx_t_10 = 0;
        {
          PyObject *__pyx_callargs[3] = {__pyx_t_16, __pyx_v_nctime, __pyx_7genexpr__pyx_v_n};
          __pyx_t_15 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_bisect_right, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 974, __pyx_L31_error)
          __Pyx_GOTREF(__pyx_t_15);
        }
        if (unlikely(__Pyx_ListComp_Append(__pyx_t_9, (PyObject*)__pyx_t_15))) __PYX_ERR(0, 974, __pyx_L31_error)
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
      }
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_XDECREF(__pyx_7genexpr__pyx_v_n); __pyx_7genexpr__pyx_v_n = 0;
      goto __pyx_L35_exit_scope;
      __pyx_L31_error:;
      __Pyx_XDECREF(__pyx_7genexpr__pyx_v_n); __pyx_7genexpr__pyx_v_n = 0;
      goto __pyx_L1_error;
      __pyx_L35_exit_scope:;
    } /* exit inner scope */
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_4);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_8, __pyx_t_9, ((PyObject *)(&PyLong_Type))};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 974, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_DECREF_SET(__pyx_v_index, __pyx_t_7);
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":975
 *         import bisect
 *         index = np.array([bisect.bisect_right(nctime, n) for n in num], int)
 *         before = index == 0             # <<<<<<<<<<<<<<
 * 
 *         index = np.array([bisect.bisect_left(nctime, n) for n in num], int)
*/
    __pyx_t_7 = __Pyx_PyLong_EqObjC(__pyx_v_index, __pyx_mstate_global->__pyx_int_0, 0, 0); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 975, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_v_before = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":977
 *         before = index == 0
 * 
 *         index = np.array([bisect.bisect_left(nctime, n) for n in num], int)             # <<<<<<<<<<<<<<
 *         after = index == N
 * 
*/
    __pyx_t_4 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 977, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 977, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    { /* enter inner scope */
      __pyx_t_9 = PyList_New(0); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 977, __pyx_L38_error)
      __Pyx_GOTREF(__pyx_t_9);
      if (likely(PyList_CheckExact(__pyx_v_num)) || PyTuple_CheckExact(__pyx_v_num)) {
        __pyx_t_6 = __pyx_v_num; __Pyx_INCREF(__pyx_t_6);
        __pyx_t_12 = 0;
        __pyx_t_18 = NULL;
      } else {
        __pyx_t_12 = -1; __pyx_t_6 = PyObject_GetIter(__pyx_v_num); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 977, __pyx_L38_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_18 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 977, __pyx_L38_error)
      }
      for (;;) {
        if (likely(!__pyx_t_18)) {
          if (likely(PyList_CheckExact(__pyx_t_6))) {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 977, __pyx_L38_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            __pyx_t_15 = __Pyx_PyList_GetItemRefFast(__pyx_t_6, __pyx_t_12, __Pyx_ReferenceSharing_OwnStrongReference);
            ++__pyx_t_12;
          } else {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 977, __pyx_L38_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
            __pyx_t_15 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_6, __pyx_t_12));
            #else
            __pyx_t_15 = __Pyx_PySequence_ITEM(__pyx_t_6, __pyx_t_12);
            #endif
            ++__pyx_t_12;
          }
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 977, __pyx_L38_error)
        } else {
          __pyx_t_15 = __pyx_t_18(__pyx_t_6);
          if (unlikely(!__pyx_t_15)) {
            PyObject* exc_type = PyErr_Occurred();
            if (exc_type) {
              if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 977, __pyx_L38_error)
              PyErr_Clear();
            }
            break;
          }
        }
        __Pyx_GOTREF(__pyx_t_15);
        __Pyx_XDECREF_SET(__pyx_8genexpr1__pyx_v_n, __pyx_t_15);
        __pyx_t_15 = 0;
        __pyx_t_16 = __pyx_v_bisect;
        __Pyx_INCREF(__pyx_t_16);
        __pyx_t_10 = 0;
        {
          PyObject *__pyx_callargs[3] = {__pyx_t_16, __pyx_v_nctime, __pyx_8genexpr1__pyx_v_n};
          __pyx_t_15 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_bisect_left, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 977, __pyx_L38_error)
          __Pyx_GOTREF(__pyx_t_15);
        }
        if (unlikely(__Pyx_ListComp_Append(__pyx_t_9, (PyObject*)__pyx_t_15))) __PYX_ERR(0, 977, __pyx_L38_error)
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
      }
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_XDECREF(__pyx_8genexpr1__pyx_v_n); __pyx_8genexpr1__pyx_v_n = 0;
      goto __pyx_L42_exit_scope;
      __pyx_L38_error:;
      __Pyx_XDECREF(__pyx_8genexpr1__pyx_v_n); __pyx_8genexpr1__pyx_v_n = 0;
      goto __pyx_L1_error;
      __pyx_L42_exit_scope:;
    } /* exit inner scope */
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_4);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_t_9, ((PyObject *)(&PyLong_Type))};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (3-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 977, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_DECREF_SET(__pyx_v_index, __pyx_t_7);
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":978
 * 
 *         index = np.array([bisect.bisect_left(nctime, n) for n in num], int)
 *         after = index == N             # <<<<<<<<<<<<<<
 * 
 *         if select in ['before', 'exact'] and np.any(before):
*/
    __pyx_t_7 = PyObject_RichCompare(__pyx_v_index, __pyx_v_N, Py_EQ); __Pyx_XGOTREF(__pyx_t_7); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 978, __pyx_L1_error)
    __pyx_v_after = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":980
 *         after = index == N
 * 
 *         if select in ['before', 'exact'] and np.any(before):             # <<<<<<<<<<<<<<
 *             raise ValueError(
 *                 'Some of the times given are before the first time in **nctime**.')
*/
    __Pyx_INCREF(__pyx_v_select);
    __pyx_t_7 = __pyx_v_select;
    __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_before, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 980, __pyx_L1_error)
    if (!__pyx_t_19) {
    } else {
      __pyx_t_14 = __pyx_t_19;
      goto __pyx_L46_bool_binop_done;
    }
    __pyx_t_19 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_exact, Py_EQ)); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 980, __pyx_L1_error)
    __pyx_t_14 = __pyx_t_19;
    __pyx_L46_bool_binop_done:;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_19 = __pyx_t_14;
    if (__pyx_t_19) {
    } else {
      __pyx_t_11 = __pyx_t_19;
      goto __pyx_L44_bool_binop_done;
    }
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_any); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 980, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_4))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_4);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_v_before};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 980, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_t_19 = __Pyx_PyObject_IsTrue(__pyx_t_7); if (unlikely((__pyx_t_19 < 0))) __PYX_ERR(0, 980, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_11 = __pyx_t_19;
    __pyx_L44_bool_binop_done:;
    if (unlikely(__pyx_t_11)) {

      /* "cftime/_cftime.pyx":981
 * 
 *         if select in ['before', 'exact'] and np.any(before):
 *             raise ValueError(             # <<<<<<<<<<<<<<
 *                 'Some of the times given are before the first time in **nctime**.')
 * 
*/
      __pyx_t_4 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_Some_of_the_times_given_are_befo};
        __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 981, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
      }
      __Pyx_Raise(__pyx_t_7, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __PYX_ERR(0, 981, __pyx_L1_error)

      /* "cftime/_cftime.pyx":980
 *         after = index == N
 * 
 *         if select in ['before', 'exact'] and np.any(before):             # <<<<<<<<<<<<<<
 *             raise ValueError(
 *                 'Some of the times given are before the first time in **nctime**.')
*/
    }

    /* "cftime/_cftime.pyx":984
 *                 'Some of the times given are before the first time in **nctime**.')
 * 
 *         if select in ['after', 'exact'] and np.any(after):             # <<<<<<<<<<<<<<
 *             raise ValueError(
 *                 'Some of the times given are after the last time in **nctime**.')
*/
    __Pyx_INCREF(__pyx_v_select);
    __pyx_t_7 = __pyx_v_select;
    __pyx_t_14 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_after, Py_EQ)); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 984, __pyx_L1_error)
    if (!__pyx_t_14) {
    } else {
      __pyx_t_19 = __pyx_t_14;
      goto __pyx_L51_bool_binop_done;
    }
    __pyx_t_14 = (__Pyx_PyUnicode_Equals(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_exact, Py_EQ)); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 984, __pyx_L1_error)
    __pyx_t_19 = __pyx_t_14;
    __pyx_L51_bool_binop_done:;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_14 = __pyx_t_19;
    if (__pyx_t_14) {
    } else {
      __pyx_t_11 = __pyx_t_14;
      goto __pyx_L49_bool_binop_done;
    }
    __pyx_t_4 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 984, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_any); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 984, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_9))) {
      __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_9);
      assert(__pyx_t_4);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9);
      __Pyx_INCREF(__pyx_t_4);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_9, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_v_after};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_9, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 984, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_t_14 = __Pyx_PyObject_IsTrue(__pyx_t_7); if (unlikely((__pyx_t_14 < 0))) __PYX_ERR(0, 984, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_11 = __pyx_t_14;
    __pyx_L49_bool_binop_done:;
    if (unlikely(__pyx_t_11)) {

      /* "cftime/_cftime.pyx":985
 * 
 *         if select in ['after', 'exact'] and np.any(after):
 *             raise ValueError(             # <<<<<<<<<<<<<<
 *                 'Some of the times given are after the last time in **nctime**.')
 * 
*/
      __pyx_t_9 = NULL;
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_mstate_global->__pyx_kp_u_Some_of_the_times_given_are_afte};
        __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 985, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
      }
      __Pyx_Raise(__pyx_t_7, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __PYX_ERR(0, 985, __pyx_L1_error)

      /* "cftime/_cftime.pyx":984
 *                 'Some of the times given are before the first time in **nctime**.')
 * 
 *         if select in ['after', 'exact'] and np.any(after):             # <<<<<<<<<<<<<<
 *             raise ValueError(
 *                 'Some of the times given are after the last time in **nctime**.')
*/
    }

    /* "cftime/_cftime.pyx":991
 *         # Use list comprehension instead of the simpler **nctime[index]** since
 *         # not all time objects support numpy integer indexing (eg dap).
 *         index[after] = N - 1             # <<<<<<<<<<<<<<
 *         ncnum = np.squeeze([nctime[i] for i in index])
 *         mismatch = np.nonzero(ncnum != num)[0]
*/
    __pyx_t_7 = __Pyx_PyLong_SubtractObjC(__pyx_v_N, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 991, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    if (unlikely((PyObject_SetItem(__pyx_v_index, __pyx_v_after, __pyx_t_7) < 0))) __PYX_ERR(0, 991, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":992
 *         # not all time objects support numpy integer indexing (eg dap).
 *         index[after] = N - 1
 *         ncnum = np.squeeze([nctime[i] for i in index])             # <<<<<<<<<<<<<<
 *         mismatch = np.nonzero(ncnum != num)[0]
 * 
*/
    __pyx_t_9 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 992, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_squeeze); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 992, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    { /* enter inner scope */
      __pyx_t_4 = PyList_New(0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 992, __pyx_L55_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (likely(PyList_CheckExact(__pyx_v_index)) || PyTuple_CheckExact(__pyx_v_index)) {
        __pyx_t_6 = __pyx_v_index; __Pyx_INCREF(__pyx_t_6);
        __pyx_t_12 = 0;
        __pyx_t_18 = NULL;
      } else {
        __pyx_t_12 = -1; __pyx_t_6 = PyObject_GetIter(__pyx_v_index); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 992, __pyx_L55_error)
        __Pyx_GOTREF(__pyx_t_6);
        __pyx_t_18 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_6); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 992, __pyx_L55_error)
      }
      for (;;) {
        if (likely(!__pyx_t_18)) {
          if (likely(PyList_CheckExact(__pyx_t_6))) {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 992, __pyx_L55_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            __pyx_t_15 = __Pyx_PyList_GetItemRefFast(__pyx_t_6, __pyx_t_12, __Pyx_ReferenceSharing_OwnStrongReference);
            ++__pyx_t_12;
          } else {
            {
              Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_6);
              #if !CYTHON_ASSUME_SAFE_SIZE
              if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 992, __pyx_L55_error)
              #endif
              if (__pyx_t_12 >= __pyx_temp) break;
            }
            #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
            __pyx_t_15 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_6, __pyx_t_12));
            #else
            __pyx_t_15 = __Pyx_PySequence_ITEM(__pyx_t_6, __pyx_t_12);
            #endif
            ++__pyx_t_12;
          }
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 992, __pyx_L55_error)
        } else {
          __pyx_t_15 = __pyx_t_18(__pyx_t_6);
          if (unlikely(!__pyx_t_15)) {
            PyObject* exc_type = PyErr_Occurred();
            if (exc_type) {
              if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 992, __pyx_L55_error)
              PyErr_Clear();
            }
            break;
          }
        }
        __Pyx_GOTREF(__pyx_t_15);
        __Pyx_XDECREF_SET(__pyx_8genexpr2__pyx_v_i, __pyx_t_15);
        __pyx_t_15 = 0;
        __pyx_t_15 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_8genexpr2__pyx_v_i); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 992, __pyx_L55_error)
        __Pyx_GOTREF(__pyx_t_15);
        if (unlikely(__Pyx_ListComp_Append(__pyx_t_4, (PyObject*)__pyx_t_15))) __PYX_ERR(0, 992, __pyx_L55_error)
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
      }
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_XDECREF(__pyx_8genexpr2__pyx_v_i); __pyx_8genexpr2__pyx_v_i = 0;
      goto __pyx_L59_exit_scope;
      __pyx_L55_error:;
      __Pyx_XDECREF(__pyx_8genexpr2__pyx_v_i); __pyx_8genexpr2__pyx_v_i = 0;
      goto __pyx_L1_error;
      __pyx_L59_exit_scope:;
    } /* exit inner scope */
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_8))) {
      __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_8);
      assert(__pyx_t_9);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
      __Pyx_INCREF(__pyx_t_9);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_9, __pyx_t_4};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 992, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_v_ncnum = __pyx_t_7;
    __pyx_t_7 = 0;

    /* "cftime/_cftime.pyx":993
 *         index[after] = N - 1
 *         ncnum = np.squeeze([nctime[i] for i in index])
 *         mismatch = np.nonzero(ncnum != num)[0]             # <<<<<<<<<<<<<<
 * 
 *         if select == 'exact':
*/
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 993, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_9 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_nonzero); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 993, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = PyObject_RichCompare(__pyx_v_ncnum, __pyx_v_num, Py_NE); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 993, __pyx_L1_error)
    __pyx_t_10 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_9))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_9);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_9);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_9, __pyx__function);
      __pyx_t_10 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_t_4};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_9, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 993, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __pyx_t_9 = __Pyx_GetItemInt(__pyx_t_7, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_OwnStrongReference); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 993, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_v_mismatch = __pyx_t_9;
    __pyx_t_9 = 0;

    /* "cftime/_cftime.pyx":995
 *         mismatch = np.nonzero(ncnum != num)[0]
 * 
 *         if select == 'exact':             # <<<<<<<<<<<<<<
 *             if len(mismatch) > 0:
 *                 raise ValueError(
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_exact, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 995, __pyx_L1_error)
    if (__pyx_t_11) {

      /* "cftime/_cftime.pyx":996
 * 
 *         if select == 'exact':
 *             if len(mismatch) > 0:             # <<<<<<<<<<<<<<
 *                 raise ValueError(
 *                     'Some of the times specified were not found in the **nctime** variable.')
*/
      __pyx_t_12 = PyObject_Length(__pyx_v_mismatch); if (unlikely(__pyx_t_12 == ((Py_ssize_t)-1))) __PYX_ERR(0, 996, __pyx_L1_error)
      __pyx_t_11 = (__pyx_t_12 > 0);
      if (unlikely(__pyx_t_11)) {

        /* "cftime/_cftime.pyx":997
 *         if select == 'exact':
 *             if len(mismatch) > 0:
 *                 raise ValueError(             # <<<<<<<<<<<<<<
 *                     'Some of the times specified were not found in the **nctime** variable.')
 * 
*/
        __pyx_t_7 = NULL;
        __pyx_t_10 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_Some_of_the_times_specified_were};
          __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 997, __pyx_L1_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(0, 997, __pyx_L1_error)

        /* "cftime/_cftime.pyx":996
 * 
 *         if select == 'exact':
 *             if len(mismatch) > 0:             # <<<<<<<<<<<<<<
 *                 raise ValueError(
 *                     'Some of the times specified were not found in the **nctime** variable.')
*/
      }

      /* "cftime/_cftime.pyx":995
 *         mismatch = np.nonzero(ncnum != num)[0]
 * 
 *         if select == 'exact':             # <<<<<<<<<<<<<<
 *             if len(mismatch) > 0:
 *                 raise ValueError(
*/
      goto __pyx_L60;
    }

    /* "cftime/_cftime.pyx":1000
 *                     'Some of the times specified were not found in the **nctime** variable.')
 * 
 *         elif select == 'before':             # <<<<<<<<<<<<<<
 *             index[after] = N
 *             index[mismatch] -= 1
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_before, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1000, __pyx_L1_error)
    if (__pyx_t_11) {

      /* "cftime/_cftime.pyx":1001
 * 
 *         elif select == 'before':
 *             index[after] = N             # <<<<<<<<<<<<<<
 *             index[mismatch] -= 1
 * 
*/
      if (unlikely((PyObject_SetItem(__pyx_v_index, __pyx_v_after, __pyx_v_N) < 0))) __PYX_ERR(0, 1001, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1002
 *         elif select == 'before':
 *             index[after] = N
 *             index[mismatch] -= 1             # <<<<<<<<<<<<<<
 * 
 *         elif select == 'after':
*/
      __Pyx_INCREF(__pyx_v_mismatch);
      __pyx_t_9 = __pyx_v_mismatch;
      __pyx_t_7 = __Pyx_PyObject_GetItem(__pyx_v_index, __pyx_t_9); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1002, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_7);
      __pyx_t_4 = __Pyx_PyLong_SubtractObjC(__pyx_t_7, __pyx_mstate_global->__pyx_int_1, 1, 1, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1002, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely((PyObject_SetItem(__pyx_v_index, __pyx_t_9, __pyx_t_4) < 0))) __PYX_ERR(0, 1002, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;

      /* "cftime/_cftime.pyx":1000
 *                     'Some of the times specified were not found in the **nctime** variable.')
 * 
 *         elif select == 'before':             # <<<<<<<<<<<<<<
 *             index[after] = N
 *             index[mismatch] -= 1
*/
      goto __pyx_L60;
    }

    /* "cftime/_cftime.pyx":1004
 *             index[mismatch] -= 1
 * 
 *         elif select == 'after':             # <<<<<<<<<<<<<<
 *             pass
 * 
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_after, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1004, __pyx_L1_error)
    if (__pyx_t_11) {
      goto __pyx_L60;
    }

    /* "cftime/_cftime.pyx":1007
 *             pass
 * 
 *         elif select == 'nearest':             # <<<<<<<<<<<<<<
 *             nearest_to_left = num[mismatch] < np.array(
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_select, __pyx_mstate_global->__pyx_n_u_nearest, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1007, __pyx_L1_error)
    if (likely(__pyx_t_11)) {

      /* "cftime/_cftime.pyx":1008
 * 
 *         elif select == 'nearest':
 *             nearest_to_left = num[mismatch] < np.array(             # <<<<<<<<<<<<<<
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.
 *             index[mismatch] = index[mismatch] - 1 * nearest_to_left
*/
      __pyx_t_9 = __Pyx_PyObject_GetItem(__pyx_v_num, __pyx_v_mismatch); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1008, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);

      /* "cftime/_cftime.pyx":1009
 *         elif select == 'nearest':
 *             nearest_to_left = num[mismatch] < np.array(
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.             # <<<<<<<<<<<<<<
 *             index[mismatch] = index[mismatch] - 1 * nearest_to_left
 * 
*/
      __pyx_t_7 = NULL;

      /* "cftime/_cftime.pyx":1008
 * 
 *         elif select == 'nearest':
 *             nearest_to_left = num[mismatch] < np.array(             # <<<<<<<<<<<<<<
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.
 *             index[mismatch] = index[mismatch] - 1 * nearest_to_left
*/
      __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1008, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1008, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      { /* enter inner scope */

        /* "cftime/_cftime.pyx":1009
 *         elif select == 'nearest':
 *             nearest_to_left = num[mismatch] < np.array(
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.             # <<<<<<<<<<<<<<
 *             index[mismatch] = index[mismatch] - 1 * nearest_to_left
 * 
*/
        __pyx_t_8 = PyList_New(0); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1009, __pyx_L64_error)
        __Pyx_GOTREF(__pyx_t_8);
        __pyx_t_15 = __Pyx_PyObject_GetItem(__pyx_v_index, __pyx_v_mismatch); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1009, __pyx_L64_error)
        __Pyx_GOTREF(__pyx_t_15);
        if (likely(PyList_CheckExact(__pyx_t_15)) || PyTuple_CheckExact(__pyx_t_15)) {
          __pyx_t_16 = __pyx_t_15; __Pyx_INCREF(__pyx_t_16);
          __pyx_t_12 = 0;
          __pyx_t_18 = NULL;
        } else {
          __pyx_t_12 = -1; __pyx_t_16 = PyObject_GetIter(__pyx_t_15); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_GOTREF(__pyx_t_16);
          __pyx_t_18 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_16); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 1009, __pyx_L64_error)
        }
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
        for (;;) {
          if (likely(!__pyx_t_18)) {
            if (likely(PyList_CheckExact(__pyx_t_16))) {
              {
                Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_16);
                #if !CYTHON_ASSUME_SAFE_SIZE
                if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1009, __pyx_L64_error)
                #endif
                if (__pyx_t_12 >= __pyx_temp) break;
              }
              __pyx_t_15 = __Pyx_PyList_GetItemRefFast(__pyx_t_16, __pyx_t_12, __Pyx_ReferenceSharing_OwnStrongReference);
              ++__pyx_t_12;
            } else {
              {
                Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_16);
                #if !CYTHON_ASSUME_SAFE_SIZE
                if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1009, __pyx_L64_error)
                #endif
                if (__pyx_t_12 >= __pyx_temp) break;
              }
              #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
              __pyx_t_15 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_16, __pyx_t_12));
              #else
              __pyx_t_15 = __Pyx_PySequence_ITEM(__pyx_t_16, __pyx_t_12);
              #endif
              ++__pyx_t_12;
            }
            if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1009, __pyx_L64_error)
          } else {
            __pyx_t_15 = __pyx_t_18(__pyx_t_16);
            if (unlikely(!__pyx_t_15)) {
              PyObject* exc_type = PyErr_Occurred();
              if (exc_type) {
                if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 1009, __pyx_L64_error)
                PyErr_Clear();
              }
              break;
            }
          }
          __Pyx_GOTREF(__pyx_t_15);
          __Pyx_XDECREF_SET(__pyx_8genexpr3__pyx_v_i, __pyx_t_15);
          __pyx_t_15 = 0;
          __pyx_t_15 = __Pyx_PyLong_SubtractObjC(__pyx_8genexpr3__pyx_v_i, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_GOTREF(__pyx_t_15);
          __pyx_t_17 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_t_15); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_GOTREF(__pyx_t_17);
          __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
          __pyx_t_20 = __Pyx_PyObject_AsDouble(__pyx_t_17); if (unlikely(__PYX_CHECK_FLOAT_EXCEPTION(__pyx_t_20, ((double)((double)-1))) && PyErr_Occurred())) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
          __pyx_t_17 = __Pyx_PyObject_GetItem(__pyx_v_nctime, __pyx_8genexpr3__pyx_v_i); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_GOTREF(__pyx_t_17);
          __pyx_t_21 = __Pyx_PyObject_AsDouble(__pyx_t_17); if (unlikely(__PYX_CHECK_FLOAT_EXCEPTION(__pyx_t_21, ((double)((double)-1))) && PyErr_Occurred())) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
          __pyx_t_17 = PyFloat_FromDouble((__pyx_t_20 + __pyx_t_21)); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_GOTREF(__pyx_t_17);
          if (unlikely(__Pyx_ListComp_Append(__pyx_t_8, (PyObject*)__pyx_t_17))) __PYX_ERR(0, 1009, __pyx_L64_error)
          __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
        }
        __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
        __Pyx_XDECREF(__pyx_8genexpr3__pyx_v_i); __pyx_8genexpr3__pyx_v_i = 0;
        goto __pyx_L68_exit_scope;
        __pyx_L64_error:;
        __Pyx_XDECREF(__pyx_8genexpr3__pyx_v_i); __pyx_8genexpr3__pyx_v_i = 0;
        goto __pyx_L1_error;
        __pyx_L68_exit_scope:;
      } /* exit inner scope */
      __pyx_t_10 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_6))) {
        __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_6);
        assert(__pyx_t_7);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
        __Pyx_INCREF(__pyx_t_7);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
        __pyx_t_10 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_8};
        __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__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;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1008, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_t_6 = __Pyx_PyFloat_TrueDivideObjC(__pyx_t_4, __pyx_mstate_global->__pyx_float_2_, 2., 0, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1009, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_t_4 = PyObject_RichCompare(__pyx_t_9, __pyx_t_6, Py_LT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1008, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __pyx_v_nearest_to_left = __pyx_t_4;
      __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":1010
 *             nearest_to_left = num[mismatch] < np.array(
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.
 *             index[mismatch] = index[mismatch] - 1 * nearest_to_left             # <<<<<<<<<<<<<<
 * 
 *         else:
*/
      __pyx_t_4 = __Pyx_PyObject_GetItem(__pyx_v_index, __pyx_v_mismatch); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1010, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_6 = __Pyx_PyLong_MultiplyCObj(__pyx_mstate_global->__pyx_int_1, __pyx_v_nearest_to_left, 1, 0, 0); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1010, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_9 = PyNumber_Subtract(__pyx_t_4, __pyx_t_6); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1010, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_9);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely((PyObject_SetItem(__pyx_v_index, __pyx_v_mismatch, __pyx_t_9) < 0))) __PYX_ERR(0, 1010, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;

      /* "cftime/_cftime.pyx":1007
 *             pass
 * 
 *         elif select == 'nearest':             # <<<<<<<<<<<<<<
 *             nearest_to_left = num[mismatch] < np.array(
 *                 [float(nctime[i - 1]) + float(nctime[i]) for i in index[mismatch]]) / 2.
*/
      goto __pyx_L60;
    }

    /* "cftime/_cftime.pyx":1013
 * 
 *         else:
 *             raise ValueError(             # <<<<<<<<<<<<<<
 *                 "%s is not an option for the **select** argument." % select)
 * 
*/
    /*else*/ {
      __pyx_t_6 = NULL;

      /* "cftime/_cftime.pyx":1014
 *         else:
 *             raise ValueError(
 *                 "%s is not an option for the **select** argument." % select)             # <<<<<<<<<<<<<<
 * 
 *         # Correct for indices equal to -1
*/
      __pyx_t_4 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_s_is_not_an_option_for_the_sele, __pyx_v_select); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1014, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_10 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_4};
        __pyx_t_9 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1013, __pyx_L1_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(0, 1013, __pyx_L1_error)
    }
    __pyx_L60:;

    /* "cftime/_cftime.pyx":1017
 * 
 *         # Correct for indices equal to -1
 *         index[before] = 0             # <<<<<<<<<<<<<<
 * 
 *     # convert numpy scalars or single element arrays to python ints.
*/
    if (unlikely((PyObject_SetItem(__pyx_v_index, __pyx_v_before, __pyx_mstate_global->__pyx_int_0) < 0))) __PYX_ERR(0, 1017, __pyx_L1_error)

    /* "cftime/_cftime.pyx":970
 *     # If the times do not correspond, then it means that the times
 *     # are not increasing uniformly and we try the bisection method.
 *     if not _check_index(index, times, nctime, select):             # <<<<<<<<<<<<<<
 * 
 *         # Use the bisection method. Assumes nctime is ordered.
*/
  }

  /* "cftime/_cftime.pyx":1020
 * 
 *     # convert numpy scalars or single element arrays to python ints.
 *     return _toscalar(index)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_9 = __pyx_f_6cftime_7_cftime__toscalar(__pyx_v_index); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1020, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_r = __pyx_t_9;
  __pyx_t_9 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":902
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def time2index(times, nctime, calendar=None, select='exact'):
 *     """
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_15);
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_XDECREF(__pyx_t_17);
  __Pyx_AddTraceback("cftime._cftime.time2index", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_index);
  __Pyx_XDECREF(__pyx_v_num);
  __Pyx_XDECREF(__pyx_v_N);
  __Pyx_XDECREF(__pyx_v_t0);
  __Pyx_XDECREF(__pyx_v_t1);
  __Pyx_XDECREF(__pyx_v_dt);
  __Pyx_XDECREF(__pyx_v_bisect);
  __Pyx_XDECREF(__pyx_v_before);
  __Pyx_XDECREF(__pyx_v_after);
  __Pyx_XDECREF(__pyx_v_ncnum);
  __Pyx_XDECREF(__pyx_v_mismatch);
  __Pyx_XDECREF(__pyx_v_nearest_to_left);
  __Pyx_XDECREF(__pyx_7genexpr__pyx_v_n);
  __Pyx_XDECREF(__pyx_8genexpr1__pyx_v_n);
  __Pyx_XDECREF(__pyx_8genexpr2__pyx_v_i);
  __Pyx_XDECREF(__pyx_8genexpr3__pyx_v_i);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1023
 * 
 * 
 * cdef _toscalar(a):             # <<<<<<<<<<<<<<
 *     if a.shape in [(), (1,)]:
 *         return a.item()
*/

static PyObject *__pyx_f_6cftime_7_cftime__toscalar(PyObject *__pyx_v_a) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_t_4;
  size_t __pyx_t_5;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_toscalar", 0);

  /* "cftime/_cftime.pyx":1024
 * 
 * cdef _toscalar(a):
 *     if a.shape in [(), (1,)]:             # <<<<<<<<<<<<<<
 *         return a.item()
 *     else:
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_a, __pyx_mstate_global->__pyx_n_u_shape); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1024, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = PyObject_RichCompare(__pyx_t_1, __pyx_mstate_global->__pyx_empty_tuple, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1024, __pyx_L1_error)
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1024, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (!__pyx_t_4) {
  } else {
    __pyx_t_2 = __pyx_t_4;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = PyObject_RichCompare(__pyx_t_1, __pyx_mstate_global->__pyx_tuple[1], Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1024, __pyx_L1_error)
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1024, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_2 = __pyx_t_4;
  __pyx_L4_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __pyx_t_2;
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":1025
 * cdef _toscalar(a):
 *     if a.shape in [(), (1,)]:
 *         return a.item()             # <<<<<<<<<<<<<<
 *     else:
 *         return a
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_3 = __pyx_v_a;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_5 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
      __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_item, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1025, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_r = __pyx_t_1;
    __pyx_t_1 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1024
 * 
 * cdef _toscalar(a):
 *     if a.shape in [(), (1,)]:             # <<<<<<<<<<<<<<
 *         return a.item()
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":1027
 *         return a.item()
 *     else:
 *         return a             # <<<<<<<<<<<<<<
 * 
 * def to_tuple(dt):
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_a);
    __pyx_r = __pyx_v_a;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1023
 * 
 * 
 * cdef _toscalar(a):             # <<<<<<<<<<<<<<
 *     if a.shape in [(), (1,)]:
 *         return a.item()
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("cftime._cftime._toscalar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1029
 *         return a
 * 
 * def to_tuple(dt):             # <<<<<<<<<<<<<<
 *     """Turn a datetime.datetime instance into a tuple of integers. Elements go
 *     in the order of decreasing significance, making it easy to compare
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_33to_tuple(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_32to_tuple, "Turn a datetime.datetime instance into a tuple of integers. Elements go\n    in the order of decreasing significance, making it easy to compare\n    datetime instances. Parts of the state that don't affect ordering\n    are omitted. Compare to datetime.timetuple().");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_33to_tuple = {"to_tuple", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_33to_tuple, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_32to_tuple};
static PyObject *__pyx_pw_6cftime_7_cftime_33to_tuple(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_dt = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("to_tuple (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_dt,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1029, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1029, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "to_tuple", 0) < (0)) __PYX_ERR(0, 1029, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("to_tuple", 1, 1, 1, i); __PYX_ERR(0, 1029, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1029, __pyx_L3_error)
    }
    __pyx_v_dt = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("to_tuple", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 1029, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.to_tuple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_32to_tuple(__pyx_self, __pyx_v_dt);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_32to_tuple(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_dt) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("to_tuple", 0);

  /* "cftime/_cftime.pyx":1034
 *     datetime instances. Parts of the state that don't affect ordering
 *     are omitted. Compare to datetime.timetuple()."""
 *     return (dt.year, dt.month, dt.day, dt.hour, dt.minute,             # <<<<<<<<<<<<<<
 *             dt.second, dt.microsecond)
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);

  /* "cftime/_cftime.pyx":1035
 *     are omitted. Compare to datetime.timetuple()."""
 *     return (dt.year, dt.month, dt.day, dt.hour, dt.minute,
 *             dt.second, dt.microsecond)             # <<<<<<<<<<<<<<
 * 
 * cdef _year_zero_defaults(calendar):
*/
  __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1035, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_v_dt, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1035, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);

  /* "cftime/_cftime.pyx":1034
 *     datetime instances. Parts of the state that don't affect ordering
 *     are omitted. Compare to datetime.timetuple()."""
 *     return (dt.year, dt.month, dt.day, dt.hour, dt.minute,             # <<<<<<<<<<<<<<
 *             dt.second, dt.microsecond)
 * 
*/
  __pyx_t_8 = PyTuple_New(7); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1034, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_2);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_2) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 2, __pyx_t_3) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_4);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 3, __pyx_t_4) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_5);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 4, __pyx_t_5) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 5, __pyx_t_6) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_7);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 6, __pyx_t_7) != (0)) __PYX_ERR(0, 1034, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __pyx_r = __pyx_t_8;
  __pyx_t_8 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1029
 *         return a
 * 
 * def to_tuple(dt):             # <<<<<<<<<<<<<<
 *     """Turn a datetime.datetime instance into a tuple of integers. Elements go
 *     in the order of decreasing significance, making it easy to compare
*/

  /* 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_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_AddTraceback("cftime._cftime.to_tuple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1037
 *             dt.second, dt.microsecond)
 * 
 * cdef _year_zero_defaults(calendar):             # <<<<<<<<<<<<<<
 *     if calendar: calendar = calendar.lower()
 *     if calendar in ['standard','gregorian','julian']:
*/

static PyObject *__pyx_f_6cftime_7_cftime__year_zero_defaults(PyObject *__pyx_v_calendar) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  int __pyx_t_5;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_year_zero_defaults", 0);
  __Pyx_INCREF(__pyx_v_calendar);

  /* "cftime/_cftime.pyx":1038
 * 
 * cdef _year_zero_defaults(calendar):
 *     if calendar: calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     if calendar in ['standard','gregorian','julian']:
 *        return False
*/
  __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_calendar); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1038, __pyx_L1_error)
  if (__pyx_t_1) {
    __pyx_t_3 = __pyx_v_calendar;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1038, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_2);
    __pyx_t_2 = 0;
  }

  /* "cftime/_cftime.pyx":1039
 * cdef _year_zero_defaults(calendar):
 *     if calendar: calendar = calendar.lower()
 *     if calendar in ['standard','gregorian','julian']:             # <<<<<<<<<<<<<<
 *        return False
 *     elif calendar in ['proleptic_gregorian']:
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1039, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_1 = __pyx_t_5;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1039, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_1 = __pyx_t_5;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1039, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_5;
  __pyx_L5_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_5 = __pyx_t_1;
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":1040
 *     if calendar: calendar = calendar.lower()
 *     if calendar in ['standard','gregorian','julian']:
 *        return False             # <<<<<<<<<<<<<<
 *     elif calendar in ['proleptic_gregorian']:
 *        return True # ISO 8601 year zero=1 BC
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_False);
    __pyx_r = Py_False;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1039
 * cdef _year_zero_defaults(calendar):
 *     if calendar: calendar = calendar.lower()
 *     if calendar in ['standard','gregorian','julian']:             # <<<<<<<<<<<<<<
 *        return False
 *     elif calendar in ['proleptic_gregorian']:
*/
  }

  /* "cftime/_cftime.pyx":1041
 *     if calendar in ['standard','gregorian','julian']:
 *        return False
 *     elif calendar in ['proleptic_gregorian']:             # <<<<<<<<<<<<<<
 *        return True # ISO 8601 year zero=1 BC
 *     elif calendar in _idealized_calendars:
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1041, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_1 = __pyx_t_5;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1042
 *        return False
 *     elif calendar in ['proleptic_gregorian']:
 *        return True # ISO 8601 year zero=1 BC             # <<<<<<<<<<<<<<
 *     elif calendar in _idealized_calendars:
 *        return True
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_True);
    __pyx_r = Py_True;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1041
 *     if calendar in ['standard','gregorian','julian']:
 *        return False
 *     elif calendar in ['proleptic_gregorian']:             # <<<<<<<<<<<<<<
 *        return True # ISO 8601 year zero=1 BC
 *     elif calendar in _idealized_calendars:
*/
  }

  /* "cftime/_cftime.pyx":1043
 *     elif calendar in ['proleptic_gregorian']:
 *        return True # ISO 8601 year zero=1 BC
 *     elif calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *        return True
 *     else:
*/
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1043, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_1 = (__Pyx_PySequence_ContainsTF(__pyx_v_calendar, __pyx_t_2, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1043, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1044
 *        return True # ISO 8601 year zero=1 BC
 *     elif calendar in _idealized_calendars:
 *        return True             # <<<<<<<<<<<<<<
 *     else:
 *        return False
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_True);
    __pyx_r = Py_True;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1043
 *     elif calendar in ['proleptic_gregorian']:
 *        return True # ISO 8601 year zero=1 BC
 *     elif calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *        return True
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":1046
 *        return True
 *     else:
 *        return False             # <<<<<<<<<<<<<<
 * 
 * # factory function without optional kwargs that can be used in datetime.__reduce__
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_False);
    __pyx_r = Py_False;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1037
 *             dt.second, dt.microsecond)
 * 
 * cdef _year_zero_defaults(calendar):             # <<<<<<<<<<<<<<
 *     if calendar: calendar = calendar.lower()
 *     if calendar in ['standard','gregorian','julian']:
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("cftime._cftime._year_zero_defaults", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1049
 * 
 * # factory function without optional kwargs that can be used in datetime.__reduce__
 * def _create_datetime(date_type, args, kwargs): return date_type(*args, **kwargs)             # <<<<<<<<<<<<<<
 * # custorm warning for invalid CF dates.
 * cfwarnmsg="this date/calendar/year zero convention is not supported by CF"
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_35_create_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyMethodDef __pyx_mdef_6cftime_7_cftime_35_create_datetime = {"_create_datetime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_35_create_datetime, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0};
static PyObject *__pyx_pw_6cftime_7_cftime_35_create_datetime(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_date_type = 0;
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[3] = {0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_create_datetime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_date_type,&__pyx_mstate_global->__pyx_n_u_args,&__pyx_mstate_global->__pyx_n_u_kwargs,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1049, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1049, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1049, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1049, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "_create_datetime", 0) < (0)) __PYX_ERR(0, 1049, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 3; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("_create_datetime", 1, 3, 3, i); __PYX_ERR(0, 1049, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 3)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1049, __pyx_L3_error)
      values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1049, __pyx_L3_error)
      values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1049, __pyx_L3_error)
    }
    __pyx_v_date_type = values[0];
    __pyx_v_args = values[1];
    __pyx_v_kwargs = values[2];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("_create_datetime", 1, 3, 3, __pyx_nargs); __PYX_ERR(0, 1049, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime._create_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_34_create_datetime(__pyx_self, __pyx_v_date_type, __pyx_v_args, __pyx_v_kwargs);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_34_create_datetime(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_date_type, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_create_datetime", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PySequence_Tuple(__pyx_v_args); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  if (unlikely(__pyx_v_kwargs == Py_None)) {
    PyErr_SetString(PyExc_TypeError, "argument after ** must be a mapping, not NoneType");
    __PYX_ERR(0, 1049, __pyx_L1_error)
  }
  if (likely(PyDict_CheckExact(__pyx_v_kwargs))) {
    __pyx_t_2 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  } else {
    __pyx_t_2 = __Pyx_PyObject_CallOneArg((PyObject*)&PyDict_Type, __pyx_v_kwargs); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_t_3 = __Pyx_PyObject_Call(__pyx_v_date_type, __pyx_t_1, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1049, __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_r = __pyx_t_3;
  __pyx_t_3 = 0;
  goto __pyx_L0;

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("cftime._cftime._create_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1120
 *     cdef readonly bint datetime_compatible
 * 
 *     def __init__(self, int year, int month, int day, int hour=0, int minute=0,             # <<<<<<<<<<<<<<
 *                        int second=0, int microsecond=0, int dayofwk=-1,
 *                        int dayofyr = -1, calendar='standard', has_year_zero=None):
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_8datetime_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_8datetime_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  int __pyx_v_year;
  int __pyx_v_month;
  int __pyx_v_day;
  int __pyx_v_hour;
  int __pyx_v_minute;
  int __pyx_v_second;
  int __pyx_v_microsecond;
  int __pyx_v_dayofwk;
  int __pyx_v_dayofyr;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[11] = {0,0,0,0,0,0,0,0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_year,&__pyx_mstate_global->__pyx_n_u_month,&__pyx_mstate_global->__pyx_n_u_day,&__pyx_mstate_global->__pyx_n_u_hour,&__pyx_mstate_global->__pyx_n_u_minute,&__pyx_mstate_global->__pyx_n_u_second,&__pyx_mstate_global->__pyx_n_u_microsecond,&__pyx_mstate_global->__pyx_n_u_dayofwk,&__pyx_mstate_global->__pyx_n_u_dayofyr,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1120, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case 11:
        values[10] = __Pyx_ArgRef_VARARGS(__pyx_args, 10);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[10])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case 10:
        values[9] = __Pyx_ArgRef_VARARGS(__pyx_args, 9);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[9])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  9:
        values[8] = __Pyx_ArgRef_VARARGS(__pyx_args, 8);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[8])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  8:
        values[7] = __Pyx_ArgRef_VARARGS(__pyx_args, 7);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[7])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  7:
        values[6] = __Pyx_ArgRef_VARARGS(__pyx_args, 6);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[6])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  6:
        values[5] = __Pyx_ArgRef_VARARGS(__pyx_args, 5);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[5])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  5:
        values[4] = __Pyx_ArgRef_VARARGS(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_VARARGS(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_VARARGS(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_VARARGS(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__init__", 0) < (0)) __PYX_ERR(0, 1120, __pyx_L3_error)
      if (!values[9]) values[9] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));

      /* "cftime/_cftime.pyx":1122
 *     def __init__(self, int year, int month, int day, int hour=0, int minute=0,
 *                        int second=0, int microsecond=0, int dayofwk=-1,
 *                        int dayofyr = -1, calendar='standard', has_year_zero=None):             # <<<<<<<<<<<<<<
 * 
 *         self.year = year
*/
      if (!values[10]) values[10] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 3; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__init__", 0, 3, 11, i); __PYX_ERR(0, 1120, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case 11:
        values[10] = __Pyx_ArgRef_VARARGS(__pyx_args, 10);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[10])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case 10:
        values[9] = __Pyx_ArgRef_VARARGS(__pyx_args, 9);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[9])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  9:
        values[8] = __Pyx_ArgRef_VARARGS(__pyx_args, 8);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[8])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  8:
        values[7] = __Pyx_ArgRef_VARARGS(__pyx_args, 7);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[7])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  7:
        values[6] = __Pyx_ArgRef_VARARGS(__pyx_args, 6);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[6])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  6:
        values[5] = __Pyx_ArgRef_VARARGS(__pyx_args, 5);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[5])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  5:
        values[4] = __Pyx_ArgRef_VARARGS(__pyx_args, 4);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  4:
        values[3] = __Pyx_ArgRef_VARARGS(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 1120, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_VARARGS(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1120, __pyx_L3_error)
        values[1] = __Pyx_ArgRef_VARARGS(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1120, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1120, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[9]) values[9] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));
      if (!values[10]) values[10] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_year = __Pyx_PyLong_As_int(values[0]); if (unlikely((__pyx_v_year == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1120, __pyx_L3_error)
    __pyx_v_month = __Pyx_PyLong_As_int(values[1]); if (unlikely((__pyx_v_month == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1120, __pyx_L3_error)
    __pyx_v_day = __Pyx_PyLong_As_int(values[2]); if (unlikely((__pyx_v_day == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1120, __pyx_L3_error)
    if (values[3]) {
      __pyx_v_hour = __Pyx_PyLong_As_int(values[3]); if (unlikely((__pyx_v_hour == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1120, __pyx_L3_error)
    } else {
      __pyx_v_hour = ((int)0);
    }
    if (values[4]) {
      __pyx_v_minute = __Pyx_PyLong_As_int(values[4]); if (unlikely((__pyx_v_minute == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1120, __pyx_L3_error)
    } else {
      __pyx_v_minute = ((int)0);
    }
    if (values[5]) {
      __pyx_v_second = __Pyx_PyLong_As_int(values[5]); if (unlikely((__pyx_v_second == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1121, __pyx_L3_error)
    } else {
      __pyx_v_second = ((int)0);
    }
    if (values[6]) {
      __pyx_v_microsecond = __Pyx_PyLong_As_int(values[6]); if (unlikely((__pyx_v_microsecond == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1121, __pyx_L3_error)
    } else {
      __pyx_v_microsecond = ((int)0);
    }
    if (values[7]) {
      __pyx_v_dayofwk = __Pyx_PyLong_As_int(values[7]); if (unlikely((__pyx_v_dayofwk == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1121, __pyx_L3_error)
    } else {
      __pyx_v_dayofwk = ((int)-1);
    }
    if (values[8]) {
      __pyx_v_dayofyr = __Pyx_PyLong_As_int(values[8]); if (unlikely((__pyx_v_dayofyr == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1122, __pyx_L3_error)
    } else {
      __pyx_v_dayofyr = ((int)-1);
    }
    __pyx_v_calendar = values[9];
    __pyx_v_has_year_zero = values[10];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("__init__", 0, 3, 11, __pyx_nargs); __PYX_ERR(0, 1120, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return -1;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime___init__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_year, __pyx_v_month, __pyx_v_day, __pyx_v_hour, __pyx_v_minute, __pyx_v_second, __pyx_v_microsecond, __pyx_v_dayofwk, __pyx_v_dayofyr, __pyx_v_calendar, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1120
 *     cdef readonly bint datetime_compatible
 * 
 *     def __init__(self, int year, int month, int day, int hour=0, int minute=0,             # <<<<<<<<<<<<<<
 *                        int second=0, int microsecond=0, int dayofwk=-1,
 *                        int dayofyr = -1, calendar='standard', has_year_zero=None):
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static int __pyx_pf_6cftime_7_cftime_8datetime___init__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, int __pyx_v_year, int __pyx_v_month, int __pyx_v_day, int __pyx_v_hour, int __pyx_v_minute, int __pyx_v_second, int __pyx_v_microsecond, int __pyx_v_dayofwk, int __pyx_v_dayofyr, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_msg = NULL;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  int __pyx_t_5;
  int __pyx_t_6;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime_assert_valid_date __pyx_t_11;
  PyObject *__pyx_t_12[5];
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1124
 *                        int dayofyr = -1, calendar='standard', has_year_zero=None):
 * 
 *         self.year = year             # <<<<<<<<<<<<<<
 *         self.month = month
 *         self.day = day
*/
  __pyx_v_self->year = __pyx_v_year;

  /* "cftime/_cftime.pyx":1125
 * 
 *         self.year = year
 *         self.month = month             # <<<<<<<<<<<<<<
 *         self.day = day
 *         self.hour = hour
*/
  __pyx_v_self->month = __pyx_v_month;

  /* "cftime/_cftime.pyx":1126
 *         self.year = year
 *         self.month = month
 *         self.day = day             # <<<<<<<<<<<<<<
 *         self.hour = hour
 *         self.minute = minute
*/
  __pyx_v_self->day = __pyx_v_day;

  /* "cftime/_cftime.pyx":1127
 *         self.month = month
 *         self.day = day
 *         self.hour = hour             # <<<<<<<<<<<<<<
 *         self.minute = minute
 *         self.second = second
*/
  __pyx_v_self->hour = __pyx_v_hour;

  /* "cftime/_cftime.pyx":1128
 *         self.day = day
 *         self.hour = hour
 *         self.minute = minute             # <<<<<<<<<<<<<<
 *         self.second = second
 *         self.microsecond = microsecond
*/
  __pyx_v_self->minute = __pyx_v_minute;

  /* "cftime/_cftime.pyx":1129
 *         self.hour = hour
 *         self.minute = minute
 *         self.second = second             # <<<<<<<<<<<<<<
 *         self.microsecond = microsecond
 *         self._dayofwk = dayofwk
*/
  __pyx_v_self->second = __pyx_v_second;

  /* "cftime/_cftime.pyx":1130
 *         self.minute = minute
 *         self.second = second
 *         self.microsecond = microsecond             # <<<<<<<<<<<<<<
 *         self._dayofwk = dayofwk
 *         self._dayofyr = dayofyr
*/
  __pyx_v_self->microsecond = __pyx_v_microsecond;

  /* "cftime/_cftime.pyx":1131
 *         self.second = second
 *         self.microsecond = microsecond
 *         self._dayofwk = dayofwk             # <<<<<<<<<<<<<<
 *         self._dayofyr = dayofyr
 *         self.tzinfo = None
*/
  __pyx_v_self->_dayofwk = __pyx_v_dayofwk;

  /* "cftime/_cftime.pyx":1132
 *         self.microsecond = microsecond
 *         self._dayofwk = dayofwk
 *         self._dayofyr = dayofyr             # <<<<<<<<<<<<<<
 *         self.tzinfo = None
 *         if calendar:
*/
  __pyx_v_self->_dayofyr = __pyx_v_dayofyr;

  /* "cftime/_cftime.pyx":1133
 *         self._dayofwk = dayofwk
 *         self._dayofyr = dayofyr
 *         self.tzinfo = None             # <<<<<<<<<<<<<<
 *         if calendar:
 *             calendar = calendar.lower()
*/
  __Pyx_INCREF(Py_None);
  __Pyx_GIVEREF(Py_None);
  __Pyx_GOTREF(__pyx_v_self->tzinfo);
  __Pyx_DECREF(__pyx_v_self->tzinfo);
  __pyx_v_self->tzinfo = Py_None;

  /* "cftime/_cftime.pyx":1134
 *         self._dayofyr = dayofyr
 *         self.tzinfo = None
 *         if calendar:             # <<<<<<<<<<<<<<
 *             calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
*/
  __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_calendar); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1134, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1135
 *         self.tzinfo = None
 *         if calendar:
 *             calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:
*/
    __pyx_t_3 = __pyx_v_calendar;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1135, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1134
 *         self._dayofyr = dayofyr
 *         self.tzinfo = None
 *         if calendar:             # <<<<<<<<<<<<<<
 *             calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
*/
  }

  /* "cftime/_cftime.pyx":1137
 *             calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:             # <<<<<<<<<<<<<<
 *             if year == 0:
 *                 # assume if user sets year to zero, the calendar should
*/
  __pyx_t_1 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1138
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:
 *             if year == 0:             # <<<<<<<<<<<<<<
 *                 # assume if user sets year to zero, the calendar should
 *                 # include the year zero (issue #248)
*/
    __pyx_t_1 = (__pyx_v_year == 0);
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1142
 *                 # include the year zero (issue #248)
 *                 # warn if calendar is being set to non-CF calendar
 *                 msg="year=0 was specified - this date/calendar/year zero convention is not supported by CF"             # <<<<<<<<<<<<<<
 *                 if calendar is not None and not _year_zero_defaults(calendar):
 *                     warnings.warn(msg,category=CFWarning)
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_year_0_was_specified_this_date_c);
      __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_year_0_was_specified_this_date_c;

      /* "cftime/_cftime.pyx":1143
 *                 # warn if calendar is being set to non-CF calendar
 *                 msg="year=0 was specified - this date/calendar/year zero convention is not supported by CF"
 *                 if calendar is not None and not _year_zero_defaults(calendar):             # <<<<<<<<<<<<<<
 *                     warnings.warn(msg,category=CFWarning)
 *                 has_year_zero=True
*/
      __pyx_t_5 = (__pyx_v_calendar != Py_None);
      if (__pyx_t_5) {
      } else {
        __pyx_t_1 = __pyx_t_5;
        goto __pyx_L7_bool_binop_done;
      }
      __pyx_t_2 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1143, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1143, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_6 = (!__pyx_t_5);
      __pyx_t_1 = __pyx_t_6;
      __pyx_L7_bool_binop_done:;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1144
 *                 msg="year=0 was specified - this date/calendar/year zero convention is not supported by CF"
 *                 if calendar is not None and not _year_zero_defaults(calendar):
 *                     warnings.warn(msg,category=CFWarning)             # <<<<<<<<<<<<<<
 *                 has_year_zero=True
 *             else:
*/
        __pyx_t_3 = NULL;
        __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_warnings); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1144, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_warn); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1144, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_CFWarning); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1144, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        __pyx_t_4 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_8))) {
          __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_8);
          assert(__pyx_t_3);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_8);
          __Pyx_INCREF(__pyx_t_3);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_8, __pyx__function);
          __pyx_t_4 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_3, __pyx_v_msg};
          __pyx_t_9 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1144, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_9);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_category, __pyx_t_7, __pyx_t_9, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1144, __pyx_L1_error)
          __pyx_t_2 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_8, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_9);
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
          __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1144, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_2);
        }
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

        /* "cftime/_cftime.pyx":1143
 *                 # warn if calendar is being set to non-CF calendar
 *                 msg="year=0 was specified - this date/calendar/year zero convention is not supported by CF"
 *                 if calendar is not None and not _year_zero_defaults(calendar):             # <<<<<<<<<<<<<<
 *                     warnings.warn(msg,category=CFWarning)
 *                 has_year_zero=True
*/
      }

      /* "cftime/_cftime.pyx":1145
 *                 if calendar is not None and not _year_zero_defaults(calendar):
 *                     warnings.warn(msg,category=CFWarning)
 *                 has_year_zero=True             # <<<<<<<<<<<<<<
 *             else:
 *                 has_year_zero = _year_zero_defaults(calendar)
*/
      __Pyx_INCREF(Py_True);
      __Pyx_DECREF_SET(__pyx_v_has_year_zero, Py_True);

      /* "cftime/_cftime.pyx":1138
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:
 *             if year == 0:             # <<<<<<<<<<<<<<
 *                 # assume if user sets year to zero, the calendar should
 *                 # include the year zero (issue #248)
*/
      goto __pyx_L5;
    }

    /* "cftime/_cftime.pyx":1147
 *                 has_year_zero=True
 *             else:
 *                 has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *         # warn if requested date not allowed by CF
 *         # (no years < 1 in mixed Julian/Gregorian calendar).
*/
    /*else*/ {
      __pyx_t_2 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1147, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_2);
      __pyx_t_2 = 0;
    }
    __pyx_L5:;

    /* "cftime/_cftime.pyx":1137
 *             calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:             # <<<<<<<<<<<<<<
 *             if year == 0:
 *                 # assume if user sets year to zero, the calendar should
*/
  }

  /* "cftime/_cftime.pyx":1153
 *         # for the proleptic_gregorian calendar. IS0 8601 uses proleptic_gregorian
 *         # and has a year zero, so for now this is the default in cftime.
 *         if calendar in ['julian','gregorian','standard'] and year <= 0:             # <<<<<<<<<<<<<<
 *             warnings.warn(cfwarnmsg,category=CFWarning)
 *         # raise exception if year zero requested but has_year_zero set
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_2 = __pyx_v_calendar;
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1153, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_6 = __pyx_t_5;
    goto __pyx_L12_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1153, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_6 = __pyx_t_5;
    goto __pyx_L12_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1153, __pyx_L1_error)
  __pyx_t_6 = __pyx_t_5;
  __pyx_L12_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_5 = __pyx_t_6;
  if (__pyx_t_5) {
  } else {
    __pyx_t_1 = __pyx_t_5;
    goto __pyx_L10_bool_binop_done;
  }
  __pyx_t_5 = (__pyx_v_year <= 0);
  __pyx_t_1 = __pyx_t_5;
  __pyx_L10_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1154
 *         # and has a year zero, so for now this is the default in cftime.
 *         if calendar in ['julian','gregorian','standard'] and year <= 0:
 *             warnings.warn(cfwarnmsg,category=CFWarning)             # <<<<<<<<<<<<<<
 *         # raise exception if year zero requested but has_year_zero set
 *         # to False (issue #248).
*/
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_warnings); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_warn); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_cfwarnmsg); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_CFWarning); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1154, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_8, __pyx_t_9};
      __pyx_t_10 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1154, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_category, __pyx_t_3, __pyx_t_10, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1154, __pyx_L1_error)
      __pyx_t_2 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_10);
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1154, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1153
 *         # for the proleptic_gregorian calendar. IS0 8601 uses proleptic_gregorian
 *         # and has a year zero, so for now this is the default in cftime.
 *         if calendar in ['julian','gregorian','standard'] and year <= 0:             # <<<<<<<<<<<<<<
 *             warnings.warn(cfwarnmsg,category=CFWarning)
 *         # raise exception if year zero requested but has_year_zero set
*/
  }

  /* "cftime/_cftime.pyx":1157
 *         # raise exception if year zero requested but has_year_zero set
 *         # to False (issue #248).
 *         if year == 0 and has_year_zero==False:             # <<<<<<<<<<<<<<
 *             msg='year zero requested, but has_year_zero=False'
 *             raise ValueError(msg)
*/
  __pyx_t_5 = (__pyx_v_year == 0);
  if (__pyx_t_5) {
  } else {
    __pyx_t_1 = __pyx_t_5;
    goto __pyx_L16_bool_binop_done;
  }
  __pyx_t_2 = PyObject_RichCompare(__pyx_v_has_year_zero, Py_False, Py_EQ); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1157, __pyx_L1_error)
  __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1157, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_1 = __pyx_t_5;
  __pyx_L16_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1158
 *         # to False (issue #248).
 *         if year == 0 and has_year_zero==False:
 *             msg='year zero requested, but has_year_zero=False'             # <<<<<<<<<<<<<<
 *             raise ValueError(msg)
 *         if not has_year_zero and calendar in _idealized_calendars:
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_year_zero_requested_but_has_year);
    __Pyx_XDECREF_SET(__pyx_v_msg, __pyx_mstate_global->__pyx_kp_u_year_zero_requested_but_has_year);

    /* "cftime/_cftime.pyx":1159
 *         if year == 0 and has_year_zero==False:
 *             msg='year zero requested, but has_year_zero=False'
 *             raise ValueError(msg)             # <<<<<<<<<<<<<<
 *         if not has_year_zero and calendar in _idealized_calendars:
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
*/
    __pyx_t_7 = NULL;
    __pyx_t_4 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_msg};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1159, __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(0, 1159, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1157
 *         # raise exception if year zero requested but has_year_zero set
 *         # to False (issue #248).
 *         if year == 0 and has_year_zero==False:             # <<<<<<<<<<<<<<
 *             msg='year zero requested, but has_year_zero=False'
 *             raise ValueError(msg)
*/
  }

  /* "cftime/_cftime.pyx":1160
 *             msg='year zero requested, but has_year_zero=False'
 *             raise ValueError(msg)
 *         if not has_year_zero and calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
 *         self.has_year_zero = has_year_zero
*/
  __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1160, __pyx_L1_error)
  __pyx_t_6 = (!__pyx_t_5);
  if (__pyx_t_6) {
  } else {
    __pyx_t_1 = __pyx_t_6;
    goto __pyx_L19_bool_binop_done;
  }
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1160, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_6 = (__Pyx_PySequence_ContainsTF(__pyx_v_calendar, __pyx_t_2, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1160, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_1 = __pyx_t_6;
  __pyx_L19_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1161
 *             raise ValueError(msg)
 *         if not has_year_zero and calendar in _idealized_calendars:
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')             # <<<<<<<<<<<<<<
 *         self.has_year_zero = has_year_zero
 *         if calendar == 'gregorian' or calendar == 'standard':
*/
    __pyx_t_7 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_warnings); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1161, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_10, __pyx_mstate_global->__pyx_n_u_warn); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1161, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __pyx_t_4 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_3))) {
      __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_3);
      assert(__pyx_t_7);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_3, __pyx__function);
      __pyx_t_4 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_has_year_zero_kwarg_ignored_for};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1161, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1160
 *             msg='year zero requested, but has_year_zero=False'
 *             raise ValueError(msg)
 *         if not has_year_zero and calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
 *         self.has_year_zero = has_year_zero
*/
  }

  /* "cftime/_cftime.pyx":1162
 *         if not has_year_zero and calendar in _idealized_calendars:
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
 *         self.has_year_zero = has_year_zero             # <<<<<<<<<<<<<<
 *         if calendar == 'gregorian' or calendar == 'standard':
 *             # dates after 1582-10-15 can be converted to and compared to
*/
  __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1162, __pyx_L1_error)
  __pyx_v_self->has_year_zero = __pyx_t_1;

  /* "cftime/_cftime.pyx":1163
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
 *         self.has_year_zero = has_year_zero
 *         if calendar == 'gregorian' or calendar == 'standard':             # <<<<<<<<<<<<<<
 *             # dates after 1582-10-15 can be converted to and compared to
 *             # proleptic Gregorian dates
*/
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1163, __pyx_L1_error)
  if (!__pyx_t_6) {
  } else {
    __pyx_t_1 = __pyx_t_6;
    goto __pyx_L22_bool_binop_done;
  }
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1163, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_6;
  __pyx_L22_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1166
 *             # dates after 1582-10-15 can be converted to and compared to
 *             # proleptic Gregorian dates
 *             self.calendar = 'standard'             # <<<<<<<<<<<<<<
 *             if self.to_tuple() >= (1582, 10, 15, 0, 0, 0, 0):
 *                 self.datetime_compatible = True
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_standard);
    __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_standard);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = __pyx_mstate_global->__pyx_n_u_standard;

    /* "cftime/_cftime.pyx":1167
 *             # proleptic Gregorian dates
 *             self.calendar = 'standard'
 *             if self.to_tuple() >= (1582, 10, 15, 0, 0, 0, 0):             # <<<<<<<<<<<<<<
 *                 self.datetime_compatible = True
 *             else:
*/
    __pyx_t_3 = ((PyObject *)__pyx_v_self);
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1167, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_3 = PyObject_RichCompare(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[2], Py_GE); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1167, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1167, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1168
 *             self.calendar = 'standard'
 *             if self.to_tuple() >= (1582, 10, 15, 0, 0, 0, 0):
 *                 self.datetime_compatible = True             # <<<<<<<<<<<<<<
 *             else:
 *                 self.datetime_compatible = False
*/
      __pyx_v_self->datetime_compatible = 1;

      /* "cftime/_cftime.pyx":1167
 *             # proleptic Gregorian dates
 *             self.calendar = 'standard'
 *             if self.to_tuple() >= (1582, 10, 15, 0, 0, 0, 0):             # <<<<<<<<<<<<<<
 *                 self.datetime_compatible = True
 *             else:
*/
      goto __pyx_L24;
    }

    /* "cftime/_cftime.pyx":1170
 *                 self.datetime_compatible = True
 *             else:
 *                 self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, is_leap_gregorian, True, has_year_zero=has_year_zero)
 *         elif calendar == 'noleap' or calendar == '365_day':
*/
    /*else*/ {
      __pyx_v_self->datetime_compatible = 0;
    }
    __pyx_L24:;

    /* "cftime/_cftime.pyx":1171
 *             else:
 *                 self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_gregorian, True, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         elif calendar == 'noleap' or calendar == '365_day':
 *             self.calendar = 'noleap'
*/
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1171, __pyx_L1_error)
    __pyx_t_11.__pyx_n = 1;
    __pyx_t_11.has_year_zero = __pyx_t_1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_is_leap_gregorian, 1, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1171, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1163
 *             warnings.warn('has_year_zero kwarg ignored for idealized calendars (always True)')
 *         self.has_year_zero = has_year_zero
 *         if calendar == 'gregorian' or calendar == 'standard':             # <<<<<<<<<<<<<<
 *             # dates after 1582-10-15 can be converted to and compared to
 *             # proleptic Gregorian dates
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1172
 *                 self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_gregorian, True, has_year_zero=has_year_zero)
 *         elif calendar == 'noleap' or calendar == '365_day':             # <<<<<<<<<<<<<<
 *             self.calendar = 'noleap'
 *             self.datetime_compatible = False
*/
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1172, __pyx_L1_error)
  if (!__pyx_t_6) {
  } else {
    __pyx_t_1 = __pyx_t_6;
    goto __pyx_L25_bool_binop_done;
  }
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_365_day, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1172, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_6;
  __pyx_L25_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1173
 *             assert_valid_date(self, is_leap_gregorian, True, has_year_zero=has_year_zero)
 *         elif calendar == 'noleap' or calendar == '365_day':
 *             self.calendar = 'noleap'             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_noleap);
    __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_noleap);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = __pyx_mstate_global->__pyx_n_u_noleap;

    /* "cftime/_cftime.pyx":1174
 *         elif calendar == 'noleap' or calendar == '365_day':
 *             self.calendar = 'noleap'
 *             self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)
 *         elif calendar == 'all_leap' or calendar == '366_day':
*/
    __pyx_v_self->datetime_compatible = 0;

    /* "cftime/_cftime.pyx":1175
 *             self.calendar = 'noleap'
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)             # <<<<<<<<<<<<<<
 *         elif calendar == 'all_leap' or calendar == '366_day':
 *             self.calendar = 'all_leap'
*/
    __pyx_t_11.__pyx_n = 1;
    __pyx_t_11.has_year_zero = 1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_no_leap, 0, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1175, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1172
 *                 self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_gregorian, True, has_year_zero=has_year_zero)
 *         elif calendar == 'noleap' or calendar == '365_day':             # <<<<<<<<<<<<<<
 *             self.calendar = 'noleap'
 *             self.datetime_compatible = False
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1176
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)
 *         elif calendar == 'all_leap' or calendar == '366_day':             # <<<<<<<<<<<<<<
 *             self.calendar = 'all_leap'
 *             self.datetime_compatible = False
*/
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_all_leap, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1176, __pyx_L1_error)
  if (!__pyx_t_6) {
  } else {
    __pyx_t_1 = __pyx_t_6;
    goto __pyx_L27_bool_binop_done;
  }
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_366_day, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1176, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_6;
  __pyx_L27_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1177
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)
 *         elif calendar == 'all_leap' or calendar == '366_day':
 *             self.calendar = 'all_leap'             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = False
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_all_leap);
    __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_all_leap);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = __pyx_mstate_global->__pyx_n_u_all_leap;

    /* "cftime/_cftime.pyx":1178
 *         elif calendar == 'all_leap' or calendar == '366_day':
 *             self.calendar = 'all_leap'
 *             self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)
 *         elif calendar == '360_day':
*/
    __pyx_v_self->datetime_compatible = 0;

    /* "cftime/_cftime.pyx":1179
 *             self.calendar = 'all_leap'
 *             self.datetime_compatible = False
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)             # <<<<<<<<<<<<<<
 *         elif calendar == '360_day':
 *             self.calendar = calendar
*/
    __pyx_t_11.__pyx_n = 1;
    __pyx_t_11.has_year_zero = 1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_all_leap, 0, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1179, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1176
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True)
 *         elif calendar == 'all_leap' or calendar == '366_day':             # <<<<<<<<<<<<<<
 *             self.calendar = 'all_leap'
 *             self.datetime_compatible = False
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1180
 *             self.datetime_compatible = False
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)
 *         elif calendar == '360_day':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = False
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1180, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1181
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)
 *         elif calendar == '360_day':
 *             self.calendar = calendar             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)
*/
    __pyx_t_3 = __pyx_v_calendar;
    __Pyx_INCREF(__pyx_t_3);
    if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_3))) __PYX_ERR(0, 1181, __pyx_L1_error)
    __Pyx_GIVEREF(__pyx_t_3);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = ((PyObject*)__pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1182
 *         elif calendar == '360_day':
 *             self.calendar = calendar
 *             self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)
 *         elif calendar == 'julian':
*/
    __pyx_v_self->datetime_compatible = 0;

    /* "cftime/_cftime.pyx":1183
 *             self.calendar = calendar
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)             # <<<<<<<<<<<<<<
 *         elif calendar == 'julian':
 *             self.calendar = calendar
*/
    __pyx_t_11.__pyx_n = 2;
    __pyx_t_11.has_year_zero = 1;
    __pyx_t_11.is_360_day = 1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_no_leap, 0, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1183, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1180
 *             self.datetime_compatible = False
 *             assert_valid_date(self, all_leap, False, has_year_zero=True)
 *         elif calendar == '360_day':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = False
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1184
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)
 *         elif calendar == 'julian':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = False
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1184, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1185
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)
 *         elif calendar == 'julian':
 *             self.calendar = calendar             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)
*/
    __pyx_t_3 = __pyx_v_calendar;
    __Pyx_INCREF(__pyx_t_3);
    if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_3))) __PYX_ERR(0, 1185, __pyx_L1_error)
    __Pyx_GIVEREF(__pyx_t_3);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = ((PyObject*)__pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1186
 *         elif calendar == 'julian':
 *             self.calendar = calendar
 *             self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':
*/
    __pyx_v_self->datetime_compatible = 0;

    /* "cftime/_cftime.pyx":1187
 *             self.calendar = calendar
 *             self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         elif calendar == 'proleptic_gregorian':
 *             self.calendar = calendar
*/
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1187, __pyx_L1_error)
    __pyx_t_11.__pyx_n = 1;
    __pyx_t_11.has_year_zero = __pyx_t_1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_is_leap_julian, 0, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1187, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1184
 *             self.datetime_compatible = False
 *             assert_valid_date(self, no_leap, False, has_year_zero=True, is_360_day=True)
 *         elif calendar == 'julian':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = False
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1188
 *             self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = True
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1188, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1189
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':
 *             self.calendar = calendar             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = True
 *             assert_valid_date(self, is_leap_proleptic_gregorian, False, has_year_zero=has_year_zero)
*/
    __pyx_t_3 = __pyx_v_calendar;
    __Pyx_INCREF(__pyx_t_3);
    if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None) || __Pyx_RaiseUnexpectedTypeError("str", __pyx_t_3))) __PYX_ERR(0, 1189, __pyx_L1_error)
    __Pyx_GIVEREF(__pyx_t_3);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = ((PyObject*)__pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1190
 *         elif calendar == 'proleptic_gregorian':
 *             self.calendar = calendar
 *             self.datetime_compatible = True             # <<<<<<<<<<<<<<
 *             assert_valid_date(self, is_leap_proleptic_gregorian, False, has_year_zero=has_year_zero)
 *         elif calendar == '' or calendar is None:
*/
    __pyx_v_self->datetime_compatible = 1;

    /* "cftime/_cftime.pyx":1191
 *             self.calendar = calendar
 *             self.datetime_compatible = True
 *             assert_valid_date(self, is_leap_proleptic_gregorian, False, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         elif calendar == '' or calendar is None:
 *             # instance not calendar-aware, some method will not work
*/
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1191, __pyx_L1_error)
    __pyx_t_11.__pyx_n = 1;
    __pyx_t_11.has_year_zero = __pyx_t_1;
    __pyx_f_6cftime_7_cftime_assert_valid_date(__pyx_v_self, __pyx_f_6cftime_7_cftime_is_leap_proleptic_gregorian, 0, &__pyx_t_11); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1191, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1188
 *             self.datetime_compatible = False
 *             assert_valid_date(self, is_leap_julian, False, has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             self.calendar = calendar
 *             self.datetime_compatible = True
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1192
 *             self.datetime_compatible = True
 *             assert_valid_date(self, is_leap_proleptic_gregorian, False, has_year_zero=has_year_zero)
 *         elif calendar == '' or calendar is None:             # <<<<<<<<<<<<<<
 *             # instance not calendar-aware, some method will not work
 *             self.calendar = ''
*/
  __pyx_t_6 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u__2, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1192, __pyx_L1_error)
  if (!__pyx_t_6) {
  } else {
    __pyx_t_1 = __pyx_t_6;
    goto __pyx_L29_bool_binop_done;
  }
  __pyx_t_6 = (__pyx_v_calendar == Py_None);
  __pyx_t_1 = __pyx_t_6;
  __pyx_L29_bool_binop_done:;
  if (likely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1194
 *         elif calendar == '' or calendar is None:
 *             # instance not calendar-aware, some method will not work
 *             self.calendar = ''             # <<<<<<<<<<<<<<
 *             self.datetime_compatible = False
 *         else:
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u__2);
    __Pyx_GIVEREF(__pyx_mstate_global->__pyx_kp_u__2);
    __Pyx_GOTREF(__pyx_v_self->calendar);
    __Pyx_DECREF(__pyx_v_self->calendar);
    __pyx_v_self->calendar = __pyx_mstate_global->__pyx_kp_u__2;

    /* "cftime/_cftime.pyx":1195
 *             # instance not calendar-aware, some method will not work
 *             self.calendar = ''
 *             self.datetime_compatible = False             # <<<<<<<<<<<<<<
 *         else:
 *             raise ValueError(
*/
    __pyx_v_self->datetime_compatible = 0;

    /* "cftime/_cftime.pyx":1192
 *             self.datetime_compatible = True
 *             assert_valid_date(self, is_leap_proleptic_gregorian, False, has_year_zero=has_year_zero)
 *         elif calendar == '' or calendar is None:             # <<<<<<<<<<<<<<
 *             # instance not calendar-aware, some method will not work
 *             self.calendar = ''
*/
    goto __pyx_L21;
  }

  /* "cftime/_cftime.pyx":1197
 *             self.datetime_compatible = False
 *         else:
 *             raise ValueError(             # <<<<<<<<<<<<<<
 *                 "calendar must be one of %s, got '%s'" % (str(_calendars), calendar))
 * 
*/
  /*else*/ {
    __pyx_t_2 = NULL;

    /* "cftime/_cftime.pyx":1198
 *         else:
 *             raise ValueError(
 *                 "calendar must be one of %s, got '%s'" % (str(_calendars), calendar))             # <<<<<<<<<<<<<<
 * 
 *     @property
*/
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_calendars); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1198, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_10 = __Pyx_PyObject_Unicode(__pyx_t_7); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1198, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_7 = __Pyx_PyObject_FormatSimpleAndDecref(PyObject_Str(__pyx_v_calendar), __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1198, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_12[0] = __pyx_mstate_global->__pyx_kp_u_calendar_must_be_one_of;
    __pyx_t_12[1] = __pyx_t_10;
    __pyx_t_12[2] = __pyx_mstate_global->__pyx_kp_u_got;
    __pyx_t_12[3] = __pyx_t_7;
    __pyx_t_12[4] = __pyx_mstate_global->__pyx_kp_u__3;
    __pyx_t_9 = __Pyx_PyUnicode_Join(__pyx_t_12, 5, 24 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_10) + 7 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_7) + 1, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_10) | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_7));
    if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1198, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_4 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_9};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1197, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __Pyx_Raise(__pyx_t_3, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __PYX_ERR(0, 1197, __pyx_L1_error)
  }
  __pyx_L21:;

  /* "cftime/_cftime.pyx":1120
 *     cdef readonly bint datetime_compatible
 * 
 *     def __init__(self, int year, int month, int day, int hour=0, int minute=0,             # <<<<<<<<<<<<<<
 *                        int second=0, int microsecond=0, int dayofwk=-1,
 *                        int dayofyr = -1, calendar='standard', has_year_zero=None):
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_AddTraceback("cftime._cftime.datetime.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1200
 *                 "calendar must be one of %s, got '%s'" % (str(_calendars), calendar))
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def format(self):
 *         return '%Y-%m-%d %H:%M:%S'
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6format_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6format_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_6format___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6format___get__(CYTHON_UNUSED struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__", 0);

  /* "cftime/_cftime.pyx":1202
 *     @property
 *     def format(self):
 *         return '%Y-%m-%d %H:%M:%S'             # <<<<<<<<<<<<<<
 * 
 *     @property
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_Y_m_d_H_M_S);
  __pyx_r = __pyx_mstate_global->__pyx_kp_u_Y_m_d_H_M_S;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1200
 *                 "calendar must be one of %s, got '%s'" % (str(_calendars), calendar))
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def format(self):
 *         return '%Y-%m-%d %H:%M:%S'
*/

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

/* "cftime/_cftime.pyx":1204
 *         return '%Y-%m-%d %H:%M:%S'
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofwk(self):
 *         if self._dayofwk < 0 and self.calendar:
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7dayofwk_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7dayofwk_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_7dayofwk___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_7dayofwk___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_v_jd = NULL;
  PyObject *__pyx_v_dayofwk = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  int __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  int __pyx_t_6;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);

  /* "cftime/_cftime.pyx":1206
 *     @property
 *     def dayofwk(self):
 *         if self._dayofwk < 0 and self.calendar:             # <<<<<<<<<<<<<<
 *             jd = self.toordinal()
 *             dayofwk = (jd + 1) % 7
*/
  __pyx_t_2 = (__pyx_v_self->_dayofwk < 0);
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L4_bool_binop_done;
  }
  if (__pyx_v_self->calendar == Py_None) __pyx_t_2 = 0;
  else
  {
    Py_ssize_t __pyx_temp = __Pyx_PyUnicode_IS_TRUE(__pyx_v_self->calendar);
    if (unlikely(((!CYTHON_ASSUME_SAFE_SIZE) && __pyx_temp < 0))) __PYX_ERR(0, 1206, __pyx_L1_error)
    __pyx_t_2 = (__pyx_temp != 0);
  }

  __pyx_t_1 = __pyx_t_2;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1207
 *     def dayofwk(self):
 *         if self._dayofwk < 0 and self.calendar:
 *             jd = self.toordinal()             # <<<<<<<<<<<<<<
 *             dayofwk = (jd + 1) % 7
 *             # convert to ISO 8601 (0 = Monday, 6 = Sunday), like python datetime
*/
    __pyx_t_4 = ((PyObject *)__pyx_v_self);
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_5 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_toordinal, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1207, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_v_jd = __pyx_t_3;
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1208
 *         if self._dayofwk < 0 and self.calendar:
 *             jd = self.toordinal()
 *             dayofwk = (jd + 1) % 7             # <<<<<<<<<<<<<<
 *             # convert to ISO 8601 (0 = Monday, 6 = Sunday), like python datetime
 *             dayofwk -= 1
*/
    __pyx_t_3 = __Pyx_PyLong_AddObjC(__pyx_v_jd, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1208, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyLong_RemainderObjC(__pyx_t_3, __pyx_mstate_global->__pyx_int_7, 7, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1208, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_dayofwk = __pyx_t_4;
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1210
 *             dayofwk = (jd + 1) % 7
 *             # convert to ISO 8601 (0 = Monday, 6 = Sunday), like python datetime
 *             dayofwk -= 1             # <<<<<<<<<<<<<<
 *             if dayofwk == -1: dayofwk = 6
 *             # cache results for dayofwk
*/
    __pyx_t_4 = __Pyx_PyLong_SubtractObjC(__pyx_v_dayofwk, __pyx_mstate_global->__pyx_int_1, 1, 1, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1210, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF_SET(__pyx_v_dayofwk, __pyx_t_4);
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1211
 *             # convert to ISO 8601 (0 = Monday, 6 = Sunday), like python datetime
 *             dayofwk -= 1
 *             if dayofwk == -1: dayofwk = 6             # <<<<<<<<<<<<<<
 *             # cache results for dayofwk
 *             self._dayofwk = dayofwk
*/
    __pyx_t_1 = (__Pyx_PyLong_BoolEqObjC(__pyx_v_dayofwk, __pyx_mstate_global->__pyx_int_neg_1, -1L, 0)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1211, __pyx_L1_error)
    if (__pyx_t_1) {
      __Pyx_INCREF(__pyx_mstate_global->__pyx_int_6);
      __Pyx_DECREF_SET(__pyx_v_dayofwk, __pyx_mstate_global->__pyx_int_6);
    }

    /* "cftime/_cftime.pyx":1213
 *             if dayofwk == -1: dayofwk = 6
 *             # cache results for dayofwk
 *             self._dayofwk = dayofwk             # <<<<<<<<<<<<<<
 *             return dayofwk
 *         else:
*/
    __pyx_t_6 = __Pyx_PyLong_As_int(__pyx_v_dayofwk); if (unlikely((__pyx_t_6 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1213, __pyx_L1_error)
    __pyx_v_self->_dayofwk = __pyx_t_6;

    /* "cftime/_cftime.pyx":1214
 *             # cache results for dayofwk
 *             self._dayofwk = dayofwk
 *             return dayofwk             # <<<<<<<<<<<<<<
 *         else:
 *             return self._dayofwk
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_dayofwk);
    __pyx_r = __pyx_v_dayofwk;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1206
 *     @property
 *     def dayofwk(self):
 *         if self._dayofwk < 0 and self.calendar:             # <<<<<<<<<<<<<<
 *             jd = self.toordinal()
 *             dayofwk = (jd + 1) % 7
*/
  }

  /* "cftime/_cftime.pyx":1216
 *             return dayofwk
 *         else:
 *             return self._dayofwk             # <<<<<<<<<<<<<<
 * 
 *     @property
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofwk); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1216, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1204
 *         return '%Y-%m-%d %H:%M:%S'
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofwk(self):
 *         if self._dayofwk < 0 and self.calendar:
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.datetime.dayofwk.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_jd);
  __Pyx_XDECREF(__pyx_v_dayofwk);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1218
 *             return self._dayofwk
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7dayofyr_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7dayofyr_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_7dayofyr___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_7dayofyr___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  long __pyx_v_dayofyr;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  int __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_6;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);

  /* "cftime/_cftime.pyx":1220
 *     @property
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:             # <<<<<<<<<<<<<<
 *             if self.calendar == '360_day':
 *                 dayofyr = (self.month-1)*30+self.day
*/
  __pyx_t_2 = (__pyx_v_self->_dayofyr < 0);
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L4_bool_binop_done;
  }
  if (__pyx_v_self->calendar == Py_None) __pyx_t_2 = 0;
  else
  {
    Py_ssize_t __pyx_temp = __Pyx_PyUnicode_IS_TRUE(__pyx_v_self->calendar);
    if (unlikely(((!CYTHON_ASSUME_SAFE_SIZE) && __pyx_temp < 0))) __PYX_ERR(0, 1220, __pyx_L1_error)
    __pyx_t_2 = (__pyx_temp != 0);
  }

  __pyx_t_1 = __pyx_t_2;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1221
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:
 *             if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *                 dayofyr = (self.month-1)*30+self.day
 *             else:
*/
    __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_self->calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1221, __pyx_L1_error)
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1222
 *         if self._dayofyr < 0 and self.calendar:
 *             if self.calendar == '360_day':
 *                 dayofyr = (self.month-1)*30+self.day             # <<<<<<<<<<<<<<
 *             else:
 *                 if _is_leap(self.year,self.calendar,has_year_zero=self.has_year_zero):
*/
      __pyx_v_dayofyr = (((__pyx_v_self->month - 1) * 30) + __pyx_v_self->day);

      /* "cftime/_cftime.pyx":1221
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:
 *             if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *                 dayofyr = (self.month-1)*30+self.day
 *             else:
*/
      goto __pyx_L6;
    }

    /* "cftime/_cftime.pyx":1224
 *                 dayofyr = (self.month-1)*30+self.day
 *             else:
 *                 if _is_leap(self.year,self.calendar,has_year_zero=self.has_year_zero):             # <<<<<<<<<<<<<<
 *                     dayofyr = _cumdayspermonth_leap[self.month-1]+self.day
 *                 else:
*/
    /*else*/ {
      __pyx_t_3 = __pyx_v_self->calendar;
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_4 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1224, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_6.__pyx_n = 1;
      __pyx_t_6.has_year_zero = __pyx_t_4;
      __pyx_t_5 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_self->year, __pyx_t_3, &__pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1224, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1224, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1225
 *             else:
 *                 if _is_leap(self.year,self.calendar,has_year_zero=self.has_year_zero):
 *                     dayofyr = _cumdayspermonth_leap[self.month-1]+self.day             # <<<<<<<<<<<<<<
 *                 else:
 *                     dayofyr = _cumdayspermonth[self.month-1]+self.day
*/
        __pyx_v_dayofyr = ((__pyx_v_6cftime_7_cftime__cumdayspermonth_leap[(__pyx_v_self->month - 1)]) + __pyx_v_self->day);

        /* "cftime/_cftime.pyx":1224
 *                 dayofyr = (self.month-1)*30+self.day
 *             else:
 *                 if _is_leap(self.year,self.calendar,has_year_zero=self.has_year_zero):             # <<<<<<<<<<<<<<
 *                     dayofyr = _cumdayspermonth_leap[self.month-1]+self.day
 *                 else:
*/
        goto __pyx_L7;
      }

      /* "cftime/_cftime.pyx":1227
 *                     dayofyr = _cumdayspermonth_leap[self.month-1]+self.day
 *                 else:
 *                     dayofyr = _cumdayspermonth[self.month-1]+self.day             # <<<<<<<<<<<<<<
 *             # cache results for dayofyr
 *             self._dayofyr = dayofyr
*/
      /*else*/ {
        __pyx_v_dayofyr = ((__pyx_v_6cftime_7_cftime__cumdayspermonth[(__pyx_v_self->month - 1)]) + __pyx_v_self->day);
      }
      __pyx_L7:;
    }
    __pyx_L6:;

    /* "cftime/_cftime.pyx":1229
 *                     dayofyr = _cumdayspermonth[self.month-1]+self.day
 *             # cache results for dayofyr
 *             self._dayofyr = dayofyr             # <<<<<<<<<<<<<<
 *             return dayofyr
 *         else:
*/
    __pyx_v_self->_dayofyr = __pyx_v_dayofyr;

    /* "cftime/_cftime.pyx":1230
 *             # cache results for dayofyr
 *             self._dayofyr = dayofyr
 *             return dayofyr             # <<<<<<<<<<<<<<
 *         else:
 *             return self._dayofyr
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_5 = __Pyx_PyLong_From_long(__pyx_v_dayofyr); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1230, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1220
 *     @property
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:             # <<<<<<<<<<<<<<
 *             if self.calendar == '360_day':
 *                 dayofyr = (self.month-1)*30+self.day
*/
  }

  /* "cftime/_cftime.pyx":1232
 *             return dayofyr
 *         else:
 *             return self._dayofyr             # <<<<<<<<<<<<<<
 * 
 *     @property
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofyr); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1232, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1218
 *             return self._dayofwk
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofyr(self):
 *         if self._dayofyr < 0 and self.calendar:
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("cftime._cftime.datetime.dayofyr.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1234
 *             return self._dayofyr
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def daysinmonth(self):
 *         if self.calendar == '360_day':
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11daysinmonth_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11daysinmonth_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_11daysinmonth___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_11daysinmonth___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_5;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);

  /* "cftime/_cftime.pyx":1236
 *     @property
 *     def daysinmonth(self):
 *         if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *             return 30
 *         else:
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_self->calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1236, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1237
 *     def daysinmonth(self):
 *         if self.calendar == '360_day':
 *             return 30             # <<<<<<<<<<<<<<
 *         else:
 *             if _is_leap(self.year,self.calendar,
*/
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_mstate_global->__pyx_int_30);
    __pyx_r = __pyx_mstate_global->__pyx_int_30;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1236
 *     @property
 *     def daysinmonth(self):
 *         if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *             return 30
 *         else:
*/
  }

  /* "cftime/_cftime.pyx":1239
 *             return 30
 *         else:
 *             if _is_leap(self.year,self.calendar,             # <<<<<<<<<<<<<<
 *                     has_year_zero=self.has_year_zero):
 *                 return _dayspermonth_leap[self.month-1]
*/
  /*else*/ {
    __pyx_t_2 = __pyx_v_self->calendar;
    __Pyx_INCREF(__pyx_t_2);

    /* "cftime/_cftime.pyx":1240
 *         else:
 *             if _is_leap(self.year,self.calendar,
 *                     has_year_zero=self.has_year_zero):             # <<<<<<<<<<<<<<
 *                 return _dayspermonth_leap[self.month-1]
 *             else:
*/
    __pyx_t_3 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1240, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);

    /* "cftime/_cftime.pyx":1239
 *             return 30
 *         else:
 *             if _is_leap(self.year,self.calendar,             # <<<<<<<<<<<<<<
 *                     has_year_zero=self.has_year_zero):
 *                 return _dayspermonth_leap[self.month-1]
*/
    __pyx_t_5.__pyx_n = 1;
    __pyx_t_5.has_year_zero = __pyx_t_3;
    __pyx_t_4 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_self->year, __pyx_t_2, &__pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1239, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1239, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1241
 *             if _is_leap(self.year,self.calendar,
 *                     has_year_zero=self.has_year_zero):
 *                 return _dayspermonth_leap[self.month-1]             # <<<<<<<<<<<<<<
 *             else:
 *                 return _dayspermonth[self.month-1]
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_4 = __Pyx_PyLong_From_int((__pyx_v_6cftime_7_cftime__dayspermonth_leap[(__pyx_v_self->month - 1)])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1241, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_r = __pyx_t_4;
      __pyx_t_4 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":1239
 *             return 30
 *         else:
 *             if _is_leap(self.year,self.calendar,             # <<<<<<<<<<<<<<
 *                     has_year_zero=self.has_year_zero):
 *                 return _dayspermonth_leap[self.month-1]
*/
    }

    /* "cftime/_cftime.pyx":1243
 *                 return _dayspermonth_leap[self.month-1]
 *             else:
 *                 return _dayspermonth[self.month-1]             # <<<<<<<<<<<<<<
 * 
 *     def strftime(self, format=None):
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_4 = __Pyx_PyLong_From_int((__pyx_v_6cftime_7_cftime__dayspermonth[(__pyx_v_self->month - 1)])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1243, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_r = __pyx_t_4;
      __pyx_t_4 = 0;
      goto __pyx_L0;
    }
  }

  /* "cftime/_cftime.pyx":1234
 *             return self._dayofyr
 * 
 *     @property             # <<<<<<<<<<<<<<
 *     def daysinmonth(self):
 *         if self.calendar == '360_day':
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.datetime.daysinmonth.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1245
 *                 return _dayspermonth[self.month-1]
 * 
 *     def strftime(self, format=None):             # <<<<<<<<<<<<<<
 *         """
 *         Return a string representing the date, controlled by an explicit format
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_3strftime(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_2strftime, "datetime.strftime(self, format=None)\n\nReturn a string representing the date, controlled by an explicit format\nstring. For a complete list of formatting directives, see section\n'strftime() and strptime() Behavior' in the base Python documentation.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_3strftime = {"strftime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_3strftime, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_2strftime};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_3strftime(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_format = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("strftime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_format,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1245, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1245, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "strftime", 0) < (0)) __PYX_ERR(0, 1245, __pyx_L3_error)
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)Py_None));
    } else {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1245, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_format = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("strftime", 0, 0, 1, __pyx_nargs); __PYX_ERR(0, 1245, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.strftime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_2strftime(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_format);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_2strftime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_format) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("strftime", 0);
  __Pyx_INCREF(__pyx_v_format);

  /* "cftime/_cftime.pyx":1251
 *         'strftime() and strptime() Behavior' in the base Python documentation.
 *         """
 *         if format is None:             # <<<<<<<<<<<<<<
 *             format = self.format
 *         return _strftime(self, format)
*/
  __pyx_t_1 = (__pyx_v_format == Py_None);
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1252
 *         """
 *         if format is None:
 *             format = self.format             # <<<<<<<<<<<<<<
 *         return _strftime(self, format)
 * 
*/
    __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_format); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1252, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF_SET(__pyx_v_format, __pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1251
 *         'strftime() and strptime() Behavior' in the base Python documentation.
 *         """
 *         if format is None:             # <<<<<<<<<<<<<<
 *             format = self.format
 *         return _strftime(self, format)
*/
  }

  /* "cftime/_cftime.pyx":1253
 *         if format is None:
 *             format = self.format
 *         return _strftime(self, format)             # <<<<<<<<<<<<<<
 * 
 *     @staticmethod
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__strftime(__pyx_v_self, __pyx_v_format); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1253, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1245
 *                 return _dayspermonth[self.month-1]
 * 
 *     def strftime(self, format=None):             # <<<<<<<<<<<<<<
 *         """
 *         Return a string representing the date, controlled by an explicit format
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.datetime.strftime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_format);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_5strptime(CYTHON_UNUSED PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_4strptime, "datetime.strptime(datestring, format, calendar='standard', has_year_zero=None)\n\nReturn a datetime corresponding to date_string, parsed according to format,\nwith a specified calendar and year zero convention.\nThe format directives 'y','Y','m','B','b','d','H','M','S' and 'f'\nare supported for all calendars and dates.  If the date is valid\nin the python 'proleptic_gregorian' calendar, then python's\ndatetime.strptime is used. For a complete list of formatting directives\nsupported in python's datetime.strptime, see section\n'strftime() and strptime() Behavior' in the base Python documentation.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_5strptime = {"strptime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_5strptime, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_4strptime};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_5strptime(CYTHON_UNUSED PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_datestring = 0;
  PyObject *__pyx_v_format = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[4] = {0,0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("strptime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_datestring,&__pyx_mstate_global->__pyx_n_u_format,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1255, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "strptime", 0) < (0)) __PYX_ERR(0, 1255, __pyx_L3_error)
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));

      /* "cftime/_cftime.pyx":1256
 * 
 *     @staticmethod
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):             # <<<<<<<<<<<<<<
 *         """
 *         Return a datetime corresponding to date_string, parsed according to format,
*/
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("strptime", 0, 2, 4, i); __PYX_ERR(0, 1255, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  4:
        values[3] = __Pyx_ArgRef_FASTCALL(__pyx_args, 3);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1255, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1255, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1255, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));
      if (!values[3]) values[3] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_datestring = values[0];
    __pyx_v_format = values[1];
    __pyx_v_calendar = values[2];
    __pyx_v_has_year_zero = values[3];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("strptime", 0, 2, 4, __pyx_nargs); __PYX_ERR(0, 1255, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.strptime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_4strptime(__pyx_v_datestring, __pyx_v_format, __pyx_v_calendar, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
static PyObject *__pyx_gb_6cftime_7_cftime_8datetime_8strptime_2generator(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value); /* proto */

/* "cftime/_cftime.pyx":1282
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):             # <<<<<<<<<<<<<<
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
 *                 raise KeyError(msg)
*/

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8strptime_genexpr(PyObject *__pyx_self, PyObject *__pyx_genexpr_arg_0) {
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *__pyx_cur_scope;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("genexpr", 0);
  __pyx_cur_scope = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct_1_genexpr(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr, __pyx_mstate_global->__pyx_empty_tuple, NULL);
  if (unlikely(!__pyx_cur_scope)) {
    __pyx_cur_scope = ((struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)Py_None);
    __Pyx_INCREF(Py_None);
    __PYX_ERR(0, 1282, __pyx_L1_error)
  } else {
    __Pyx_GOTREF((PyObject *)__pyx_cur_scope);
  }
  __pyx_cur_scope->__pyx_outer_scope = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *) __pyx_self;
  __Pyx_INCREF((PyObject *)__pyx_cur_scope->__pyx_outer_scope);
  __Pyx_GIVEREF((PyObject *)__pyx_cur_scope->__pyx_outer_scope);
  __pyx_cur_scope->__pyx_genexpr_arg_0 = __pyx_genexpr_arg_0;
  __Pyx_INCREF(__pyx_cur_scope->__pyx_genexpr_arg_0);
  __Pyx_GIVEREF(__pyx_cur_scope->__pyx_genexpr_arg_0);
  {
    __pyx_CoroutineObject *gen = __Pyx_Generator_New((__pyx_coroutine_body_t) __pyx_gb_6cftime_7_cftime_8datetime_8strptime_2generator, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[0]), (PyObject *) __pyx_cur_scope, __pyx_mstate_global->__pyx_n_u_genexpr, __pyx_mstate_global->__pyx_n_u_strptime_locals_genexpr, __pyx_mstate_global->__pyx_n_u_cftime__cftime); if (unlikely(!gen)) __PYX_ERR(0, 1282, __pyx_L1_error)
    __Pyx_DECREF(__pyx_cur_scope);
    __Pyx_RefNannyFinishContext();
    return (PyObject *) gen;
  }

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_AddTraceback("cftime._cftime.datetime.strptime.genexpr", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __Pyx_DECREF((PyObject *)__pyx_cur_scope);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_gb_6cftime_7_cftime_8datetime_8strptime_2generator(__pyx_CoroutineObject *__pyx_generator, CYTHON_UNUSED PyThreadState *__pyx_tstate, PyObject *__pyx_sent_value) /* generator body */
{
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *__pyx_cur_scope = ((struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)__pyx_generator->closure);
  PyObject *__pyx_r = NULL;
  PyObject *__pyx_t_1 = NULL;
  Py_ssize_t __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  int __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("genexpr", 0);
  switch (__pyx_generator->resume_label) {
    case 0: goto __pyx_L3_first_run;
    default: /* CPython raises the right error here */
    __Pyx_RefNannyFinishContext();
    return NULL;
  }
  __pyx_L3_first_run:;
  if (unlikely(!__pyx_sent_value)) __PYX_ERR(0, 1282, __pyx_L1_error)
  if (unlikely(!__pyx_cur_scope->__pyx_genexpr_arg_0)) { __Pyx_RaiseUnboundLocalError(".0"); __PYX_ERR(0, 1282, __pyx_L1_error) }
  __pyx_t_1 = __pyx_cur_scope->__pyx_genexpr_arg_0; __Pyx_INCREF(__pyx_t_1);
  __pyx_t_2 = 0;
  for (;;) {
    {
      Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_1);
      #if !CYTHON_ASSUME_SAFE_SIZE
      if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1282, __pyx_L1_error)
      #endif
      if (__pyx_t_2 >= __pyx_temp) break;
    }
    __pyx_t_3 = __Pyx_PyList_GetItemRefFast(__pyx_t_1, __pyx_t_2, __Pyx_ReferenceSharing_OwnStrongReference);
    ++__pyx_t_2;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1282, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_XGOTREF(__pyx_cur_scope->__pyx_v_x);
    __Pyx_XDECREF_SET(__pyx_cur_scope->__pyx_v_x, __pyx_t_3);
    __Pyx_GIVEREF(__pyx_t_3);
    __pyx_t_3 = 0;
    if (unlikely(!__pyx_cur_scope->__pyx_outer_scope->__pyx_v_special_fd)) { __Pyx_RaiseClosureNameError("special_fd"); __PYX_ERR(0, 1282, __pyx_L1_error) }
    __pyx_t_4 = (__Pyx_PySequence_ContainsTF(__pyx_cur_scope->__pyx_v_x, __pyx_cur_scope->__pyx_outer_scope->__pyx_v_special_fd, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1282, __pyx_L1_error)
    if (__pyx_t_4) {
      __Pyx_XDECREF(__pyx_r);
      __Pyx_INCREF(Py_True);
      __pyx_r = Py_True;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      goto __pyx_L0;
    }
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(Py_False);
    __pyx_r = Py_False;
    goto __pyx_L0;
  }
  CYTHON_MAYBE_UNUSED_VAR(__pyx_cur_scope);

  /* function exit code */
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_3);
  if (__Pyx_PyErr_Occurred()) {
    __Pyx_Generator_Replace_StopIteration(0);
    __Pyx_AddTraceback("genexpr", __pyx_clineno, __pyx_lineno, __pyx_filename);
  }
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  #if !CYTHON_USE_EXC_INFO_STACK
  __Pyx_Coroutine_ResetAndClearException(__pyx_generator);
  #endif
  __pyx_generator->resume_label = -1;
  __Pyx_Coroutine_clear((PyObject*)__pyx_generator);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4strptime(PyObject *__pyx_v_datestring, PyObject *__pyx_v_format, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *__pyx_cur_scope;
  PyObject *__pyx_v_fd = NULL;
  PyObject *__pyx_v_pydatetime = NULL;
  PyObject *__pyx_v_compatible_date = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_v_year = NULL;
  PyObject *__pyx_v_month = NULL;
  PyObject *__pyx_v_day = NULL;
  PyObject *__pyx_v_hour = NULL;
  PyObject *__pyx_v_minute = NULL;
  PyObject *__pyx_v_second = NULL;
  PyObject *__pyx_v_microsecond = NULL;
  PyObject *__pyx_8genexpr4__pyx_v_d = NULL;
  PyObject *__pyx_gb_6cftime_7_cftime_8datetime_8strptime_2generator = 0;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  Py_ssize_t __pyx_t_5;
  PyObject *(*__pyx_t_6)(PyObject *);
  int __pyx_t_7;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  int __pyx_t_12;
  int __pyx_t_13;
  PyObject *__pyx_t_14 = NULL;
  PyObject *__pyx_t_15 = NULL;
  PyObject *__pyx_t_16 = NULL;
  PyObject *__pyx_t_17 = NULL;
  PyObject *__pyx_t_18 = NULL;
  PyObject *__pyx_t_19 = NULL;
  int __pyx_t_20;
  PyObject *__pyx_t_21 = NULL;
  PyObject *__pyx_t_22 = NULL;
  PyObject *(*__pyx_t_23)(PyObject *);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("strptime", 0);
  __pyx_cur_scope = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct__strptime(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime, __pyx_mstate_global->__pyx_empty_tuple, NULL);
  if (unlikely(!__pyx_cur_scope)) {
    __pyx_cur_scope = ((struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)Py_None);
    __Pyx_INCREF(Py_None);
    __PYX_ERR(0, 1255, __pyx_L1_error)
  } else {
    __Pyx_GOTREF((PyObject *)__pyx_cur_scope);
  }

  /* "cftime/_cftime.pyx":1269
 *         # if possible use python's datetime.strptime to get a python datetime instance
 *         # (works for dates in proleptic_gregorian calendar)
 *         fd = [d[0] for d in format.split('%') if d] # extract format descriptors             # <<<<<<<<<<<<<<
 *         # calendar specific format descriptors that won't work will all calendars
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']
*/
  { /* enter inner scope */
    __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1269, __pyx_L5_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_3 = __pyx_v_format;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_4 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u__4};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_split, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1269, __pyx_L5_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    if (likely(PyList_CheckExact(__pyx_t_2)) || PyTuple_CheckExact(__pyx_t_2)) {
      __pyx_t_3 = __pyx_t_2; __Pyx_INCREF(__pyx_t_3);
      __pyx_t_5 = 0;
      __pyx_t_6 = NULL;
    } else {
      __pyx_t_5 = -1; __pyx_t_3 = PyObject_GetIter(__pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1269, __pyx_L5_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_6 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1269, __pyx_L5_error)
    }
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    for (;;) {
      if (likely(!__pyx_t_6)) {
        if (likely(PyList_CheckExact(__pyx_t_3))) {
          {
            Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_3);
            #if !CYTHON_ASSUME_SAFE_SIZE
            if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1269, __pyx_L5_error)
            #endif
            if (__pyx_t_5 >= __pyx_temp) break;
          }
          __pyx_t_2 = __Pyx_PyList_GetItemRefFast(__pyx_t_3, __pyx_t_5, __Pyx_ReferenceSharing_OwnStrongReference);
          ++__pyx_t_5;
        } else {
          {
            Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_3);
            #if !CYTHON_ASSUME_SAFE_SIZE
            if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1269, __pyx_L5_error)
            #endif
            if (__pyx_t_5 >= __pyx_temp) break;
          }
          #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
          __pyx_t_2 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_3, __pyx_t_5));
          #else
          __pyx_t_2 = __Pyx_PySequence_ITEM(__pyx_t_3, __pyx_t_5);
          #endif
          ++__pyx_t_5;
        }
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1269, __pyx_L5_error)
      } else {
        __pyx_t_2 = __pyx_t_6(__pyx_t_3);
        if (unlikely(!__pyx_t_2)) {
          PyObject* exc_type = PyErr_Occurred();
          if (exc_type) {
            if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 1269, __pyx_L5_error)
            PyErr_Clear();
          }
          break;
        }
      }
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_XDECREF_SET(__pyx_8genexpr4__pyx_v_d, __pyx_t_2);
      __pyx_t_2 = 0;
      __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_8genexpr4__pyx_v_d); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1269, __pyx_L5_error)
      if (__pyx_t_7) {
        __pyx_t_2 = __Pyx_GetItemInt(__pyx_8genexpr4__pyx_v_d, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1, __Pyx_ReferenceSharing_SharedReference); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1269, __pyx_L5_error)
        __Pyx_GOTREF(__pyx_t_2);
        if (unlikely(__Pyx_ListComp_Append(__pyx_t_1, (PyObject*)__pyx_t_2))) __PYX_ERR(0, 1269, __pyx_L5_error)
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      }
    }
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_XDECREF(__pyx_8genexpr4__pyx_v_d); __pyx_8genexpr4__pyx_v_d = 0;
    goto __pyx_L10_exit_scope;
    __pyx_L5_error:;
    __Pyx_XDECREF(__pyx_8genexpr4__pyx_v_d); __pyx_8genexpr4__pyx_v_d = 0;
    goto __pyx_L1_error;
    __pyx_L10_exit_scope:;
  } /* exit inner scope */
  __pyx_v_fd = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1271
 *         fd = [d[0] for d in format.split('%') if d] # extract format descriptors
 *         # calendar specific format descriptors that won't work will all calendars
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']             # <<<<<<<<<<<<<<
 *         try:
 *             pydatetime = datetime_python.strptime(datestring, format)
*/
  __pyx_t_1 = PyList_New(9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1271, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_a);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_a);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 0, __pyx_mstate_global->__pyx_n_u_a) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_A);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_A);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 1, __pyx_mstate_global->__pyx_n_u_A) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_w);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_w);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 2, __pyx_mstate_global->__pyx_n_u_w) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_j);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_j);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 3, __pyx_mstate_global->__pyx_n_u_j) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_U);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_U);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 4, __pyx_mstate_global->__pyx_n_u_U) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_W);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_W);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 5, __pyx_mstate_global->__pyx_n_u_W) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_G);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_G);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 6, __pyx_mstate_global->__pyx_n_u_G) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_u);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_u);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 7, __pyx_mstate_global->__pyx_n_u_u) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_V);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_n_u_V);
  if (__Pyx_PyList_SET_ITEM(__pyx_t_1, 8, __pyx_mstate_global->__pyx_n_u_V) != (0)) __PYX_ERR(0, 1271, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_1);
  __pyx_cur_scope->__pyx_v_special_fd = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1272
 *         # calendar specific format descriptors that won't work will all calendars
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']
 *         try:             # <<<<<<<<<<<<<<
 *             pydatetime = datetime_python.strptime(datestring, format)
 *             # remove time zone offset
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_8, &__pyx_t_9, &__pyx_t_10);
    __Pyx_XGOTREF(__pyx_t_8);
    __Pyx_XGOTREF(__pyx_t_9);
    __Pyx_XGOTREF(__pyx_t_10);
    /*try:*/ {

      /* "cftime/_cftime.pyx":1273
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']
 *         try:
 *             pydatetime = datetime_python.strptime(datestring, format)             # <<<<<<<<<<<<<<
 *             # remove time zone offset
 *             if getattr(pydatetime, 'tzinfo',None) is not None:
*/
      __pyx_t_3 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1273, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_strptime); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1273, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_11);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_4 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_11))) {
        __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_11);
        assert(__pyx_t_3);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
        __Pyx_INCREF(__pyx_t_3);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
        __pyx_t_4 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_3, __pyx_v_datestring, __pyx_v_format};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1273, __pyx_L11_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __pyx_v_pydatetime = __pyx_t_1;
      __pyx_t_1 = 0;

      /* "cftime/_cftime.pyx":1275
 *             pydatetime = datetime_python.strptime(datestring, format)
 *             # remove time zone offset
 *             if getattr(pydatetime, 'tzinfo',None) is not None:             # <<<<<<<<<<<<<<
 *                  pydatetime = pydatetime.replace(tzinfo=None) - pydatetime.utcoffset()
 *             compatible_date =\
*/
      __pyx_t_1 = __Pyx_GetAttr3(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_tzinfo, Py_None); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1275, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_7 = (__pyx_t_1 != Py_None);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (__pyx_t_7) {

        /* "cftime/_cftime.pyx":1276
 *             # remove time zone offset
 *             if getattr(pydatetime, 'tzinfo',None) is not None:
 *                  pydatetime = pydatetime.replace(tzinfo=None) - pydatetime.utcoffset()             # <<<<<<<<<<<<<<
 *             compatible_date =\
 *             calendar == 'proleptic_gregorian' or \
*/
        __pyx_t_11 = __pyx_v_pydatetime;
        __Pyx_INCREF(__pyx_t_11);
        __pyx_t_4 = 0;
        {
          PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_11, NULL};
          __pyx_t_3 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1276, __pyx_L11_error)
          __Pyx_GOTREF(__pyx_t_3);
          if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_tzinfo, Py_None, __pyx_t_3, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 1276, __pyx_L11_error)
          __pyx_t_1 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_replace, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_3);
          __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
          __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1276, __pyx_L11_error)
          __Pyx_GOTREF(__pyx_t_1);
        }
        __pyx_t_11 = __pyx_v_pydatetime;
        __Pyx_INCREF(__pyx_t_11);
        __pyx_t_4 = 0;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_11, NULL};
          __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_utcoffset, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
          if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1276, __pyx_L11_error)
          __Pyx_GOTREF(__pyx_t_3);
        }
        __pyx_t_11 = PyNumber_Subtract(__pyx_t_1, __pyx_t_3); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1276, __pyx_L11_error)
        __Pyx_GOTREF(__pyx_t_11);
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        __Pyx_DECREF_SET(__pyx_v_pydatetime, __pyx_t_11);
        __pyx_t_11 = 0;

        /* "cftime/_cftime.pyx":1275
 *             pydatetime = datetime_python.strptime(datestring, format)
 *             # remove time zone offset
 *             if getattr(pydatetime, 'tzinfo',None) is not None:             # <<<<<<<<<<<<<<
 *                  pydatetime = pydatetime.replace(tzinfo=None) - pydatetime.utcoffset()
 *             compatible_date =\
*/
      }

      /* "cftime/_cftime.pyx":1278
 *                  pydatetime = pydatetime.replace(tzinfo=None) - pydatetime.utcoffset()
 *             compatible_date =\
 *             calendar == 'proleptic_gregorian' or \             # <<<<<<<<<<<<<<
 *             (calendar in ['gregorian','standard'] and (pydatetime.year > 1582 or \
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
*/
      __pyx_t_3 = PyObject_RichCompare(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1278, __pyx_L11_error)
      __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1278, __pyx_L11_error)
      if (!__pyx_t_7) {
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      } else {
        __Pyx_INCREF(__pyx_t_3);
        __pyx_t_11 = __pyx_t_3;
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        goto __pyx_L18_bool_binop_done;
      }

      /* "cftime/_cftime.pyx":1279
 *             compatible_date =\
 *             calendar == 'proleptic_gregorian' or \
 *             (calendar in ['gregorian','standard'] and (pydatetime.year > 1582 or \             # <<<<<<<<<<<<<<
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
*/
      __Pyx_INCREF(__pyx_v_calendar);
      __pyx_t_3 = __pyx_v_calendar;
      __pyx_t_12 = (__Pyx_PyUnicode_Equals(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1279, __pyx_L11_error)
      if (!__pyx_t_12) {
      } else {
        __pyx_t_7 = __pyx_t_12;
        goto __pyx_L21_bool_binop_done;
      }
      __pyx_t_12 = (__Pyx_PyUnicode_Equals(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1279, __pyx_L11_error)
      __pyx_t_7 = __pyx_t_12;
      __pyx_L21_bool_binop_done:;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_12 = __pyx_t_7;
      if (__pyx_t_12) {
      } else {
        __pyx_t_3 = __Pyx_PyBool_FromLong(__pyx_t_12); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1279, __pyx_L11_error)
        __Pyx_GOTREF(__pyx_t_3);
        __pyx_t_11 = __pyx_t_3;
        __pyx_t_3 = 0;
        goto __pyx_L18_bool_binop_done;
      }
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1279, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_1 = PyObject_RichCompare(__pyx_t_3, __pyx_mstate_global->__pyx_int_1582, Py_GT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1279, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1279, __pyx_L11_error)
      if (!__pyx_t_12) {
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      } else {
        __Pyx_INCREF(__pyx_t_1);
        __pyx_t_11 = __pyx_t_1;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        goto __pyx_L18_bool_binop_done;
      }

      /* "cftime/_cftime.pyx":1280
 *             calendar == 'proleptic_gregorian' or \
 *             (calendar in ['gregorian','standard'] and (pydatetime.year > 1582 or \
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \             # <<<<<<<<<<<<<<
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):
*/
      __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1280, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyLong_EqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_1582, 0x62E, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1280, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1280, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (!__pyx_t_12) {
        goto __pyx_L24_next_or;
      } else {
      }
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1280, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_1 = PyObject_RichCompare(__pyx_t_3, __pyx_mstate_global->__pyx_int_10, Py_GT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1280, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1280, __pyx_L11_error)
      if (!__pyx_t_12) {
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      } else {
        __Pyx_INCREF(__pyx_t_1);
        __pyx_t_11 = __pyx_t_1;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        goto __pyx_L18_bool_binop_done;
      }
      __pyx_L24_next_or:;

      /* "cftime/_cftime.pyx":1281
 *             (calendar in ['gregorian','standard'] and (pydatetime.year > 1582 or \
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))             # <<<<<<<<<<<<<<
 *             if not compatible_date and any(x in special_fd for x in fd):
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
*/
      __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = __Pyx_PyLong_EqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_1582, 0x62E, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1281, __pyx_L11_error)
      if (__pyx_t_12) {
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      } else {
        __Pyx_INCREF(__pyx_t_3);
        __pyx_t_11 = __pyx_t_3;
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        goto __pyx_L18_bool_binop_done;
      }
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_1 = __Pyx_PyLong_EqObjC(__pyx_t_3, __pyx_mstate_global->__pyx_int_10, 10, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_12 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_12 < 0))) __PYX_ERR(0, 1281, __pyx_L11_error)
      if (__pyx_t_12) {
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      } else {
        __Pyx_INCREF(__pyx_t_1);
        __pyx_t_11 = __pyx_t_1;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        goto __pyx_L18_bool_binop_done;
      }
      __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_3 = PyObject_RichCompare(__pyx_t_1, __pyx_mstate_global->__pyx_int_15, Py_GT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1281, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_11 = __pyx_t_3;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_L18_bool_binop_done:;
      __pyx_v_compatible_date = __pyx_t_11;
      __pyx_t_11 = 0;

      /* "cftime/_cftime.pyx":1282
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):             # <<<<<<<<<<<<<<
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
 *                 raise KeyError(msg)
*/
      __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_compatible_date); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1282, __pyx_L11_error)
      __pyx_t_13 = (!__pyx_t_7);
      if (__pyx_t_13) {
      } else {
        __pyx_t_12 = __pyx_t_13;
        goto __pyx_L29_bool_binop_done;
      }
      __pyx_t_11 = __pyx_pf_6cftime_7_cftime_8datetime_8strptime_genexpr(((PyObject*)__pyx_cur_scope), __pyx_v_fd); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1282, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_11);
      __pyx_t_3 = __Pyx_Generator_GetInlinedResult(__pyx_t_11); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1282, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __pyx_t_13 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 1282, __pyx_L11_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_12 = __pyx_t_13;
      __pyx_L29_bool_binop_done:;
      if (unlikely(__pyx_t_12)) {

        /* "cftime/_cftime.pyx":1283
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'             # <<<<<<<<<<<<<<
 *                 raise KeyError(msg)
 *             # convert the cftime datetime instance
*/
        __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_one_of_the_supplied_format_direc);
        __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_one_of_the_supplied_format_direc;

        /* "cftime/_cftime.pyx":1284
 *             if not compatible_date and any(x in special_fd for x in fd):
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
 *                 raise KeyError(msg)             # <<<<<<<<<<<<<<
 *             # convert the cftime datetime instance
 *             return datetime(pydatetime.year, pydatetime.month, pydatetime.day,
*/
        __pyx_t_11 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_v_msg};
          __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_KeyError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
          if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1284, __pyx_L11_error)
          __Pyx_GOTREF(__pyx_t_3);
        }
        __Pyx_Raise(__pyx_t_3, 0, 0, 0);
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        __PYX_ERR(0, 1284, __pyx_L11_error)

        /* "cftime/_cftime.pyx":1282
 *              (pydatetime.year == 1582 and pydatetime.month > 10) or \
 *              (pydatetime.year == 1582 and pydatetime.month == 10 and pydatetime.day > 15)))
 *             if not compatible_date and any(x in special_fd for x in fd):             # <<<<<<<<<<<<<<
 *                 msg='one of the supplied format directives may not be consistent with the chosen calendar'
 *                 raise KeyError(msg)
*/
      }

      /* "cftime/_cftime.pyx":1286
 *                 raise KeyError(msg)
 *             # convert the cftime datetime instance
 *             return datetime(pydatetime.year, pydatetime.month, pydatetime.day,             # <<<<<<<<<<<<<<
 *                             pydatetime.hour, pydatetime.minute, pydatetime.second,
 *                             pydatetime.microsecond, calendar=calendar, has_year_zero=has_year_zero)
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_11 = NULL;
      __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1286, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_month); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1286, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_day); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 1286, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_14);

      /* "cftime/_cftime.pyx":1287
 *             # convert the cftime datetime instance
 *             return datetime(pydatetime.year, pydatetime.month, pydatetime.day,
 *                             pydatetime.hour, pydatetime.minute, pydatetime.second,             # <<<<<<<<<<<<<<
 *                             pydatetime.microsecond, calendar=calendar, has_year_zero=has_year_zero)
 *         # otherwise use a stripped-down version of C-python's _strptime.py
*/
      __pyx_t_15 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1287, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_15);
      __pyx_t_16 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 1287, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_16);
      __pyx_t_17 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1287, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_17);

      /* "cftime/_cftime.pyx":1288
 *             return datetime(pydatetime.year, pydatetime.month, pydatetime.day,
 *                             pydatetime.hour, pydatetime.minute, pydatetime.second,
 *                             pydatetime.microsecond, calendar=calendar, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         # otherwise use a stripped-down version of C-python's _strptime.py
 *         # (doesn't understand all possible formats, just
*/
      __pyx_t_18 = __Pyx_PyObject_GetAttrStr(__pyx_v_pydatetime, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_18)) __PYX_ERR(0, 1288, __pyx_L11_error)
      __Pyx_GOTREF(__pyx_t_18);
      __pyx_t_4 = 1;
      {
        PyObject *__pyx_callargs[8 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_11, __pyx_t_1, __pyx_t_2, __pyx_t_14, __pyx_t_15, __pyx_t_16, __pyx_t_17, __pyx_t_18};
        __pyx_t_19 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_19)) __PYX_ERR(0, 1286, __pyx_L11_error)
        __Pyx_GOTREF(__pyx_t_19);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_19, __pyx_callargs+8, 0) < (0)) __PYX_ERR(0, 1286, __pyx_L11_error)
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_19, __pyx_callargs+8, 1) < (0)) __PYX_ERR(0, 1286, __pyx_L11_error)
        __pyx_t_3 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_callargs+__pyx_t_4, (8-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_19);
        __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
        __Pyx_DECREF(__pyx_t_16); __pyx_t_16 = 0;
        __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
        __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
        __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
        if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1286, __pyx_L11_error)
        __Pyx_GOTREF((PyObject *)__pyx_t_3);
      }
      __pyx_r = ((PyObject *)__pyx_t_3);
      __pyx_t_3 = 0;
      goto __pyx_L15_try_return;

      /* "cftime/_cftime.pyx":1272
 *         # calendar specific format descriptors that won't work will all calendars
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']
 *         try:             # <<<<<<<<<<<<<<
 *             pydatetime = datetime_python.strptime(datestring, format)
 *             # remove time zone offset
*/
    }
    __pyx_L11_error:;
    __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0;
    __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
    __Pyx_XDECREF(__pyx_t_17); __pyx_t_17 = 0;
    __Pyx_XDECREF(__pyx_t_18); __pyx_t_18 = 0;
    __Pyx_XDECREF(__pyx_t_19); __pyx_t_19 = 0;
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1292
 *         # (doesn't understand all possible formats, just
 *         # 'y','Y','m','B','b','d','H','M','S' and 'f')
 *         except ValueError:             # <<<<<<<<<<<<<<
 *             year,month,day,hour,minute,second,microsecond = _strptime(datestring,format)
 *             return datetime(year,month,day,hour,minute,second,microsecond,
*/
    __pyx_t_20 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_ValueError))));
    if (__pyx_t_20) {
      __Pyx_AddTraceback("cftime._cftime.datetime.strptime", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_3, &__pyx_t_19, &__pyx_t_18) < 0) __PYX_ERR(0, 1292, __pyx_L13_except_error)
      __Pyx_XGOTREF(__pyx_t_3);
      __Pyx_XGOTREF(__pyx_t_19);
      __Pyx_XGOTREF(__pyx_t_18);

      /* "cftime/_cftime.pyx":1293
 *         # 'y','Y','m','B','b','d','H','M','S' and 'f')
 *         except ValueError:
 *             year,month,day,hour,minute,second,microsecond = _strptime(datestring,format)             # <<<<<<<<<<<<<<
 *             return datetime(year,month,day,hour,minute,second,microsecond,
 *                             calendar=calendar,has_year_zero=has_year_zero)
*/
      __pyx_t_16 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_15, __pyx_mstate_global->__pyx_n_u_strptime_2); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
      __Pyx_GOTREF(__pyx_t_15);
      __pyx_t_4 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_15))) {
        __pyx_t_16 = PyMethod_GET_SELF(__pyx_t_15);
        assert(__pyx_t_16);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_15);
        __Pyx_INCREF(__pyx_t_16);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_15, __pyx__function);
        __pyx_t_4 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_16, __pyx_v_datestring, __pyx_v_format};
        __pyx_t_17 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_15, __pyx_callargs+__pyx_t_4, (3-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0;
        __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0;
        if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
        __Pyx_GOTREF(__pyx_t_17);
      }
      if ((likely(PyTuple_CheckExact(__pyx_t_17))) || (PyList_CheckExact(__pyx_t_17))) {
        PyObject* sequence = __pyx_t_17;
        Py_ssize_t size = __Pyx_PySequence_SIZE(sequence);
        if (unlikely(size != 7)) {
          if (size > 7) __Pyx_RaiseTooManyValuesError(7);
          else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size);
          __PYX_ERR(0, 1293, __pyx_L13_except_error)
        }
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        if (likely(PyTuple_CheckExact(sequence))) {
          __pyx_t_15 = PyTuple_GET_ITEM(sequence, 0);
          __Pyx_INCREF(__pyx_t_15);
          __pyx_t_16 = PyTuple_GET_ITEM(sequence, 1);
          __Pyx_INCREF(__pyx_t_16);
          __pyx_t_14 = PyTuple_GET_ITEM(sequence, 2);
          __Pyx_INCREF(__pyx_t_14);
          __pyx_t_2 = PyTuple_GET_ITEM(sequence, 3);
          __Pyx_INCREF(__pyx_t_2);
          __pyx_t_1 = PyTuple_GET_ITEM(sequence, 4);
          __Pyx_INCREF(__pyx_t_1);
          __pyx_t_11 = PyTuple_GET_ITEM(sequence, 5);
          __Pyx_INCREF(__pyx_t_11);
          __pyx_t_21 = PyTuple_GET_ITEM(sequence, 6);
          __Pyx_INCREF(__pyx_t_21);
        } else {
          __pyx_t_15 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_15);
          __pyx_t_16 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_16)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_16);
          __pyx_t_14 = __Pyx_PyList_GetItemRefFast(sequence, 2, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_14);
          __pyx_t_2 = __Pyx_PyList_GetItemRefFast(sequence, 3, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_2);
          __pyx_t_1 = __Pyx_PyList_GetItemRefFast(sequence, 4, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_1);
          __pyx_t_11 = __Pyx_PyList_GetItemRefFast(sequence, 5, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_11);
          __pyx_t_21 = __Pyx_PyList_GetItemRefFast(sequence, 6, __Pyx_ReferenceSharing_SharedReference);
          if (unlikely(!__pyx_t_21)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
          __Pyx_XGOTREF(__pyx_t_21);
        }
        #else
        {
          Py_ssize_t i;
          PyObject** temps[7] = {&__pyx_t_15,&__pyx_t_16,&__pyx_t_14,&__pyx_t_2,&__pyx_t_1,&__pyx_t_11,&__pyx_t_21};
          for (i=0; i < 7; i++) {
            PyObject* item = __Pyx_PySequence_ITEM(sequence, i); if (unlikely(!item)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
            __Pyx_GOTREF(item);
            *(temps[i]) = item;
          }
        }
        #endif
        __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
      } else {
        Py_ssize_t index = -1;
        PyObject** temps[7] = {&__pyx_t_15,&__pyx_t_16,&__pyx_t_14,&__pyx_t_2,&__pyx_t_1,&__pyx_t_11,&__pyx_t_21};
        __pyx_t_22 = PyObject_GetIter(__pyx_t_17); if (unlikely(!__pyx_t_22)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
        __Pyx_GOTREF(__pyx_t_22);
        __Pyx_DECREF(__pyx_t_17); __pyx_t_17 = 0;
        __pyx_t_23 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_22);
        for (index=0; index < 7; index++) {
          PyObject* item = __pyx_t_23(__pyx_t_22); if (unlikely(!item)) goto __pyx_L33_unpacking_failed;
          __Pyx_GOTREF(item);
          *(temps[index]) = item;
        }
        if (__Pyx_IternextUnpackEndCheck(__pyx_t_23(__pyx_t_22), 7) < (0)) __PYX_ERR(0, 1293, __pyx_L13_except_error)
        __pyx_t_23 = NULL;
        __Pyx_DECREF(__pyx_t_22); __pyx_t_22 = 0;
        goto __pyx_L34_unpacking_done;
        __pyx_L33_unpacking_failed:;
        __Pyx_DECREF(__pyx_t_22); __pyx_t_22 = 0;
        __pyx_t_23 = NULL;
        if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index);
        __PYX_ERR(0, 1293, __pyx_L13_except_error)
        __pyx_L34_unpacking_done:;
      }
      __pyx_v_year = __pyx_t_15;
      __pyx_t_15 = 0;
      __pyx_v_month = __pyx_t_16;
      __pyx_t_16 = 0;
      __pyx_v_day = __pyx_t_14;
      __pyx_t_14 = 0;
      __pyx_v_hour = __pyx_t_2;
      __pyx_t_2 = 0;
      __pyx_v_minute = __pyx_t_1;
      __pyx_t_1 = 0;
      __pyx_v_second = __pyx_t_11;
      __pyx_t_11 = 0;
      __pyx_v_microsecond = __pyx_t_21;
      __pyx_t_21 = 0;

      /* "cftime/_cftime.pyx":1294
 *         except ValueError:
 *             year,month,day,hour,minute,second,microsecond = _strptime(datestring,format)
 *             return datetime(year,month,day,hour,minute,second,microsecond,             # <<<<<<<<<<<<<<
 *                             calendar=calendar,has_year_zero=has_year_zero)
 * 
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_21 = NULL;

      /* "cftime/_cftime.pyx":1295
 *             year,month,day,hour,minute,second,microsecond = _strptime(datestring,format)
 *             return datetime(year,month,day,hour,minute,second,microsecond,
 *                             calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     def __format__(self, format):
*/
      __pyx_t_4 = 1;
      {
        PyObject *__pyx_callargs[8 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_21, __pyx_v_year, __pyx_v_month, __pyx_v_day, __pyx_v_hour, __pyx_v_minute, __pyx_v_second, __pyx_v_microsecond};
        __pyx_t_11 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1294, __pyx_L13_except_error)
        __Pyx_GOTREF(__pyx_t_11);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_11, __pyx_callargs+8, 0) < (0)) __PYX_ERR(0, 1294, __pyx_L13_except_error)
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_11, __pyx_callargs+8, 1) < (0)) __PYX_ERR(0, 1294, __pyx_L13_except_error)
        __pyx_t_17 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_callargs+__pyx_t_4, (8-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_11);
        __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0;
        __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        if (unlikely(!__pyx_t_17)) __PYX_ERR(0, 1294, __pyx_L13_except_error)
        __Pyx_GOTREF((PyObject *)__pyx_t_17);
      }
      __pyx_r = ((PyObject *)__pyx_t_17);
      __pyx_t_17 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_18); __pyx_t_18 = 0;
      __Pyx_DECREF(__pyx_t_19); __pyx_t_19 = 0;
      goto __pyx_L14_except_return;
    }
    goto __pyx_L13_except_error;

    /* "cftime/_cftime.pyx":1272
 *         # calendar specific format descriptors that won't work will all calendars
 *         special_fd = ['a', 'A', 'w', 'j', 'U', 'W', 'G', 'u', 'V']
 *         try:             # <<<<<<<<<<<<<<
 *             pydatetime = datetime_python.strptime(datestring, format)
 *             # remove time zone offset
*/
    __pyx_L13_except_error:;
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_XGIVEREF(__pyx_t_9);
    __Pyx_XGIVEREF(__pyx_t_10);
    __Pyx_ExceptionReset(__pyx_t_8, __pyx_t_9, __pyx_t_10);
    goto __pyx_L1_error;
    __pyx_L15_try_return:;
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_XGIVEREF(__pyx_t_9);
    __Pyx_XGIVEREF(__pyx_t_10);
    __Pyx_ExceptionReset(__pyx_t_8, __pyx_t_9, __pyx_t_10);
    goto __pyx_L0;
    __pyx_L14_except_return:;
    __Pyx_XGIVEREF(__pyx_t_8);
    __Pyx_XGIVEREF(__pyx_t_9);
    __Pyx_XGIVEREF(__pyx_t_10);
    __Pyx_ExceptionReset(__pyx_t_8, __pyx_t_9, __pyx_t_10);
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/

  /* 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_11);
  __Pyx_XDECREF(__pyx_t_14);
  __Pyx_XDECREF(__pyx_t_15);
  __Pyx_XDECREF(__pyx_t_16);
  __Pyx_XDECREF(__pyx_t_17);
  __Pyx_XDECREF(__pyx_t_18);
  __Pyx_XDECREF(__pyx_t_19);
  __Pyx_XDECREF(__pyx_t_21);
  __Pyx_XDECREF(__pyx_t_22);
  __Pyx_AddTraceback("cftime._cftime.datetime.strptime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_fd);
  __Pyx_XDECREF(__pyx_v_pydatetime);
  __Pyx_XDECREF(__pyx_v_compatible_date);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_year);
  __Pyx_XDECREF(__pyx_v_month);
  __Pyx_XDECREF(__pyx_v_day);
  __Pyx_XDECREF(__pyx_v_hour);
  __Pyx_XDECREF(__pyx_v_minute);
  __Pyx_XDECREF(__pyx_v_second);
  __Pyx_XDECREF(__pyx_v_microsecond);
  __Pyx_XDECREF(__pyx_8genexpr4__pyx_v_d);
  __Pyx_XDECREF(__pyx_gb_6cftime_7_cftime_8datetime_8strptime_2generator);
  __Pyx_DECREF((PyObject *)__pyx_cur_scope);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1297
 *                             calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     def __format__(self, format):             # <<<<<<<<<<<<<<
 *         # the string format "{t_obj}".format(t_obj=t_obj)
 *         # without an explicit format gives an empty string (format='')
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7__format__(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_6__format__, "datetime.__format__(self, format)");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_7__format__ = {"__format__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_7__format__, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_6__format__};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_7__format__(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_format = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__format__ (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_format,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1297, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1297, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__format__", 0) < (0)) __PYX_ERR(0, 1297, __pyx_L3_error)
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__format__", 1, 1, 1, i); __PYX_ERR(0, 1297, __pyx_L3_error) }
      }
    } else if (unlikely(__pyx_nargs != 1)) {
      goto __pyx_L5_argtuple_error;
    } else {
      values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
      if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1297, __pyx_L3_error)
    }
    __pyx_v_format = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("__format__", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 1297, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.__format__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_6__format__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_format);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6__format__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_format) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__format__", 0);
  __Pyx_INCREF(__pyx_v_format);

  /* "cftime/_cftime.pyx":1301
 *         # without an explicit format gives an empty string (format='')
 *         # so set this to None to get the default strftime behaviour
 *         if format == '':             # <<<<<<<<<<<<<<
 *             format = None
 *         return self.strftime(format)
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_format, __pyx_mstate_global->__pyx_kp_u__2, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1301, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1302
 *         # so set this to None to get the default strftime behaviour
 *         if format == '':
 *             format = None             # <<<<<<<<<<<<<<
 *         return self.strftime(format)
 * 
*/
    __Pyx_INCREF(Py_None);
    __Pyx_DECREF_SET(__pyx_v_format, Py_None);

    /* "cftime/_cftime.pyx":1301
 *         # without an explicit format gives an empty string (format='')
 *         # so set this to None to get the default strftime behaviour
 *         if format == '':             # <<<<<<<<<<<<<<
 *             format = None
 *         return self.strftime(format)
*/
  }

  /* "cftime/_cftime.pyx":1303
 *         if format == '':
 *             format = None
 *         return self.strftime(format)             # <<<<<<<<<<<<<<
 * 
 *     def replace(self, **kwargs):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_3 = ((PyObject *)__pyx_v_self);
  __Pyx_INCREF(__pyx_t_3);
  __pyx_t_4 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_format};
    __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_strftime, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1303, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1297
 *                             calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     def __format__(self, format):             # <<<<<<<<<<<<<<
 *         # the string format "{t_obj}".format(t_obj=t_obj)
 *         # without an explicit format gives an empty string (format='')
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_AddTraceback("cftime._cftime.datetime.__format__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_format);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1305
 *         return self.strftime(format)
 * 
 *     def replace(self, **kwargs):             # <<<<<<<<<<<<<<
 *         """Return datetime with new specified fields."""
 *         args = {"year": self.year,
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_9replace(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_8replace, "datetime.replace(self, **kwargs)\n\nReturn datetime with new specified fields.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_9replace = {"replace", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_9replace, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_8replace};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_9replace(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_kwargs = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("replace (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("replace", 1, 0, 0, __pyx_nargs); return NULL; }
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return NULL;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("replace", __pyx_kwds) == -1)) return NULL;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_FASTCALL(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return NULL;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return NULL;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_8replace(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_kwargs);

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8replace(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_kwargs) {
  PyObject *__pyx_v_args = NULL;
  PyObject *__pyx_v_name = NULL;
  PyObject *__pyx_v_value = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  int __pyx_t_4;
  size_t __pyx_t_5;
  Py_ssize_t __pyx_t_6;
  Py_ssize_t __pyx_t_7;
  int __pyx_t_8;
  PyObject *__pyx_t_9 = NULL;
  int __pyx_t_10;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("replace", 0);

  /* "cftime/_cftime.pyx":1307
 *     def replace(self, **kwargs):
 *         """Return datetime with new specified fields."""
 *         args = {"year": self.year,             # <<<<<<<<<<<<<<
 *                 "month": self.month,
 *                 "day": self.day,
*/
  __pyx_t_1 = __Pyx_PyDict_NewPresized(9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_year, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1308
 *         """Return datetime with new specified fields."""
 *         args = {"year": self.year,
 *                 "month": self.month,             # <<<<<<<<<<<<<<
 *                 "day": self.day,
 *                 "hour": self.hour,
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1308, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_month, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1309
 *         args = {"year": self.year,
 *                 "month": self.month,
 *                 "day": self.day,             # <<<<<<<<<<<<<<
 *                 "hour": self.hour,
 *                 "minute": self.minute,
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1309, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_day, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1310
 *                 "month": self.month,
 *                 "day": self.day,
 *                 "hour": self.hour,             # <<<<<<<<<<<<<<
 *                 "minute": self.minute,
 *                 "second": self.second,
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1310, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_hour, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1311
 *                 "day": self.day,
 *                 "hour": self.hour,
 *                 "minute": self.minute,             # <<<<<<<<<<<<<<
 *                 "second": self.second,
 *                 "microsecond": self.microsecond,
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1311, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_minute, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1312
 *                 "hour": self.hour,
 *                 "minute": self.minute,
 *                 "second": self.second,             # <<<<<<<<<<<<<<
 *                 "microsecond": self.microsecond,
 *                 "has_year_zero": self.has_year_zero,
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1312, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_second, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1313
 *                 "minute": self.minute,
 *                 "second": self.second,
 *                 "microsecond": self.microsecond,             # <<<<<<<<<<<<<<
 *                 "has_year_zero": self.has_year_zero,
 *                 "calendar": self.calendar}
*/
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1313, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_microsecond, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1314
 *                 "second": self.second,
 *                 "microsecond": self.microsecond,
 *                 "has_year_zero": self.has_year_zero,             # <<<<<<<<<<<<<<
 *                 "calendar": self.calendar}
 * 
*/
  __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1314, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_2) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1315
 *                 "microsecond": self.microsecond,
 *                 "has_year_zero": self.has_year_zero,
 *                 "calendar": self.calendar}             # <<<<<<<<<<<<<<
 * 
 *         if 'dayofyr' in kwargs or 'dayofwk' in kwargs:
*/
  if (PyDict_SetItem(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_self->calendar) < (0)) __PYX_ERR(0, 1307, __pyx_L1_error)
  __pyx_v_args = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1317
 *                 "calendar": self.calendar}
 * 
 *         if 'dayofyr' in kwargs or 'dayofwk' in kwargs:             # <<<<<<<<<<<<<<
 *             raise ValueError('Replacing the dayofyr or dayofwk of a datetime is '
 *                              'not supported.')
*/
  __pyx_t_4 = (__Pyx_PyDict_ContainsTF(__pyx_mstate_global->__pyx_n_u_dayofyr, __pyx_v_kwargs, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1317, __pyx_L1_error)
  if (!__pyx_t_4) {
  } else {
    __pyx_t_3 = __pyx_t_4;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_4 = (__Pyx_PyDict_ContainsTF(__pyx_mstate_global->__pyx_n_u_dayofwk, __pyx_v_kwargs, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1317, __pyx_L1_error)
  __pyx_t_3 = __pyx_t_4;
  __pyx_L4_bool_binop_done:;
  if (unlikely(__pyx_t_3)) {

    /* "cftime/_cftime.pyx":1318
 * 
 *         if 'dayofyr' in kwargs or 'dayofwk' in kwargs:
 *             raise ValueError('Replacing the dayofyr or dayofwk of a datetime is '             # <<<<<<<<<<<<<<
 *                              'not supported.')
 * 
*/
    __pyx_t_2 = NULL;
    __pyx_t_5 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Replacing_the_dayofyr_or_dayofwk};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1318, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 1318, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1317
 *                 "calendar": self.calendar}
 * 
 *         if 'dayofyr' in kwargs or 'dayofwk' in kwargs:             # <<<<<<<<<<<<<<
 *             raise ValueError('Replacing the dayofyr or dayofwk of a datetime is '
 *                              'not supported.')
*/
  }

  /* "cftime/_cftime.pyx":1321
 *                              'not supported.')
 * 
 *         if 'calendar' in kwargs:             # <<<<<<<<<<<<<<
 *             raise ValueError('Replacing the calendar of a datetime is '
 *                              'not supported.')
*/
  __pyx_t_3 = (__Pyx_PyDict_ContainsTF(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_kwargs, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1321, __pyx_L1_error)
  if (unlikely(__pyx_t_3)) {

    /* "cftime/_cftime.pyx":1322
 * 
 *         if 'calendar' in kwargs:
 *             raise ValueError('Replacing the calendar of a datetime is '             # <<<<<<<<<<<<<<
 *                              'not supported.')
 * 
*/
    __pyx_t_2 = NULL;
    __pyx_t_5 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Replacing_the_calendar_of_a_date};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1322, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 1322, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1321
 *                              'not supported.')
 * 
 *         if 'calendar' in kwargs:             # <<<<<<<<<<<<<<
 *             raise ValueError('Replacing the calendar of a datetime is '
 *                              'not supported.')
*/
  }

  /* "cftime/_cftime.pyx":1327
 *         # if attempting to set year to zero, also set has_year_zero=True
 *         # (issue #248)
 *         if 'year' in kwargs:             # <<<<<<<<<<<<<<
 *             if kwargs['year']==0 and 'has_year_zero' not in kwargs:
 *                 kwargs['has_year_zero']=True
*/
  __pyx_t_3 = (__Pyx_PyDict_ContainsTF(__pyx_mstate_global->__pyx_n_u_year, __pyx_v_kwargs, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1327, __pyx_L1_error)
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":1328
 *         # (issue #248)
 *         if 'year' in kwargs:
 *             if kwargs['year']==0 and 'has_year_zero' not in kwargs:             # <<<<<<<<<<<<<<
 *                 kwargs['has_year_zero']=True
 * 
*/
    __pyx_t_1 = __Pyx_PyDict_GetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1328, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = (__Pyx_PyLong_BoolEqObjC(__pyx_t_1, __pyx_mstate_global->__pyx_int_0, 0, 0)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1328, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    if (__pyx_t_4) {
    } else {
      __pyx_t_3 = __pyx_t_4;
      goto __pyx_L9_bool_binop_done;
    }
    __pyx_t_4 = (__Pyx_PyDict_ContainsTF(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_kwargs, Py_NE)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1328, __pyx_L1_error)
    __pyx_t_3 = __pyx_t_4;
    __pyx_L9_bool_binop_done:;
    if (__pyx_t_3) {

      /* "cftime/_cftime.pyx":1329
 *         if 'year' in kwargs:
 *             if kwargs['year']==0 and 'has_year_zero' not in kwargs:
 *                 kwargs['has_year_zero']=True             # <<<<<<<<<<<<<<
 * 
 *         for name, value in kwargs.items():
*/
      if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_has_year_zero, Py_True) < 0))) __PYX_ERR(0, 1329, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1328
 *         # (issue #248)
 *         if 'year' in kwargs:
 *             if kwargs['year']==0 and 'has_year_zero' not in kwargs:             # <<<<<<<<<<<<<<
 *                 kwargs['has_year_zero']=True
 * 
*/
    }

    /* "cftime/_cftime.pyx":1327
 *         # if attempting to set year to zero, also set has_year_zero=True
 *         # (issue #248)
 *         if 'year' in kwargs:             # <<<<<<<<<<<<<<
 *             if kwargs['year']==0 and 'has_year_zero' not in kwargs:
 *                 kwargs['has_year_zero']=True
*/
  }

  /* "cftime/_cftime.pyx":1331
 *                 kwargs['has_year_zero']=True
 * 
 *         for name, value in kwargs.items():             # <<<<<<<<<<<<<<
 *             args[name] = value
 * 
*/
  __pyx_t_6 = 0;
  __pyx_t_2 = __Pyx_dict_iterator(__pyx_v_kwargs, 1, __pyx_mstate_global->__pyx_n_u_items, (&__pyx_t_7), (&__pyx_t_8)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1331, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_1);
  __pyx_t_1 = __pyx_t_2;
  __pyx_t_2 = 0;
  while (1) {
    __pyx_t_10 = __Pyx_dict_iter_next(__pyx_t_1, __pyx_t_7, &__pyx_t_6, &__pyx_t_2, &__pyx_t_9, NULL, __pyx_t_8);
    if (unlikely(__pyx_t_10 == 0)) break;
    if (unlikely(__pyx_t_10 == -1)) __PYX_ERR(0, 1331, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_GOTREF(__pyx_t_9);
    __Pyx_XDECREF_SET(__pyx_v_name, __pyx_t_2);
    __pyx_t_2 = 0;
    __Pyx_XDECREF_SET(__pyx_v_value, __pyx_t_9);
    __pyx_t_9 = 0;

    /* "cftime/_cftime.pyx":1332
 * 
 *         for name, value in kwargs.items():
 *             args[name] = value             # <<<<<<<<<<<<<<
 * 
 *         return self.__class__(**args)
*/
    if (unlikely((PyDict_SetItem(__pyx_v_args, __pyx_v_name, __pyx_v_value) < 0))) __PYX_ERR(0, 1332, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1334
 *             args[name] = value
 * 
 *         return self.__class__(**args)             # <<<<<<<<<<<<<<
 * 
 *     def timetuple(self):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_class); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1334, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_9 = PyDict_Copy(__pyx_v_args); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1334, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_2 = __Pyx_PyObject_Call(__pyx_t_1, __pyx_mstate_global->__pyx_empty_tuple, __pyx_t_9); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1334, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1305
 *         return self.strftime(format)
 * 
 *     def replace(self, **kwargs):             # <<<<<<<<<<<<<<
 *         """Return datetime with new specified fields."""
 *         args = {"year": self.year,
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime.datetime.replace", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_args);
  __Pyx_XDECREF(__pyx_v_name);
  __Pyx_XDECREF(__pyx_v_value);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1336
 *         return self.__class__(**args)
 * 
 *     def timetuple(self):             # <<<<<<<<<<<<<<
 *         """
 *         Return a time.struct_time such as returned by time.localtime().
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11timetuple(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_10timetuple, "datetime.timetuple(self)\n\nReturn a time.struct_time such as returned by time.localtime().\nThe DST flag is -1. d.timetuple() is equivalent to\ntime.struct_time((d.year, d.month, d.day, d.hour, d.minute,\nd.second, d.weekday(), yday, dst)), where yday is the\nday number within the current year starting with 1 for January 1st.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_11timetuple = {"timetuple", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_11timetuple, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_10timetuple};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11timetuple(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("timetuple (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("timetuple", 1, 0, 0, __pyx_nargs); return NULL; }
  const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return NULL;
  if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("timetuple", __pyx_kwds); return NULL;}
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_10timetuple(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_10timetuple(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  size_t __pyx_t_13;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("timetuple", 0);

  /* "cftime/_cftime.pyx":1344
 *         day number within the current year starting with 1 for January 1st.
 *         """
 *         return time.struct_time((self.year, self.month, self.day, self.hour,             # <<<<<<<<<<<<<<
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_time); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_struct_time); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);

  /* "cftime/_cftime.pyx":1345
 *         """
 *         return time.struct_time((self.year, self.month, self.day, self.hour,
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))             # <<<<<<<<<<<<<<
 * 
 *     cpdef _to_real_datetime(self):
*/
  __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1345, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1345, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_dayofwk); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1345, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_11 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_dayofyr); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1345, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);

  /* "cftime/_cftime.pyx":1344
 *         day number within the current year starting with 1 for January 1st.
 *         """
 *         return time.struct_time((self.year, self.month, self.day, self.hour,             # <<<<<<<<<<<<<<
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))
 * 
*/
  __pyx_t_12 = PyTuple_New(9); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1344, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_3) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_5);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_5) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_t_6) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_7);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 3, __pyx_t_7) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_8);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 4, __pyx_t_8) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_9);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 5, __pyx_t_9) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_10);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 6, __pyx_t_10) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_11);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 7, __pyx_t_11) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_int_neg_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 8, __pyx_mstate_global->__pyx_int_neg_1) != (0)) __PYX_ERR(0, 1344, __pyx_L1_error);
  __pyx_t_3 = 0;
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __pyx_t_8 = 0;
  __pyx_t_9 = 0;
  __pyx_t_10 = 0;
  __pyx_t_11 = 0;
  __pyx_t_13 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_13 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_12};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_13, (2-__pyx_t_13) | (__pyx_t_13*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1344, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1336
 *         return self.__class__(**args)
 * 
 *     def timetuple(self):             # <<<<<<<<<<<<<<
 *         """
 *         Return a time.struct_time such as returned by time.localtime().
*/

  /* 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_6);
  __Pyx_XDECREF(__pyx_t_7);
  __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_AddTraceback("cftime._cftime.datetime.timetuple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1347
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))
 * 
 *     cpdef _to_real_datetime(self):             # <<<<<<<<<<<<<<
 *         return real_datetime(self.year, self.month, self.day,
 *                              self.hour, self.minute, self.second,
*/

static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_13_to_real_datetime(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
static PyObject *__pyx_f_6cftime_7_cftime_8datetime__to_real_datetime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, int __pyx_skip_dispatch) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_to_real_datetime", 0);
  /* Check if called by wrapper */
  if (unlikely(__pyx_skip_dispatch)) ;
  /* Check if overridden in Python */
  else if (
  #if !CYTHON_USE_TYPE_SLOTS
  unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime &&
  __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC))
  #else
  unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE)))
  #endif
  ) {
    #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS
    static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT;
    if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) {
      PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self));
      #endif
      __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_to_real_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1347, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_6cftime_7_cftime_8datetime_13_to_real_datetime)) {
        __Pyx_XDECREF(__pyx_r);
        __pyx_t_3 = NULL;
        __Pyx_INCREF(__pyx_t_1);
        __pyx_t_4 = __pyx_t_1; 
        __pyx_t_5 = 1;
        #if CYTHON_UNPACK_METHODS
        if (unlikely(PyMethod_Check(__pyx_t_4))) {
          __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4);
          assert(__pyx_t_3);
          PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
          __Pyx_INCREF(__pyx_t_3);
          __Pyx_INCREF(__pyx__function);
          __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
          __pyx_t_5 = 0;
        }
        #endif
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
          __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1347, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_2);
        }
        __pyx_r = __pyx_t_2;
        __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
        goto __pyx_L0;
      }
      #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS
      __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self));
      __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self));
      if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) {
        __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT;
      }
      #endif
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS
    }
    #endif
  }

  /* "cftime/_cftime.pyx":1348
 * 
 *     cpdef _to_real_datetime(self):
 *         return real_datetime(self.year, self.month, self.day,             # <<<<<<<<<<<<<<
 *                              self.hour, self.minute, self.second,
 *                              self.microsecond)
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_real_datetime); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1348, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);

  /* "cftime/_cftime.pyx":1349
 *     cpdef _to_real_datetime(self):
 *         return real_datetime(self.year, self.month, self.day,
 *                              self.hour, self.minute, self.second,             # <<<<<<<<<<<<<<
 *                              self.microsecond)
 * 
*/
  __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1349, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);

  /* "cftime/_cftime.pyx":1350
 *         return real_datetime(self.year, self.month, self.day,
 *                              self.hour, self.minute, self.second,
 *                              self.microsecond)             # <<<<<<<<<<<<<<
 * 
 *     def __repr__(self):
*/
  __pyx_t_11 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1350, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_5 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_5 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[8] = {__pyx_t_2, __pyx_t_3, __pyx_t_6, __pyx_t_7, __pyx_t_8, __pyx_t_9, __pyx_t_10, __pyx_t_11};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_5, (8-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1348, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1347
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))
 * 
 *     cpdef _to_real_datetime(self):             # <<<<<<<<<<<<<<
 *         return real_datetime(self.year, self.month, self.day,
 *                              self.hour, self.minute, self.second,
*/

  /* 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_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_AddTraceback("cftime._cftime.datetime._to_real_datetime", __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_6cftime_7_cftime_8datetime_13_to_real_datetime(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_12_to_real_datetime, "datetime._to_real_datetime(self)");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_13_to_real_datetime = {"_to_real_datetime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_13_to_real_datetime, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_12_to_real_datetime};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_13_to_real_datetime(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_to_real_datetime (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("_to_real_datetime", 1, 0, 0, __pyx_nargs); return NULL; }
  const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return NULL;
  if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("_to_real_datetime", __pyx_kwds); return NULL;}
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_12_to_real_datetime(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_12_to_real_datetime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_to_real_datetime", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __pyx_f_6cftime_7_cftime_8datetime__to_real_datetime(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1347, __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("cftime._cftime.datetime._to_real_datetime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1352
 *                              self.microsecond)
 * 
 *     def __repr__(self):             # <<<<<<<<<<<<<<
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_15__repr__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_15__repr__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__repr__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_14__repr__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_14__repr__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  size_t __pyx_t_13;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__repr__", 0);

  /* "cftime/_cftime.pyx":1353
 * 
 *     def __repr__(self):
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class             # <<<<<<<<<<<<<<
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
 *             self.__class__.__name__,
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_class); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1353, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_name); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1353, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_datetime, Py_NE)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1353, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":1354
 *     def __repr__(self):
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',             # <<<<<<<<<<<<<<
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = __pyx_mstate_global->__pyx_kp_u_0_1_2_3_4_5_6_7_8_has_year_zero;
    __Pyx_INCREF(__pyx_t_1);

    /* "cftime/_cftime.pyx":1355
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
 *             self.__class__.__name__,             # <<<<<<<<<<<<<<
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)
 *         if self.calendar == None:
*/
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_class); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1355, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_name); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1355, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1356
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)             # <<<<<<<<<<<<<<
 *         if self.calendar == None:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',
*/
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_11 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_12 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1356, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_13 = 0;
    {
      PyObject *__pyx_callargs[11] = {__pyx_t_1, __pyx_mstate_global->__pyx_n_u_cftime, __pyx_t_5, __pyx_t_4, __pyx_t_6, __pyx_t_7, __pyx_t_8, __pyx_t_9, __pyx_t_10, __pyx_t_11, __pyx_t_12};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_13, (11-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1354, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1353
 * 
 *     def __repr__(self):
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class             # <<<<<<<<<<<<<<
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
 *             self.__class__.__name__,
*/
  }

  /* "cftime/_cftime.pyx":1357
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)
 *         if self.calendar == None:             # <<<<<<<<<<<<<<
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,
*/
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_self->calendar, Py_None, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1357, __pyx_L1_error)
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":1358
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)
 *         if self.calendar == None:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',             # <<<<<<<<<<<<<<
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_12 = __pyx_mstate_global->__pyx_kp_u_0_1_2_3_4_5_6_7_8_calendar_9_ha;
    __Pyx_INCREF(__pyx_t_12);

    /* "cftime/_cftime.pyx":1359
 *         if self.calendar == None:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,             # <<<<<<<<<<<<<<
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
 *         else:
*/
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_class); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1359, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_name); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1359, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;

    /* "cftime/_cftime.pyx":1360
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)             # <<<<<<<<<<<<<<
 *         else:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar='{9}', has_year_zero={10})".format('cftime',
*/
    __pyx_t_11 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1360, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_13 = 0;
    {
      PyObject *__pyx_callargs[12] = {__pyx_t_12, __pyx_mstate_global->__pyx_n_u_cftime, __pyx_t_10, __pyx_t_11, __pyx_t_9, __pyx_t_8, __pyx_t_7, __pyx_t_6, __pyx_t_4, __pyx_t_5, __pyx_v_self->calendar, __pyx_t_1};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_13, (12-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __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_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1358, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1357
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.has_year_zero)
 *         if self.calendar == None:             # <<<<<<<<<<<<<<
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,
*/
  }

  /* "cftime/_cftime.pyx":1362
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
 *         else:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar='{9}', has_year_zero={10})".format('cftime',             # <<<<<<<<<<<<<<
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = __pyx_mstate_global->__pyx_kp_u_0_1_2_3_4_5_6_7_8_calendar_9_ha_2;
    __Pyx_INCREF(__pyx_t_1);

    /* "cftime/_cftime.pyx":1363
 *         else:
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar='{9}', has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,             # <<<<<<<<<<<<<<
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
 * 
*/
    __pyx_t_5 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_class); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_name); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1363, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;

    /* "cftime/_cftime.pyx":1364
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar='{9}', has_year_zero={10})".format('cftime',
 *             self.__class__.__name__,
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     def __str__(self):
*/
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_11 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_12 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1364, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_12);
    __pyx_t_13 = 0;
    {
      PyObject *__pyx_callargs[12] = {__pyx_t_1, __pyx_mstate_global->__pyx_n_u_cftime, __pyx_t_4, __pyx_t_5, __pyx_t_6, __pyx_t_7, __pyx_t_8, __pyx_t_9, __pyx_t_11, __pyx_t_10, __pyx_v_self->calendar, __pyx_t_12};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_13, (12-__pyx_t_13) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__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_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1362, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1352
 *                              self.microsecond)
 * 
 *     def __repr__(self):             # <<<<<<<<<<<<<<
 *         if self.__class__.__name__ != 'datetime': # a calendar-specific sub-class
 *             return "{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9})".format('cftime',
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __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_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_AddTraceback("cftime._cftime.datetime.__repr__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1366
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
 * 
 *     def __str__(self):             # <<<<<<<<<<<<<<
 *         return self.isoformat(' ')
 * 
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_17__str__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_17__str__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__str__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_16__str__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_16__str__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__str__", 0);

  /* "cftime/_cftime.pyx":1367
 * 
 *     def __str__(self):
 *         return self.isoformat(' ')             # <<<<<<<<<<<<<<
 * 
 *     def isoformat(self, sep='T', timespec='auto'):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_2 = ((PyObject *)__pyx_v_self);
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u__5};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_isoformat, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1367, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1366
 *             self.year,self.month,self.day,self.hour,self.minute,self.second,self.microsecond,self.calendar,self.has_year_zero)
 * 
 *     def __str__(self):             # <<<<<<<<<<<<<<
 *         return self.isoformat(' ')
 * 
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.datetime.__str__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1369
 *         return self.isoformat(' ')
 * 
 *     def isoformat(self, sep='T', timespec='auto'):             # <<<<<<<<<<<<<<
 *         """
 *         ISO date representation
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_19isoformat(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_18isoformat, "datetime.isoformat(self, sep='T', timespec='auto')\n\nISO date representation");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_19isoformat = {"isoformat", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_19isoformat, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_18isoformat};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_19isoformat(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_sep = 0;
  PyObject *__pyx_v_timespec = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("isoformat (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_sep,&__pyx_mstate_global->__pyx_n_u_timespec,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1369, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1369, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1369, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "isoformat", 0) < (0)) __PYX_ERR(0, 1369, __pyx_L3_error)
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_T));
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_auto));
    } else {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1369, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1369, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_T));
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_auto));
    }
    __pyx_v_sep = values[0];
    __pyx_v_timespec = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("isoformat", 0, 0, 2, __pyx_nargs); __PYX_ERR(0, 1369, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.isoformat", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_18isoformat(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_sep, __pyx_v_timespec);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_18isoformat(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_sep, PyObject *__pyx_v_timespec) {
  PyObject *__pyx_v_form0 = NULL;
  PyObject *__pyx_v_form = NULL;
  PyObject *__pyx_v_second = NULL;
  PyObject *__pyx_v_millisecs = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  size_t __pyx_t_7;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  int __pyx_t_11;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("isoformat", 0);

  /* "cftime/_cftime.pyx":1374
 * 
 *         """
 *         if self.year < 0:             # <<<<<<<<<<<<<<
 *             form0 = '{:05d}-{:02d}-{:02d}'
 *         else:
*/
  __pyx_t_1 = (__pyx_v_self->year < 0);
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1375
 *         """
 *         if self.year < 0:
 *             form0 = '{:05d}-{:02d}-{:02d}'             # <<<<<<<<<<<<<<
 *         else:
 *             form0 = '{:04d}-{:02d}-{:02d}'
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_05d_02d_02d);
    __pyx_v_form0 = __pyx_mstate_global->__pyx_kp_u_05d_02d_02d;

    /* "cftime/_cftime.pyx":1374
 * 
 *         """
 *         if self.year < 0:             # <<<<<<<<<<<<<<
 *             form0 = '{:05d}-{:02d}-{:02d}'
 *         else:
*/
    goto __pyx_L3;
  }

  /* "cftime/_cftime.pyx":1377
 *             form0 = '{:05d}-{:02d}-{:02d}'
 *         else:
 *             form0 = '{:04d}-{:02d}-{:02d}'             # <<<<<<<<<<<<<<
 *         if timespec == 'days':
 *             form = form0
*/
  /*else*/ {
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_04d_02d_02d);
    __pyx_v_form0 = __pyx_mstate_global->__pyx_kp_u_04d_02d_02d;
  }
  __pyx_L3:;

  /* "cftime/_cftime.pyx":1378
 *         else:
 *             form0 = '{:04d}-{:02d}-{:02d}'
 *         if timespec == 'days':             # <<<<<<<<<<<<<<
 *             form = form0
 *             return form.format(self.year, self.month, self.day)
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_days, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1378, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1379
 *             form0 = '{:04d}-{:02d}-{:02d}'
 *         if timespec == 'days':
 *             form = form0             # <<<<<<<<<<<<<<
 *             return form.format(self.year, self.month, self.day)
 *         elif timespec == 'hours':
*/
    __Pyx_INCREF(__pyx_v_form0);
    __pyx_v_form = __pyx_v_form0;

    /* "cftime/_cftime.pyx":1380
 *         if timespec == 'days':
 *             form = form0
 *             return form.format(self.year, self.month, self.day)             # <<<<<<<<<<<<<<
 *         elif timespec == 'hours':
 *             form = form0 + '{:s}{:02d}'
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_3 = __pyx_v_form;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1380, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1380, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1380, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[4] = {__pyx_t_3, __pyx_t_4, __pyx_t_5, __pyx_t_6};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (4-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__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;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1380, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1378
 *         else:
 *             form0 = '{:04d}-{:02d}-{:02d}'
 *         if timespec == 'days':             # <<<<<<<<<<<<<<
 *             form = form0
 *             return form.format(self.year, self.month, self.day)
*/
  }

  /* "cftime/_cftime.pyx":1381
 *             form = form0
 *             return form.format(self.year, self.month, self.day)
 *         elif timespec == 'hours':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_hours, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1381, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1382
 *             return form.format(self.year, self.month, self.day)
 *         elif timespec == 'hours':
 *             form = form0 + '{:s}{:02d}'             # <<<<<<<<<<<<<<
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour)
*/
    __pyx_t_2 = __Pyx_PyUnicode_Concat(__pyx_v_form0, __pyx_mstate_global->__pyx_kp_u_s_02d); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1382, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_v_form = ((PyObject*)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1383
 *         elif timespec == 'hours':
 *             form = form0 + '{:s}{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,             # <<<<<<<<<<<<<<
 *                                self.hour)
 *         elif timespec == 'minutes':
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_6 = __pyx_v_form;
    __Pyx_INCREF(__pyx_t_6);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1383, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1383, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1383, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);

    /* "cftime/_cftime.pyx":1384
 *             form = form0 + '{:s}{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour)             # <<<<<<<<<<<<<<
 *         elif timespec == 'minutes':
 *             form = form0 + '{:s}{:02d}:{:02d}'
*/
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1384, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[6] = {__pyx_t_6, __pyx_t_5, __pyx_t_4, __pyx_t_3, __pyx_v_sep, __pyx_t_8};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (6-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1383, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1381
 *             form = form0
 *             return form.format(self.year, self.month, self.day)
 *         elif timespec == 'hours':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  }

  /* "cftime/_cftime.pyx":1385
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour)
 *         elif timespec == 'minutes':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_minutes, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1385, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1386
 *                                self.hour)
 *         elif timespec == 'minutes':
 *             form = form0 + '{:s}{:02d}:{:02d}'             # <<<<<<<<<<<<<<
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute)
*/
    __pyx_t_2 = __Pyx_PyUnicode_Concat(__pyx_v_form0, __pyx_mstate_global->__pyx_kp_u_s_02d_02d); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1386, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_v_form = ((PyObject*)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1387
 *         elif timespec == 'minutes':
 *             form = form0 + '{:s}{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,             # <<<<<<<<<<<<<<
 *                                self.hour, self.minute)
 *         elif timespec == 'seconds':
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __pyx_v_form;
    __Pyx_INCREF(__pyx_t_8);
    __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1387, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1387, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1387, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);

    /* "cftime/_cftime.pyx":1388
 *             form = form0 + '{:s}{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute)             # <<<<<<<<<<<<<<
 *         elif timespec == 'seconds':
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'
*/
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1388, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_9);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[7] = {__pyx_t_8, __pyx_t_3, __pyx_t_4, __pyx_t_5, __pyx_v_sep, __pyx_t_6, __pyx_t_9};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (7-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 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;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1387, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1385
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour)
 *         elif timespec == 'minutes':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  }

  /* "cftime/_cftime.pyx":1389
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute)
 *         elif timespec == 'seconds':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_seconds, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1389, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1390
 *                                self.hour, self.minute)
 *         elif timespec == 'seconds':
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'             # <<<<<<<<<<<<<<
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, self.second)
*/
    __pyx_t_2 = __Pyx_PyUnicode_Concat(__pyx_v_form0, __pyx_mstate_global->__pyx_kp_u_s_02d_02d_02d); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1390, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_v_form = ((PyObject*)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1391
 *         elif timespec == 'seconds':
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,             # <<<<<<<<<<<<<<
 *                                self.hour, self.minute, self.second)
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_9 = __pyx_v_form;
    __Pyx_INCREF(__pyx_t_9);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1391, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);

    /* "cftime/_cftime.pyx":1392
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, self.second)             # <<<<<<<<<<<<<<
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:
 *             second = '{:02d}'.format(self.second)
*/
    __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1392, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1392, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1392, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[8] = {__pyx_t_9, __pyx_t_6, __pyx_t_5, __pyx_t_4, __pyx_v_sep, __pyx_t_3, __pyx_t_8, __pyx_t_10};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (8-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1391, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1389
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute)
 *         elif timespec == 'seconds':             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}:{:02d}:{:02d}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
  }

  /* "cftime/_cftime.pyx":1393
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, self.second)
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:             # <<<<<<<<<<<<<<
 *             second = '{:02d}'.format(self.second)
 *             if timespec == 'milliseconds':
*/
  __Pyx_INCREF(__pyx_v_timespec);
  __pyx_t_2 = __pyx_v_timespec;
  __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_auto, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1393, __pyx_L1_error)
  if (!__pyx_t_11) {
  } else {
    __pyx_t_1 = __pyx_t_11;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_microseconds, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1393, __pyx_L1_error)
  if (!__pyx_t_11) {
  } else {
    __pyx_t_1 = __pyx_t_11;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_milliseconds, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1393, __pyx_L1_error)
  __pyx_t_1 = __pyx_t_11;
  __pyx_L5_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_11 = __pyx_t_1;
  if (likely(__pyx_t_11)) {

    /* "cftime/_cftime.pyx":1394
 *                                self.hour, self.minute, self.second)
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:
 *             second = '{:02d}'.format(self.second)             # <<<<<<<<<<<<<<
 *             if timespec == 'milliseconds':
 *                 millisecs = int(round(self.microsecond / 1000, 0))
*/
    __pyx_t_10 = __pyx_mstate_global->__pyx_kp_u_02d;
    __Pyx_INCREF(__pyx_t_10);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1394, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_8};
      __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1394, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_v_second = ((PyObject*)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1395
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:
 *             second = '{:02d}'.format(self.second)
 *             if timespec == 'milliseconds':             # <<<<<<<<<<<<<<
 *                 millisecs = int(round(self.microsecond / 1000, 0))
 *                 second += '.{:03d}'.format(millisecs)
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_milliseconds, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1395, __pyx_L1_error)
    if (__pyx_t_11) {

      /* "cftime/_cftime.pyx":1396
 *             second = '{:02d}'.format(self.second)
 *             if timespec == 'milliseconds':
 *                 millisecs = int(round(self.microsecond / 1000, 0))             # <<<<<<<<<<<<<<
 *                 second += '.{:03d}'.format(millisecs)
 *             elif timespec == 'microseconds':
*/
      __pyx_t_8 = NULL;
      __pyx_t_10 = PyFloat_FromDouble((((double)__pyx_v_self->microsecond) / 1000.0)); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1396, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __pyx_t_7 = 1;
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_8, __pyx_t_10, __pyx_mstate_global->__pyx_int_0};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_round, __pyx_callargs+__pyx_t_7, (3-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
        __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1396, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
      }
      __pyx_t_10 = __Pyx_PyNumber_Int(__pyx_t_2); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1396, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_v_millisecs = ((PyObject*)__pyx_t_10);
      __pyx_t_10 = 0;

      /* "cftime/_cftime.pyx":1397
 *             if timespec == 'milliseconds':
 *                 millisecs = int(round(self.microsecond / 1000, 0))
 *                 second += '.{:03d}'.format(millisecs)             # <<<<<<<<<<<<<<
 *             elif timespec == 'microseconds':
 *                 second += '.{:06d}'.format(self.microsecond)
*/
      __pyx_t_2 = __pyx_mstate_global->__pyx_kp_u_03d;
      __Pyx_INCREF(__pyx_t_2);
      __pyx_t_7 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_millisecs};
        __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1397, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
      }
      __pyx_t_2 = __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlaceSafe(__pyx_v_second, __pyx_t_10); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1397, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF_SET(__pyx_v_second, ((PyObject*)__pyx_t_2));
      __pyx_t_2 = 0;

      /* "cftime/_cftime.pyx":1395
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:
 *             second = '{:02d}'.format(self.second)
 *             if timespec == 'milliseconds':             # <<<<<<<<<<<<<<
 *                 millisecs = int(round(self.microsecond / 1000, 0))
 *                 second += '.{:03d}'.format(millisecs)
*/
      goto __pyx_L8;
    }

    /* "cftime/_cftime.pyx":1398
 *                 millisecs = int(round(self.microsecond / 1000, 0))
 *                 second += '.{:03d}'.format(millisecs)
 *             elif timespec == 'microseconds':             # <<<<<<<<<<<<<<
 *                 second += '.{:06d}'.format(self.microsecond)
 *             else:
*/
    __pyx_t_11 = (__Pyx_PyUnicode_Equals(__pyx_v_timespec, __pyx_mstate_global->__pyx_n_u_microseconds, Py_EQ)); if (unlikely((__pyx_t_11 < 0))) __PYX_ERR(0, 1398, __pyx_L1_error)
    if (__pyx_t_11) {

      /* "cftime/_cftime.pyx":1399
 *                 second += '.{:03d}'.format(millisecs)
 *             elif timespec == 'microseconds':
 *                 second += '.{:06d}'.format(self.microsecond)             # <<<<<<<<<<<<<<
 *             else:
 *                 if self.microsecond > 0:
*/
      __pyx_t_10 = __pyx_mstate_global->__pyx_kp_u_06d;
      __Pyx_INCREF(__pyx_t_10);
      __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1399, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      __pyx_t_7 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_10, __pyx_t_8};
        __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1399, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
      }
      __pyx_t_8 = __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlaceSafe(__pyx_v_second, __pyx_t_2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1399, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF_SET(__pyx_v_second, ((PyObject*)__pyx_t_8));
      __pyx_t_8 = 0;

      /* "cftime/_cftime.pyx":1398
 *                 millisecs = int(round(self.microsecond / 1000, 0))
 *                 second += '.{:03d}'.format(millisecs)
 *             elif timespec == 'microseconds':             # <<<<<<<<<<<<<<
 *                 second += '.{:06d}'.format(self.microsecond)
 *             else:
*/
      goto __pyx_L8;
    }

    /* "cftime/_cftime.pyx":1401
 *                 second += '.{:06d}'.format(self.microsecond)
 *             else:
 *                 if self.microsecond > 0:             # <<<<<<<<<<<<<<
 *                     second += '.{:06d}'.format(self.microsecond)
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'
*/
    /*else*/ {
      __pyx_t_11 = (__pyx_v_self->microsecond > 0);
      if (__pyx_t_11) {

        /* "cftime/_cftime.pyx":1402
 *             else:
 *                 if self.microsecond > 0:
 *                     second += '.{:06d}'.format(self.microsecond)             # <<<<<<<<<<<<<<
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'
 *             return form.format(self.year, self.month, self.day, sep,
*/
        __pyx_t_2 = __pyx_mstate_global->__pyx_kp_u_06d;
        __Pyx_INCREF(__pyx_t_2);
        __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1402, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __pyx_t_7 = 0;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_10};
          __pyx_t_8 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
          __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
          if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1402, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_8);
        }
        __pyx_t_10 = __Pyx_PyUnicode_Concat__Pyx_ReferenceSharing_OwnStrongReferenceInPlaceSafe(__pyx_v_second, __pyx_t_8); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1402, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_10);
        __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
        __Pyx_DECREF_SET(__pyx_v_second, ((PyObject*)__pyx_t_10));
        __pyx_t_10 = 0;

        /* "cftime/_cftime.pyx":1401
 *                 second += '.{:06d}'.format(self.microsecond)
 *             else:
 *                 if self.microsecond > 0:             # <<<<<<<<<<<<<<
 *                     second += '.{:06d}'.format(self.microsecond)
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'
*/
      }
    }
    __pyx_L8:;

    /* "cftime/_cftime.pyx":1403
 *                 if self.microsecond > 0:
 *                     second += '.{:06d}'.format(self.microsecond)
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'             # <<<<<<<<<<<<<<
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, second)
*/
    __pyx_t_10 = __Pyx_PyUnicode_Concat(__pyx_v_form0, __pyx_mstate_global->__pyx_kp_u_s_02d_02d_s); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1403, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __pyx_v_form = ((PyObject*)__pyx_t_10);
    __pyx_t_10 = 0;

    /* "cftime/_cftime.pyx":1404
 *                     second += '.{:06d}'.format(self.microsecond)
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'
 *             return form.format(self.year, self.month, self.day, sep,             # <<<<<<<<<<<<<<
 *                                self.hour, self.minute, second)
 *         else:
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __pyx_v_form;
    __Pyx_INCREF(__pyx_t_8);
    __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1404, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1404, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1404, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);

    /* "cftime/_cftime.pyx":1405
 *             form = form0 + '{:s}{:02d}:{:02d}:{:s}'
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, second)             # <<<<<<<<<<<<<<
 *         else:
 *             raise ValueError('illegal timespec')
*/
    __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1405, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1405, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = 0;
    {
      PyObject *__pyx_callargs[8] = {__pyx_t_8, __pyx_t_2, __pyx_t_3, __pyx_t_4, __pyx_v_sep, __pyx_t_5, __pyx_t_6, __pyx_v_second};
      __pyx_t_10 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_7, (8-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __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;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1404, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __pyx_r = __pyx_t_10;
    __pyx_t_10 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1393
 *             return form.format(self.year, self.month, self.day, sep,
 *                                self.hour, self.minute, self.second)
 *         elif timespec in ['auto', 'microseconds', 'milliseconds']:             # <<<<<<<<<<<<<<
 *             second = '{:02d}'.format(self.second)
 *             if timespec == 'milliseconds':
*/
  }

  /* "cftime/_cftime.pyx":1407
 *                                self.hour, self.minute, second)
 *         else:
 *             raise ValueError('illegal timespec')             # <<<<<<<<<<<<<<
 * 
 *     def __hash__(self):
*/
  /*else*/ {
    __pyx_t_6 = NULL;
    __pyx_t_7 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_illegal_timespec};
      __pyx_t_10 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1407, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_10);
    }
    __Pyx_Raise(__pyx_t_10, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
    __PYX_ERR(0, 1407, __pyx_L1_error)
  }

  /* "cftime/_cftime.pyx":1369
 *         return self.isoformat(' ')
 * 
 *     def isoformat(self, sep='T', timespec='auto'):             # <<<<<<<<<<<<<<
 *         """
 *         ISO date representation
*/

  /* 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_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_AddTraceback("cftime._cftime.datetime.isoformat", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_form0);
  __Pyx_XDECREF(__pyx_v_form);
  __Pyx_XDECREF(__pyx_v_second);
  __Pyx_XDECREF(__pyx_v_millisecs);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1409
 *             raise ValueError('illegal timespec')
 * 
 *     def __hash__(self):             # <<<<<<<<<<<<<<
 *         try:
 *             d = self._to_real_datetime()
*/

/* Python wrapper */
static Py_hash_t __pyx_pw_6cftime_7_cftime_8datetime_21__hash__(PyObject *__pyx_v_self); /*proto*/
static Py_hash_t __pyx_pw_6cftime_7_cftime_8datetime_21__hash__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  Py_hash_t __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__hash__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_20__hash__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static Py_hash_t __pyx_pf_6cftime_7_cftime_8datetime_20__hash__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_v_d = NULL;
  Py_hash_t __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  size_t __pyx_t_10;
  Py_hash_t __pyx_t_11;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__hash__", 0);

  /* "cftime/_cftime.pyx":1410
 * 
 *     def __hash__(self):
 *         try:             # <<<<<<<<<<<<<<
 *             d = self._to_real_datetime()
 *         except ValueError:
*/
  {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3);
    __Pyx_XGOTREF(__pyx_t_1);
    __Pyx_XGOTREF(__pyx_t_2);
    __Pyx_XGOTREF(__pyx_t_3);
    /*try:*/ {

      /* "cftime/_cftime.pyx":1411
 *     def __hash__(self):
 *         try:
 *             d = self._to_real_datetime()             # <<<<<<<<<<<<<<
 *         except ValueError:
 *             return hash(self.timetuple())
*/
      __pyx_t_4 = ((struct __pyx_vtabstruct_6cftime_7_cftime_datetime *)__pyx_v_self->__pyx_vtab)->_to_real_datetime(__pyx_v_self, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1411, __pyx_L3_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_v_d = __pyx_t_4;
      __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":1410
 * 
 *     def __hash__(self):
 *         try:             # <<<<<<<<<<<<<<
 *             d = self._to_real_datetime()
 *         except ValueError:
*/
    }
    __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;

    /* "cftime/_cftime.pyx":1412
 *         try:
 *             d = self._to_real_datetime()
 *         except ValueError:             # <<<<<<<<<<<<<<
 *             return hash(self.timetuple())
 *         return hash(d)
*/
    __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_ValueError))));
    if (__pyx_t_5) {
      __Pyx_AddTraceback("cftime._cftime.datetime.__hash__", __pyx_clineno, __pyx_lineno, __pyx_filename);
      if (__Pyx_GetException(&__pyx_t_4, &__pyx_t_6, &__pyx_t_7) < 0) __PYX_ERR(0, 1412, __pyx_L5_except_error)
      __Pyx_XGOTREF(__pyx_t_4);
      __Pyx_XGOTREF(__pyx_t_6);
      __Pyx_XGOTREF(__pyx_t_7);

      /* "cftime/_cftime.pyx":1413
 *             d = self._to_real_datetime()
 *         except ValueError:
 *             return hash(self.timetuple())             # <<<<<<<<<<<<<<
 *         return hash(d)
 * 
*/
      __pyx_t_9 = ((PyObject *)__pyx_v_self);
      __Pyx_INCREF(__pyx_t_9);
      __pyx_t_10 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_9, NULL};
        __pyx_t_8 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_timetuple, __pyx_callargs+__pyx_t_10, (1-__pyx_t_10) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1413, __pyx_L5_except_error)
        __Pyx_GOTREF(__pyx_t_8);
      }
      __pyx_t_11 = PyObject_Hash(__pyx_t_8); if (unlikely(__pyx_t_11 == ((Py_hash_t)-1))) __PYX_ERR(0, 1413, __pyx_L5_except_error)
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __pyx_r = __pyx_t_11;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      goto __pyx_L6_except_return;
    }
    goto __pyx_L5_except_error;

    /* "cftime/_cftime.pyx":1410
 * 
 *     def __hash__(self):
 *         try:             # <<<<<<<<<<<<<<
 *             d = self._to_real_datetime()
 *         except ValueError:
*/
    __pyx_L5_except_error:;
    __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_L6_except_return:;
    __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_L0;
    __pyx_L8_try_end:;
  }

  /* "cftime/_cftime.pyx":1414
 *         except ValueError:
 *             return hash(self.timetuple())
 *         return hash(d)             # <<<<<<<<<<<<<<
 * 
 *     def to_tuple(self):
*/
  __pyx_t_11 = PyObject_Hash(__pyx_v_d); if (unlikely(__pyx_t_11 == ((Py_hash_t)-1))) __PYX_ERR(0, 1414, __pyx_L1_error)
  __pyx_r = __pyx_t_11;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1409
 *             raise ValueError('illegal timespec')
 * 
 *     def __hash__(self):             # <<<<<<<<<<<<<<
 *         try:
 *             d = self._to_real_datetime()
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime.datetime.__hash__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_d);
  if (unlikely(__pyx_r == -1) && !PyErr_Occurred()) __pyx_r = -2;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1416
 *         return hash(d)
 * 
 *     def to_tuple(self):             # <<<<<<<<<<<<<<
 *         return (self.year, self.month, self.day, self.hour, self.minute,
 *                 self.second, self.microsecond)
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_23to_tuple(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_22to_tuple, "datetime.to_tuple(self)");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_23to_tuple = {"to_tuple", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_23to_tuple, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_22to_tuple};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_23to_tuple(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("to_tuple (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("to_tuple", 1, 0, 0, __pyx_nargs); return NULL; }
  const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return NULL;
  if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("to_tuple", __pyx_kwds); return NULL;}
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_22to_tuple(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_22to_tuple(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("to_tuple", 0);

  /* "cftime/_cftime.pyx":1417
 * 
 *     def to_tuple(self):
 *         return (self.year, self.month, self.day, self.hour, self.minute,             # <<<<<<<<<<<<<<
 *                 self.second, self.microsecond)
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);

  /* "cftime/_cftime.pyx":1418
 *     def to_tuple(self):
 *         return (self.year, self.month, self.day, self.hour, self.minute,
 *                 self.second, self.microsecond)             # <<<<<<<<<<<<<<
 * 
 *     def __richcmp__(self, other, int op):
*/
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1418, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1418, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);

  /* "cftime/_cftime.pyx":1417
 * 
 *     def to_tuple(self):
 *         return (self.year, self.month, self.day, self.hour, self.minute,             # <<<<<<<<<<<<<<
 *                 self.second, self.microsecond)
 * 
*/
  __pyx_t_8 = PyTuple_New(7); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1417, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_2);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_2) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 2, __pyx_t_3) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_4);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 3, __pyx_t_4) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_5);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 4, __pyx_t_5) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 5, __pyx_t_6) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_7);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 6, __pyx_t_7) != (0)) __PYX_ERR(0, 1417, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __pyx_r = __pyx_t_8;
  __pyx_t_8 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1416
 *         return hash(d)
 * 
 *     def to_tuple(self):             # <<<<<<<<<<<<<<
 *         return (self.year, self.month, self.day, self.hour, self.minute,
 *                 self.second, self.microsecond)
*/

  /* 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_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_AddTraceback("cftime._cftime.datetime.to_tuple", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1420
 *                 self.second, self.microsecond)
 * 
 *     def __richcmp__(self, other, int op):             # <<<<<<<<<<<<<<
 *         cdef datetime dt, dt_other, d1, d2
 *         dt = self
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_25__richcmp__(PyObject *__pyx_v_self, PyObject *__pyx_v_other, int __pyx_v_op); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_25__richcmp__(PyObject *__pyx_v_self, PyObject *__pyx_v_other, int __pyx_v_op) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__richcmp__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_24__richcmp__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), ((PyObject *)__pyx_v_other), ((int)__pyx_v_op));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_24__richcmp__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_other, int __pyx_v_op) {
  struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt = 0;
  struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt_other = 0;
  PyObject *__pyx_v_other2 = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__richcmp__", 0);

  /* "cftime/_cftime.pyx":1422
 *     def __richcmp__(self, other, int op):
 *         cdef datetime dt, dt_other, d1, d2
 *         dt = self             # <<<<<<<<<<<<<<
 *         if isinstance(other, datetime):
 *             dt_other = other
*/
  __Pyx_INCREF((PyObject *)__pyx_v_self);
  __pyx_v_dt = __pyx_v_self;

  /* "cftime/_cftime.pyx":1423
 *         cdef datetime dt, dt_other, d1, d2
 *         dt = self
 *         if isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *             dt_other = other
 *             # comparing two datetime instances
*/
  __pyx_t_1 = __Pyx_TypeCheck(__pyx_v_other, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); 
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1424
 *         dt = self
 *         if isinstance(other, datetime):
 *             dt_other = other             # <<<<<<<<<<<<<<
 *             # comparing two datetime instances
 *             if dt.calendar == dt_other.calendar and dt.has_year_zero == dt_other.has_year_zero:
*/
    __pyx_t_2 = __pyx_v_other;
    __Pyx_INCREF(__pyx_t_2);
    if (!(likely(((__pyx_t_2) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_2, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1424, __pyx_L1_error)
    __pyx_v_dt_other = ((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1426
 *             dt_other = other
 *             # comparing two datetime instances
 *             if dt.calendar == dt_other.calendar and dt.has_year_zero == dt_other.has_year_zero:             # <<<<<<<<<<<<<<
 *                 return PyObject_RichCompare(dt.to_tuple(), dt_other.to_tuple(), op)
 *             else:
*/
    __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_dt->calendar, __pyx_v_dt_other->calendar, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1426, __pyx_L1_error)
    if (__pyx_t_3) {
    } else {
      __pyx_t_1 = __pyx_t_3;
      goto __pyx_L5_bool_binop_done;
    }
    __pyx_t_3 = (__pyx_v_dt->has_year_zero == __pyx_v_dt_other->has_year_zero);
    __pyx_t_1 = __pyx_t_3;
    __pyx_L5_bool_binop_done:;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1427
 *             # comparing two datetime instances
 *             if dt.calendar == dt_other.calendar and dt.has_year_zero == dt_other.has_year_zero:
 *                 return PyObject_RichCompare(dt.to_tuple(), dt_other.to_tuple(), op)             # <<<<<<<<<<<<<<
 *             else:
 *                 # raise an error if either is an idealized calendar (comparison not valid)
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_4 = ((PyObject *)__pyx_v_dt);
      __Pyx_INCREF(__pyx_t_4);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL};
        __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
      }
      __pyx_t_6 = ((PyObject *)__pyx_v_dt_other);
      __Pyx_INCREF(__pyx_t_6);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL};
        __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1427, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_t_6 = PyObject_RichCompare(__pyx_t_2, __pyx_t_4, __pyx_v_op); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1427, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_r = __pyx_t_6;
      __pyx_t_6 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":1426
 *             dt_other = other
 *             # comparing two datetime instances
 *             if dt.calendar == dt_other.calendar and dt.has_year_zero == dt_other.has_year_zero:             # <<<<<<<<<<<<<<
 *                 return PyObject_RichCompare(dt.to_tuple(), dt_other.to_tuple(), op)
 *             else:
*/
    }

    /* "cftime/_cftime.pyx":1430
 *             else:
 *                 # raise an error if either is an idealized calendar (comparison not valid)
 *                 if dt.calendar in _idealized_calendars or other.calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compare {0!r} and {1!r}".format(dt, other))
 *                 # convert one to match calendar of the other.
*/
    /*else*/ {
      __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_3 = (__Pyx_PySequence_ContainsTF(__pyx_v_dt->calendar, __pyx_t_6, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1430, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (!__pyx_t_3) {
      } else {
        __pyx_t_1 = __pyx_t_3;
        goto __pyx_L8_bool_binop_done;
      }
      __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1430, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __pyx_t_3 = (__Pyx_PySequence_ContainsTF(__pyx_t_6, __pyx_t_4, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1430, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __pyx_t_1 = __pyx_t_3;
      __pyx_L8_bool_binop_done:;
      if (unlikely(__pyx_t_1)) {

        /* "cftime/_cftime.pyx":1431
 *                 # raise an error if either is an idealized calendar (comparison not valid)
 *                 if dt.calendar in _idealized_calendars or other.calendar in _idealized_calendars:
 *                     raise TypeError("cannot compare {0!r} and {1!r}".format(dt, other))             # <<<<<<<<<<<<<<
 *                 # convert one to match calendar of the other.
 *                 other2 = other.change_calendar(dt.calendar,has_year_zero=dt.has_year_zero)
*/
        __pyx_t_6 = NULL;
        __pyx_t_7 = __pyx_mstate_global->__pyx_kp_u_cannot_compare_0_r_and_1_r;
        __Pyx_INCREF(__pyx_t_7);
        __pyx_t_5 = 0;
        {
          PyObject *__pyx_callargs[3] = {__pyx_t_7, ((PyObject *)__pyx_v_dt), __pyx_v_other};
          __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1431, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_2);
        }
        __pyx_t_5 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_2};
          __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1431, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_4);
        }
        __Pyx_Raise(__pyx_t_4, 0, 0, 0);
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        __PYX_ERR(0, 1431, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1430
 *             else:
 *                 # raise an error if either is an idealized calendar (comparison not valid)
 *                 if dt.calendar in _idealized_calendars or other.calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compare {0!r} and {1!r}".format(dt, other))
 *                 # convert one to match calendar of the other.
*/
      }

      /* "cftime/_cftime.pyx":1433
 *                     raise TypeError("cannot compare {0!r} and {1!r}".format(dt, other))
 *                 # convert one to match calendar of the other.
 *                 other2 = other.change_calendar(dt.calendar,has_year_zero=dt.has_year_zero)             # <<<<<<<<<<<<<<
 *                 return PyObject_RichCompare(dt.to_tuple(), other2.to_tuple(), op)
 *         elif isinstance(other, datetime_python):
*/
      __pyx_t_2 = __pyx_v_other;
      __Pyx_INCREF(__pyx_t_2);
      __pyx_t_6 = __Pyx_PyBool_FromLong(__pyx_v_dt->has_year_zero); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1433, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, __pyx_v_dt->calendar};
        __pyx_t_7 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
        if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_6, __pyx_t_7, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1433, __pyx_L1_error)
        __pyx_t_4 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_change_calendar, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_7);
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1433, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_v_other2 = __pyx_t_4;
      __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":1434
 *                 # convert one to match calendar of the other.
 *                 other2 = other.change_calendar(dt.calendar,has_year_zero=dt.has_year_zero)
 *                 return PyObject_RichCompare(dt.to_tuple(), other2.to_tuple(), op)             # <<<<<<<<<<<<<<
 *         elif isinstance(other, datetime_python):
 *             # comparing datetime and real_datetime
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_7 = ((PyObject *)__pyx_v_dt);
      __Pyx_INCREF(__pyx_t_7);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_7, NULL};
        __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_t_6 = __pyx_v_other2;
      __Pyx_INCREF(__pyx_t_6);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL};
        __pyx_t_7 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1434, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_7);
      }
      __pyx_t_6 = PyObject_RichCompare(__pyx_t_4, __pyx_t_7, __pyx_v_op); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1434, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      __pyx_r = __pyx_t_6;
      __pyx_t_6 = 0;
      goto __pyx_L0;
    }

    /* "cftime/_cftime.pyx":1423
 *         cdef datetime dt, dt_other, d1, d2
 *         dt = self
 *         if isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *             dt_other = other
 *             # comparing two datetime instances
*/
  }

  /* "cftime/_cftime.pyx":1435
 *                 other2 = other.change_calendar(dt.calendar,has_year_zero=dt.has_year_zero)
 *                 return PyObject_RichCompare(dt.to_tuple(), other2.to_tuple(), op)
 *         elif isinstance(other, datetime_python):             # <<<<<<<<<<<<<<
 *             # comparing datetime and real_datetime
 *             if not dt.datetime_compatible:
*/
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1435, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_1 = PyObject_IsInstance(__pyx_v_other, __pyx_t_6); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 1435, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1437
 *         elif isinstance(other, datetime_python):
 *             # comparing datetime and real_datetime
 *             if not dt.datetime_compatible:             # <<<<<<<<<<<<<<
 *                 raise TypeError("cannot compare {0!r} and {1!r} (different calendars)".format(self, other))
 *             return PyObject_RichCompare(dt.to_tuple(), to_tuple(other), op)
*/
    __pyx_t_1 = (!__pyx_v_dt->datetime_compatible);
    if (unlikely(__pyx_t_1)) {

      /* "cftime/_cftime.pyx":1438
 *             # comparing datetime and real_datetime
 *             if not dt.datetime_compatible:
 *                 raise TypeError("cannot compare {0!r} and {1!r} (different calendars)".format(self, other))             # <<<<<<<<<<<<<<
 *             return PyObject_RichCompare(dt.to_tuple(), to_tuple(other), op)
 *         else:
*/
      __pyx_t_7 = NULL;
      __pyx_t_2 = __pyx_mstate_global->__pyx_kp_u_cannot_compare_0_r_and_1_r_diffe;
      __Pyx_INCREF(__pyx_t_2);
      __pyx_t_5 = 0;
      {
        PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_v_self), __pyx_v_other};
        __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1438, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_t_5 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_t_4};
        __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1438, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_6);
      }
      __Pyx_Raise(__pyx_t_6, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      __PYX_ERR(0, 1438, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1437
 *         elif isinstance(other, datetime_python):
 *             # comparing datetime and real_datetime
 *             if not dt.datetime_compatible:             # <<<<<<<<<<<<<<
 *                 raise TypeError("cannot compare {0!r} and {1!r} (different calendars)".format(self, other))
 *             return PyObject_RichCompare(dt.to_tuple(), to_tuple(other), op)
*/
    }

    /* "cftime/_cftime.pyx":1439
 *             if not dt.datetime_compatible:
 *                 raise TypeError("cannot compare {0!r} and {1!r} (different calendars)".format(self, other))
 *             return PyObject_RichCompare(dt.to_tuple(), to_tuple(other), op)             # <<<<<<<<<<<<<<
 *         else:
 *             # Delegate responsibility of comparison to the other object.
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = ((PyObject *)__pyx_v_dt);
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_5 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL};
      __pyx_t_6 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1439, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_6);
    }
    __pyx_t_7 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_to_tuple); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1439, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_5 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_2))) {
      __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_2);
      assert(__pyx_t_7);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
      __Pyx_INCREF(__pyx_t_7);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
      __pyx_t_5 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_other};
      __pyx_t_4 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1439, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_2 = PyObject_RichCompare(__pyx_t_6, __pyx_t_4, __pyx_v_op); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1439, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_r = __pyx_t_2;
    __pyx_t_2 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1435
 *                 other2 = other.change_calendar(dt.calendar,has_year_zero=dt.has_year_zero)
 *                 return PyObject_RichCompare(dt.to_tuple(), other2.to_tuple(), op)
 *         elif isinstance(other, datetime_python):             # <<<<<<<<<<<<<<
 *             # comparing datetime and real_datetime
 *             if not dt.datetime_compatible:
*/
  }

  /* "cftime/_cftime.pyx":1442
 *         else:
 *             # Delegate responsibility of comparison to the other object.
 *             return NotImplemented             # <<<<<<<<<<<<<<
 * 
 *     cdef _getstate(self):
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_builtin_NotImplemented);
    __pyx_r = __pyx_builtin_NotImplemented;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1420
 *                 self.second, self.microsecond)
 * 
 *     def __richcmp__(self, other, int op):             # <<<<<<<<<<<<<<
 *         cdef datetime dt, dt_other, d1, d2
 *         dt = self
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_AddTraceback("cftime._cftime.datetime.__richcmp__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF((PyObject *)__pyx_v_dt);
  __Pyx_XDECREF((PyObject *)__pyx_v_dt_other);
  __Pyx_XDECREF(__pyx_v_other2);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1444
 *             return NotImplemented
 * 
 *     cdef _getstate(self):             # <<<<<<<<<<<<<<
 *         """return args and kwargs needed to create class instance"""
 *         args = (self.year, self.month, self.day)
*/

static PyObject *__pyx_f_6cftime_7_cftime_8datetime__getstate(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_v_args = NULL;
  PyObject *__pyx_v_kwargs = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_getstate", 0);

  /* "cftime/_cftime.pyx":1446
 *     cdef _getstate(self):
 *         """return args and kwargs needed to create class instance"""
 *         args = (self.year, self.month, self.day)             # <<<<<<<<<<<<<<
 *         kwargs = {'hour': self.hour,
 *                   'minute': self.minute,
*/
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1446, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1446, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1446, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1446, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1446, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_2);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_2) != (0)) __PYX_ERR(0, 1446, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_3) != (0)) __PYX_ERR(0, 1446, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_2 = 0;
  __pyx_t_3 = 0;
  __pyx_v_args = __pyx_t_4;
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1447
 *         """return args and kwargs needed to create class instance"""
 *         args = (self.year, self.month, self.day)
 *         kwargs = {'hour': self.hour,             # <<<<<<<<<<<<<<
 *                   'minute': self.minute,
 *                   'second': self.second,
*/
  __pyx_t_4 = __Pyx_PyDict_NewPresized(8); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_hour, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1448
 *         args = (self.year, self.month, self.day)
 *         kwargs = {'hour': self.hour,
 *                   'minute': self.minute,             # <<<<<<<<<<<<<<
 *                   'second': self.second,
 *                   'microsecond': self.microsecond,
*/
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1448, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_minute, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1449
 *         kwargs = {'hour': self.hour,
 *                   'minute': self.minute,
 *                   'second': self.second,             # <<<<<<<<<<<<<<
 *                   'microsecond': self.microsecond,
 *                   'dayofwk': self._dayofwk,
*/
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1449, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_second, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1450
 *                   'minute': self.minute,
 *                   'second': self.second,
 *                   'microsecond': self.microsecond,             # <<<<<<<<<<<<<<
 *                   'dayofwk': self._dayofwk,
 *                   'dayofyr': self._dayofyr,
*/
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1450, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_microsecond, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1451
 *                   'second': self.second,
 *                   'microsecond': self.microsecond,
 *                   'dayofwk': self._dayofwk,             # <<<<<<<<<<<<<<
 *                   'dayofyr': self._dayofyr,
 *                   'calendar': self.calendar,
*/
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofwk); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1451, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dayofwk, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1452
 *                   'microsecond': self.microsecond,
 *                   'dayofwk': self._dayofwk,
 *                   'dayofyr': self._dayofyr,             # <<<<<<<<<<<<<<
 *                   'calendar': self.calendar,
 *                   'has_year_zero': self.has_year_zero}
*/
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofyr); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1452, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dayofyr, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1453
 *                   'dayofwk': self._dayofwk,
 *                   'dayofyr': self._dayofyr,
 *                   'calendar': self.calendar,             # <<<<<<<<<<<<<<
 *                   'has_year_zero': self.has_year_zero}
 *         return args, kwargs
*/
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_self->calendar) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)

  /* "cftime/_cftime.pyx":1454
 *                   'dayofyr': self._dayofyr,
 *                   'calendar': self.calendar,
 *                   'has_year_zero': self.has_year_zero}             # <<<<<<<<<<<<<<
 *         return args, kwargs
 * 
*/
  __pyx_t_3 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1454, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  if (PyDict_SetItem(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_3) < (0)) __PYX_ERR(0, 1447, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_v_kwargs = ((PyObject*)__pyx_t_4);
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1455
 *                   'calendar': self.calendar,
 *                   'has_year_zero': self.has_year_zero}
 *         return args, kwargs             # <<<<<<<<<<<<<<
 * 
 *     def __reduce__(self):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1455, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_INCREF(__pyx_v_args);
  __Pyx_GIVEREF(__pyx_v_args);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v_args) != (0)) __PYX_ERR(0, 1455, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_kwargs);
  __Pyx_GIVEREF(__pyx_v_kwargs);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_v_kwargs) != (0)) __PYX_ERR(0, 1455, __pyx_L1_error);
  __pyx_r = __pyx_t_4;
  __pyx_t_4 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1444
 *             return NotImplemented
 * 
 *     cdef _getstate(self):             # <<<<<<<<<<<<<<
 *         """return args and kwargs needed to create class instance"""
 *         args = (self.year, self.month, self.day)
*/

  /* 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("cftime._cftime.datetime._getstate", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_args);
  __Pyx_XDECREF(__pyx_v_kwargs);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1457
 *         return args, kwargs
 * 
 *     def __reduce__(self):             # <<<<<<<<<<<<<<
 *         """special method that allows instance to be pickled"""
 *         args, kwargs = self._getstate()
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_27__reduce__(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_26__reduce__, "datetime.__reduce__(self)\n\nspecial method that allows instance to be pickled");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_27__reduce__ = {"__reduce__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_27__reduce__, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_26__reduce__};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_27__reduce__(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__reduce__ (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("__reduce__", 1, 0, 0, __pyx_nargs); return NULL; }
  const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return NULL;
  if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("__reduce__", __pyx_kwds); return NULL;}
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_26__reduce__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_26__reduce__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_v_args = NULL;
  PyObject *__pyx_v_kwargs = NULL;
  PyTypeObject *__pyx_v_date_type = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *(*__pyx_t_5)(PyObject *);
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__reduce__", 0);

  /* "cftime/_cftime.pyx":1459
 *     def __reduce__(self):
 *         """special method that allows instance to be pickled"""
 *         args, kwargs = self._getstate()             # <<<<<<<<<<<<<<
 *         date_type = type(self)
 *         return (_create_datetime, (date_type, args, kwargs))
*/
  __pyx_t_1 = ((struct __pyx_vtabstruct_6cftime_7_cftime_datetime *)__pyx_v_self->__pyx_vtab)->_getstate(__pyx_v_self); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1459, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  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(0, 1459, __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_INCREF(__pyx_t_2);
      __pyx_t_3 = PyTuple_GET_ITEM(sequence, 1);
      __Pyx_INCREF(__pyx_t_3);
    } else {
      __pyx_t_2 = __Pyx_PyList_GetItemRefFast(sequence, 0, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1459, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_2);
      __pyx_t_3 = __Pyx_PyList_GetItemRefFast(sequence, 1, __Pyx_ReferenceSharing_SharedReference);
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1459, __pyx_L1_error)
      __Pyx_XGOTREF(__pyx_t_3);
    }
    #else
    __pyx_t_2 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1459, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1459, __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(0, 1459, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_5 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4);
    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(0, 1459, __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(0, 1459, __pyx_L1_error)
    __pyx_L4_unpacking_done:;
  }
  __pyx_v_args = __pyx_t_2;
  __pyx_t_2 = 0;
  __pyx_v_kwargs = __pyx_t_3;
  __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1460
 *         """special method that allows instance to be pickled"""
 *         args, kwargs = self._getstate()
 *         date_type = type(self)             # <<<<<<<<<<<<<<
 *         return (_create_datetime, (date_type, args, kwargs))
 * 
*/
  __Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));
  __pyx_v_date_type = ((PyTypeObject*)((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self))));

  /* "cftime/_cftime.pyx":1461
 *         args, kwargs = self._getstate()
 *         date_type = type(self)
 *         return (_create_datetime, (date_type, args, kwargs))             # <<<<<<<<<<<<<<
 * 
 *     cdef _add_timedelta(self, other):
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_create_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1461, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = PyTuple_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1461, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_INCREF((PyObject *)__pyx_v_date_type);
  __Pyx_GIVEREF((PyObject *)__pyx_v_date_type);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 0, ((PyObject *)__pyx_v_date_type)) != (0)) __PYX_ERR(0, 1461, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_args);
  __Pyx_GIVEREF(__pyx_v_args);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_v_args) != (0)) __PYX_ERR(0, 1461, __pyx_L1_error);
  __Pyx_INCREF(__pyx_v_kwargs);
  __Pyx_GIVEREF(__pyx_v_kwargs);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_v_kwargs) != (0)) __PYX_ERR(0, 1461, __pyx_L1_error);
  __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1461, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1461, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_3) != (0)) __PYX_ERR(0, 1461, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_3 = 0;
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1457
 *         return args, kwargs
 * 
 *     def __reduce__(self):             # <<<<<<<<<<<<<<
 *         """special method that allows instance to be pickled"""
 *         args, kwargs = self._getstate()
*/

  /* 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("cftime._cftime.datetime.__reduce__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_args);
  __Pyx_XDECREF(__pyx_v_kwargs);
  __Pyx_XDECREF((PyObject *)__pyx_v_date_type);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1463
 *         return (_create_datetime, (date_type, args, kwargs))
 * 
 *     cdef _add_timedelta(self, other):             # <<<<<<<<<<<<<<
 *         return NotImplemented
 * 
*/

static PyObject *__pyx_f_6cftime_7_cftime_8datetime__add_timedelta(CYTHON_UNUSED struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_other) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("_add_timedelta", 0);

  /* "cftime/_cftime.pyx":1464
 * 
 *     cdef _add_timedelta(self, other):
 *         return NotImplemented             # <<<<<<<<<<<<<<
 * 
 *     @staticmethod
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_builtin_NotImplemented);
  __pyx_r = __pyx_builtin_NotImplemented;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1463
 *         return (_create_datetime, (date_type, args, kwargs))
 * 
 *     cdef _add_timedelta(self, other):             # <<<<<<<<<<<<<<
 *         return NotImplemented
 * 
*/

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

/* "cftime/_cftime.pyx":1466
 *         return NotImplemented
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def fromordinal(jday,calendar='standard',has_year_zero=None):
 *         """Create a datetime instance from a julian day ordinal, calendar
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_29fromordinal(CYTHON_UNUSED PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_28fromordinal, "datetime.fromordinal(jday, calendar='standard', has_year_zero=None)\n\nCreate a datetime instance from a julian day ordinal, calendar\nand (optionally) year zero convention (inverse of toordinal). The\nJulian day number is the number of days since noon UTC January 1, -4713\nin the proleptic julian calendar with no year zero  (November 24, -4713 \nin the proleptic gregorian calendar that includes the year zero). For\nidealized calendars, the origin is noon UTC of the year zero.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_29fromordinal = {"fromordinal", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_29fromordinal, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_28fromordinal};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_29fromordinal(CYTHON_UNUSED PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_jday = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[3] = {0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("fromordinal (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_jday,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1466, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1466, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1466, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1466, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "fromordinal", 0) < (0)) __PYX_ERR(0, 1466, __pyx_L3_error)
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));

      /* "cftime/_cftime.pyx":1467
 * 
 *     @staticmethod
 *     def fromordinal(jday,calendar='standard',has_year_zero=None):             # <<<<<<<<<<<<<<
 *         """Create a datetime instance from a julian day ordinal, calendar
 *         and (optionally) year zero convention (inverse of toordinal). The
*/
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("fromordinal", 0, 1, 3, i); __PYX_ERR(0, 1466, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1466, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1466, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1466, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_n_u_standard));
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_jday = values[0];
    __pyx_v_calendar = values[1];
    __pyx_v_has_year_zero = values[2];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("fromordinal", 0, 1, 3, __pyx_nargs); __PYX_ERR(0, 1466, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.fromordinal", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_28fromordinal(__pyx_v_jday, __pyx_v_calendar, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1466
 *         return NotImplemented
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def fromordinal(jday,calendar='standard',has_year_zero=None):
 *         """Create a datetime instance from a julian day ordinal, calendar
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_28fromordinal(PyObject *__pyx_v_jday, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_v_units = NULL;
  PyObject *__pyx_v_jd = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_t_4;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  PyObject *__pyx_t_13 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("fromordinal", 0);
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1474
 *         in the proleptic gregorian calendar that includes the year zero). For
 *         idealized calendars, the origin is noon UTC of the year zero."""
 *         calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:
*/
  __pyx_t_2 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1474, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1476
 *         calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:             # <<<<<<<<<<<<<<
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:
*/
  __pyx_t_4 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":1477
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:
 *             has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *         if calendar in ['standard','julian','gregorian']:
 *             if has_year_zero:
*/
    __pyx_t_1 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1477, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_1);
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1476
 *         calendar = calendar.lower()
 *         # set calendar-specific defaults for has_year_zero
 *         if has_year_zero is None:             # <<<<<<<<<<<<<<
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:
*/
  }

  /* "cftime/_cftime.pyx":1478
 *         if has_year_zero is None:
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:             # <<<<<<<<<<<<<<
 *             if has_year_zero:
 *                units = 'days since -4712-1-1-12'
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_1 = __pyx_v_calendar;
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1478, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_4 = __pyx_t_5;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1478, __pyx_L1_error)
  if (!__pyx_t_5) {
  } else {
    __pyx_t_4 = __pyx_t_5;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1478, __pyx_L1_error)
  __pyx_t_4 = __pyx_t_5;
  __pyx_L5_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_5 = __pyx_t_4;
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":1479
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:
 *             if has_year_zero:             # <<<<<<<<<<<<<<
 *                units = 'days since -4712-1-1-12'
 *             else:
*/
    __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1479, __pyx_L1_error)
    if (__pyx_t_5) {

      /* "cftime/_cftime.pyx":1480
 *         if calendar in ['standard','julian','gregorian']:
 *             if has_year_zero:
 *                units = 'days since -4712-1-1-12'             # <<<<<<<<<<<<<<
 *             else:
 *                units = 'days since -4713-1-1-12'
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_days_since_4712_1_1_12);
      __pyx_v_units = __pyx_mstate_global->__pyx_kp_u_days_since_4712_1_1_12;

      /* "cftime/_cftime.pyx":1479
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:
 *             if has_year_zero:             # <<<<<<<<<<<<<<
 *                units = 'days since -4712-1-1-12'
 *             else:
*/
      goto __pyx_L8;
    }

    /* "cftime/_cftime.pyx":1482
 *                units = 'days since -4712-1-1-12'
 *             else:
 *                units = 'days since -4713-1-1-12'             # <<<<<<<<<<<<<<
 *         elif calendar == 'proleptic_gregorian':
 *             if has_year_zero:
*/
    /*else*/ {
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_days_since_4713_1_1_12);
      __pyx_v_units = __pyx_mstate_global->__pyx_kp_u_days_since_4713_1_1_12;
    }
    __pyx_L8:;

    /* "cftime/_cftime.pyx":1478
 *         if has_year_zero is None:
 *             has_year_zero = _year_zero_defaults(calendar)
 *         if calendar in ['standard','julian','gregorian']:             # <<<<<<<<<<<<<<
 *             if has_year_zero:
 *                units = 'days since -4712-1-1-12'
*/
    goto __pyx_L4;
  }

  /* "cftime/_cftime.pyx":1483
 *             else:
 *                units = 'days since -4713-1-1-12'
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             if has_year_zero:
 *                 units = 'days since -4713-11-24-12'
*/
  __pyx_t_5 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1483, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":1484
 *                units = 'days since -4713-1-1-12'
 *         elif calendar == 'proleptic_gregorian':
 *             if has_year_zero:             # <<<<<<<<<<<<<<
 *                 units = 'days since -4713-11-24-12'
 *             else:
*/
    __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1484, __pyx_L1_error)
    if (__pyx_t_5) {

      /* "cftime/_cftime.pyx":1485
 *         elif calendar == 'proleptic_gregorian':
 *             if has_year_zero:
 *                 units = 'days since -4713-11-24-12'             # <<<<<<<<<<<<<<
 *             else:
 *                 units = 'days since -4714-11-24-12'
*/
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_days_since_4713_11_24_12);
      __pyx_v_units = __pyx_mstate_global->__pyx_kp_u_days_since_4713_11_24_12;

      /* "cftime/_cftime.pyx":1484
 *                units = 'days since -4713-1-1-12'
 *         elif calendar == 'proleptic_gregorian':
 *             if has_year_zero:             # <<<<<<<<<<<<<<
 *                 units = 'days since -4713-11-24-12'
 *             else:
*/
      goto __pyx_L9;
    }

    /* "cftime/_cftime.pyx":1487
 *                 units = 'days since -4713-11-24-12'
 *             else:
 *                 units = 'days since -4714-11-24-12'             # <<<<<<<<<<<<<<
 *         else:
 *             units = 'days since 0-1-1-12'
*/
    /*else*/ {
      __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_days_since_4714_11_24_12);
      __pyx_v_units = __pyx_mstate_global->__pyx_kp_u_days_since_4714_11_24_12;
    }
    __pyx_L9:;

    /* "cftime/_cftime.pyx":1483
 *             else:
 *                units = 'days since -4713-1-1-12'
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             if has_year_zero:
 *                 units = 'days since -4713-11-24-12'
*/
    goto __pyx_L4;
  }

  /* "cftime/_cftime.pyx":1489
 *                 units = 'days since -4714-11-24-12'
 *         else:
 *             units = 'days since 0-1-1-12'             # <<<<<<<<<<<<<<
 *         # suppress warning about invalid CF date (year <= 0)
 *         with warnings.catch_warnings():
*/
  /*else*/ {
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_days_since_0_1_1_12);
    __pyx_v_units = __pyx_mstate_global->__pyx_kp_u_days_since_0_1_1_12;
  }
  __pyx_L4:;

  /* "cftime/_cftime.pyx":1491
 *             units = 'days since 0-1-1-12'
 *         # suppress warning about invalid CF date (year <= 0)
 *         with warnings.catch_warnings():             # <<<<<<<<<<<<<<
 *             warnings.simplefilter("ignore",category=CFWarning)
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)
*/
  /*with:*/ {
    __pyx_t_2 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_warnings); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1491, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_catch_warnings); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1491, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_3 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_3 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __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(0, 1491, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_8 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_exit); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1491, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_2 = NULL;
    __pyx_t_6 = __Pyx_PyObject_LookupSpecial(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_enter); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1491, __pyx_L10_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_3 = 1;
    #if CYTHON_UNPACK_METHODS
    if (likely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_2);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_2);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_3 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
      __pyx_t_7 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1491, __pyx_L10_error)
      __Pyx_GOTREF(__pyx_t_7);
    }
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    /*try:*/ {
      {
        __Pyx_PyThreadState_declare
        __Pyx_PyThreadState_assign
        __Pyx_ExceptionSave(&__pyx_t_9, &__pyx_t_10, &__pyx_t_11);
        __Pyx_XGOTREF(__pyx_t_9);
        __Pyx_XGOTREF(__pyx_t_10);
        __Pyx_XGOTREF(__pyx_t_11);
        /*try:*/ {

          /* "cftime/_cftime.pyx":1492
 *         # suppress warning about invalid CF date (year <= 0)
 *         with warnings.catch_warnings():
 *             warnings.simplefilter("ignore",category=CFWarning)             # <<<<<<<<<<<<<<
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)
 *         return jd
*/
          __pyx_t_7 = NULL;
          __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_warnings); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1492, __pyx_L14_error)
          __Pyx_GOTREF(__pyx_t_6);
          __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_simplefilter); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1492, __pyx_L14_error)
          __Pyx_GOTREF(__pyx_t_2);
          __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
          __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_CFWarning); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1492, __pyx_L14_error)
          __Pyx_GOTREF(__pyx_t_6);
          __pyx_t_3 = 1;
          #if CYTHON_UNPACK_METHODS
          if (unlikely(PyMethod_Check(__pyx_t_2))) {
            __pyx_t_7 = PyMethod_GET_SELF(__pyx_t_2);
            assert(__pyx_t_7);
            PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
            __Pyx_INCREF(__pyx_t_7);
            __Pyx_INCREF(__pyx__function);
            __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
            __pyx_t_3 = 0;
          }
          #endif
          {
            PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_7, __pyx_mstate_global->__pyx_n_u_ignore};
            __pyx_t_12 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1492, __pyx_L14_error)
            __Pyx_GOTREF(__pyx_t_12);
            if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_category, __pyx_t_6, __pyx_t_12, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1492, __pyx_L14_error)
            __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_12);
            __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
            __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
            __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
            __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
            if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1492, __pyx_L14_error)
            __Pyx_GOTREF(__pyx_t_1);
          }
          __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;

          /* "cftime/_cftime.pyx":1493
 *         with warnings.catch_warnings():
 *             warnings.simplefilter("ignore",category=CFWarning)
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         return jd
 * 
*/
          __pyx_t_2 = NULL;
          __Pyx_GetModuleGlobalName(__pyx_t_12, __pyx_mstate_global->__pyx_n_u_num2date); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1493, __pyx_L14_error)
          __Pyx_GOTREF(__pyx_t_12);
          __pyx_t_3 = 1;
          #if CYTHON_UNPACK_METHODS
          if (unlikely(PyMethod_Check(__pyx_t_12))) {
            __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_12);
            assert(__pyx_t_2);
            PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_12);
            __Pyx_INCREF(__pyx_t_2);
            __Pyx_INCREF(__pyx__function);
            __Pyx_DECREF_SET(__pyx_t_12, __pyx__function);
            __pyx_t_3 = 0;
          }
          #endif
          {
            PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 3 : 0)] = {__pyx_t_2, __pyx_v_jday};
            __pyx_t_6 = __Pyx_MakeVectorcallBuilderKwds(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1493, __pyx_L14_error)
            __Pyx_GOTREF(__pyx_t_6);
            if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_units_2, __pyx_v_units, __pyx_t_6, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1493, __pyx_L14_error)
            if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_6, __pyx_callargs+2, 1) < (0)) __PYX_ERR(0, 1493, __pyx_L14_error)
            if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_6, __pyx_callargs+2, 2) < (0)) __PYX_ERR(0, 1493, __pyx_L14_error)
            __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder((PyObject*)__pyx_t_12, __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_6);
            __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
            __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
            __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;
            if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1493, __pyx_L14_error)
            __Pyx_GOTREF(__pyx_t_1);
          }
          __pyx_v_jd = __pyx_t_1;
          __pyx_t_1 = 0;

          /* "cftime/_cftime.pyx":1491
 *             units = 'days since 0-1-1-12'
 *         # suppress warning about invalid CF date (year <= 0)
 *         with warnings.catch_warnings():             # <<<<<<<<<<<<<<
 *             warnings.simplefilter("ignore",category=CFWarning)
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)
*/
        }
        __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0;
        __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
        __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
        goto __pyx_L19_try_end;
        __pyx_L14_error:;
        __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
        __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
        __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
        /*except:*/ {
          __Pyx_AddTraceback("cftime._cftime.datetime.fromordinal", __pyx_clineno, __pyx_lineno, __pyx_filename);
          if (__Pyx_GetException(&__pyx_t_1, &__pyx_t_12, &__pyx_t_6) < 0) __PYX_ERR(0, 1491, __pyx_L16_except_error)
          __Pyx_XGOTREF(__pyx_t_1);
          __Pyx_XGOTREF(__pyx_t_12);
          __Pyx_XGOTREF(__pyx_t_6);
          __pyx_t_2 = PyTuple_Pack(3, __pyx_t_1, __pyx_t_12, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1491, __pyx_L16_except_error)
          __Pyx_GOTREF(__pyx_t_2);
          __pyx_t_13 = __Pyx_PyObject_Call(__pyx_t_8, __pyx_t_2, NULL);
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
          if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 1491, __pyx_L16_except_error)
          __Pyx_GOTREF(__pyx_t_13);
          __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_13);
          __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
          if (__pyx_t_5 < (0)) __PYX_ERR(0, 1491, __pyx_L16_except_error)
          __pyx_t_4 = (!__pyx_t_5);
          if (unlikely(__pyx_t_4)) {
            __Pyx_GIVEREF(__pyx_t_1);
            __Pyx_GIVEREF(__pyx_t_12);
            __Pyx_XGIVEREF(__pyx_t_6);
            __Pyx_ErrRestoreWithState(__pyx_t_1, __pyx_t_12, __pyx_t_6);
            __pyx_t_1 = 0;  __pyx_t_12 = 0;  __pyx_t_6 = 0; 
            __PYX_ERR(0, 1491, __pyx_L16_except_error)
          }
          __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
          __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0;
          __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
          goto __pyx_L15_exception_handled;
        }
        __pyx_L16_except_error:;
        __Pyx_XGIVEREF(__pyx_t_9);
        __Pyx_XGIVEREF(__pyx_t_10);
        __Pyx_XGIVEREF(__pyx_t_11);
        __Pyx_ExceptionReset(__pyx_t_9, __pyx_t_10, __pyx_t_11);
        goto __pyx_L1_error;
        __pyx_L15_exception_handled:;
        __Pyx_XGIVEREF(__pyx_t_9);
        __Pyx_XGIVEREF(__pyx_t_10);
        __Pyx_XGIVEREF(__pyx_t_11);
        __Pyx_ExceptionReset(__pyx_t_9, __pyx_t_10, __pyx_t_11);
        __pyx_L19_try_end:;
      }
    }
    /*finally:*/ {
      /*normal exit:*/{
        if (__pyx_t_8) {
          __pyx_t_11 = __Pyx_PyObject_Call(__pyx_t_8, __pyx_mstate_global->__pyx_tuple[3], NULL);
          __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
          if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1491, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_11);
          __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
        }
        goto __pyx_L13;
      }
      __pyx_L13:;
    }
    goto __pyx_L23;
    __pyx_L10_error:;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    goto __pyx_L1_error;
    __pyx_L23:;
  }

  /* "cftime/_cftime.pyx":1494
 *             warnings.simplefilter("ignore",category=CFWarning)
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)
 *         return jd             # <<<<<<<<<<<<<<
 * 
 *     def toordinal(self,fractional=False):
*/
  __Pyx_XDECREF(__pyx_r);
  if (unlikely(!__pyx_v_jd)) { __Pyx_RaiseUnboundLocalError("jd"); __PYX_ERR(0, 1494, __pyx_L1_error) }
  __Pyx_INCREF(__pyx_v_jd);
  __pyx_r = __pyx_v_jd;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1466
 *         return NotImplemented
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def fromordinal(jday,calendar='standard',has_year_zero=None):
 *         """Create a datetime instance from a julian day ordinal, calendar
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_AddTraceback("cftime._cftime.datetime.fromordinal", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_units);
  __Pyx_XDECREF(__pyx_v_jd);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1496
 *         return jd
 * 
 *     def toordinal(self,fractional=False):             # <<<<<<<<<<<<<<
 *         """Return (integer) julian day ordinal.
 * 
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_31toordinal(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_30toordinal, "datetime.toordinal(self, fractional=False)\n\nReturn (integer) julian day ordinal.\n\nDay 0 starts at noon January 1 of the year -4713 for the\njulian, gregorian and standard calendars (year -4712 if year\nzero allowed).\n\nDay 0 starts at noon on November 24 of the year -4714 for the\nproleptic gregorian calendar (year -4713 if year zero allowed).\n\nDay 0 starts at noon on January 1 of the year zero is for the\n360_day, 365_day, 366_day, all_leap and noleap calendars.\n\nIf fractional=True, fractional part of day is included (default\nFalse).");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_31toordinal = {"toordinal", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_31toordinal, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_30toordinal};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_31toordinal(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_fractional = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[1] = {0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("toordinal (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_fractional,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1496, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1496, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "toordinal", 0) < (0)) __PYX_ERR(0, 1496, __pyx_L3_error)
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)Py_False));
    } else {
      switch (__pyx_nargs) {
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1496, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)Py_False));
    }
    __pyx_v_fractional = values[0];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("toordinal", 0, 0, 1, __pyx_nargs); __PYX_ERR(0, 1496, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.toordinal", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_30toordinal(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_fractional);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_30toordinal(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_fractional) {
  PyObject *__pyx_v_ijd = NULL;
  PyObject *__pyx_v_fracday = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__IntJulianDayFromDate __pyx_t_4;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  size_t __pyx_t_9;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("toordinal", 0);

  /* "cftime/_cftime.pyx":1511
 *         If fractional=True, fractional part of day is included (default
 *         False)."""
 *         ijd = _IntJulianDayFromDate(self.year, self.month, self.day, self.calendar,             # <<<<<<<<<<<<<<
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:
*/
  __pyx_t_1 = __pyx_v_self->calendar;
  __Pyx_INCREF(__pyx_t_1);

  /* "cftime/_cftime.pyx":1512
 *         False)."""
 *         ijd = _IntJulianDayFromDate(self.year, self.month, self.day, self.calendar,
 *                skip_transition=False,has_year_zero=self.has_year_zero)             # <<<<<<<<<<<<<<
 *         if fractional:
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
*/
  __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1512, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);

  /* "cftime/_cftime.pyx":1511
 *         If fractional=True, fractional part of day is included (default
 *         False)."""
 *         ijd = _IntJulianDayFromDate(self.year, self.month, self.day, self.calendar,             # <<<<<<<<<<<<<<
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:
*/
  __pyx_t_4.__pyx_n = 2;
  __pyx_t_4.skip_transition = Py_False;
  __pyx_t_4.has_year_zero = __pyx_t_2;
  __pyx_t_3 = __pyx_f_6cftime_7_cftime__IntJulianDayFromDate(__pyx_v_self->year, __pyx_v_self->month, __pyx_v_self->day, __pyx_t_1, &__pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1511, __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_v_ijd = __pyx_t_3;
  __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1513
 *         ijd = _IntJulianDayFromDate(self.year, self.month, self.day, self.calendar,
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:             # <<<<<<<<<<<<<<
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \
*/
  __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_v_fractional); if (unlikely((__pyx_t_5 < 0))) __PYX_ERR(0, 1513, __pyx_L1_error)
  if (__pyx_t_5) {

    /* "cftime/_cftime.pyx":1514
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:
 *             fracday = self.hour / np.array(24.,np.longdouble) + \             # <<<<<<<<<<<<<<
 *                       self.minute / np.array(1440.0,np.longdouble) + \
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\
*/
    __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_7))) {
      __pyx_t_1 = PyMethod_GET_SELF(__pyx_t_7);
      assert(__pyx_t_1);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_7);
      __Pyx_INCREF(__pyx_t_1);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_7, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_1, __pyx_mstate_global->__pyx_float_24_, __pyx_t_8};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_7, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
      __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1514, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_7 = __Pyx_PyNumber_Divide(__pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1515
 *         if fractional:
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \             # <<<<<<<<<<<<<<
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\
 *                       np.array(86400.0,np.longdouble)
*/
    __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_8 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_6 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_6))) {
      __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_6);
      assert(__pyx_t_8);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_6);
      __Pyx_INCREF(__pyx_t_8);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_6, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_8, __pyx_mstate_global->__pyx_float_1440_0, __pyx_t_10};
      __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_6, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1515, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = __Pyx_PyNumber_Divide(__pyx_t_2, __pyx_t_3); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1514
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:
 *             fracday = self.hour / np.array(24.,np.longdouble) + \             # <<<<<<<<<<<<<<
 *                       self.minute / np.array(1440.0,np.longdouble) + \
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\
*/
    __pyx_t_3 = PyNumber_Add(__pyx_t_7, __pyx_t_6); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1514, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

    /* "cftime/_cftime.pyx":1516
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\             # <<<<<<<<<<<<<<
 *                       np.array(86400.0,np.longdouble)
 *             # at this point jd is an integer representing noon UTC on the given
*/
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_10 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_1))) {
      __pyx_t_10 = PyMethod_GET_SELF(__pyx_t_1);
      assert(__pyx_t_10);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_1);
      __Pyx_INCREF(__pyx_t_10);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_1, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_10, __pyx_mstate_global->__pyx_float_1_e6, __pyx_t_11};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_1, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1516, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
    }
    __pyx_t_1 = __Pyx_PyNumber_Divide(__pyx_t_7, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = PyNumber_Add(__pyx_t_6, __pyx_t_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1517
 *                       self.minute / np.array(1440.0,np.longdouble) + \
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\
 *                       np.array(86400.0,np.longdouble)             # <<<<<<<<<<<<<<
 *             # at this point jd is an integer representing noon UTC on the given
 *             # year,month,day.
*/
    __pyx_t_6 = NULL;
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1517, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1517, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_GetModuleGlobalName(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1517, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_7);
    __pyx_t_10 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_mstate_global->__pyx_n_u_longdouble); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1517, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_10);
    __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0;
    __pyx_t_9 = 1;
    #if CYTHON_UNPACK_METHODS
    if (unlikely(PyMethod_Check(__pyx_t_11))) {
      __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_11);
      assert(__pyx_t_6);
      PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_11);
      __Pyx_INCREF(__pyx_t_6);
      __Pyx_INCREF(__pyx__function);
      __Pyx_DECREF_SET(__pyx_t_11, __pyx__function);
      __pyx_t_9 = 0;
    }
    #endif
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_6, __pyx_mstate_global->__pyx_float_86400_0, __pyx_t_10};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_9, (3-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;
      __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1517, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }

    /* "cftime/_cftime.pyx":1516
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\             # <<<<<<<<<<<<<<
 *                       np.array(86400.0,np.longdouble)
 *             # at this point jd is an integer representing noon UTC on the given
*/
    __pyx_t_11 = __Pyx_PyNumber_Divide(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1516, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1515
 *         if fractional:
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \             # <<<<<<<<<<<<<<
 *                       (self.second + self.microsecond/(np.array(1.e6,np.longdouble)))/\
 *                       np.array(86400.0,np.longdouble)
*/
    __pyx_t_1 = PyNumber_Add(__pyx_t_3, __pyx_t_11); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1515, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    __pyx_v_fracday = __pyx_t_1;
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1521
 *             # year,month,day.
 *             # compute fractional day from hour,minute,second,microsecond
 *             return ijd - 0.5 + fracday             # <<<<<<<<<<<<<<
 *         else:
 *             return ijd
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_1 = __Pyx_PyFloat_SubtractObjC(__pyx_v_ijd, __pyx_mstate_global->__pyx_float_0_5, 0.5, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1521, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_11 = PyNumber_Add(__pyx_t_1, __pyx_v_fracday); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1521, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_11);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_r = __pyx_t_11;
    __pyx_t_11 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1513
 *         ijd = _IntJulianDayFromDate(self.year, self.month, self.day, self.calendar,
 *                skip_transition=False,has_year_zero=self.has_year_zero)
 *         if fractional:             # <<<<<<<<<<<<<<
 *             fracday = self.hour / np.array(24.,np.longdouble) + \
 *                       self.minute / np.array(1440.0,np.longdouble) + \
*/
  }

  /* "cftime/_cftime.pyx":1523
 *             return ijd - 0.5 + fracday
 *         else:
 *             return ijd             # <<<<<<<<<<<<<<
 * 
 *     def change_calendar(self,calendar,has_year_zero=None):
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_v_ijd);
    __pyx_r = __pyx_v_ijd;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1496
 *         return jd
 * 
 *     def toordinal(self,fractional=False):             # <<<<<<<<<<<<<<
 *         """Return (integer) julian day ordinal.
 * 
*/

  /* 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_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_AddTraceback("cftime._cftime.datetime.toordinal", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_ijd);
  __Pyx_XDECREF(__pyx_v_fracday);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1525
 *             return ijd
 * 
 *     def change_calendar(self,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_33change_calendar(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_8datetime_32change_calendar, "datetime.change_calendar(self, calendar, has_year_zero=None)");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_8datetime_33change_calendar = {"change_calendar", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_33change_calendar, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_32change_calendar};
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_33change_calendar(PyObject *__pyx_v_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[2] = {0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("change_calendar (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1525, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1525, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1525, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "change_calendar", 0) < (0)) __PYX_ERR(0, 1525, __pyx_L3_error)
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 1; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("change_calendar", 0, 1, 2, i); __PYX_ERR(0, 1525, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1525, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1525, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[1]) values[1] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_calendar = values[0];
    __pyx_v_has_year_zero = values[1];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("change_calendar", 0, 1, 2, __pyx_nargs); __PYX_ERR(0, 1525, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.datetime.change_calendar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_32change_calendar(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_v_calendar, __pyx_v_has_year_zero);

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_32change_calendar(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("change_calendar", 0);

  /* "cftime/_cftime.pyx":1528
 *         cdef datetime dt
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
 *         if calendar in _idealized_calendars or self.calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *             raise ValueError('change_calendar only works for real-world calendars')
 *         # fixed frame of reference is days since -4713-1-1 in the Julian calendar with no year zero
*/
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1528, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = (__Pyx_PySequence_ContainsTF(__pyx_v_calendar, __pyx_t_2, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1528, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (!__pyx_t_3) {
  } else {
    __pyx_t_1 = __pyx_t_3;
    goto __pyx_L4_bool_binop_done;
  }
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_idealized_calendars); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1528, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_3 = (__Pyx_PySequence_ContainsTF(__pyx_v_self->calendar, __pyx_t_2, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1528, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_1 = __pyx_t_3;
  __pyx_L4_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1529
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
 *         if calendar in _idealized_calendars or self.calendar in _idealized_calendars:
 *             raise ValueError('change_calendar only works for real-world calendars')             # <<<<<<<<<<<<<<
 *         # fixed frame of reference is days since -4713-1-1 in the Julian calendar with no year zero
 *         return self.fromordinal(self.toordinal(fractional=True),
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_change_calendar_only_works_for_r};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1529, __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(0, 1529, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1528
 *         cdef datetime dt
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
 *         if calendar in _idealized_calendars or self.calendar in _idealized_calendars:             # <<<<<<<<<<<<<<
 *             raise ValueError('change_calendar only works for real-world calendars')
 *         # fixed frame of reference is days since -4713-1-1 in the Julian calendar with no year zero
*/
  }

  /* "cftime/_cftime.pyx":1531
 *             raise ValueError('change_calendar only works for real-world calendars')
 *         # fixed frame of reference is days since -4713-1-1 in the Julian calendar with no year zero
 *         return self.fromordinal(self.toordinal(fractional=True),             # <<<<<<<<<<<<<<
 *                                 calendar=calendar,has_year_zero=has_year_zero)
 * 
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_4 = ((PyObject *)__pyx_v_self);
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_7 = ((PyObject *)__pyx_v_self);
  __Pyx_INCREF(__pyx_t_7);
  __pyx_t_5 = 0;
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_7, NULL};
    __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_fractional, Py_True, __pyx_t_8, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __pyx_t_6 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_toordinal, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
    __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }

  /* "cftime/_cftime.pyx":1532
 *         # fixed frame of reference is days since -4713-1-1 in the Julian calendar with no year zero
 *         return self.fromordinal(self.toordinal(fractional=True),
 *                                 calendar=calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     def __add__(self, other):
*/
  __pyx_t_5 = 0;
  {
    PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 2 : 0)] = {__pyx_t_4, __pyx_t_6};
    __pyx_t_8 = __Pyx_MakeVectorcallBuilderKwds(2); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_calendar, __pyx_v_calendar, __pyx_t_8, __pyx_callargs+2, 0) < (0)) __PYX_ERR(0, 1531, __pyx_L1_error)
    if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_v_has_year_zero, __pyx_t_8, __pyx_callargs+2, 1) < (0)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __pyx_t_2 = __Pyx_Object_VectorcallMethod_CallFromBuilder((PyObject*)__pyx_mstate_global->__pyx_n_u_fromordinal, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_8);
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1531, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1525
 *             return ijd
 * 
 *     def change_calendar(self,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_7);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_AddTraceback("cftime._cftime.datetime.change_calendar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1534
 *                                 calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     def __add__(self, other):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         cdef bint has_year_zero
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_35__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_other); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_35__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_other) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__add__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_34__add__(((PyObject *)__pyx_v_self), ((PyObject *)__pyx_v_other));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_34__add__(PyObject *__pyx_v_self, PyObject *__pyx_v_other) {
  struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt = 0;
  int __pyx_v_has_year_zero;
  PyObject *__pyx_v_calendar = NULL;
  PyObject *__pyx_v_delta = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  int __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__add__", 0);

  /* "cftime/_cftime.pyx":1537
 *         cdef datetime dt
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime) and isinstance(other, timedelta):             # <<<<<<<<<<<<<<
 *             dt = self
 *             calendar = self.calendar
*/
  __pyx_t_2 = __Pyx_TypeCheck(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); 
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L4_bool_binop_done;
  }
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1537, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = PyObject_IsInstance(__pyx_v_other, __pyx_t_3); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(0, 1537, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_1 = __pyx_t_2;
  __pyx_L4_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1538
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime) and isinstance(other, timedelta):
 *             dt = self             # <<<<<<<<<<<<<<
 *             calendar = self.calendar
 *             has_year_zero = self.has_year_zero
*/
    __pyx_t_3 = __pyx_v_self;
    __Pyx_INCREF(__pyx_t_3);
    if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1538, __pyx_L1_error)
    __pyx_v_dt = ((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1539
 *         if isinstance(self, datetime) and isinstance(other, timedelta):
 *             dt = self
 *             calendar = self.calendar             # <<<<<<<<<<<<<<
 *             has_year_zero = self.has_year_zero
 *             delta = other
*/
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1539, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_v_calendar = __pyx_t_3;
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1540
 *             dt = self
 *             calendar = self.calendar
 *             has_year_zero = self.has_year_zero             # <<<<<<<<<<<<<<
 *             delta = other
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):
*/
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1540, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1540, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_has_year_zero = __pyx_t_1;

    /* "cftime/_cftime.pyx":1541
 *             calendar = self.calendar
 *             has_year_zero = self.has_year_zero
 *             delta = other             # <<<<<<<<<<<<<<
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):
 *             dt = other
*/
    __Pyx_INCREF(__pyx_v_other);
    __pyx_v_delta = __pyx_v_other;

    /* "cftime/_cftime.pyx":1537
 *         cdef datetime dt
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime) and isinstance(other, timedelta):             # <<<<<<<<<<<<<<
 *             dt = self
 *             calendar = self.calendar
*/
    goto __pyx_L3;
  }

  /* "cftime/_cftime.pyx":1542
 *             has_year_zero = self.has_year_zero
 *             delta = other
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *             dt = other
 *             calendar = other.calendar
*/
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1542, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_2 = PyObject_IsInstance(__pyx_v_self, __pyx_t_3); if (unlikely(__pyx_t_2 == ((int)-1))) __PYX_ERR(0, 1542, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  if (__pyx_t_2) {
  } else {
    __pyx_t_1 = __pyx_t_2;
    goto __pyx_L6_bool_binop_done;
  }
  __pyx_t_2 = __Pyx_TypeCheck(__pyx_v_other, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); 
  __pyx_t_1 = __pyx_t_2;
  __pyx_L6_bool_binop_done:;
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1543
 *             delta = other
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):
 *             dt = other             # <<<<<<<<<<<<<<
 *             calendar = other.calendar
 *             has_year_zero = other.has_year_zero
*/
    __pyx_t_3 = __pyx_v_other;
    __Pyx_INCREF(__pyx_t_3);
    if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1543, __pyx_L1_error)
    __pyx_v_dt = ((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1544
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):
 *             dt = other
 *             calendar = other.calendar             # <<<<<<<<<<<<<<
 *             has_year_zero = other.has_year_zero
 *             delta = self
*/
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1544, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_v_calendar = __pyx_t_3;
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1545
 *             dt = other
 *             calendar = other.calendar
 *             has_year_zero = other.has_year_zero             # <<<<<<<<<<<<<<
 *             delta = self
 *         else:
*/
    __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1545, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1545, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_has_year_zero = __pyx_t_1;

    /* "cftime/_cftime.pyx":1546
 *             calendar = other.calendar
 *             has_year_zero = other.has_year_zero
 *             delta = self             # <<<<<<<<<<<<<<
 *         else:
 *             return NotImplemented
*/
    __Pyx_INCREF(__pyx_v_self);
    __pyx_v_delta = __pyx_v_self;

    /* "cftime/_cftime.pyx":1542
 *             has_year_zero = self.has_year_zero
 *             delta = other
 *         elif isinstance(self, timedelta) and isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *             dt = other
 *             calendar = other.calendar
*/
    goto __pyx_L3;
  }

  /* "cftime/_cftime.pyx":1548
 *             delta = self
 *         else:
 *             return NotImplemented             # <<<<<<<<<<<<<<
 *         # return calendar-specific subclasses for backward compatibility,
 *         # even though after 1.3.0 this is no longer necessary.
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_builtin_NotImplemented);
    __pyx_r = __pyx_builtin_NotImplemented;
    goto __pyx_L0;
  }
  __pyx_L3:;

  /* "cftime/_cftime.pyx":1551
 *         # return calendar-specific subclasses for backward compatibility,
 *         # even though after 1.3.0 this is no longer necessary.
 *         if calendar == '360_day':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta_360_day(dt, delta),calendar=calendar)
 *             return Datetime360Day(*add_timedelta_360_day(dt, delta))
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1551, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1553
 *         if calendar == '360_day':
 *             #return dt.__class__(*add_timedelta_360_day(dt, delta),calendar=calendar)
 *             return Datetime360Day(*add_timedelta_360_day(dt, delta))             # <<<<<<<<<<<<<<
 *         elif calendar == 'noleap':
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta_360_day(__pyx_v_dt, __pyx_v_delta); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1553, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    if (unlikely(__pyx_t_3 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1553, __pyx_L1_error)
    }
    __pyx_t_4 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_Datetime360Day), __pyx_t_3, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1553, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1551
 *         # return calendar-specific subclasses for backward compatibility,
 *         # even though after 1.3.0 this is no longer necessary.
 *         if calendar == '360_day':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta_360_day(dt, delta),calendar=calendar)
 *             return Datetime360Day(*add_timedelta_360_day(dt, delta))
*/
  }

  /* "cftime/_cftime.pyx":1554
 *             #return dt.__class__(*add_timedelta_360_day(dt, delta),calendar=calendar)
 *             return Datetime360Day(*add_timedelta_360_day(dt, delta))
 *         elif calendar == 'noleap':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
 *             return DatetimeNoLeap(*add_timedelta(dt, delta, no_leap, False, True))
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1554, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1556
 *         elif calendar == 'noleap':
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
 *             return DatetimeNoLeap(*add_timedelta(dt, delta, no_leap, False, True))             # <<<<<<<<<<<<<<
 *         elif calendar == 'all_leap':
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = __pyx_f_6cftime_7_cftime_add_timedelta(__pyx_v_dt, __pyx_v_delta, __pyx_f_6cftime_7_cftime_no_leap, 0, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (unlikely(__pyx_t_4 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1556, __pyx_L1_error)
    }
    __pyx_t_3 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap), __pyx_t_4, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1556, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_r = __pyx_t_3;
    __pyx_t_3 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1554
 *             #return dt.__class__(*add_timedelta_360_day(dt, delta),calendar=calendar)
 *             return Datetime360Day(*add_timedelta_360_day(dt, delta))
 *         elif calendar == 'noleap':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
 *             return DatetimeNoLeap(*add_timedelta(dt, delta, no_leap, False, True))
*/
  }

  /* "cftime/_cftime.pyx":1557
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
 *             return DatetimeNoLeap(*add_timedelta(dt, delta, no_leap, False, True))
 *         elif calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
 *             return DatetimeAllLeap(*add_timedelta(dt, delta, all_leap, False, True))
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_all_leap, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1557, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1559
 *         elif calendar == 'all_leap':
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
 *             return DatetimeAllLeap(*add_timedelta(dt, delta, all_leap, False, True))             # <<<<<<<<<<<<<<
 *         elif calendar == 'julian':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta(__pyx_v_dt, __pyx_v_delta, __pyx_f_6cftime_7_cftime_all_leap, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1559, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    if (unlikely(__pyx_t_3 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1559, __pyx_L1_error)
    }
    __pyx_t_4 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap), __pyx_t_3, NULL); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1559, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1557
 *             #return dt.__class__(*add_timedelta(dt, delta, no_leap, False, True),calendar=calendar)
 *             return DatetimeNoLeap(*add_timedelta(dt, delta, no_leap, False, True))
 *         elif calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
 *             return DatetimeAllLeap(*add_timedelta(dt, delta, all_leap, False, True))
*/
  }

  /* "cftime/_cftime.pyx":1560
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
 *             return DatetimeAllLeap(*add_timedelta(dt, delta, all_leap, False, True))
 *         elif calendar == 'julian':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeJulian(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),has_year_zero=has_year_zero)
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1560, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1562
 *         elif calendar == 'julian':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeJulian(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         elif calendar == 'standard':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = __pyx_f_6cftime_7_cftime_add_timedelta(__pyx_v_dt, __pyx_v_delta, __pyx_f_6cftime_7_cftime_is_leap_julian, 0, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1562, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (unlikely(__pyx_t_4 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1562, __pyx_L1_error)
    }
    __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1562, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_5 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1562, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_5) < (0)) __PYX_ERR(0, 1562, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeJulian), __pyx_t_4, __pyx_t_3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1562, __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_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1560
 *             #return dt.__class__(*add_timedelta(dt, delta, all_leap, False, True),calendar=calendar)
 *             return DatetimeAllLeap(*add_timedelta(dt, delta, all_leap, False, True))
 *         elif calendar == 'julian':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeJulian(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),has_year_zero=has_year_zero)
*/
  }

  /* "cftime/_cftime.pyx":1563
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeJulian(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),has_year_zero=has_year_zero)
 *         elif calendar == 'standard':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeGregorian(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),has_year_zero=has_year_zero)
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1563, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1565
 *         elif calendar == 'standard':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeGregorian(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         elif calendar == 'proleptic_gregorian':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_5 = __pyx_f_6cftime_7_cftime_add_timedelta(__pyx_v_dt, __pyx_v_delta, __pyx_f_6cftime_7_cftime_is_leap_gregorian, 1, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1565, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (unlikely(__pyx_t_5 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1565, __pyx_L1_error)
    }
    __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1565, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1565, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_4) < (0)) __PYX_ERR(0, 1565, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian), __pyx_t_5, __pyx_t_3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1565, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_r = __pyx_t_4;
    __pyx_t_4 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1563
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeJulian(*add_timedelta(dt, delta, is_leap_julian, False, has_year_zero),has_year_zero=has_year_zero)
 *         elif calendar == 'standard':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeGregorian(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),has_year_zero=has_year_zero)
*/
  }

  /* "cftime/_cftime.pyx":1566
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeGregorian(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeProlepticGregorian(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=has_year_zero)
*/
  __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1566, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1568
 *         elif calendar == 'proleptic_gregorian':
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeProlepticGregorian(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *         else:
 *             return NotImplemented
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_4 = __pyx_f_6cftime_7_cftime_add_timedelta(__pyx_v_dt, __pyx_v_delta, __pyx_f_6cftime_7_cftime_is_leap_proleptic_gregorian, 0, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1568, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    if (unlikely(__pyx_t_4 == Py_None)) {
      PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
      __PYX_ERR(0, 1568, __pyx_L1_error)
    }
    __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1568, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_5 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1568, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_5) < (0)) __PYX_ERR(0, 1568, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
    __pyx_t_5 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian), __pyx_t_4, __pyx_t_3); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1568, __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_r = __pyx_t_5;
    __pyx_t_5 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1566
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeGregorian(*add_timedelta(dt, delta, is_leap_gregorian, True, has_year_zero),has_year_zero=has_year_zero)
 *         elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *             #return dt.__class__(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),calendar=calendar,has_year_zero=has_year_zero)
 *             return DatetimeProlepticGregorian(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=has_year_zero)
*/
  }

  /* "cftime/_cftime.pyx":1570
 *             return DatetimeProlepticGregorian(*add_timedelta(dt, delta, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=has_year_zero)
 *         else:
 *             return NotImplemented             # <<<<<<<<<<<<<<
 * 
 *     def __sub__(self, other):
*/
  /*else*/ {
    __Pyx_XDECREF(__pyx_r);
    __Pyx_INCREF(__pyx_builtin_NotImplemented);
    __pyx_r = __pyx_builtin_NotImplemented;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1534
 *                                 calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     def __add__(self, other):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         cdef bint has_year_zero
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("cftime._cftime.datetime.__add__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF((PyObject *)__pyx_v_dt);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_delta);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1572
 *             return NotImplemented
 * 
 *     def __sub__(self, other):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         cdef bint has_year_zero
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_37__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_other); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_37__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_other) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__sub__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_36__sub__(((PyObject *)__pyx_v_self), ((PyObject *)__pyx_v_other));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_36__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_other) {
  struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt = 0;
  int __pyx_v_has_year_zero;
  PyObject *__pyx_v_ordinal_self = NULL;
  PyObject *__pyx_v_ordinal_other = NULL;
  PyObject *__pyx_v_days = NULL;
  PyObject *__pyx_v_seconds_self = NULL;
  PyObject *__pyx_v_seconds_other = NULL;
  PyObject *__pyx_v_seconds = NULL;
  PyObject *__pyx_v_microseconds = NULL;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  size_t __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  int __pyx_t_6;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__sub__", 0);

  /* "cftime/_cftime.pyx":1575
 *         cdef datetime dt
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime): # left arg is a datetime instance             # <<<<<<<<<<<<<<
 *             dt = self
 *             if isinstance(other, datetime):
*/
  __pyx_t_1 = __Pyx_TypeCheck(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); 
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1576
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime): # left arg is a datetime instance
 *             dt = self             # <<<<<<<<<<<<<<
 *             if isinstance(other, datetime):
 *                 # datetime - datetime
*/
    __pyx_t_2 = __pyx_v_self;
    __Pyx_INCREF(__pyx_t_2);
    if (!(likely(((__pyx_t_2) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_2, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1576, __pyx_L1_error)
    __pyx_v_dt = ((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1577
 *         if isinstance(self, datetime): # left arg is a datetime instance
 *             dt = self
 *             if isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *                 # datetime - datetime
 *                 if dt.calendar != other.calendar:
*/
    __pyx_t_1 = __Pyx_TypeCheck(__pyx_v_other, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); 
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1579
 *             if isinstance(other, datetime):
 *                 # datetime - datetime
 *                 if dt.calendar != other.calendar:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")
 *                 if dt.calendar == "":
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1579, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_dt->calendar, __pyx_t_2, Py_NE)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1579, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(__pyx_t_1)) {

        /* "cftime/_cftime.pyx":1580
 *                 # datetime - datetime
 *                 if dt.calendar != other.calendar:
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")             # <<<<<<<<<<<<<<
 *                 if dt.calendar == "":
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
*/
        __pyx_t_3 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_cannot_compute_the_time_differen};
          __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1580, __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(0, 1580, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1579
 *             if isinstance(other, datetime):
 *                 # datetime - datetime
 *                 if dt.calendar != other.calendar:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")
 *                 if dt.calendar == "":
*/
      }

      /* "cftime/_cftime.pyx":1581
 *                 if dt.calendar != other.calendar:
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")
 *                 if dt.calendar == "":             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
 *                 if dt.has_year_zero != other.has_year_zero:
*/
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_v_dt->calendar, __pyx_mstate_global->__pyx_kp_u__2, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1581, __pyx_L1_error)
      if (unlikely(__pyx_t_1)) {

        /* "cftime/_cftime.pyx":1582
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")
 *                 if dt.calendar == "":
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")             # <<<<<<<<<<<<<<
 *                 if dt.has_year_zero != other.has_year_zero:
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")
*/
        __pyx_t_3 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_cannot_compute_the_time_differen_2};
          __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1582, __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(0, 1582, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1581
 *                 if dt.calendar != other.calendar:
 *                     raise TypeError("cannot compute the time difference between dates with different calendars")
 *                 if dt.calendar == "":             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
 *                 if dt.has_year_zero != other.has_year_zero:
*/
      }

      /* "cftime/_cftime.pyx":1583
 *                 if dt.calendar == "":
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
 *                 if dt.has_year_zero != other.has_year_zero:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")
 *                 ordinal_self = self.toordinal() # julian day
*/
      __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_v_dt->has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1583, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1583, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_5 = PyObject_RichCompare(__pyx_t_2, __pyx_t_3, Py_NE); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1583, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1583, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(__pyx_t_1)) {

        /* "cftime/_cftime.pyx":1584
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
 *                 if dt.has_year_zero != other.has_year_zero:
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")             # <<<<<<<<<<<<<<
 *                 ordinal_self = self.toordinal() # julian day
 *                 ordinal_other = other.toordinal()
*/
        __pyx_t_3 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_cannot_compute_the_time_differen_3};
          __pyx_t_5 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1584, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_5);
        }
        __Pyx_Raise(__pyx_t_5, 0, 0, 0);
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __PYX_ERR(0, 1584, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1583
 *                 if dt.calendar == "":
 *                     raise TypeError("cannot compute the time difference between dates that are not calendar-aware")
 *                 if dt.has_year_zero != other.has_year_zero:             # <<<<<<<<<<<<<<
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")
 *                 ordinal_self = self.toordinal() # julian day
*/
      }

      /* "cftime/_cftime.pyx":1585
 *                 if dt.has_year_zero != other.has_year_zero:
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")
 *                 ordinal_self = self.toordinal() # julian day             # <<<<<<<<<<<<<<
 *                 ordinal_other = other.toordinal()
 *                 days = ordinal_self - ordinal_other
*/
      __pyx_t_3 = __pyx_v_self;
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_4 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
        __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_toordinal, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1585, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __pyx_v_ordinal_self = __pyx_t_5;
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":1586
 *                     raise TypeError("cannot compute the time difference between dates with year zero conventions")
 *                 ordinal_self = self.toordinal() # julian day
 *                 ordinal_other = other.toordinal()             # <<<<<<<<<<<<<<
 *                 days = ordinal_self - ordinal_other
 *                 seconds_self = dt.second + 60 * dt.minute + 3600 * dt.hour
*/
      __pyx_t_3 = __pyx_v_other;
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_4 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
        __pyx_t_5 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_toordinal, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1586, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
      }
      __pyx_v_ordinal_other = __pyx_t_5;
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":1587
 *                 ordinal_self = self.toordinal() # julian day
 *                 ordinal_other = other.toordinal()
 *                 days = ordinal_self - ordinal_other             # <<<<<<<<<<<<<<
 *                 seconds_self = dt.second + 60 * dt.minute + 3600 * dt.hour
 *                 seconds_other = other.second + 60 * other.minute + 3600 * other.hour
*/
      __pyx_t_5 = PyNumber_Subtract(__pyx_v_ordinal_self, __pyx_v_ordinal_other); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1587, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_v_days = __pyx_t_5;
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":1588
 *                 ordinal_other = other.toordinal()
 *                 days = ordinal_self - ordinal_other
 *                 seconds_self = dt.second + 60 * dt.minute + 3600 * dt.hour             # <<<<<<<<<<<<<<
 *                 seconds_other = other.second + 60 * other.minute + 3600 * other.hour
 *                 seconds = seconds_self - seconds_other
*/
      __pyx_t_5 = __Pyx_PyLong_From_long(((__pyx_v_dt->second + (60 * __pyx_v_dt->minute)) + (0xE10 * __pyx_v_dt->hour))); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1588, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_v_seconds_self = __pyx_t_5;
      __pyx_t_5 = 0;

      /* "cftime/_cftime.pyx":1589
 *                 days = ordinal_self - ordinal_other
 *                 seconds_self = dt.second + 60 * dt.minute + 3600 * dt.hour
 *                 seconds_other = other.second + 60 * other.minute + 3600 * other.hour             # <<<<<<<<<<<<<<
 *                 seconds = seconds_self - seconds_other
 *                 microseconds = dt.microsecond - other.microsecond
*/
      __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_second); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_minute); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_2 = __Pyx_PyLong_MultiplyCObj(__pyx_mstate_global->__pyx_int_60, __pyx_t_3, 60, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __pyx_t_3 = PyNumber_Add(__pyx_t_5, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_hour); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_5 = __Pyx_PyLong_MultiplyCObj(__pyx_mstate_global->__pyx_int_3600, __pyx_t_2, 0xE10, 0, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_2 = PyNumber_Add(__pyx_t_3, __pyx_t_5); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1589, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __pyx_v_seconds_other = __pyx_t_2;
      __pyx_t_2 = 0;

      /* "cftime/_cftime.pyx":1590
 *                 seconds_self = dt.second + 60 * dt.minute + 3600 * dt.hour
 *                 seconds_other = other.second + 60 * other.minute + 3600 * other.hour
 *                 seconds = seconds_self - seconds_other             # <<<<<<<<<<<<<<
 *                 microseconds = dt.microsecond - other.microsecond
 *                 return timedelta(days, seconds, microseconds)
*/
      __pyx_t_2 = PyNumber_Subtract(__pyx_v_seconds_self, __pyx_v_seconds_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1590, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_v_seconds = __pyx_t_2;
      __pyx_t_2 = 0;

      /* "cftime/_cftime.pyx":1591
 *                 seconds_other = other.second + 60 * other.minute + 3600 * other.hour
 *                 seconds = seconds_self - seconds_other
 *                 microseconds = dt.microsecond - other.microsecond             # <<<<<<<<<<<<<<
 *                 return timedelta(days, seconds, microseconds)
 *             elif isinstance(other, datetime_python):
*/
      __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_dt->microsecond); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1591, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_microsecond); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1591, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_3 = PyNumber_Subtract(__pyx_t_2, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1591, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      __pyx_v_microseconds = __pyx_t_3;
      __pyx_t_3 = 0;

      /* "cftime/_cftime.pyx":1592
 *                 seconds = seconds_self - seconds_other
 *                 microseconds = dt.microsecond - other.microsecond
 *                 return timedelta(days, seconds, microseconds)             # <<<<<<<<<<<<<<
 *             elif isinstance(other, datetime_python):
 *                 # datetime - real_datetime
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_5 = NULL;
      __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1592, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_4 = 1;
      #if CYTHON_UNPACK_METHODS
      if (unlikely(PyMethod_Check(__pyx_t_2))) {
        __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2);
        assert(__pyx_t_5);
        PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_2);
        __Pyx_INCREF(__pyx_t_5);
        __Pyx_INCREF(__pyx__function);
        __Pyx_DECREF_SET(__pyx_t_2, __pyx__function);
        __pyx_t_4 = 0;
      }
      #endif
      {
        PyObject *__pyx_callargs[4] = {__pyx_t_5, __pyx_v_days, __pyx_v_seconds, __pyx_v_microseconds};
        __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_4, (4-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __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(0, 1592, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
      }
      __pyx_r = __pyx_t_3;
      __pyx_t_3 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":1577
 *         if isinstance(self, datetime): # left arg is a datetime instance
 *             dt = self
 *             if isinstance(other, datetime):             # <<<<<<<<<<<<<<
 *                 # datetime - datetime
 *                 if dt.calendar != other.calendar:
*/
    }

    /* "cftime/_cftime.pyx":1593
 *                 microseconds = dt.microsecond - other.microsecond
 *                 return timedelta(days, seconds, microseconds)
 *             elif isinstance(other, datetime_python):             # <<<<<<<<<<<<<<
 *                 # datetime - real_datetime
 *                 if not dt.datetime_compatible:
*/
    __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1593, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = PyObject_IsInstance(__pyx_v_other, __pyx_t_3); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 1593, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1595
 *             elif isinstance(other, datetime_python):
 *                 # datetime - real_datetime
 *                 if not dt.datetime_compatible:             # <<<<<<<<<<<<<<
 *                     msg="""
 * Cannot compute the time difference between dates with different calendars.
*/
      __pyx_t_1 = (!__pyx_v_dt->datetime_compatible);
      if (unlikely(__pyx_t_1)) {

        /* "cftime/_cftime.pyx":1596
 *                 # datetime - real_datetime
 *                 if not dt.datetime_compatible:
 *                     msg="""             # <<<<<<<<<<<<<<
 * Cannot compute the time difference between dates with different calendars.
 * One of the datetime objects may have been converted to a native python
*/
        __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_Cannot_compute_the_time_differe);
        __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_Cannot_compute_the_time_differe;

        /* "cftime/_cftime.pyx":1601
 * datetime instance.  Try using only_use_cftime_datetimes=True when creating the
 * datetime object."""
 *                     raise TypeError(msg)             # <<<<<<<<<<<<<<
 *                 return dt._to_real_datetime() - other
 *             elif isinstance(other, timedelta):
*/
        __pyx_t_2 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_msg};
          __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
          if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1601, __pyx_L1_error)
          __Pyx_GOTREF(__pyx_t_3);
        }
        __Pyx_Raise(__pyx_t_3, 0, 0, 0);
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        __PYX_ERR(0, 1601, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1595
 *             elif isinstance(other, datetime_python):
 *                 # datetime - real_datetime
 *                 if not dt.datetime_compatible:             # <<<<<<<<<<<<<<
 *                     msg="""
 * Cannot compute the time difference between dates with different calendars.
*/
      }

      /* "cftime/_cftime.pyx":1602
 * datetime object."""
 *                     raise TypeError(msg)
 *                 return dt._to_real_datetime() - other             # <<<<<<<<<<<<<<
 *             elif isinstance(other, timedelta):
 *                 # datetime - timedelta
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_3 = ((struct __pyx_vtabstruct_6cftime_7_cftime_datetime *)__pyx_v_dt->__pyx_vtab)->_to_real_datetime(__pyx_v_dt, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1602, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_2 = PyNumber_Subtract(__pyx_t_3, __pyx_v_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1602, __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;

      /* "cftime/_cftime.pyx":1593
 *                 microseconds = dt.microsecond - other.microsecond
 *                 return timedelta(days, seconds, microseconds)
 *             elif isinstance(other, datetime_python):             # <<<<<<<<<<<<<<
 *                 # datetime - real_datetime
 *                 if not dt.datetime_compatible:
*/
    }

    /* "cftime/_cftime.pyx":1603
 *                     raise TypeError(msg)
 *                 return dt._to_real_datetime() - other
 *             elif isinstance(other, timedelta):             # <<<<<<<<<<<<<<
 *                 # datetime - timedelta
 *                 # return calendar-specific subclasses for backward compatibility,
*/
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_timedelta); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1603, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = PyObject_IsInstance(__pyx_v_other, __pyx_t_2); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 1603, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1607
 *                 # return calendar-specific subclasses for backward compatibility,
 *                 # even though after 1.3.0 this is no longer necessary.
 *                 has_year_zero=self.has_year_zero             # <<<<<<<<<<<<<<
 *                 if self.calendar == '360_day':
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1607, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1607, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_v_has_year_zero = __pyx_t_1;

      /* "cftime/_cftime.pyx":1608
 *                 # even though after 1.3.0 this is no longer necessary.
 *                 has_year_zero=self.has_year_zero
 *                 if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
 *                     return Datetime360Day(*add_timedelta_360_day(self, -other))
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1608, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1608, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1610
 *                 if self.calendar == '360_day':
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
 *                     return Datetime360Day(*add_timedelta_360_day(self, -other))             # <<<<<<<<<<<<<<
 *                 elif self.calendar == 'noleap':
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1610, __pyx_L1_error)
        __pyx_t_2 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1610, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta_360_day(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1610, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(__pyx_t_3 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1610, __pyx_L1_error)
        }
        __pyx_t_2 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_Datetime360Day), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1610, __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;

        /* "cftime/_cftime.pyx":1608
 *                 # even though after 1.3.0 this is no longer necessary.
 *                 has_year_zero=self.has_year_zero
 *                 if self.calendar == '360_day':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
 *                     return Datetime360Day(*add_timedelta_360_day(self, -other))
*/
      }

      /* "cftime/_cftime.pyx":1611
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
 *                     return Datetime360Day(*add_timedelta_360_day(self, -other))
 *                 elif self.calendar == 'noleap':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
 *                     return DatetimeNoLeap(*add_timedelta(self, -other, no_leap, False, True))
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1611, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1611, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1613
 *                 elif self.calendar == 'noleap':
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
 *                     return DatetimeNoLeap(*add_timedelta(self, -other, no_leap, False, True))             # <<<<<<<<<<<<<<
 *                 elif self.calendar == 'all_leap':
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1613, __pyx_L1_error)
        __pyx_t_2 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1613, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_2, __pyx_f_6cftime_7_cftime_no_leap, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1613, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(__pyx_t_3 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1613, __pyx_L1_error)
        }
        __pyx_t_2 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1613, __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;

        /* "cftime/_cftime.pyx":1611
 *                     #return self.__class__(*add_timedelta_360_day(self, -other),calendar=self.calendar)
 *                     return Datetime360Day(*add_timedelta_360_day(self, -other))
 *                 elif self.calendar == 'noleap':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
 *                     return DatetimeNoLeap(*add_timedelta(self, -other, no_leap, False, True))
*/
      }

      /* "cftime/_cftime.pyx":1614
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
 *                     return DatetimeNoLeap(*add_timedelta(self, -other, no_leap, False, True))
 *                 elif self.calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
 *                     return DatetimeAllLeap(*add_timedelta(self, -other, all_leap, False, True))
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1614, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_all_leap, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1614, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1616
 *                 elif self.calendar == 'all_leap':
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
 *                     return DatetimeAllLeap(*add_timedelta(self, -other, all_leap, False, True))             # <<<<<<<<<<<<<<
 *                 elif self.calendar == 'julian':
 *                     #return self.__class__(*add_timedelta(self, -other,
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1616, __pyx_L1_error)
        __pyx_t_2 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1616, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_2, __pyx_f_6cftime_7_cftime_all_leap, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1616, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(__pyx_t_3 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1616, __pyx_L1_error)
        }
        __pyx_t_2 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap), __pyx_t_3, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1616, __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;

        /* "cftime/_cftime.pyx":1614
 *                     #return self.__class__(*add_timedelta(self, -other, no_leap, False, True),calendar=self.calendar)
 *                     return DatetimeNoLeap(*add_timedelta(self, -other, no_leap, False, True))
 *                 elif self.calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
 *                     return DatetimeAllLeap(*add_timedelta(self, -other, all_leap, False, True))
*/
      }

      /* "cftime/_cftime.pyx":1617
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
 *                     return DatetimeAllLeap(*add_timedelta(self, -other, all_leap, False, True))
 *                 elif self.calendar == 'julian':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_julian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1617, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1617, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1620
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_julian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeJulian(*add_timedelta(self, -other, is_leap_julian, False, has_year_zero),has_year_zero=self.has_year_zero)             # <<<<<<<<<<<<<<
 *                 elif self.calendar == 'standard':
 *                     #return self.__class__(*add_timedelta(self, -other,
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1620, __pyx_L1_error)
        __pyx_t_2 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1620, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_add_timedelta(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_2, __pyx_f_6cftime_7_cftime_is_leap_julian, 0, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1620, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        if (unlikely(__pyx_t_3 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1620, __pyx_L1_error)
        }
        __pyx_t_2 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1620, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1620, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        if (PyDict_SetItem(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_5) < (0)) __PYX_ERR(0, 1620, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_t_5 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeJulian), __pyx_t_3, __pyx_t_2); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1620, __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_r = __pyx_t_5;
        __pyx_t_5 = 0;
        goto __pyx_L0;

        /* "cftime/_cftime.pyx":1617
 *                     #return self.__class__(*add_timedelta(self, -other, all_leap, False, True),calendar=self.calendar)
 *                     return DatetimeAllLeap(*add_timedelta(self, -other, all_leap, False, True))
 *                 elif self.calendar == 'julian':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_julian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      }

      /* "cftime/_cftime.pyx":1621
 *                     #     is_leap_julian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeJulian(*add_timedelta(self, -other, is_leap_julian, False, has_year_zero),has_year_zero=self.has_year_zero)
 *                 elif self.calendar == 'standard':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_gregorian, True, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      __pyx_t_5 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1621, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_5);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1621, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1624
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_gregorian, True, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeGregorian(*add_timedelta(self, -other, is_leap_gregorian, True, has_year_zero),has_year_zero=self.has_year_zero)             # <<<<<<<<<<<<<<
 *                 elif self.calendar == 'proleptic_gregorian':
 *                     #return self.__class__(*add_timedelta(self, -other,
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1624, __pyx_L1_error)
        __pyx_t_5 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_2 = __pyx_f_6cftime_7_cftime_add_timedelta(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_5, __pyx_f_6cftime_7_cftime_is_leap_gregorian, 1, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(__pyx_t_2 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1624, __pyx_L1_error)
        }
        __pyx_t_5 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        if (PyDict_SetItem(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_3) < (0)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        __pyx_t_3 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian), __pyx_t_2, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1624, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
        __pyx_r = __pyx_t_3;
        __pyx_t_3 = 0;
        goto __pyx_L0;

        /* "cftime/_cftime.pyx":1621
 *                     #     is_leap_julian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeJulian(*add_timedelta(self, -other, is_leap_julian, False, has_year_zero),has_year_zero=self.has_year_zero)
 *                 elif self.calendar == 'standard':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #     is_leap_gregorian, True, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      }

      /* "cftime/_cftime.pyx":1625
 *                     #     is_leap_gregorian, True, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeGregorian(*add_timedelta(self, -other, is_leap_gregorian, True, has_year_zero),has_year_zero=self.has_year_zero)
 *                 elif self.calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #    is_leap_proleptic_gregorian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_calendar); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1625, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __pyx_t_1 = (__Pyx_PyUnicode_Equals(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1625, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (__pyx_t_1) {

        /* "cftime/_cftime.pyx":1628
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #    is_leap_proleptic_gregorian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeProlepticGregorian(*add_timedelta(self, -other, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=self.has_year_zero)             # <<<<<<<<<<<<<<
 *                 else:
 *                     return NotImplemented
*/
        __Pyx_XDECREF(__pyx_r);
        if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime))))) __PYX_ERR(0, 1628, __pyx_L1_error)
        __pyx_t_3 = PyNumber_Negative(__pyx_v_other); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1628, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __pyx_t_5 = __pyx_f_6cftime_7_cftime_add_timedelta(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self), __pyx_t_3, __pyx_f_6cftime_7_cftime_is_leap_proleptic_gregorian, 0, __pyx_v_has_year_zero); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1628, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_5);
        __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
        if (unlikely(__pyx_t_5 == Py_None)) {
          PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
          __PYX_ERR(0, 1628, __pyx_L1_error)
        }
        __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1628, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_3);
        __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_self, __pyx_mstate_global->__pyx_n_u_has_year_zero); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1628, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
        if (PyDict_SetItem(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_has_year_zero, __pyx_t_2) < (0)) __PYX_ERR(0, 1628, __pyx_L1_error)
        __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
        __pyx_t_2 = __Pyx_PyObject_Call(((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian), __pyx_t_5, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1628, __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_r = __pyx_t_2;
        __pyx_t_2 = 0;
        goto __pyx_L0;

        /* "cftime/_cftime.pyx":1625
 *                     #     is_leap_gregorian, True, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
 *                     return DatetimeGregorian(*add_timedelta(self, -other, is_leap_gregorian, True, has_year_zero),has_year_zero=self.has_year_zero)
 *                 elif self.calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *                     #return self.__class__(*add_timedelta(self, -other,
 *                     #    is_leap_proleptic_gregorian, False, has_year_zero),calendar=self.calendar,has_year_zero=self.has_year_zero)
*/
      }

      /* "cftime/_cftime.pyx":1630
 *                     return DatetimeProlepticGregorian(*add_timedelta(self, -other, is_leap_proleptic_gregorian, False, has_year_zero),has_year_zero=self.has_year_zero)
 *                 else:
 *                     return NotImplemented             # <<<<<<<<<<<<<<
 *             else:
 *                 return NotImplemented
*/
      /*else*/ {
        __Pyx_XDECREF(__pyx_r);
        __Pyx_INCREF(__pyx_builtin_NotImplemented);
        __pyx_r = __pyx_builtin_NotImplemented;
        goto __pyx_L0;
      }

      /* "cftime/_cftime.pyx":1603
 *                     raise TypeError(msg)
 *                 return dt._to_real_datetime() - other
 *             elif isinstance(other, timedelta):             # <<<<<<<<<<<<<<
 *                 # datetime - timedelta
 *                 # return calendar-specific subclasses for backward compatibility,
*/
    }

    /* "cftime/_cftime.pyx":1632
 *                     return NotImplemented
 *             else:
 *                 return NotImplemented             # <<<<<<<<<<<<<<
 *         else:
 *             if isinstance(self, datetime_python):
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __Pyx_INCREF(__pyx_builtin_NotImplemented);
      __pyx_r = __pyx_builtin_NotImplemented;
      goto __pyx_L0;
    }

    /* "cftime/_cftime.pyx":1575
 *         cdef datetime dt
 *         cdef bint has_year_zero
 *         if isinstance(self, datetime): # left arg is a datetime instance             # <<<<<<<<<<<<<<
 *             dt = self
 *             if isinstance(other, datetime):
*/
  }

  /* "cftime/_cftime.pyx":1634
 *                 return NotImplemented
 *         else:
 *             if isinstance(self, datetime_python):             # <<<<<<<<<<<<<<
 *                 # real_datetime - datetime
 *                 if not other.datetime_compatible:
*/
  /*else*/ {
    __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1634, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_1 = PyObject_IsInstance(__pyx_v_self, __pyx_t_2); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 1634, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (__pyx_t_1) {

      /* "cftime/_cftime.pyx":1636
 *             if isinstance(self, datetime_python):
 *                 # real_datetime - datetime
 *                 if not other.datetime_compatible:             # <<<<<<<<<<<<<<
 *                     msg="""
 * Cannot compute the time difference between dates with different calendars.
*/
      __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_v_other, __pyx_mstate_global->__pyx_n_u_datetime_compatible); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1636, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_2);
      __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 1636, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_t_6 = (!__pyx_t_1);
      if (unlikely(__pyx_t_6)) {

        /* "cftime/_cftime.pyx":1637
 *                 # real_datetime - datetime
 *                 if not other.datetime_compatible:
 *                     msg="""             # <<<<<<<<<<<<<<
 * Cannot compute the time difference between dates with different calendars.
 * One of the datetime objects may have been converted to a native python
*/
        __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_Cannot_compute_the_time_differe);
        __pyx_v_msg = __pyx_mstate_global->__pyx_kp_u_Cannot_compute_the_time_differe;

        /* "cftime/_cftime.pyx":1642
 * datetime instance.  Try using only_use_cftime_datetimes=True when creating the
 * datetime object."""
 *                     raise TypeError(msg)             # <<<<<<<<<<<<<<
 *                 return self - other._to_real_datetime()
 *             else:
*/
        __pyx_t_3 = NULL;
        __pyx_t_4 = 1;
        {
          PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_msg};
          __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
          __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
          if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1642, __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(0, 1642, __pyx_L1_error)

        /* "cftime/_cftime.pyx":1636
 *             if isinstance(self, datetime_python):
 *                 # real_datetime - datetime
 *                 if not other.datetime_compatible:             # <<<<<<<<<<<<<<
 *                     msg="""
 * Cannot compute the time difference between dates with different calendars.
*/
      }

      /* "cftime/_cftime.pyx":1643
 * datetime object."""
 *                     raise TypeError(msg)
 *                 return self - other._to_real_datetime()             # <<<<<<<<<<<<<<
 *             else:
 *                 return NotImplemented
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_3 = __pyx_v_other;
      __Pyx_INCREF(__pyx_t_3);
      __pyx_t_4 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL};
        __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_to_real_datetime, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1643, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_2);
      }
      __pyx_t_3 = PyNumber_Subtract(__pyx_v_self, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1643, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      __pyx_r = __pyx_t_3;
      __pyx_t_3 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":1634
 *                 return NotImplemented
 *         else:
 *             if isinstance(self, datetime_python):             # <<<<<<<<<<<<<<
 *                 # real_datetime - datetime
 *                 if not other.datetime_compatible:
*/
    }

    /* "cftime/_cftime.pyx":1645
 *                 return self - other._to_real_datetime()
 *             else:
 *                 return NotImplemented             # <<<<<<<<<<<<<<
 * 
 * _illegal_s = re.compile(r"((^|[^%])(%%)*%s)")
*/
    /*else*/ {
      __Pyx_XDECREF(__pyx_r);
      __Pyx_INCREF(__pyx_builtin_NotImplemented);
      __pyx_r = __pyx_builtin_NotImplemented;
      goto __pyx_L0;
    }
  }

  /* "cftime/_cftime.pyx":1572
 *             return NotImplemented
 * 
 *     def __sub__(self, other):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         cdef bint has_year_zero
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_3);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_AddTraceback("cftime._cftime.datetime.__sub__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XDECREF((PyObject *)__pyx_v_dt);
  __Pyx_XDECREF(__pyx_v_ordinal_self);
  __Pyx_XDECREF(__pyx_v_ordinal_other);
  __Pyx_XDECREF(__pyx_v_days);
  __Pyx_XDECREF(__pyx_v_seconds_self);
  __Pyx_XDECREF(__pyx_v_seconds_other);
  __Pyx_XDECREF(__pyx_v_seconds);
  __Pyx_XDECREF(__pyx_v_microseconds);
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1107
 * (default %Y-%m-%d %H:%M:%S).
 *     """
 *     cdef readonly int year, month, day, hour, minute             # <<<<<<<<<<<<<<
 *     cdef readonly int second, microsecond
 *     cdef readonly str calendar
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_4year_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_4year_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_4year___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4year___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1107, __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("cftime._cftime.datetime.year.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_5month_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_5month_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_5month___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_5month___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->month); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1107, __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("cftime._cftime.datetime.month.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_3day_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_3day_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_3day___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_3day___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->day); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1107, __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("cftime._cftime.datetime.day.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_4hour_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_4hour_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_4hour___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_4hour___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->hour); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1107, __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("cftime._cftime.datetime.hour.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6minute_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6minute_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_6minute___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6minute___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->minute); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1107, __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("cftime._cftime.datetime.minute.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1108
 *     """
 *     cdef readonly int year, month, day, hour, minute
 *     cdef readonly int second, microsecond             # <<<<<<<<<<<<<<
 *     cdef readonly str calendar
 *     cdef readonly int _dayofwk, _dayofyr
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6second_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6second_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_6second___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6second___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->second); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1108, __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("cftime._cftime.datetime.second.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11microsecond_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_11microsecond_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_11microsecond___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_11microsecond___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->microsecond); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1108, __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("cftime._cftime.datetime.microsecond.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1109
 *     cdef readonly int year, month, day, hour, minute
 *     cdef readonly int second, microsecond
 *     cdef readonly str calendar             # <<<<<<<<<<<<<<
 *     cdef readonly int _dayofwk, _dayofyr
 *     cdef readonly bint has_year_zero
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8calendar_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8calendar_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_8calendar___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8calendar___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_self->calendar);
  __pyx_r = __pyx_v_self->calendar;
  goto __pyx_L0;

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

/* "cftime/_cftime.pyx":1110
 *     cdef readonly int second, microsecond
 *     cdef readonly str calendar
 *     cdef readonly int _dayofwk, _dayofyr             # <<<<<<<<<<<<<<
 *     cdef readonly bint has_year_zero
 *     cdef readonly object tzinfo
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8_dayofwk_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8_dayofwk_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_8_dayofwk___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8_dayofwk___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofwk); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1110, __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("cftime._cftime.datetime._dayofwk.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8_dayofyr_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_8_dayofyr_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_8_dayofyr___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_8_dayofyr___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_self->_dayofyr); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1110, __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("cftime._cftime.datetime._dayofyr.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1111
 *     cdef readonly str calendar
 *     cdef readonly int _dayofwk, _dayofyr
 *     cdef readonly bint has_year_zero             # <<<<<<<<<<<<<<
 *     cdef readonly object tzinfo
 * 
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_13has_year_zero_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_13has_year_zero_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_13has_year_zero___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_13has_year_zero___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_self->has_year_zero); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 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("cftime._cftime.datetime.has_year_zero.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1112
 *     cdef readonly int _dayofwk, _dayofyr
 *     cdef readonly bint has_year_zero
 *     cdef readonly object tzinfo             # <<<<<<<<<<<<<<
 * 
 *     # Python's datetime.datetime uses the proleptic Gregorian
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6tzinfo_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_6tzinfo_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_6tzinfo___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_6tzinfo___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_self->tzinfo);
  __pyx_r = __pyx_v_self->tzinfo;
  goto __pyx_L0;

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

/* "cftime/_cftime.pyx":1118
 *     # cftime.datetime instance can be converted to
 *     # datetime.datetime.
 *     cdef readonly bint datetime_compatible             # <<<<<<<<<<<<<<
 * 
 *     def __init__(self, int year, int month, int day, int hour=0, int minute=0,
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_19datetime_compatible_1__get__(PyObject *__pyx_v_self); /*proto*/
static PyObject *__pyx_pw_6cftime_7_cftime_8datetime_19datetime_compatible_1__get__(PyObject *__pyx_v_self) {
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__get__ (wrapper)", 0);
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  __pyx_r = __pyx_pf_6cftime_7_cftime_8datetime_19datetime_compatible___get__(((struct __pyx_obj_6cftime_7_cftime_datetime *)__pyx_v_self));

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

static PyObject *__pyx_pf_6cftime_7_cftime_8datetime_19datetime_compatible___get__(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_self) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__get__", 0);
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_self->datetime_compatible); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1118, __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("cftime._cftime.datetime.datetime_compatible.__get__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1650
 * 
 * 
 * cdef _findall(text, substr):             # <<<<<<<<<<<<<<
 *     # Also finds overlaps
 *     sites = []
*/

static PyObject *__pyx_f_6cftime_7_cftime__findall(PyObject *__pyx_v_text, PyObject *__pyx_v_substr) {
  PyObject *__pyx_v_sites = NULL;
  PyObject *__pyx_v_i = NULL;
  PyObject *__pyx_v_j = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_t_4;
  int __pyx_t_5;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_findall", 0);

  /* "cftime/_cftime.pyx":1652
 * cdef _findall(text, substr):
 *     # Also finds overlaps
 *     sites = []             # <<<<<<<<<<<<<<
 *     i = 0
 *     while 1:
*/
  __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1652, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_sites = ((PyObject*)__pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1653
 *     # Also finds overlaps
 *     sites = []
 *     i = 0             # <<<<<<<<<<<<<<
 *     while 1:
 *         j = text.find(substr, i)
*/
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_0);
  __pyx_v_i = __pyx_mstate_global->__pyx_int_0;

  /* "cftime/_cftime.pyx":1654
 *     sites = []
 *     i = 0
 *     while 1:             # <<<<<<<<<<<<<<
 *         j = text.find(substr, i)
 *         if j == -1:
*/
  while (1) {

    /* "cftime/_cftime.pyx":1655
 *     i = 0
 *     while 1:
 *         j = text.find(substr, i)             # <<<<<<<<<<<<<<
 *         if j == -1:
 *             break
*/
    __pyx_t_2 = __pyx_v_text;
    __Pyx_INCREF(__pyx_t_2);
    __pyx_t_3 = 0;
    {
      PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_substr, __pyx_v_i};
      __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_find, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1655, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_XDECREF_SET(__pyx_v_j, __pyx_t_1);
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1656
 *     while 1:
 *         j = text.find(substr, i)
 *         if j == -1:             # <<<<<<<<<<<<<<
 *             break
 *         sites.append(j)
*/
    __pyx_t_4 = (__Pyx_PyLong_BoolEqObjC(__pyx_v_j, __pyx_mstate_global->__pyx_int_neg_1, -1L, 0)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1656, __pyx_L1_error)
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":1657
 *         j = text.find(substr, i)
 *         if j == -1:
 *             break             # <<<<<<<<<<<<<<
 *         sites.append(j)
 *         i = j + 1
*/
      goto __pyx_L4_break;

      /* "cftime/_cftime.pyx":1656
 *     while 1:
 *         j = text.find(substr, i)
 *         if j == -1:             # <<<<<<<<<<<<<<
 *             break
 *         sites.append(j)
*/
    }

    /* "cftime/_cftime.pyx":1658
 *         if j == -1:
 *             break
 *         sites.append(j)             # <<<<<<<<<<<<<<
 *         i = j + 1
 *     return sites
*/
    __pyx_t_5 = __Pyx_PyList_Append(__pyx_v_sites, __pyx_v_j); if (unlikely(__pyx_t_5 == ((int)-1))) __PYX_ERR(0, 1658, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1659
 *             break
 *         sites.append(j)
 *         i = j + 1             # <<<<<<<<<<<<<<
 *     return sites
 * 
*/
    __pyx_t_1 = __Pyx_PyLong_AddObjC(__pyx_v_j, __pyx_mstate_global->__pyx_int_1, 1, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1659, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF_SET(__pyx_v_i, __pyx_t_1);
    __pyx_t_1 = 0;
  }
  __pyx_L4_break:;

  /* "cftime/_cftime.pyx":1660
 *         sites.append(j)
 *         i = j + 1
 *     return sites             # <<<<<<<<<<<<<<
 * 
 * # Every 28 years the calendar repeats, except through century leap
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_sites);
  __pyx_r = __pyx_v_sites;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1650
 * 
 * 
 * cdef _findall(text, substr):             # <<<<<<<<<<<<<<
 *     # Also finds overlaps
 *     sites = []
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime._findall", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_sites);
  __Pyx_XDECREF(__pyx_v_i);
  __Pyx_XDECREF(__pyx_v_j);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1667
 * # Make also 4-digit negative years
 * # Allow .%f for microseconds
 * cdef _strftime(datetime dt, fmt):             # <<<<<<<<<<<<<<
 *     if _illegal_s.search(fmt):
 *         raise TypeError("This strftime implementation does not handle %s")
*/

static PyObject *__pyx_f_6cftime_7_cftime__strftime(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt, PyObject *__pyx_v_fmt) {
  int __pyx_v_ihavems;
  PyObject *__pyx_v_fmt1 = NULL;
  PyObject *__pyx_v_year = NULL;
  PyObject *__pyx_v_delta = NULL;
  PyObject *__pyx_v_off = NULL;
  PyObject *__pyx_v_timetuple = NULL;
  PyObject *__pyx_v_s1 = NULL;
  PyObject *__pyx_v_twodigityear = NULL;
  PyObject *__pyx_v_sites1 = NULL;
  PyObject *__pyx_v_s2 = NULL;
  PyObject *__pyx_v_sites2 = NULL;
  PyObject *__pyx_v_sites = NULL;
  PyObject *__pyx_v_site = NULL;
  PyObject *__pyx_v_s = NULL;
  PyObject *__pyx_v_syear = NULL;
  PyObject *__pyx_v_n = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  size_t __pyx_t_5;
  int __pyx_t_6;
  int __pyx_t_7;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  Py_ssize_t __pyx_t_10;
  PyObject *(*__pyx_t_11)(PyObject *);
  int __pyx_t_12;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_strftime", 0);

  /* "cftime/_cftime.pyx":1668
 * # Allow .%f for microseconds
 * cdef _strftime(datetime dt, fmt):
 *     if _illegal_s.search(fmt):             # <<<<<<<<<<<<<<
 *         raise TypeError("This strftime implementation does not handle %s")
 *     # don't use strftime method at all.
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_illegal_s); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1668, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_search); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1668, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
  __pyx_t_5 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_5 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_fmt};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1668, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1668, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(__pyx_t_6)) {

    /* "cftime/_cftime.pyx":1669
 * cdef _strftime(datetime dt, fmt):
 *     if _illegal_s.search(fmt):
 *         raise TypeError("This strftime implementation does not handle %s")             # <<<<<<<<<<<<<<
 *     # don't use strftime method at all.
 *     # if dt.year > 1900:
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_This_strftime_implementation_doe};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1669, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 1669, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1668
 * # Allow .%f for microseconds
 * cdef _strftime(datetime dt, fmt):
 *     if _illegal_s.search(fmt):             # <<<<<<<<<<<<<<
 *         raise TypeError("This strftime implementation does not handle %s")
 *     # don't use strftime method at all.
*/
  }

  /* "cftime/_cftime.pyx":1673
 *     # if dt.year > 1900:
 *     #    return dt.strftime(fmt)
 *     if '%f' in fmt:             # <<<<<<<<<<<<<<
 *         if not fmt.endswith('.%f'):
 *             raise TypeError('If %f is used for microseconds it must be the'
*/
  __pyx_t_6 = (__Pyx_PySequence_ContainsTF(__pyx_mstate_global->__pyx_kp_u_f_2, __pyx_v_fmt, Py_EQ)); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1673, __pyx_L1_error)
  if (__pyx_t_6) {

    /* "cftime/_cftime.pyx":1674
 *     #    return dt.strftime(fmt)
 *     if '%f' in fmt:
 *         if not fmt.endswith('.%f'):             # <<<<<<<<<<<<<<
 *             raise TypeError('If %f is used for microseconds it must be the'
 *                             ' at the end as .%f')
*/
    __pyx_t_4 = __pyx_v_fmt;
    __Pyx_INCREF(__pyx_t_4);
    __pyx_t_5 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_f_3};
      __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_endswith, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1674, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __pyx_t_6 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_6 < 0))) __PYX_ERR(0, 1674, __pyx_L1_error)
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __pyx_t_7 = (!__pyx_t_6);
    if (unlikely(__pyx_t_7)) {

      /* "cftime/_cftime.pyx":1675
 *     if '%f' in fmt:
 *         if not fmt.endswith('.%f'):
 *             raise TypeError('If %f is used for microseconds it must be the'             # <<<<<<<<<<<<<<
 *                             ' at the end as .%f')
 *         else:
*/
      __pyx_t_4 = NULL;
      __pyx_t_5 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_If_f_is_used_for_microseconds_it};
        __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_TypeError)), __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1675, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_1);
      }
      __Pyx_Raise(__pyx_t_1, 0, 0, 0);
      __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
      __PYX_ERR(0, 1675, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1674
 *     #    return dt.strftime(fmt)
 *     if '%f' in fmt:
 *         if not fmt.endswith('.%f'):             # <<<<<<<<<<<<<<
 *             raise TypeError('If %f is used for microseconds it must be the'
 *                             ' at the end as .%f')
*/
    }

    /* "cftime/_cftime.pyx":1678
 *                             ' at the end as .%f')
 *         else:
 *             ihavems = True             # <<<<<<<<<<<<<<
 *             fmt1 = fmt[:-3]
 *     else:
*/
    /*else*/ {
      __pyx_v_ihavems = 1;

      /* "cftime/_cftime.pyx":1679
 *         else:
 *             ihavems = True
 *             fmt1 = fmt[:-3]             # <<<<<<<<<<<<<<
 *     else:
 *         ihavems = False
*/
      __pyx_t_1 = __Pyx_PyObject_GetSlice(__pyx_v_fmt, 0, -3L, NULL, NULL, &__pyx_mstate_global->__pyx_slice[2], 0, 1, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1679, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
      __pyx_v_fmt1 = __pyx_t_1;
      __pyx_t_1 = 0;
    }

    /* "cftime/_cftime.pyx":1673
 *     # if dt.year > 1900:
 *     #    return dt.strftime(fmt)
 *     if '%f' in fmt:             # <<<<<<<<<<<<<<
 *         if not fmt.endswith('.%f'):
 *             raise TypeError('If %f is used for microseconds it must be the'
*/
    goto __pyx_L4;
  }

  /* "cftime/_cftime.pyx":1681
 *             fmt1 = fmt[:-3]
 *     else:
 *         ihavems = False             # <<<<<<<<<<<<<<
 *         fmt1 = fmt
 * 
*/
  /*else*/ {
    __pyx_v_ihavems = 0;

    /* "cftime/_cftime.pyx":1682
 *     else:
 *         ihavems = False
 *         fmt1 = fmt             # <<<<<<<<<<<<<<
 * 
 *     year = dt.year
*/
    __Pyx_INCREF(__pyx_v_fmt);
    __pyx_v_fmt1 = __pyx_v_fmt;
  }
  __pyx_L4:;

  /* "cftime/_cftime.pyx":1684
 *         fmt1 = fmt
 * 
 *     year = dt.year             # <<<<<<<<<<<<<<
 *     # For every non-leap year century, advance by
 *     # 6 years to get into the 28-year repeat cycle
*/
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_dt->year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1684, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_year = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1687
 *     # For every non-leap year century, advance by
 *     # 6 years to get into the 28-year repeat cycle
 *     delta = 2000 - year             # <<<<<<<<<<<<<<
 *     off = 6 * (delta // 100 + delta // 400)
 *     year = year + off
*/
  __pyx_t_1 = __Pyx_PyLong_SubtractCObj(__pyx_mstate_global->__pyx_int_2000, __pyx_v_year, 0x7D0, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1687, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_v_delta = __pyx_t_1;
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1688
 *     # 6 years to get into the 28-year repeat cycle
 *     delta = 2000 - year
 *     off = 6 * (delta // 100 + delta // 400)             # <<<<<<<<<<<<<<
 *     year = year + off
 * 
*/
  __pyx_t_1 = __Pyx_PyLong_FloorDivideObjC(__pyx_v_delta, __pyx_mstate_global->__pyx_int_100, 0x64, 0, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyLong_FloorDivideObjC(__pyx_v_delta, __pyx_mstate_global->__pyx_int_400, 0x190, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = PyNumber_Add(__pyx_t_1, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyLong_MultiplyCObj(__pyx_mstate_global->__pyx_int_6, __pyx_t_2, 6, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1688, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_v_off = __pyx_t_4;
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1689
 *     delta = 2000 - year
 *     off = 6 * (delta // 100 + delta // 400)
 *     year = year + off             # <<<<<<<<<<<<<<
 * 
 *     # Move to around the year 2000
*/
  __pyx_t_4 = PyNumber_Add(__pyx_v_year, __pyx_v_off); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1689, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF_SET(__pyx_v_year, __pyx_t_4);
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1692
 * 
 *     # Move to around the year 2000
 *     year = year + ((2000 - year) // 28) * 28             # <<<<<<<<<<<<<<
 *     timetuple = dt.timetuple()
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])
*/
  __pyx_t_4 = __Pyx_PyLong_SubtractCObj(__pyx_mstate_global->__pyx_int_2000, __pyx_v_year, 0x7D0, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1692, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyLong_FloorDivideObjC(__pyx_t_4, __pyx_mstate_global->__pyx_int_28, 28, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1692, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_PyLong_MultiplyObjC(__pyx_t_2, __pyx_mstate_global->__pyx_int_28, 28, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1692, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_2 = PyNumber_Add(__pyx_v_year, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1692, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF_SET(__pyx_v_year, __pyx_t_2);
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1693
 *     # Move to around the year 2000
 *     year = year + ((2000 - year) // 28) * 28
 *     timetuple = dt.timetuple()             # <<<<<<<<<<<<<<
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])
 *     twodigityear = 'y' in fmt1
*/
  __pyx_t_4 = ((PyObject *)__pyx_v_dt);
  __Pyx_INCREF(__pyx_t_4);
  __pyx_t_5 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, NULL};
    __pyx_t_2 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_timetuple, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1693, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_v_timetuple = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1694
 *     year = year + ((2000 - year) // 28) * 28
 *     timetuple = dt.timetuple()
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])             # <<<<<<<<<<<<<<
 *     twodigityear = 'y' in fmt1
 *     if twodigityear:
*/
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_time); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_strftime); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_INCREF(__pyx_v_year);
  __Pyx_GIVEREF(__pyx_v_year);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_year) != (0)) __PYX_ERR(0, 1694, __pyx_L1_error);
  __pyx_t_8 = __Pyx_PyObject_GetSlice(__pyx_v_timetuple, 1, 0, NULL, NULL, &__pyx_mstate_global->__pyx_slice[3], 1, 0, 1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = PyNumber_Add(__pyx_t_1, __pyx_t_8); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_5 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_3))) {
    __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_3);
    assert(__pyx_t_4);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3);
    __Pyx_INCREF(__pyx_t_4);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_3, __pyx__function);
    __pyx_t_5 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_4, __pyx_v_fmt1, __pyx_t_9};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_3, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1694, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_v_s1 = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1695
 *     timetuple = dt.timetuple()
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])
 *     twodigityear = 'y' in fmt1             # <<<<<<<<<<<<<<
 *     if twodigityear:
 *         sites1 = _findall(s1, str(year)[-2:])
*/
  __pyx_t_7 = (__Pyx_PySequence_ContainsTF(__pyx_mstate_global->__pyx_n_u_y, __pyx_v_fmt1, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1695, __pyx_L1_error)
  __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_t_7); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1695, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_v_twodigityear = __pyx_t_2;
  __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1696
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])
 *     twodigityear = 'y' in fmt1
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *         sites1 = _findall(s1, str(year)[-2:])
 *     else:
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_twodigityear); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1696, __pyx_L1_error)
  if (__pyx_t_7) {

    /* "cftime/_cftime.pyx":1697
 *     twodigityear = 'y' in fmt1
 *     if twodigityear:
 *         sites1 = _findall(s1, str(year)[-2:])             # <<<<<<<<<<<<<<
 *     else:
 *         sites1 = _findall(s1, str(year))
*/
    __pyx_t_2 = __Pyx_PyObject_Unicode(__pyx_v_year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1697, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __Pyx_PyUnicode_Substring(__pyx_t_2, -2L, PY_SSIZE_T_MAX); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1697, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_t_2 = __pyx_f_6cftime_7_cftime__findall(__pyx_v_s1, __pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1697, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_sites1 = __pyx_t_2;
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1696
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])
 *     twodigityear = 'y' in fmt1
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *         sites1 = _findall(s1, str(year)[-2:])
 *     else:
*/
    goto __pyx_L6;
  }

  /* "cftime/_cftime.pyx":1699
 *         sites1 = _findall(s1, str(year)[-2:])
 *     else:
 *         sites1 = _findall(s1, str(year))             # <<<<<<<<<<<<<<
 * 
 *     s2 = time.strftime(fmt1, (year + 28,) + timetuple[1:])
*/
  /*else*/ {
    __pyx_t_2 = __Pyx_PyObject_Unicode(__pyx_v_year); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1699, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_3 = __pyx_f_6cftime_7_cftime__findall(__pyx_v_s1, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1699, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    __pyx_v_sites1 = __pyx_t_3;
    __pyx_t_3 = 0;
  }
  __pyx_L6:;

  /* "cftime/_cftime.pyx":1701
 *         sites1 = _findall(s1, str(year))
 * 
 *     s2 = time.strftime(fmt1, (year + 28,) + timetuple[1:])             # <<<<<<<<<<<<<<
 *     if twodigityear:
 *        sites2 = _findall(s2, str(year + 28)[-2:])
*/
  __pyx_t_2 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_time); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_9, __pyx_mstate_global->__pyx_n_u_strftime); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_9 = __Pyx_PyLong_AddObjC(__pyx_v_year, __pyx_mstate_global->__pyx_int_28, 28, 0, 0); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_8 = PyTuple_New(1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __Pyx_GIVEREF(__pyx_t_9);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_t_9) != (0)) __PYX_ERR(0, 1701, __pyx_L1_error);
  __pyx_t_9 = 0;
  __pyx_t_9 = __Pyx_PyObject_GetSlice(__pyx_v_timetuple, 1, 0, NULL, NULL, &__pyx_mstate_global->__pyx_slice[3], 1, 0, 1); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_1 = PyNumber_Add(__pyx_t_8, __pyx_t_9); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1701, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;
  __pyx_t_5 = 1;
  #if CYTHON_UNPACK_METHODS
  if (unlikely(PyMethod_Check(__pyx_t_4))) {
    __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_4);
    assert(__pyx_t_2);
    PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4);
    __Pyx_INCREF(__pyx_t_2);
    __Pyx_INCREF(__pyx__function);
    __Pyx_DECREF_SET(__pyx_t_4, __pyx__function);
    __pyx_t_5 = 0;
  }
  #endif
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, __pyx_v_fmt1, __pyx_t_1};
    __pyx_t_3 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_5, (3-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1701, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
  }
  __pyx_v_s2 = __pyx_t_3;
  __pyx_t_3 = 0;

  /* "cftime/_cftime.pyx":1702
 * 
 *     s2 = time.strftime(fmt1, (year + 28,) + timetuple[1:])
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *        sites2 = _findall(s2, str(year + 28)[-2:])
 *     else:
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_twodigityear); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1702, __pyx_L1_error)
  if (__pyx_t_7) {

    /* "cftime/_cftime.pyx":1703
 *     s2 = time.strftime(fmt1, (year + 28,) + timetuple[1:])
 *     if twodigityear:
 *        sites2 = _findall(s2, str(year + 28)[-2:])             # <<<<<<<<<<<<<<
 *     else:
 *        sites2 = _findall(s2, str(year + 28))
*/
    __pyx_t_3 = __Pyx_PyLong_AddObjC(__pyx_v_year, __pyx_mstate_global->__pyx_int_28, 28, 0, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1703, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_4 = __Pyx_PyObject_Unicode(__pyx_t_3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1703, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = __Pyx_PyUnicode_Substring(__pyx_t_4, -2L, PY_SSIZE_T_MAX); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1703, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = __pyx_f_6cftime_7_cftime__findall(__pyx_v_s2, __pyx_t_3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1703, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_sites2 = __pyx_t_4;
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1702
 * 
 *     s2 = time.strftime(fmt1, (year + 28,) + timetuple[1:])
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *        sites2 = _findall(s2, str(year + 28)[-2:])
 *     else:
*/
    goto __pyx_L7;
  }

  /* "cftime/_cftime.pyx":1705
 *        sites2 = _findall(s2, str(year + 28)[-2:])
 *     else:
 *        sites2 = _findall(s2, str(year + 28))             # <<<<<<<<<<<<<<
 * 
 *     sites = []
*/
  /*else*/ {
    __pyx_t_4 = __Pyx_PyLong_AddObjC(__pyx_v_year, __pyx_mstate_global->__pyx_int_28, 28, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1705, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_3 = __Pyx_PyObject_Unicode(__pyx_t_4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1705, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __pyx_t_4 = __pyx_f_6cftime_7_cftime__findall(__pyx_v_s2, __pyx_t_3); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1705, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_v_sites2 = __pyx_t_4;
    __pyx_t_4 = 0;
  }
  __pyx_L7:;

  /* "cftime/_cftime.pyx":1707
 *        sites2 = _findall(s2, str(year + 28))
 * 
 *     sites = []             # <<<<<<<<<<<<<<
 *     for site in sites1:
 *         if site in sites2:
*/
  __pyx_t_4 = PyList_New(0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1707, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_v_sites = ((PyObject*)__pyx_t_4);
  __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1708
 * 
 *     sites = []
 *     for site in sites1:             # <<<<<<<<<<<<<<
 *         if site in sites2:
 *             sites.append(site)
*/
  if (likely(PyList_CheckExact(__pyx_v_sites1)) || PyTuple_CheckExact(__pyx_v_sites1)) {
    __pyx_t_4 = __pyx_v_sites1; __Pyx_INCREF(__pyx_t_4);
    __pyx_t_10 = 0;
    __pyx_t_11 = NULL;
  } else {
    __pyx_t_10 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_sites1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1708, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_11 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1708, __pyx_L1_error)
  }
  for (;;) {
    if (likely(!__pyx_t_11)) {
      if (likely(PyList_CheckExact(__pyx_t_4))) {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1708, __pyx_L1_error)
          #endif
          if (__pyx_t_10 >= __pyx_temp) break;
        }
        __pyx_t_3 = __Pyx_PyList_GetItemRefFast(__pyx_t_4, __pyx_t_10, __Pyx_ReferenceSharing_OwnStrongReference);
        ++__pyx_t_10;
      } else {
        {
          Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4);
          #if !CYTHON_ASSUME_SAFE_SIZE
          if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1708, __pyx_L1_error)
          #endif
          if (__pyx_t_10 >= __pyx_temp) break;
        }
        #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
        __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_10));
        #else
        __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_10);
        #endif
        ++__pyx_t_10;
      }
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1708, __pyx_L1_error)
    } else {
      __pyx_t_3 = __pyx_t_11(__pyx_t_4);
      if (unlikely(!__pyx_t_3)) {
        PyObject* exc_type = PyErr_Occurred();
        if (exc_type) {
          if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 1708, __pyx_L1_error)
          PyErr_Clear();
        }
        break;
      }
    }
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_XDECREF_SET(__pyx_v_site, __pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1709
 *     sites = []
 *     for site in sites1:
 *         if site in sites2:             # <<<<<<<<<<<<<<
 *             sites.append(site)
 * 
*/
    __pyx_t_7 = (__Pyx_PySequence_ContainsTF(__pyx_v_site, __pyx_v_sites2, Py_EQ)); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1709, __pyx_L1_error)
    if (__pyx_t_7) {

      /* "cftime/_cftime.pyx":1710
 *     for site in sites1:
 *         if site in sites2:
 *             sites.append(site)             # <<<<<<<<<<<<<<
 * 
 *     s = s1
*/
      __pyx_t_12 = __Pyx_PyList_Append(__pyx_v_sites, __pyx_v_site); if (unlikely(__pyx_t_12 == ((int)-1))) __PYX_ERR(0, 1710, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1709
 *     sites = []
 *     for site in sites1:
 *         if site in sites2:             # <<<<<<<<<<<<<<
 *             sites.append(site)
 * 
*/
    }

    /* "cftime/_cftime.pyx":1708
 * 
 *     sites = []
 *     for site in sites1:             # <<<<<<<<<<<<<<
 *         if site in sites2:
 *             sites.append(site)
*/
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1712
 *             sites.append(site)
 * 
 *     s = s1             # <<<<<<<<<<<<<<
 *     if dt.year < 0:
 *         syear = "%05d" % (dt.year,)
*/
  __Pyx_INCREF(__pyx_v_s1);
  __pyx_v_s = __pyx_v_s1;

  /* "cftime/_cftime.pyx":1713
 * 
 *     s = s1
 *     if dt.year < 0:             # <<<<<<<<<<<<<<
 *         syear = "%05d" % (dt.year,)
 *     else:
*/
  __pyx_t_7 = (__pyx_v_dt->year < 0);
  if (__pyx_t_7) {

    /* "cftime/_cftime.pyx":1714
 *     s = s1
 *     if dt.year < 0:
 *         syear = "%05d" % (dt.year,)             # <<<<<<<<<<<<<<
 *     else:
 *         syear = "%04d" % (dt.year,)
*/
    __pyx_t_4 = __Pyx_PyUnicode_From_int(__pyx_v_dt->year, 5, '0', 'd'); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1714, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_v_syear = ((PyObject*)__pyx_t_4);
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1713
 * 
 *     s = s1
 *     if dt.year < 0:             # <<<<<<<<<<<<<<
 *         syear = "%05d" % (dt.year,)
 *     else:
*/
    goto __pyx_L12;
  }

  /* "cftime/_cftime.pyx":1716
 *         syear = "%05d" % (dt.year,)
 *     else:
 *         syear = "%04d" % (dt.year,)             # <<<<<<<<<<<<<<
 *     n=4
 *     if twodigityear:
*/
  /*else*/ {
    __pyx_t_4 = __Pyx_PyUnicode_From_int(__pyx_v_dt->year, 4, '0', 'd'); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1716, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_v_syear = ((PyObject*)__pyx_t_4);
    __pyx_t_4 = 0;
  }
  __pyx_L12:;

  /* "cftime/_cftime.pyx":1717
 *     else:
 *         syear = "%04d" % (dt.year,)
 *     n=4             # <<<<<<<<<<<<<<
 *     if twodigityear:
 *         syear = syear[-2:]
*/
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_4);
  __pyx_v_n = __pyx_mstate_global->__pyx_int_4;

  /* "cftime/_cftime.pyx":1718
 *         syear = "%04d" % (dt.year,)
 *     n=4
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *         syear = syear[-2:]
 *         if dt.year < 0:
*/
  __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_twodigityear); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 1718, __pyx_L1_error)
  if (__pyx_t_7) {

    /* "cftime/_cftime.pyx":1719
 *     n=4
 *     if twodigityear:
 *         syear = syear[-2:]             # <<<<<<<<<<<<<<
 *         if dt.year < 0:
 *             syear = '-'+syear
*/
    __pyx_t_4 = __Pyx_PyUnicode_Substring(__pyx_v_syear, -2L, PY_SSIZE_T_MAX); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1719, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF_SET(__pyx_v_syear, ((PyObject*)__pyx_t_4));
    __pyx_t_4 = 0;

    /* "cftime/_cftime.pyx":1720
 *     if twodigityear:
 *         syear = syear[-2:]
 *         if dt.year < 0:             # <<<<<<<<<<<<<<
 *             syear = '-'+syear
 *         n=2
*/
    __pyx_t_7 = (__pyx_v_dt->year < 0);
    if (__pyx_t_7) {

      /* "cftime/_cftime.pyx":1721
 *         syear = syear[-2:]
 *         if dt.year < 0:
 *             syear = '-'+syear             # <<<<<<<<<<<<<<
 *         n=2
 *     for site in sites:
*/
      __pyx_t_4 = __Pyx_PyUnicode_Concat(__pyx_mstate_global->__pyx_kp_u_, __pyx_v_syear); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1721, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      __Pyx_DECREF_SET(__pyx_v_syear, ((PyObject*)__pyx_t_4));
      __pyx_t_4 = 0;

      /* "cftime/_cftime.pyx":1720
 *     if twodigityear:
 *         syear = syear[-2:]
 *         if dt.year < 0:             # <<<<<<<<<<<<<<
 *             syear = '-'+syear
 *         n=2
*/
    }

    /* "cftime/_cftime.pyx":1722
 *         if dt.year < 0:
 *             syear = '-'+syear
 *         n=2             # <<<<<<<<<<<<<<
 *     for site in sites:
 *         s = s[:site] + syear + s[site + n:]
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_int_2);
    __Pyx_DECREF_SET(__pyx_v_n, __pyx_mstate_global->__pyx_int_2);

    /* "cftime/_cftime.pyx":1718
 *         syear = "%04d" % (dt.year,)
 *     n=4
 *     if twodigityear:             # <<<<<<<<<<<<<<
 *         syear = syear[-2:]
 *         if dt.year < 0:
*/
  }

  /* "cftime/_cftime.pyx":1723
 *             syear = '-'+syear
 *         n=2
 *     for site in sites:             # <<<<<<<<<<<<<<
 *         s = s[:site] + syear + s[site + n:]
 *     if ihavems:
*/
  __pyx_t_4 = __pyx_v_sites; __Pyx_INCREF(__pyx_t_4);
  __pyx_t_10 = 0;
  for (;;) {
    {
      Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4);
      #if !CYTHON_ASSUME_SAFE_SIZE
      if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 1723, __pyx_L1_error)
      #endif
      if (__pyx_t_10 >= __pyx_temp) break;
    }
    __pyx_t_3 = __Pyx_PyList_GetItemRefFast(__pyx_t_4, __pyx_t_10, __Pyx_ReferenceSharing_OwnStrongReference);
    ++__pyx_t_10;
    if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1723, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __Pyx_XDECREF_SET(__pyx_v_site, __pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1724
 *         n=2
 *     for site in sites:
 *         s = s[:site] + syear + s[site + n:]             # <<<<<<<<<<<<<<
 *     if ihavems:
 *         s = s + '.{:06d}'.format(dt.microsecond)
*/
    __pyx_t_3 = __Pyx_PyObject_GetSlice(__pyx_v_s, 0, 0, NULL, &__pyx_v_site, NULL, 0, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1724, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_1 = PyNumber_Add(__pyx_t_3, __pyx_v_syear); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1724, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = PyNumber_Add(__pyx_v_site, __pyx_v_n); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1724, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_3);
    __pyx_t_2 = __Pyx_PyObject_GetSlice(__pyx_v_s, 0, 0, &__pyx_t_3, NULL, NULL, 0, 0, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1724, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
    __pyx_t_3 = PyNumber_Add(__pyx_t_1, __pyx_t_2); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1724, __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_SET(__pyx_v_s, __pyx_t_3);
    __pyx_t_3 = 0;

    /* "cftime/_cftime.pyx":1723
 *             syear = '-'+syear
 *         n=2
 *     for site in sites:             # <<<<<<<<<<<<<<
 *         s = s[:site] + syear + s[site + n:]
 *     if ihavems:
*/
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1725
 *     for site in sites:
 *         s = s[:site] + syear + s[site + n:]
 *     if ihavems:             # <<<<<<<<<<<<<<
 *         s = s + '.{:06d}'.format(dt.microsecond)
 *     return s
*/
  if (__pyx_v_ihavems) {

    /* "cftime/_cftime.pyx":1726
 *         s = s[:site] + syear + s[site + n:]
 *     if ihavems:
 *         s = s + '.{:06d}'.format(dt.microsecond)             # <<<<<<<<<<<<<<
 *     return s
 * 
*/
    __pyx_t_3 = __pyx_mstate_global->__pyx_kp_u_06d;
    __Pyx_INCREF(__pyx_t_3);
    __pyx_t_2 = __Pyx_PyLong_From_int(__pyx_v_dt->microsecond); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1726, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __pyx_t_5 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_2};
      __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1726, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_2 = PyNumber_Add(__pyx_v_s, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1726, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF_SET(__pyx_v_s, __pyx_t_2);
    __pyx_t_2 = 0;

    /* "cftime/_cftime.pyx":1725
 *     for site in sites:
 *         s = s[:site] + syear + s[site + n:]
 *     if ihavems:             # <<<<<<<<<<<<<<
 *         s = s + '.{:06d}'.format(dt.microsecond)
 *     return s
*/
  }

  /* "cftime/_cftime.pyx":1727
 *     if ihavems:
 *         s = s + '.{:06d}'.format(dt.microsecond)
 *     return s             # <<<<<<<<<<<<<<
 * 
 * cdef bint is_leap_julian(int year, bint has_year_zero):
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_s);
  __pyx_r = __pyx_v_s;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1667
 * # Make also 4-digit negative years
 * # Allow .%f for microseconds
 * cdef _strftime(datetime dt, fmt):             # <<<<<<<<<<<<<<
 *     if _illegal_s.search(fmt):
 *         raise TypeError("This strftime implementation does not handle %s")
*/

  /* 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_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime._strftime", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_fmt1);
  __Pyx_XDECREF(__pyx_v_year);
  __Pyx_XDECREF(__pyx_v_delta);
  __Pyx_XDECREF(__pyx_v_off);
  __Pyx_XDECREF(__pyx_v_timetuple);
  __Pyx_XDECREF(__pyx_v_s1);
  __Pyx_XDECREF(__pyx_v_twodigityear);
  __Pyx_XDECREF(__pyx_v_sites1);
  __Pyx_XDECREF(__pyx_v_s2);
  __Pyx_XDECREF(__pyx_v_sites2);
  __Pyx_XDECREF(__pyx_v_sites);
  __Pyx_XDECREF(__pyx_v_site);
  __Pyx_XDECREF(__pyx_v_s);
  __Pyx_XDECREF(__pyx_v_syear);
  __Pyx_XDECREF(__pyx_v_n);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1729
 *     return s
 * 
 * cdef bint is_leap_julian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Julian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='julian',has_year_zero=has_year_zero)
*/

static int __pyx_f_6cftime_7_cftime_is_leap_julian(int __pyx_v_year, int __pyx_v_has_year_zero) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_3;
  int __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("is_leap_julian", 0);

  /* "cftime/_cftime.pyx":1731
 * cdef bint is_leap_julian(int year, bint has_year_zero):
 *     "Return 1 if year is a leap year in the Julian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='julian',has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * cdef bint is_leap_proleptic_gregorian(int year, bint has_year_zero):
*/
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1731, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3.__pyx_n = 1;
  __pyx_t_3.has_year_zero = __pyx_t_1;
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_year, __pyx_mstate_global->__pyx_n_u_julian, &__pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1731, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1731, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_4;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1729
 *     return s
 * 
 * cdef bint is_leap_julian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Julian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='julian',has_year_zero=has_year_zero)
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.is_leap_julian", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1733
 *     return _is_leap(year, calendar='julian',has_year_zero=has_year_zero)
 * 
 * cdef bint is_leap_proleptic_gregorian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Proleptic Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='proleptic_gregorian',has_year_zero=has_year_zero)
*/

static int __pyx_f_6cftime_7_cftime_is_leap_proleptic_gregorian(int __pyx_v_year, int __pyx_v_has_year_zero) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_3;
  int __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("is_leap_proleptic_gregorian", 0);

  /* "cftime/_cftime.pyx":1735
 * cdef bint is_leap_proleptic_gregorian(int year, bint has_year_zero):
 *     "Return 1 if year is a leap year in the Proleptic Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='proleptic_gregorian',has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * cdef bint is_leap_gregorian(int year, bint has_year_zero):
*/
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3.__pyx_n = 1;
  __pyx_t_3.has_year_zero = __pyx_t_1;
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_year, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, &__pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1735, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1735, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_4;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1733
 *     return _is_leap(year, calendar='julian',has_year_zero=has_year_zero)
 * 
 * cdef bint is_leap_proleptic_gregorian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Proleptic Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='proleptic_gregorian',has_year_zero=has_year_zero)
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.is_leap_proleptic_gregorian", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1737
 *     return _is_leap(year, calendar='proleptic_gregorian',has_year_zero=has_year_zero)
 * 
 * cdef bint is_leap_gregorian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='standard',has_year_zero=has_year_zero)
*/

static int __pyx_f_6cftime_7_cftime_is_leap_gregorian(int __pyx_v_year, int __pyx_v_has_year_zero) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_3;
  int __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("is_leap_gregorian", 0);

  /* "cftime/_cftime.pyx":1739
 * cdef bint is_leap_gregorian(int year, bint has_year_zero):
 *     "Return 1 if year is a leap year in the Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='standard',has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * cdef bint all_leap(int year, bint has_year_zero):
*/
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_has_year_zero); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1739, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3.__pyx_n = 1;
  __pyx_t_3.has_year_zero = __pyx_t_1;
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_year, __pyx_mstate_global->__pyx_n_u_standard, &__pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1739, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1739, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_r = __pyx_t_4;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1737
 *     return _is_leap(year, calendar='proleptic_gregorian',has_year_zero=has_year_zero)
 * 
 * cdef bint is_leap_gregorian(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return 1 if year is a leap year in the Gregorian calendar, 0 otherwise."
 *     return _is_leap(year, calendar='standard',has_year_zero=has_year_zero)
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.is_leap_gregorian", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1741
 *     return _is_leap(year, calendar='standard',has_year_zero=has_year_zero)
 * 
 * cdef bint all_leap(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return True for all years."
 *     return True
*/

static int __pyx_f_6cftime_7_cftime_all_leap(CYTHON_UNUSED int __pyx_v_year, CYTHON_UNUSED int __pyx_v_has_year_zero) {
  int __pyx_r;

  /* "cftime/_cftime.pyx":1743
 * cdef bint all_leap(int year, bint has_year_zero):
 *     "Return True for all years."
 *     return True             # <<<<<<<<<<<<<<
 * 
 * cdef bint no_leap(int year, bint has_year_zero):
*/
  __pyx_r = 1;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1741
 *     return _is_leap(year, calendar='standard',has_year_zero=has_year_zero)
 * 
 * cdef bint all_leap(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return True for all years."
 *     return True
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1745
 *     return True
 * 
 * cdef bint no_leap(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return False for all years."
 *     return False
*/

static int __pyx_f_6cftime_7_cftime_no_leap(CYTHON_UNUSED int __pyx_v_year, CYTHON_UNUSED int __pyx_v_has_year_zero) {
  int __pyx_r;

  /* "cftime/_cftime.pyx":1747
 * cdef bint no_leap(int year, bint has_year_zero):
 *     "Return False for all years."
 *     return False             # <<<<<<<<<<<<<<
 * 
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):
*/
  __pyx_r = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1745
 *     return True
 * 
 * cdef bint no_leap(int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     "Return False for all years."
 *     return False
*/

  /* function exit code */
  __pyx_L0:;
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1749
 *     return False
 * 
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     if is_leap(year,has_year_zero):
 *         return _dayspermonth_leap
*/

static int *__pyx_f_6cftime_7_cftime_month_lengths(int (*__pyx_v_is_leap)(int, int), int __pyx_v_year, int __pyx_v_has_year_zero) {
  int *__pyx_r;
  int __pyx_t_1;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;

  /* "cftime/_cftime.pyx":1750
 * 
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):
 *     if is_leap(year,has_year_zero):             # <<<<<<<<<<<<<<
 *         return _dayspermonth_leap
 *     else:
*/
  __pyx_t_1 = __pyx_v_is_leap(__pyx_v_year, __pyx_v_has_year_zero); if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1750, __pyx_L1_error)
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1751
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):
 *     if is_leap(year,has_year_zero):
 *         return _dayspermonth_leap             # <<<<<<<<<<<<<<
 *     else:
 *         return _dayspermonth
*/
    __pyx_r = __pyx_v_6cftime_7_cftime__dayspermonth_leap;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":1750
 * 
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):
 *     if is_leap(year,has_year_zero):             # <<<<<<<<<<<<<<
 *         return _dayspermonth_leap
 *     else:
*/
  }

  /* "cftime/_cftime.pyx":1753
 *         return _dayspermonth_leap
 *     else:
 *         return _dayspermonth             # <<<<<<<<<<<<<<
 * 
 * cdef void assert_valid_date(datetime dt, bint (*is_leap)(int, bint),
*/
  /*else*/ {
    __pyx_r = __pyx_v_6cftime_7_cftime__dayspermonth;
    goto __pyx_L0;
  }

  /* "cftime/_cftime.pyx":1749
 *     return False
 * 
 * cdef int * month_lengths(bint (*is_leap)(int,bint), int year, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     if is_leap(year,has_year_zero):
 *         return _dayspermonth_leap
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_AddTraceback("cftime._cftime.month_lengths", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1755
 *         return _dayspermonth
 * 
 * cdef void assert_valid_date(datetime dt, bint (*is_leap)(int, bint),             # <<<<<<<<<<<<<<
 *                             bint julian_gregorian_mixed,
 *                             bint has_year_zero=False,
*/

static void __pyx_f_6cftime_7_cftime_assert_valid_date(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt, int (*__pyx_v_is_leap)(int, int), int __pyx_v_julian_gregorian_mixed, struct __pyx_opt_args_6cftime_7_cftime_assert_valid_date *__pyx_optional_args) {

  /* "cftime/_cftime.pyx":1757
 * cdef void assert_valid_date(datetime dt, bint (*is_leap)(int, bint),
 *                             bint julian_gregorian_mixed,
 *                             bint has_year_zero=False,             # <<<<<<<<<<<<<<
 *                             bint is_360_day=False) except *:
 *     cdef int[12] month_length
*/
  int __pyx_v_has_year_zero = ((int)0);

  /* "cftime/_cftime.pyx":1758
 *                             bint julian_gregorian_mixed,
 *                             bint has_year_zero=False,
 *                             bint is_360_day=False) except *:             # <<<<<<<<<<<<<<
 *     cdef int[12] month_length
 * 
*/
  int __pyx_v_is_360_day = ((int)0);
  int __pyx_v_month_length[12];
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  size_t __pyx_t_6;
  int __pyx_t_7[12];
  int *__pyx_t_8;
  int __pyx_t_9;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("assert_valid_date", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_has_year_zero = __pyx_optional_args->has_year_zero;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_is_360_day = __pyx_optional_args->is_360_day;
      }
    }
  }

  /* "cftime/_cftime.pyx":1761
 *     cdef int[12] month_length
 * 
 *     if not has_year_zero:             # <<<<<<<<<<<<<<
 *         if dt.year == 0:
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
*/
  __pyx_t_1 = (!__pyx_v_has_year_zero);
  if (__pyx_t_1) {

    /* "cftime/_cftime.pyx":1762
 * 
 *     if not has_year_zero:
 *         if dt.year == 0:             # <<<<<<<<<<<<<<
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
 *     if is_360_day:
*/
    __pyx_t_1 = (__pyx_v_dt->year == 0);
    if (unlikely(__pyx_t_1)) {

      /* "cftime/_cftime.pyx":1763
 *     if not has_year_zero:
 *         if dt.year == 0:
 *             raise ValueError("invalid year provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 *     if is_360_day:
 *         month_length = 12*[30]
*/
      __pyx_t_3 = NULL;
      __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_year_provided_in_0_r;
      __Pyx_INCREF(__pyx_t_5);
      __pyx_t_6 = 0;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
        __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
        if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1763, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_4);
      }
      __pyx_t_6 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_4};
        __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
        __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1763, __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(0, 1763, __pyx_L1_error)

      /* "cftime/_cftime.pyx":1762
 * 
 *     if not has_year_zero:
 *         if dt.year == 0:             # <<<<<<<<<<<<<<
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
 *     if is_360_day:
*/
    }

    /* "cftime/_cftime.pyx":1761
 *     cdef int[12] month_length
 * 
 *     if not has_year_zero:             # <<<<<<<<<<<<<<
 *         if dt.year == 0:
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
*/
  }

  /* "cftime/_cftime.pyx":1764
 *         if dt.year == 0:
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
 *     if is_360_day:             # <<<<<<<<<<<<<<
 *         month_length = 12*[30]
 *     else:
*/
  if (__pyx_v_is_360_day) {

    /* "cftime/_cftime.pyx":1765
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
 *     if is_360_day:
 *         month_length = 12*[30]             # <<<<<<<<<<<<<<
 *     else:
 *         month_length = month_lengths(is_leap, dt.year, has_year_zero)
*/
    {
      Py_ssize_t __pyx_temp;
      for (__pyx_temp = 0; __pyx_temp < 12; __pyx_temp++) {
        __pyx_t_7[0+ (1 * __pyx_temp)] = 30;
      }
    }
    memcpy(&(__pyx_v_month_length[0]), __pyx_t_7, sizeof(__pyx_v_month_length[0]) * (12));

    /* "cftime/_cftime.pyx":1764
 *         if dt.year == 0:
 *             raise ValueError("invalid year provided in {0!r}".format(dt))
 *     if is_360_day:             # <<<<<<<<<<<<<<
 *         month_length = 12*[30]
 *     else:
*/
    goto __pyx_L5;
  }

  /* "cftime/_cftime.pyx":1767
 *         month_length = 12*[30]
 *     else:
 *         month_length = month_lengths(is_leap, dt.year, has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * 
*/
  /*else*/ {
    __pyx_t_8 = __pyx_f_6cftime_7_cftime_month_lengths(__pyx_v_is_leap, __pyx_v_dt->year, __pyx_v_has_year_zero); if (unlikely(__pyx_t_8 == ((void *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 1767, __pyx_L1_error)
    memcpy(&(__pyx_v_month_length[0]), __pyx_t_8, sizeof(__pyx_v_month_length[0]) * (12 - 0));
  }
  __pyx_L5:;

  /* "cftime/_cftime.pyx":1770
 * 
 * 
 *     if dt.month < 1 or dt.month > 12:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid month provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->month < 1);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L7_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->month > 12);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L7_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1771
 * 
 *     if dt.month < 1 or dt.month > 12:
 *         raise ValueError("invalid month provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if dt.day < 1 or dt.day > month_length[dt.month-1]:
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_month_provided_in_0_r;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1771, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1771, __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(0, 1771, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1770
 * 
 * 
 *     if dt.month < 1 or dt.month > 12:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid month provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1773
 *         raise ValueError("invalid month provided in {0!r}".format(dt))
 * 
 *     if dt.day < 1 or dt.day > month_length[dt.month-1]:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid day number provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->day < 1);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L10_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->day > (__pyx_v_month_length[(__pyx_v_dt->month - 1)]));
  __pyx_t_1 = __pyx_t_9;
  __pyx_L10_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1774
 * 
 *     if dt.day < 1 or dt.day > month_length[dt.month-1]:
 *         raise ValueError("invalid day number provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if julian_gregorian_mixed and dt.year == 1582 and dt.month == 10 and dt.day > 4 and dt.day < 15:
*/
    __pyx_t_3 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_day_number_provided_in_0;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1774, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1774, __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(0, 1774, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1773
 *         raise ValueError("invalid month provided in {0!r}".format(dt))
 * 
 *     if dt.day < 1 or dt.day > month_length[dt.month-1]:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid day number provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1776
 *         raise ValueError("invalid day number provided in {0!r}".format(dt))
 * 
 *     if julian_gregorian_mixed and dt.year == 1582 and dt.month == 10 and dt.day > 4 and dt.day < 15:             # <<<<<<<<<<<<<<
 *         raise ValueError("{0!r} is not present in the mixed Julian/Gregorian calendar".format(dt))
 * 
*/
  if (__pyx_v_julian_gregorian_mixed) {
  } else {
    __pyx_t_1 = __pyx_v_julian_gregorian_mixed;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->year == 0x62E);
  if (__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->month == 10);
  if (__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->day > 4);
  if (__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L13_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->day < 15);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L13_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1777
 * 
 *     if julian_gregorian_mixed and dt.year == 1582 and dt.month == 10 and dt.day > 4 and dt.day < 15:
 *         raise ValueError("{0!r} is not present in the mixed Julian/Gregorian calendar".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if dt.hour < 0 or dt.hour > 23:
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_0_r_is_not_present_in_the_mixed;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1777, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1777, __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(0, 1777, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1776
 *         raise ValueError("invalid day number provided in {0!r}".format(dt))
 * 
 *     if julian_gregorian_mixed and dt.year == 1582 and dt.month == 10 and dt.day > 4 and dt.day < 15:             # <<<<<<<<<<<<<<
 *         raise ValueError("{0!r} is not present in the mixed Julian/Gregorian calendar".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1779
 *         raise ValueError("{0!r} is not present in the mixed Julian/Gregorian calendar".format(dt))
 * 
 *     if dt.hour < 0 or dt.hour > 23:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid hour provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->hour < 0);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L19_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->hour > 23);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L19_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1780
 * 
 *     if dt.hour < 0 or dt.hour > 23:
 *         raise ValueError("invalid hour provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if dt.minute < 0 or dt.minute > 59:
*/
    __pyx_t_3 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_hour_provided_in_0_r;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1780, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1780, __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(0, 1780, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1779
 *         raise ValueError("{0!r} is not present in the mixed Julian/Gregorian calendar".format(dt))
 * 
 *     if dt.hour < 0 or dt.hour > 23:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid hour provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1782
 *         raise ValueError("invalid hour provided in {0!r}".format(dt))
 * 
 *     if dt.minute < 0 or dt.minute > 59:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid minute provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->minute < 0);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L22_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->minute > 59);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L22_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1783
 * 
 *     if dt.minute < 0 or dt.minute > 59:
 *         raise ValueError("invalid minute provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if dt.second < 0 or dt.second > 59:
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_minute_provided_in_0_r;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1783, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1783, __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(0, 1783, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1782
 *         raise ValueError("invalid hour provided in {0!r}".format(dt))
 * 
 *     if dt.minute < 0 or dt.minute > 59:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid minute provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1785
 *         raise ValueError("invalid minute provided in {0!r}".format(dt))
 * 
 *     if dt.second < 0 or dt.second > 59:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid second provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->second < 0);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L25_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->second > 59);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L25_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1786
 * 
 *     if dt.second < 0 or dt.second > 59:
 *         raise ValueError("invalid second provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 *     if dt.microsecond < 0 or dt.microsecond > 999999:
*/
    __pyx_t_3 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_second_provided_in_0_r;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_4 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1786, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_4};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1786, __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(0, 1786, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1785
 *         raise ValueError("invalid minute provided in {0!r}".format(dt))
 * 
 *     if dt.second < 0 or dt.second > 59:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid second provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1788
 *         raise ValueError("invalid second provided in {0!r}".format(dt))
 * 
 *     if dt.microsecond < 0 or dt.microsecond > 999999:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid microsecond provided in {0!r}".format(dt))
 * 
*/
  __pyx_t_9 = (__pyx_v_dt->microsecond < 0);
  if (!__pyx_t_9) {
  } else {
    __pyx_t_1 = __pyx_t_9;
    goto __pyx_L28_bool_binop_done;
  }
  __pyx_t_9 = (__pyx_v_dt->microsecond > 0xF423F);
  __pyx_t_1 = __pyx_t_9;
  __pyx_L28_bool_binop_done:;
  if (unlikely(__pyx_t_1)) {

    /* "cftime/_cftime.pyx":1789
 * 
 *     if dt.microsecond < 0 or dt.microsecond > 999999:
 *         raise ValueError("invalid microsecond provided in {0!r}".format(dt))             # <<<<<<<<<<<<<<
 * 
 * # Add a datetime.timedelta to a cftime.datetime instance. Uses
*/
    __pyx_t_4 = NULL;
    __pyx_t_5 = __pyx_mstate_global->__pyx_kp_u_invalid_microsecond_provided_in;
    __Pyx_INCREF(__pyx_t_5);
    __pyx_t_6 = 0;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, ((PyObject *)__pyx_v_dt)};
      __pyx_t_3 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_format, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1789, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_3);
    }
    __pyx_t_6 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3};
      __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
      __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
      if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1789, __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(0, 1789, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1788
 *         raise ValueError("invalid second provided in {0!r}".format(dt))
 * 
 *     if dt.microsecond < 0 or dt.microsecond > 999999:             # <<<<<<<<<<<<<<
 *         raise ValueError("invalid microsecond provided in {0!r}".format(dt))
 * 
*/
  }

  /* "cftime/_cftime.pyx":1755
 *         return _dayspermonth
 * 
 * cdef void assert_valid_date(datetime dt, bint (*is_leap)(int, bint),             # <<<<<<<<<<<<<<
 *                             bint julian_gregorian_mixed,
 *                             bint has_year_zero=False,
*/

  /* 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_AddTraceback("cftime._cftime.assert_valid_date", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
}

/* "cftime/_cftime.pyx":1805
 * # the number of invalid dates are hard-wired (1582-10-4 is the last day
 * # of the Julian calendar, after which follows 1582-10-15).
 * cdef tuple add_timedelta(datetime dt, delta, bint (*is_leap)(int,bint), bint julian_gregorian_mixed, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     cdef int microsecond, second, minute, hour, day, month, year
 *     cdef int delta_microseconds, delta_seconds, delta_days
*/

static PyObject *__pyx_f_6cftime_7_cftime_add_timedelta(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt, PyObject *__pyx_v_delta, int (*__pyx_v_is_leap)(int, int), int __pyx_v_julian_gregorian_mixed, int __pyx_v_has_year_zero) {
  int __pyx_v_microsecond;
  int __pyx_v_second;
  int __pyx_v_minute;
  int __pyx_v_hour;
  int __pyx_v_day;
  int __pyx_v_month;
  int __pyx_v_year;
  int __pyx_v_delta_microseconds;
  int __pyx_v_delta_seconds;
  int __pyx_v_delta_days;
  int *__pyx_v_month_length;
  int __pyx_v_extra_days;
  int __pyx_v_n_invalid_dates;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  int *__pyx_t_3;
  int __pyx_t_4;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  PyObject *__pyx_t_10 = NULL;
  PyObject *__pyx_t_11 = NULL;
  PyObject *__pyx_t_12 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("add_timedelta", 0);

  /* "cftime/_cftime.pyx":1812
 * 
 *     # extract these inputs here to avoid type conversion in the code below
 *     delta_microseconds = delta.microseconds             # <<<<<<<<<<<<<<
 *     delta_seconds = delta.seconds
 *     delta_days = delta.days
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_microseconds); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1812, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1812, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_microseconds = __pyx_t_2;

  /* "cftime/_cftime.pyx":1813
 *     # extract these inputs here to avoid type conversion in the code below
 *     delta_microseconds = delta.microseconds
 *     delta_seconds = delta.seconds             # <<<<<<<<<<<<<<
 *     delta_days = delta.days
 * 
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_seconds); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1813, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1813, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_seconds = __pyx_t_2;

  /* "cftime/_cftime.pyx":1814
 *     delta_microseconds = delta.microseconds
 *     delta_seconds = delta.seconds
 *     delta_days = delta.days             # <<<<<<<<<<<<<<
 * 
 *     # shift microseconds, seconds, days
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_days); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1814, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1814, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_days = __pyx_t_2;

  /* "cftime/_cftime.pyx":1817
 * 
 *     # shift microseconds, seconds, days
 *     microsecond = dt.microsecond + delta_microseconds             # <<<<<<<<<<<<<<
 *     second = dt.second + delta_seconds
 *     minute = dt.minute
*/
  __pyx_v_microsecond = (__pyx_v_dt->microsecond + __pyx_v_delta_microseconds);

  /* "cftime/_cftime.pyx":1818
 *     # shift microseconds, seconds, days
 *     microsecond = dt.microsecond + delta_microseconds
 *     second = dt.second + delta_seconds             # <<<<<<<<<<<<<<
 *     minute = dt.minute
 *     hour = dt.hour
*/
  __pyx_v_second = (__pyx_v_dt->second + __pyx_v_delta_seconds);

  /* "cftime/_cftime.pyx":1819
 *     microsecond = dt.microsecond + delta_microseconds
 *     second = dt.second + delta_seconds
 *     minute = dt.minute             # <<<<<<<<<<<<<<
 *     hour = dt.hour
 *     day = dt.day
*/
  __pyx_t_2 = __pyx_v_dt->minute;
  __pyx_v_minute = __pyx_t_2;

  /* "cftime/_cftime.pyx":1820
 *     second = dt.second + delta_seconds
 *     minute = dt.minute
 *     hour = dt.hour             # <<<<<<<<<<<<<<
 *     day = dt.day
 *     month = dt.month
*/
  __pyx_t_2 = __pyx_v_dt->hour;
  __pyx_v_hour = __pyx_t_2;

  /* "cftime/_cftime.pyx":1821
 *     minute = dt.minute
 *     hour = dt.hour
 *     day = dt.day             # <<<<<<<<<<<<<<
 *     month = dt.month
 *     year = dt.year
*/
  __pyx_t_2 = __pyx_v_dt->day;
  __pyx_v_day = __pyx_t_2;

  /* "cftime/_cftime.pyx":1822
 *     hour = dt.hour
 *     day = dt.day
 *     month = dt.month             # <<<<<<<<<<<<<<
 *     year = dt.year
 * 
*/
  __pyx_t_2 = __pyx_v_dt->month;
  __pyx_v_month = __pyx_t_2;

  /* "cftime/_cftime.pyx":1823
 *     day = dt.day
 *     month = dt.month
 *     year = dt.year             # <<<<<<<<<<<<<<
 * 
 *     month_length = month_lengths(is_leap, year, has_year_zero)
*/
  __pyx_t_2 = __pyx_v_dt->year;
  __pyx_v_year = __pyx_t_2;

  /* "cftime/_cftime.pyx":1825
 *     year = dt.year
 * 
 *     month_length = month_lengths(is_leap, year, has_year_zero)             # <<<<<<<<<<<<<<
 * 
 *     n_invalid_dates = 10 if julian_gregorian_mixed else 0
*/
  __pyx_t_3 = __pyx_f_6cftime_7_cftime_month_lengths(__pyx_v_is_leap, __pyx_v_year, __pyx_v_has_year_zero); if (unlikely(__pyx_t_3 == ((void *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 1825, __pyx_L1_error)
  __pyx_v_month_length = __pyx_t_3;

  /* "cftime/_cftime.pyx":1827
 *     month_length = month_lengths(is_leap, year, has_year_zero)
 * 
 *     n_invalid_dates = 10 if julian_gregorian_mixed else 0             # <<<<<<<<<<<<<<
 * 
 *     # Normalize microseconds, seconds, minutes, hours.
*/
  if (__pyx_v_julian_gregorian_mixed) {
    __pyx_t_2 = 10;
  } else {
    __pyx_t_2 = 0;
  }
  __pyx_v_n_invalid_dates = __pyx_t_2;

  /* "cftime/_cftime.pyx":1830
 * 
 *     # Normalize microseconds, seconds, minutes, hours.
 *     second += microsecond // 1000000             # <<<<<<<<<<<<<<
 *     microsecond = microsecond % 1000000
 *     minute += second // 60
*/
  __pyx_v_second = (__pyx_v_second + __Pyx_div_long(__pyx_v_microsecond, 0xF4240, 1));

  /* "cftime/_cftime.pyx":1831
 *     # Normalize microseconds, seconds, minutes, hours.
 *     second += microsecond // 1000000
 *     microsecond = microsecond % 1000000             # <<<<<<<<<<<<<<
 *     minute += second // 60
 *     second = second % 60
*/
  __pyx_v_microsecond = __Pyx_mod_long(__pyx_v_microsecond, 0xF4240, 1);

  /* "cftime/_cftime.pyx":1832
 *     second += microsecond // 1000000
 *     microsecond = microsecond % 1000000
 *     minute += second // 60             # <<<<<<<<<<<<<<
 *     second = second % 60
 *     hour += minute // 60
*/
  __pyx_v_minute = (__pyx_v_minute + __Pyx_div_long(__pyx_v_second, 60, 1));

  /* "cftime/_cftime.pyx":1833
 *     microsecond = microsecond % 1000000
 *     minute += second // 60
 *     second = second % 60             # <<<<<<<<<<<<<<
 *     hour += minute // 60
 *     minute = minute % 60
*/
  __pyx_v_second = __Pyx_mod_long(__pyx_v_second, 60, 1);

  /* "cftime/_cftime.pyx":1834
 *     minute += second // 60
 *     second = second % 60
 *     hour += minute // 60             # <<<<<<<<<<<<<<
 *     minute = minute % 60
 *     extra_days = hour // 24
*/
  __pyx_v_hour = (__pyx_v_hour + __Pyx_div_long(__pyx_v_minute, 60, 1));

  /* "cftime/_cftime.pyx":1835
 *     second = second % 60
 *     hour += minute // 60
 *     minute = minute % 60             # <<<<<<<<<<<<<<
 *     extra_days = hour // 24
 *     hour = hour % 24
*/
  __pyx_v_minute = __Pyx_mod_long(__pyx_v_minute, 60, 1);

  /* "cftime/_cftime.pyx":1836
 *     hour += minute // 60
 *     minute = minute % 60
 *     extra_days = hour // 24             # <<<<<<<<<<<<<<
 *     hour = hour % 24
 * 
*/
  __pyx_v_extra_days = __Pyx_div_long(__pyx_v_hour, 24, 1);

  /* "cftime/_cftime.pyx":1837
 *     minute = minute % 60
 *     extra_days = hour // 24
 *     hour = hour % 24             # <<<<<<<<<<<<<<
 * 
 *     delta_days += extra_days
*/
  __pyx_v_hour = __Pyx_mod_long(__pyx_v_hour, 24, 1);

  /* "cftime/_cftime.pyx":1839
 *     hour = hour % 24
 * 
 *     delta_days += extra_days             # <<<<<<<<<<<<<<
 * 
 *     while delta_days < 0:
*/
  __pyx_v_delta_days = (__pyx_v_delta_days + __pyx_v_extra_days);

  /* "cftime/_cftime.pyx":1841
 *     delta_days += extra_days
 * 
 *     while delta_days < 0:             # <<<<<<<<<<<<<<
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:
 *             delta_days -= n_invalid_dates    # skip over invalid dates
*/
  while (1) {
    __pyx_t_4 = (__pyx_v_delta_days < 0);
    if (!__pyx_t_4) break;

    /* "cftime/_cftime.pyx":1842
 * 
 *     while delta_days < 0:
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:             # <<<<<<<<<<<<<<
 *             delta_days -= n_invalid_dates    # skip over invalid dates
 *         if day + delta_days < 1:
*/
    __pyx_t_5 = (__pyx_v_year == 0x62E);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L6_bool_binop_done;
    }
    __pyx_t_5 = (__pyx_v_month == 10);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L6_bool_binop_done;
    }
    __pyx_t_5 = (__pyx_v_day > 14);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L6_bool_binop_done;
    }
    __pyx_t_5 = ((__pyx_v_day + __pyx_v_delta_days) < 15);
    __pyx_t_4 = __pyx_t_5;
    __pyx_L6_bool_binop_done:;
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":1843
 *     while delta_days < 0:
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:
 *             delta_days -= n_invalid_dates    # skip over invalid dates             # <<<<<<<<<<<<<<
 *         if day + delta_days < 1:
 *             delta_days += day
*/
      __pyx_v_delta_days = (__pyx_v_delta_days - __pyx_v_n_invalid_dates);

      /* "cftime/_cftime.pyx":1842
 * 
 *     while delta_days < 0:
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:             # <<<<<<<<<<<<<<
 *             delta_days -= n_invalid_dates    # skip over invalid dates
 *         if day + delta_days < 1:
*/
    }

    /* "cftime/_cftime.pyx":1844
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:
 *             delta_days -= n_invalid_dates    # skip over invalid dates
 *         if day + delta_days < 1:             # <<<<<<<<<<<<<<
 *             delta_days += day
 *             # decrement month
*/
    __pyx_t_4 = ((__pyx_v_day + __pyx_v_delta_days) < 1);
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":1845
 *             delta_days -= n_invalid_dates    # skip over invalid dates
 *         if day + delta_days < 1:
 *             delta_days += day             # <<<<<<<<<<<<<<
 *             # decrement month
 *             month -= 1
*/
      __pyx_v_delta_days = (__pyx_v_delta_days + __pyx_v_day);

      /* "cftime/_cftime.pyx":1847
 *             delta_days += day
 *             # decrement month
 *             month -= 1             # <<<<<<<<<<<<<<
 *             if month < 1:
 *                 month = 12
*/
      __pyx_v_month = (__pyx_v_month - 1);

      /* "cftime/_cftime.pyx":1848
 *             # decrement month
 *             month -= 1
 *             if month < 1:             # <<<<<<<<<<<<<<
 *                 month = 12
 *                 year -= 1
*/
      __pyx_t_4 = (__pyx_v_month < 1);
      if (__pyx_t_4) {

        /* "cftime/_cftime.pyx":1849
 *             month -= 1
 *             if month < 1:
 *                 month = 12             # <<<<<<<<<<<<<<
 *                 year -= 1
 *                 if year == 0 and not has_year_zero:
*/
        __pyx_v_month = 12;

        /* "cftime/_cftime.pyx":1850
 *             if month < 1:
 *                 month = 12
 *                 year -= 1             # <<<<<<<<<<<<<<
 *                 if year == 0 and not has_year_zero:
 *                     year = -1
*/
        __pyx_v_year = (__pyx_v_year - 1);

        /* "cftime/_cftime.pyx":1851
 *                 month = 12
 *                 year -= 1
 *                 if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *                     year = -1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
*/
        __pyx_t_5 = (__pyx_v_year == 0);
        if (__pyx_t_5) {
        } else {
          __pyx_t_4 = __pyx_t_5;
          goto __pyx_L13_bool_binop_done;
        }
        __pyx_t_5 = (!__pyx_v_has_year_zero);
        __pyx_t_4 = __pyx_t_5;
        __pyx_L13_bool_binop_done:;
        if (__pyx_t_4) {

          /* "cftime/_cftime.pyx":1852
 *                 year -= 1
 *                 if year == 0 and not has_year_zero:
 *                     year = -1             # <<<<<<<<<<<<<<
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
 *             day = month_length[month-1]
*/
          __pyx_v_year = -1;

          /* "cftime/_cftime.pyx":1851
 *                 month = 12
 *                 year -= 1
 *                 if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *                     year = -1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
*/
        }

        /* "cftime/_cftime.pyx":1853
 *                 if year == 0 and not has_year_zero:
 *                     year = -1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)             # <<<<<<<<<<<<<<
 *             day = month_length[month-1]
 *         else:
*/
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_month_lengths(__pyx_v_is_leap, __pyx_v_year, __pyx_v_has_year_zero); if (unlikely(__pyx_t_3 == ((void *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 1853, __pyx_L1_error)
        __pyx_v_month_length = __pyx_t_3;

        /* "cftime/_cftime.pyx":1848
 *             # decrement month
 *             month -= 1
 *             if month < 1:             # <<<<<<<<<<<<<<
 *                 month = 12
 *                 year -= 1
*/
      }

      /* "cftime/_cftime.pyx":1854
 *                     year = -1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
 *             day = month_length[month-1]             # <<<<<<<<<<<<<<
 *         else:
 *             day += delta_days
*/
      __pyx_v_day = (__pyx_v_month_length[(__pyx_v_month - 1)]);

      /* "cftime/_cftime.pyx":1844
 *         if year == 1582 and month == 10 and day > 14 and day + delta_days < 15:
 *             delta_days -= n_invalid_dates    # skip over invalid dates
 *         if day + delta_days < 1:             # <<<<<<<<<<<<<<
 *             delta_days += day
 *             # decrement month
*/
      goto __pyx_L10;
    }

    /* "cftime/_cftime.pyx":1856
 *             day = month_length[month-1]
 *         else:
 *             day += delta_days             # <<<<<<<<<<<<<<
 *             delta_days = 0
 * 
*/
    /*else*/ {
      __pyx_v_day = (__pyx_v_day + __pyx_v_delta_days);

      /* "cftime/_cftime.pyx":1857
 *         else:
 *             day += delta_days
 *             delta_days = 0             # <<<<<<<<<<<<<<
 * 
 *     while delta_days > 0:
*/
      __pyx_v_delta_days = 0;
    }
    __pyx_L10:;
  }

  /* "cftime/_cftime.pyx":1859
 *             delta_days = 0
 * 
 *     while delta_days > 0:             # <<<<<<<<<<<<<<
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:
 *             delta_days += n_invalid_dates    # skip over invalid dates
*/
  while (1) {
    __pyx_t_4 = (__pyx_v_delta_days > 0);
    if (!__pyx_t_4) break;

    /* "cftime/_cftime.pyx":1860
 * 
 *     while delta_days > 0:
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:             # <<<<<<<<<<<<<<
 *             delta_days += n_invalid_dates    # skip over invalid dates
 *         if day + delta_days > month_length[month-1]:
*/
    __pyx_t_5 = (__pyx_v_year == 0x62E);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L18_bool_binop_done;
    }
    __pyx_t_5 = (__pyx_v_month == 10);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L18_bool_binop_done;
    }
    __pyx_t_5 = (__pyx_v_day < 5);
    if (__pyx_t_5) {
    } else {
      __pyx_t_4 = __pyx_t_5;
      goto __pyx_L18_bool_binop_done;
    }
    __pyx_t_5 = ((__pyx_v_day + __pyx_v_delta_days) > 4);
    __pyx_t_4 = __pyx_t_5;
    __pyx_L18_bool_binop_done:;
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":1861
 *     while delta_days > 0:
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:
 *             delta_days += n_invalid_dates    # skip over invalid dates             # <<<<<<<<<<<<<<
 *         if day + delta_days > month_length[month-1]:
 *             delta_days -= month_length[month-1] - (day - 1)
*/
      __pyx_v_delta_days = (__pyx_v_delta_days + __pyx_v_n_invalid_dates);

      /* "cftime/_cftime.pyx":1860
 * 
 *     while delta_days > 0:
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:             # <<<<<<<<<<<<<<
 *             delta_days += n_invalid_dates    # skip over invalid dates
 *         if day + delta_days > month_length[month-1]:
*/
    }

    /* "cftime/_cftime.pyx":1862
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:
 *             delta_days += n_invalid_dates    # skip over invalid dates
 *         if day + delta_days > month_length[month-1]:             # <<<<<<<<<<<<<<
 *             delta_days -= month_length[month-1] - (day - 1)
 *             # increment month
*/
    __pyx_t_4 = ((__pyx_v_day + __pyx_v_delta_days) > (__pyx_v_month_length[(__pyx_v_month - 1)]));
    if (__pyx_t_4) {

      /* "cftime/_cftime.pyx":1863
 *             delta_days += n_invalid_dates    # skip over invalid dates
 *         if day + delta_days > month_length[month-1]:
 *             delta_days -= month_length[month-1] - (day - 1)             # <<<<<<<<<<<<<<
 *             # increment month
 *             month += 1
*/
      __pyx_v_delta_days = (__pyx_v_delta_days - ((__pyx_v_month_length[(__pyx_v_month - 1)]) - (__pyx_v_day - 1)));

      /* "cftime/_cftime.pyx":1865
 *             delta_days -= month_length[month-1] - (day - 1)
 *             # increment month
 *             month += 1             # <<<<<<<<<<<<<<
 *             if month > 12:
 *                 month = 1
*/
      __pyx_v_month = (__pyx_v_month + 1);

      /* "cftime/_cftime.pyx":1866
 *             # increment month
 *             month += 1
 *             if month > 12:             # <<<<<<<<<<<<<<
 *                 month = 1
 *                 year += 1
*/
      __pyx_t_4 = (__pyx_v_month > 12);
      if (__pyx_t_4) {

        /* "cftime/_cftime.pyx":1867
 *             month += 1
 *             if month > 12:
 *                 month = 1             # <<<<<<<<<<<<<<
 *                 year += 1
 *                 if year == 0 and not has_year_zero:
*/
        __pyx_v_month = 1;

        /* "cftime/_cftime.pyx":1868
 *             if month > 12:
 *                 month = 1
 *                 year += 1             # <<<<<<<<<<<<<<
 *                 if year == 0 and not has_year_zero:
 *                     year = 1
*/
        __pyx_v_year = (__pyx_v_year + 1);

        /* "cftime/_cftime.pyx":1869
 *                 month = 1
 *                 year += 1
 *                 if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *                     year = 1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
*/
        __pyx_t_5 = (__pyx_v_year == 0);
        if (__pyx_t_5) {
        } else {
          __pyx_t_4 = __pyx_t_5;
          goto __pyx_L25_bool_binop_done;
        }
        __pyx_t_5 = (!__pyx_v_has_year_zero);
        __pyx_t_4 = __pyx_t_5;
        __pyx_L25_bool_binop_done:;
        if (__pyx_t_4) {

          /* "cftime/_cftime.pyx":1870
 *                 year += 1
 *                 if year == 0 and not has_year_zero:
 *                     year = 1             # <<<<<<<<<<<<<<
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
 *             day = 1
*/
          __pyx_v_year = 1;

          /* "cftime/_cftime.pyx":1869
 *                 month = 1
 *                 year += 1
 *                 if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *                     year = 1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
*/
        }

        /* "cftime/_cftime.pyx":1871
 *                 if year == 0 and not has_year_zero:
 *                     year = 1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)             # <<<<<<<<<<<<<<
 *             day = 1
 *         else:
*/
        __pyx_t_3 = __pyx_f_6cftime_7_cftime_month_lengths(__pyx_v_is_leap, __pyx_v_year, __pyx_v_has_year_zero); if (unlikely(__pyx_t_3 == ((void *)NULL) && PyErr_Occurred())) __PYX_ERR(0, 1871, __pyx_L1_error)
        __pyx_v_month_length = __pyx_t_3;

        /* "cftime/_cftime.pyx":1866
 *             # increment month
 *             month += 1
 *             if month > 12:             # <<<<<<<<<<<<<<
 *                 month = 1
 *                 year += 1
*/
      }

      /* "cftime/_cftime.pyx":1872
 *                     year = 1
 *                 month_length = month_lengths(is_leap, year, has_year_zero)
 *             day = 1             # <<<<<<<<<<<<<<
 *         else:
 *             day += delta_days
*/
      __pyx_v_day = 1;

      /* "cftime/_cftime.pyx":1862
 *         if year == 1582 and month == 10 and day < 5 and day + delta_days > 4:
 *             delta_days += n_invalid_dates    # skip over invalid dates
 *         if day + delta_days > month_length[month-1]:             # <<<<<<<<<<<<<<
 *             delta_days -= month_length[month-1] - (day - 1)
 *             # increment month
*/
      goto __pyx_L22;
    }

    /* "cftime/_cftime.pyx":1874
 *             day = 1
 *         else:
 *             day += delta_days             # <<<<<<<<<<<<<<
 *             delta_days = 0
 * 
*/
    /*else*/ {
      __pyx_v_day = (__pyx_v_day + __pyx_v_delta_days);

      /* "cftime/_cftime.pyx":1875
 *         else:
 *             day += delta_days
 *             delta_days = 0             # <<<<<<<<<<<<<<
 * 
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
*/
      __pyx_v_delta_days = 0;
    }
    __pyx_L22:;
  }

  /* "cftime/_cftime.pyx":1877
 *             delta_days = 0
 * 
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)             # <<<<<<<<<<<<<<
 * 
 * # Add a datetime.timedelta to a cftime.datetime instance with the 360_day calendar.
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_month); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_day); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_hour); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = __Pyx_PyLong_From_int(__pyx_v_minute); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __pyx_t_10 = __Pyx_PyLong_From_int(__pyx_v_second); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_10);
  __pyx_t_11 = __Pyx_PyLong_From_int(__pyx_v_microsecond); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_12 = PyTuple_New(9); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 1877, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_12);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_t_6) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_7);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 2, __pyx_t_7) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_8);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 3, __pyx_t_8) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_9);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 4, __pyx_t_9) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_10);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 5, __pyx_t_10) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_11);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 6, __pyx_t_11) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_int_neg_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 7, __pyx_mstate_global->__pyx_int_neg_1) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_int_neg_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_12, 8, __pyx_mstate_global->__pyx_int_neg_1) != (0)) __PYX_ERR(0, 1877, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __pyx_t_8 = 0;
  __pyx_t_9 = 0;
  __pyx_t_10 = 0;
  __pyx_t_11 = 0;
  __pyx_r = ((PyObject*)__pyx_t_12);
  __pyx_t_12 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1805
 * # the number of invalid dates are hard-wired (1582-10-4 is the last day
 * # of the Julian calendar, after which follows 1582-10-15).
 * cdef tuple add_timedelta(datetime dt, delta, bint (*is_leap)(int,bint), bint julian_gregorian_mixed, bint has_year_zero):             # <<<<<<<<<<<<<<
 *     cdef int microsecond, second, minute, hour, day, month, year
 *     cdef int delta_microseconds, delta_seconds, delta_days
*/

  /* 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_XDECREF(__pyx_t_10);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_12);
  __Pyx_AddTraceback("cftime._cftime.add_timedelta", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1885
 * # months are 30 days long, so we can compute month and year by using
 * # "//" and "%".
 * cdef tuple add_timedelta_360_day(datetime dt, delta):             # <<<<<<<<<<<<<<
 *     cdef int microsecond, second, minute, hour, day, month, year
 *     cdef int delta_microseconds, delta_seconds, delta_days
*/

static PyObject *__pyx_f_6cftime_7_cftime_add_timedelta_360_day(struct __pyx_obj_6cftime_7_cftime_datetime *__pyx_v_dt, PyObject *__pyx_v_delta) {
  int __pyx_v_microsecond;
  int __pyx_v_second;
  int __pyx_v_minute;
  int __pyx_v_hour;
  int __pyx_v_day;
  int __pyx_v_month;
  int __pyx_v_year;
  int __pyx_v_delta_microseconds;
  int __pyx_v_delta_seconds;
  int __pyx_v_delta_days;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  PyObject *__pyx_t_3 = NULL;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7 = NULL;
  PyObject *__pyx_t_8 = NULL;
  PyObject *__pyx_t_9 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("add_timedelta_360_day", 0);

  /* "cftime/_cftime.pyx":1890
 * 
 *     # extract these inputs here to avoid type conversion in the code below
 *     delta_microseconds = delta.microseconds             # <<<<<<<<<<<<<<
 *     delta_seconds = delta.seconds
 *     delta_days = delta.days
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_microseconds); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1890, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1890, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_microseconds = __pyx_t_2;

  /* "cftime/_cftime.pyx":1891
 *     # extract these inputs here to avoid type conversion in the code below
 *     delta_microseconds = delta.microseconds
 *     delta_seconds = delta.seconds             # <<<<<<<<<<<<<<
 *     delta_days = delta.days
 * 
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_seconds); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1891, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1891, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_seconds = __pyx_t_2;

  /* "cftime/_cftime.pyx":1892
 *     delta_microseconds = delta.microseconds
 *     delta_seconds = delta.seconds
 *     delta_days = delta.days             # <<<<<<<<<<<<<<
 * 
 *     # shift microseconds, seconds, days
*/
  __pyx_t_1 = __Pyx_PyObject_GetAttrStr(__pyx_v_delta, __pyx_mstate_global->__pyx_n_u_days); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1892, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_2 = __Pyx_PyLong_As_int(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1892, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_v_delta_days = __pyx_t_2;

  /* "cftime/_cftime.pyx":1895
 * 
 *     # shift microseconds, seconds, days
 *     microsecond = dt.microsecond + delta_microseconds             # <<<<<<<<<<<<<<
 *     second = dt.second + delta_seconds
 *     minute = dt.minute
*/
  __pyx_v_microsecond = (__pyx_v_dt->microsecond + __pyx_v_delta_microseconds);

  /* "cftime/_cftime.pyx":1896
 *     # shift microseconds, seconds, days
 *     microsecond = dt.microsecond + delta_microseconds
 *     second = dt.second + delta_seconds             # <<<<<<<<<<<<<<
 *     minute = dt.minute
 *     hour = dt.hour
*/
  __pyx_v_second = (__pyx_v_dt->second + __pyx_v_delta_seconds);

  /* "cftime/_cftime.pyx":1897
 *     microsecond = dt.microsecond + delta_microseconds
 *     second = dt.second + delta_seconds
 *     minute = dt.minute             # <<<<<<<<<<<<<<
 *     hour = dt.hour
 *     day = dt.day + delta_days
*/
  __pyx_t_2 = __pyx_v_dt->minute;
  __pyx_v_minute = __pyx_t_2;

  /* "cftime/_cftime.pyx":1898
 *     second = dt.second + delta_seconds
 *     minute = dt.minute
 *     hour = dt.hour             # <<<<<<<<<<<<<<
 *     day = dt.day + delta_days
 *     month = dt.month
*/
  __pyx_t_2 = __pyx_v_dt->hour;
  __pyx_v_hour = __pyx_t_2;

  /* "cftime/_cftime.pyx":1899
 *     minute = dt.minute
 *     hour = dt.hour
 *     day = dt.day + delta_days             # <<<<<<<<<<<<<<
 *     month = dt.month
 *     year = dt.year
*/
  __pyx_v_day = (__pyx_v_dt->day + __pyx_v_delta_days);

  /* "cftime/_cftime.pyx":1900
 *     hour = dt.hour
 *     day = dt.day + delta_days
 *     month = dt.month             # <<<<<<<<<<<<<<
 *     year = dt.year
 * 
*/
  __pyx_t_2 = __pyx_v_dt->month;
  __pyx_v_month = __pyx_t_2;

  /* "cftime/_cftime.pyx":1901
 *     day = dt.day + delta_days
 *     month = dt.month
 *     year = dt.year             # <<<<<<<<<<<<<<
 * 
 *     # Normalize microseconds, seconds, minutes, hours, days, and months.
*/
  __pyx_t_2 = __pyx_v_dt->year;
  __pyx_v_year = __pyx_t_2;

  /* "cftime/_cftime.pyx":1904
 * 
 *     # Normalize microseconds, seconds, minutes, hours, days, and months.
 *     second += microsecond // 1000000             # <<<<<<<<<<<<<<
 *     microsecond = microsecond % 1000000
 *     minute += second // 60
*/
  __pyx_v_second = (__pyx_v_second + __Pyx_div_long(__pyx_v_microsecond, 0xF4240, 1));

  /* "cftime/_cftime.pyx":1905
 *     # Normalize microseconds, seconds, minutes, hours, days, and months.
 *     second += microsecond // 1000000
 *     microsecond = microsecond % 1000000             # <<<<<<<<<<<<<<
 *     minute += second // 60
 *     second = second % 60
*/
  __pyx_v_microsecond = __Pyx_mod_long(__pyx_v_microsecond, 0xF4240, 1);

  /* "cftime/_cftime.pyx":1906
 *     second += microsecond // 1000000
 *     microsecond = microsecond % 1000000
 *     minute += second // 60             # <<<<<<<<<<<<<<
 *     second = second % 60
 *     hour += minute // 60
*/
  __pyx_v_minute = (__pyx_v_minute + __Pyx_div_long(__pyx_v_second, 60, 1));

  /* "cftime/_cftime.pyx":1907
 *     microsecond = microsecond % 1000000
 *     minute += second // 60
 *     second = second % 60             # <<<<<<<<<<<<<<
 *     hour += minute // 60
 *     minute = minute % 60
*/
  __pyx_v_second = __Pyx_mod_long(__pyx_v_second, 60, 1);

  /* "cftime/_cftime.pyx":1908
 *     minute += second // 60
 *     second = second % 60
 *     hour += minute // 60             # <<<<<<<<<<<<<<
 *     minute = minute % 60
 *     day += hour // 24
*/
  __pyx_v_hour = (__pyx_v_hour + __Pyx_div_long(__pyx_v_minute, 60, 1));

  /* "cftime/_cftime.pyx":1909
 *     second = second % 60
 *     hour += minute // 60
 *     minute = minute % 60             # <<<<<<<<<<<<<<
 *     day += hour // 24
 *     hour = hour % 24
*/
  __pyx_v_minute = __Pyx_mod_long(__pyx_v_minute, 60, 1);

  /* "cftime/_cftime.pyx":1910
 *     hour += minute // 60
 *     minute = minute % 60
 *     day += hour // 24             # <<<<<<<<<<<<<<
 *     hour = hour % 24
 *     # day and month are counted from 1; all months have 30 days
*/
  __pyx_v_day = (__pyx_v_day + __Pyx_div_long(__pyx_v_hour, 24, 1));

  /* "cftime/_cftime.pyx":1911
 *     minute = minute % 60
 *     day += hour // 24
 *     hour = hour % 24             # <<<<<<<<<<<<<<
 *     # day and month are counted from 1; all months have 30 days
 *     month += (day - 1) // 30
*/
  __pyx_v_hour = __Pyx_mod_long(__pyx_v_hour, 24, 1);

  /* "cftime/_cftime.pyx":1913
 *     hour = hour % 24
 *     # day and month are counted from 1; all months have 30 days
 *     month += (day - 1) // 30             # <<<<<<<<<<<<<<
 *     day = (day - 1) % 30 + 1
 *     # all years have 12 months
*/
  __pyx_v_month = (__pyx_v_month + __Pyx_div_long((__pyx_v_day - 1), 30, 1));

  /* "cftime/_cftime.pyx":1914
 *     # day and month are counted from 1; all months have 30 days
 *     month += (day - 1) // 30
 *     day = (day - 1) % 30 + 1             # <<<<<<<<<<<<<<
 *     # all years have 12 months
 *     year += (month - 1) // 12
*/
  __pyx_v_day = (__Pyx_mod_long((__pyx_v_day - 1), 30, 1) + 1);

  /* "cftime/_cftime.pyx":1916
 *     day = (day - 1) % 30 + 1
 *     # all years have 12 months
 *     year += (month - 1) // 12             # <<<<<<<<<<<<<<
 *     month = (month - 1) % 12 + 1
 * 
*/
  __pyx_v_year = (__pyx_v_year + __Pyx_div_long((__pyx_v_month - 1), 12, 1));

  /* "cftime/_cftime.pyx":1917
 *     # all years have 12 months
 *     year += (month - 1) // 12
 *     month = (month - 1) % 12 + 1             # <<<<<<<<<<<<<<
 * 
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
*/
  __pyx_v_month = (__Pyx_mod_long((__pyx_v_month - 1), 12, 1) + 1);

  /* "cftime/_cftime.pyx":1919
 *     month = (month - 1) % 12 + 1
 * 
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_year); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_month); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_3);
  __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_day); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_hour); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_5);
  __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_minute); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_7 = __Pyx_PyLong_From_int(__pyx_v_second); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_7);
  __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_microsecond); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_9 = PyTuple_New(9); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 1919, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_9);
  __Pyx_GIVEREF(__pyx_t_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_3);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 1, __pyx_t_3) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_4);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 2, __pyx_t_4) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_5);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 3, __pyx_t_5) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_6);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 4, __pyx_t_6) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_7);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 5, __pyx_t_7) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_GIVEREF(__pyx_t_8);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 6, __pyx_t_8) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_int_neg_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 7, __pyx_mstate_global->__pyx_int_neg_1) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __Pyx_INCREF(__pyx_mstate_global->__pyx_int_neg_1);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_int_neg_1);
  if (__Pyx_PyTuple_SET_ITEM(__pyx_t_9, 8, __pyx_mstate_global->__pyx_int_neg_1) != (0)) __PYX_ERR(0, 1919, __pyx_L1_error);
  __pyx_t_1 = 0;
  __pyx_t_3 = 0;
  __pyx_t_4 = 0;
  __pyx_t_5 = 0;
  __pyx_t_6 = 0;
  __pyx_t_7 = 0;
  __pyx_t_8 = 0;
  __pyx_r = ((PyObject*)__pyx_t_9);
  __pyx_t_9 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1885
 * # months are 30 days long, so we can compute month and year by using
 * # "//" and "%".
 * cdef tuple add_timedelta_360_day(datetime dt, delta):             # <<<<<<<<<<<<<<
 *     cdef int microsecond, second, minute, hour, day, month, year
 *     cdef int delta_microseconds, delta_seconds, delta_days
*/

  /* 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_XDECREF(__pyx_t_8);
  __Pyx_XDECREF(__pyx_t_9);
  __Pyx_AddTraceback("cftime._cftime.add_timedelta_360_day", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1921
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def is_leap_year(year, calendar, has_year_zero=None):
 *     """returns `True` if specified year in specified calendar is
*/

/* Python wrapper */
static PyObject *__pyx_pw_6cftime_7_cftime_37is_leap_year(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
); /*proto*/
PyDoc_STRVAR(__pyx_doc_6cftime_7_cftime_36is_leap_year, "is_leap_year(year, calendar, has_year_zero=None)\n\nreturns `True` if specified year in specified calendar is\na leap year. Optional kwarg `has_year_zero`\ncontrols whether astronomical year numbering\nis used and the year zero exists.  If not specified,\ncalendar-specific default is assumed.");
static PyMethodDef __pyx_mdef_6cftime_7_cftime_37is_leap_year = {"is_leap_year", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_37is_leap_year, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_36is_leap_year};
static PyObject *__pyx_pw_6cftime_7_cftime_37is_leap_year(PyObject *__pyx_self, 
#if CYTHON_METH_FASTCALL
PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds
#else
PyObject *__pyx_args, PyObject *__pyx_kwds
#endif
) {
  PyObject *__pyx_v_year = 0;
  PyObject *__pyx_v_calendar = 0;
  PyObject *__pyx_v_has_year_zero = 0;
  #if !CYTHON_METH_FASTCALL
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  #endif
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  PyObject* values[3] = {0,0,0};
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  PyObject *__pyx_r = 0;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("is_leap_year (wrapper)", 0);
  #if !CYTHON_METH_FASTCALL
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL;
  #endif
  #endif
  __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs);
  {
    PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_year,&__pyx_mstate_global->__pyx_n_u_calendar,&__pyx_mstate_global->__pyx_n_u_has_year_zero,0};
    const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0;
    if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 1921, __pyx_L3_error)
    if (__pyx_kwds_len > 0) {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1921, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1921, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  1:
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1921, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  0: break;
        default: goto __pyx_L5_argtuple_error;
      }
      const Py_ssize_t kwd_pos_args = __pyx_nargs;
      if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "is_leap_year", 0) < (0)) __PYX_ERR(0, 1921, __pyx_L3_error)

      /* "cftime/_cftime.pyx":1922
 * 
 * @cython.embedsignature(True)
 * def is_leap_year(year, calendar, has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """returns `True` if specified year in specified calendar is
 *     a leap year. Optional kwarg `has_year_zero`
*/
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
      for (Py_ssize_t i = __pyx_nargs; i < 2; i++) {
        if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("is_leap_year", 0, 2, 3, i); __PYX_ERR(0, 1921, __pyx_L3_error) }
      }
    } else {
      switch (__pyx_nargs) {
        case  3:
        values[2] = __Pyx_ArgRef_FASTCALL(__pyx_args, 2);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 1921, __pyx_L3_error)
        CYTHON_FALLTHROUGH;
        case  2:
        values[1] = __Pyx_ArgRef_FASTCALL(__pyx_args, 1);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 1921, __pyx_L3_error)
        values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0);
        if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 1921, __pyx_L3_error)
        break;
        default: goto __pyx_L5_argtuple_error;
      }
      if (!values[2]) values[2] = __Pyx_NewRef(((PyObject *)Py_None));
    }
    __pyx_v_year = values[0];
    __pyx_v_calendar = values[1];
    __pyx_v_has_year_zero = values[2];
  }
  goto __pyx_L6_skip;
  __pyx_L5_argtuple_error:;
  __Pyx_RaiseArgtupleInvalid("is_leap_year", 0, 2, 3, __pyx_nargs); __PYX_ERR(0, 1921, __pyx_L3_error)
  __pyx_L6_skip:;
  goto __pyx_L4_argument_unpacking_done;
  __pyx_L3_error:;
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_AddTraceback("cftime._cftime.is_leap_year", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __Pyx_RefNannyFinishContext();
  return NULL;
  __pyx_L4_argument_unpacking_done:;
  __pyx_r = __pyx_pf_6cftime_7_cftime_36is_leap_year(__pyx_self, __pyx_v_year, __pyx_v_calendar, __pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1921
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def is_leap_year(year, calendar, has_year_zero=None):
 *     """returns `True` if specified year in specified calendar is
*/

  /* function exit code */
  for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) {
    Py_XDECREF(values[__pyx_temp]);
  }
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

static PyObject *__pyx_pf_6cftime_7_cftime_36is_leap_year(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_year, PyObject *__pyx_v_calendar, PyObject *__pyx_v_has_year_zero) {
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  int __pyx_t_1;
  PyObject *__pyx_t_2 = NULL;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_3;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("is_leap_year", 0);

  /* "cftime/_cftime.pyx":1929
 *     calendar-specific default is assumed."""
 *     # public version of _is_leap (issue #259)
 *     return _is_leap(year, calendar, has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 * 
 * cdef _is_leap(int year, calendar, has_year_zero=None):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyLong_As_int(__pyx_v_year); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 1929, __pyx_L1_error)
  __pyx_t_3.__pyx_n = 1;
  __pyx_t_3.has_year_zero = __pyx_v_has_year_zero;
  __pyx_t_2 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_t_1, __pyx_v_calendar, &__pyx_t_3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1929, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_r = __pyx_t_2;
  __pyx_t_2 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1921
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def is_leap_year(year, calendar, has_year_zero=None):
 *     """returns `True` if specified year in specified calendar is
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime.is_leap_year", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = NULL;
  __pyx_L0:;
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1931
 *     return _is_leap(year, calendar, has_year_zero=has_year_zero)
 * 
 * cdef _is_leap(int year, calendar, has_year_zero=None):             # <<<<<<<<<<<<<<
 *     cdef int tyear
 *     cdef bint leap
*/

static PyObject *__pyx_f_6cftime_7_cftime__is_leap(int __pyx_v_year, PyObject *__pyx_v_calendar, struct __pyx_opt_args_6cftime_7_cftime__is_leap *__pyx_optional_args) {
  PyObject *__pyx_v_has_year_zero = ((PyObject *)Py_None);
  int __pyx_v_tyear;
  int __pyx_v_leap;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  int __pyx_t_3;
  int __pyx_t_4;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  size_t __pyx_t_7;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_is_leap", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_has_year_zero = __pyx_optional_args->has_year_zero;
    }
  }
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":1934
 *     cdef int tyear
 *     cdef bint leap
 *     calendar = _check_calendar(calendar)             # <<<<<<<<<<<<<<
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
*/
  __pyx_t_1 = __pyx_f_6cftime_7_cftime__check_calendar(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1934, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1936
 *     calendar = _check_calendar(calendar)
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if year == 0 and not has_year_zero:
*/
  __pyx_t_2 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":1937
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *     if year == 0 and not has_year_zero:
 *         raise ValueError('year zero does not exist in the %s calendar' %\
*/
    __pyx_t_1 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1937, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_1);
    __pyx_t_1 = 0;

    /* "cftime/_cftime.pyx":1936
 *     calendar = _check_calendar(calendar)
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if year == 0 and not has_year_zero:
*/
  }

  /* "cftime/_cftime.pyx":1938
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)
*/
  __pyx_t_3 = (__pyx_v_year == 0);
  if (__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L5_bool_binop_done;
  }
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1938, __pyx_L1_error)
  __pyx_t_4 = (!__pyx_t_3);
  __pyx_t_2 = __pyx_t_4;
  __pyx_L5_bool_binop_done:;
  if (unlikely(__pyx_t_2)) {

    /* "cftime/_cftime.pyx":1939
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if year == 0 and not has_year_zero:
 *         raise ValueError('year zero does not exist in the %s calendar' %\             # <<<<<<<<<<<<<<
 *                 calendar)
 *     # Because there is no year 0 in the Julian calendar, years -1, -5, -9, etc
*/
    __pyx_t_5 = NULL;

    /* "cftime/_cftime.pyx":1940
 *     if year == 0 and not has_year_zero:
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)             # <<<<<<<<<<<<<<
 *     # Because there is no year 0 in the Julian calendar, years -1, -5, -9, etc
 *     # are leap years. year zero is a leap year if it exists.
*/
    __pyx_t_6 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_year_zero_does_not_exist_in_the, __pyx_v_calendar); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1939, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_6};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_7, (2-__pyx_t_7) | (__pyx_t_7*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1939, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 1939, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1938
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)
*/
  }

  /* "cftime/_cftime.pyx":1943
 *     # Because there is no year 0 in the Julian calendar, years -1, -5, -9, etc
 *     # are leap years. year zero is a leap year if it exists.
 *     if year < 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         tyear = year + 1
 *     else:
*/
  __pyx_t_4 = (__pyx_v_year < 0);
  if (__pyx_t_4) {
  } else {
    __pyx_t_2 = __pyx_t_4;
    goto __pyx_L8_bool_binop_done;
  }
  __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1943, __pyx_L1_error)
  __pyx_t_3 = (!__pyx_t_4);
  __pyx_t_2 = __pyx_t_3;
  __pyx_L8_bool_binop_done:;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":1944
 *     # are leap years. year zero is a leap year if it exists.
 *     if year < 0 and not has_year_zero:
 *         tyear = year + 1             # <<<<<<<<<<<<<<
 *     else:
 *         tyear = year
*/
    __pyx_v_tyear = (__pyx_v_year + 1);

    /* "cftime/_cftime.pyx":1943
 *     # Because there is no year 0 in the Julian calendar, years -1, -5, -9, etc
 *     # are leap years. year zero is a leap year if it exists.
 *     if year < 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         tyear = year + 1
 *     else:
*/
    goto __pyx_L7;
  }

  /* "cftime/_cftime.pyx":1946
 *         tyear = year + 1
 *     else:
 *         tyear = year             # <<<<<<<<<<<<<<
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):
 *         if tyear % 4: # not divisible by 4
*/
  /*else*/ {
    __pyx_v_tyear = __pyx_v_year;
  }
  __pyx_L7:;

  /* "cftime/_cftime.pyx":1947
 *     else:
 *         tyear = year
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):             # <<<<<<<<<<<<<<
 *         if tyear % 4: # not divisible by 4
 *             leap = False
*/
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1947, __pyx_L1_error)
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L11_bool_binop_done;
  }
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1947, __pyx_L1_error)
  if (__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L11_bool_binop_done;
  }
  __pyx_t_3 = (__pyx_v_year > 0x62D);
  __pyx_t_2 = __pyx_t_3;
  __pyx_L11_bool_binop_done:;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":1948
 *         tyear = year
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):
 *         if tyear % 4: # not divisible by 4             # <<<<<<<<<<<<<<
 *             leap = False
 *         elif tyear % 100: # not divisible by 100
*/
    __pyx_t_2 = (__Pyx_mod_long(__pyx_v_tyear, 4, 1) != 0);
    if (__pyx_t_2) {

      /* "cftime/_cftime.pyx":1949
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):
 *         if tyear % 4: # not divisible by 4
 *             leap = False             # <<<<<<<<<<<<<<
 *         elif tyear % 100: # not divisible by 100
 *             leap = True
*/
      __pyx_v_leap = 0;

      /* "cftime/_cftime.pyx":1948
 *         tyear = year
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):
 *         if tyear % 4: # not divisible by 4             # <<<<<<<<<<<<<<
 *             leap = False
 *         elif tyear % 100: # not divisible by 100
*/
      goto __pyx_L14;
    }

    /* "cftime/_cftime.pyx":1950
 *         if tyear % 4: # not divisible by 4
 *             leap = False
 *         elif tyear % 100: # not divisible by 100             # <<<<<<<<<<<<<<
 *             leap = True
 *         elif tyear % 400: # not divisible by 400
*/
    __pyx_t_2 = (__Pyx_mod_long(__pyx_v_tyear, 0x64, 1) != 0);
    if (__pyx_t_2) {

      /* "cftime/_cftime.pyx":1951
 *             leap = False
 *         elif tyear % 100: # not divisible by 100
 *             leap = True             # <<<<<<<<<<<<<<
 *         elif tyear % 400: # not divisible by 400
 *             leap = False
*/
      __pyx_v_leap = 1;

      /* "cftime/_cftime.pyx":1950
 *         if tyear % 4: # not divisible by 4
 *             leap = False
 *         elif tyear % 100: # not divisible by 100             # <<<<<<<<<<<<<<
 *             leap = True
 *         elif tyear % 400: # not divisible by 400
*/
      goto __pyx_L14;
    }

    /* "cftime/_cftime.pyx":1952
 *         elif tyear % 100: # not divisible by 100
 *             leap = True
 *         elif tyear % 400: # not divisible by 400             # <<<<<<<<<<<<<<
 *             leap = False
 *         else:
*/
    __pyx_t_2 = (__Pyx_mod_long(__pyx_v_tyear, 0x190, 1) != 0);
    if (__pyx_t_2) {

      /* "cftime/_cftime.pyx":1953
 *             leap = True
 *         elif tyear % 400: # not divisible by 400
 *             leap = False             # <<<<<<<<<<<<<<
 *         else:
 *             leap = True
*/
      __pyx_v_leap = 0;

      /* "cftime/_cftime.pyx":1952
 *         elif tyear % 100: # not divisible by 100
 *             leap = True
 *         elif tyear % 400: # not divisible by 400             # <<<<<<<<<<<<<<
 *             leap = False
 *         else:
*/
      goto __pyx_L14;
    }

    /* "cftime/_cftime.pyx":1955
 *             leap = False
 *         else:
 *             leap = True             # <<<<<<<<<<<<<<
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):
 *         leap = tyear % 4 == 0
*/
    /*else*/ {
      __pyx_v_leap = 1;
    }
    __pyx_L14:;

    /* "cftime/_cftime.pyx":1947
 *     else:
 *         tyear = year
 *     if calendar == 'proleptic_gregorian' or (calendar == 'standard' and year > 1581):             # <<<<<<<<<<<<<<
 *         if tyear % 4: # not divisible by 4
 *             leap = False
*/
    goto __pyx_L10;
  }

  /* "cftime/_cftime.pyx":1956
 *         else:
 *             leap = True
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):             # <<<<<<<<<<<<<<
 *         leap = tyear % 4 == 0
 *     elif calendar == '366_day':
*/
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1956, __pyx_L1_error)
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L15_bool_binop_done;
  }
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 1956, __pyx_L1_error)
  if (__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L15_bool_binop_done;
  }
  __pyx_t_3 = (__pyx_v_year < 0x62E);
  __pyx_t_2 = __pyx_t_3;
  __pyx_L15_bool_binop_done:;
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":1957
 *             leap = True
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):
 *         leap = tyear % 4 == 0             # <<<<<<<<<<<<<<
 *     elif calendar == '366_day':
 *         leap = True
*/
    __pyx_v_leap = (__Pyx_mod_long(__pyx_v_tyear, 4, 1) == 0);

    /* "cftime/_cftime.pyx":1956
 *         else:
 *             leap = True
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):             # <<<<<<<<<<<<<<
 *         leap = tyear % 4 == 0
 *     elif calendar == '366_day':
*/
    goto __pyx_L10;
  }

  /* "cftime/_cftime.pyx":1958
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):
 *         leap = tyear % 4 == 0
 *     elif calendar == '366_day':             # <<<<<<<<<<<<<<
 *         leap = True
 *     else:
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_366_day, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 1958, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":1959
 *         leap = tyear % 4 == 0
 *     elif calendar == '366_day':
 *         leap = True             # <<<<<<<<<<<<<<
 *     else:
 *         leap = False
*/
    __pyx_v_leap = 1;

    /* "cftime/_cftime.pyx":1958
 *     elif calendar == 'julian' or (calendar == 'standard' and year < 1582):
 *         leap = tyear % 4 == 0
 *     elif calendar == '366_day':             # <<<<<<<<<<<<<<
 *         leap = True
 *     else:
*/
    goto __pyx_L10;
  }

  /* "cftime/_cftime.pyx":1961
 *         leap = True
 *     else:
 *         leap = False             # <<<<<<<<<<<<<<
 *     return leap
 * 
*/
  /*else*/ {
    __pyx_v_leap = 0;
  }
  __pyx_L10:;

  /* "cftime/_cftime.pyx":1962
 *     else:
 *         leap = False
 *     return leap             # <<<<<<<<<<<<<<
 * 
 * cdef _check_calendar(calendar):
*/
  __Pyx_XDECREF(__pyx_r);
  __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_leap); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1962, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_r = __pyx_t_1;
  __pyx_t_1 = 0;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1931
 *     return _is_leap(year, calendar, has_year_zero=has_year_zero)
 * 
 * cdef _is_leap(int year, calendar, has_year_zero=None):             # <<<<<<<<<<<<<<
 *     cdef int tyear
 *     cdef bint leap
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_AddTraceback("cftime._cftime._is_leap", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1964
 *     return leap
 * 
 * cdef _check_calendar(calendar):             # <<<<<<<<<<<<<<
 *     """validate calendars, convert to subset of names to get rid of synonyms"""
 *     calendar = calendar.lower()
*/

static PyObject *__pyx_f_6cftime_7_cftime__check_calendar(PyObject *__pyx_v_calendar) {
  PyObject *__pyx_v_calout = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  int __pyx_t_4;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_check_calendar", 0);
  __Pyx_INCREF(__pyx_v_calendar);

  /* "cftime/_cftime.pyx":1966
 * cdef _check_calendar(calendar):
 *     """validate calendars, convert to subset of names to get rid of synonyms"""
 *     calendar = calendar.lower()             # <<<<<<<<<<<<<<
 *     if calendar not in _calendars:
 *         raise ValueError('unsupported calendar')
*/
  __pyx_t_2 = __pyx_v_calendar;
  __Pyx_INCREF(__pyx_t_2);
  __pyx_t_3 = 0;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL};
    __pyx_t_1 = __Pyx_PyObject_FastCallMethod((PyObject*)__pyx_mstate_global->__pyx_n_u_lower, __pyx_callargs+__pyx_t_3, (1-__pyx_t_3) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1966, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":1967
 *     """validate calendars, convert to subset of names to get rid of synonyms"""
 *     calendar = calendar.lower()
 *     if calendar not in _calendars:             # <<<<<<<<<<<<<<
 *         raise ValueError('unsupported calendar')
 *     calout = calendar
*/
  __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_calendars); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1967, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = (__Pyx_PySequence_ContainsTF(__pyx_v_calendar, __pyx_t_1, Py_NE)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1967, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(__pyx_t_4)) {

    /* "cftime/_cftime.pyx":1968
 *     calendar = calendar.lower()
 *     if calendar not in _calendars:
 *         raise ValueError('unsupported calendar')             # <<<<<<<<<<<<<<
 *     calout = calendar
 *     # remove 'gregorian','noleap','all_leap'
*/
    __pyx_t_2 = NULL;
    __pyx_t_3 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_unsupported_calendar};
      __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_3, (2-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
      if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1968, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_1);
    }
    __Pyx_Raise(__pyx_t_1, 0, 0, 0);
    __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
    __PYX_ERR(0, 1968, __pyx_L1_error)

    /* "cftime/_cftime.pyx":1967
 *     """validate calendars, convert to subset of names to get rid of synonyms"""
 *     calendar = calendar.lower()
 *     if calendar not in _calendars:             # <<<<<<<<<<<<<<
 *         raise ValueError('unsupported calendar')
 *     calout = calendar
*/
  }

  /* "cftime/_cftime.pyx":1969
 *     if calendar not in _calendars:
 *         raise ValueError('unsupported calendar')
 *     calout = calendar             # <<<<<<<<<<<<<<
 *     # remove 'gregorian','noleap','all_leap'
 *     if calendar == 'gregorian':
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_v_calout = __pyx_v_calendar;

  /* "cftime/_cftime.pyx":1971
 *     calout = calendar
 *     # remove 'gregorian','noleap','all_leap'
 *     if calendar == 'gregorian':             # <<<<<<<<<<<<<<
 *         calout = 'standard'
 *     if calendar == 'noleap':
*/
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1971, __pyx_L1_error)
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":1972
 *     # remove 'gregorian','noleap','all_leap'
 *     if calendar == 'gregorian':
 *         calout = 'standard'             # <<<<<<<<<<<<<<
 *     if calendar == 'noleap':
 *         calout = '365_day'
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_standard);
    __Pyx_DECREF_SET(__pyx_v_calout, __pyx_mstate_global->__pyx_n_u_standard);

    /* "cftime/_cftime.pyx":1971
 *     calout = calendar
 *     # remove 'gregorian','noleap','all_leap'
 *     if calendar == 'gregorian':             # <<<<<<<<<<<<<<
 *         calout = 'standard'
 *     if calendar == 'noleap':
*/
  }

  /* "cftime/_cftime.pyx":1973
 *     if calendar == 'gregorian':
 *         calout = 'standard'
 *     if calendar == 'noleap':             # <<<<<<<<<<<<<<
 *         calout = '365_day'
 *     if calendar == 'all_leap':
*/
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_noleap, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1973, __pyx_L1_error)
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":1974
 *         calout = 'standard'
 *     if calendar == 'noleap':
 *         calout = '365_day'             # <<<<<<<<<<<<<<
 *     if calendar == 'all_leap':
 *         calout = '366_day'
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_365_day);
    __Pyx_DECREF_SET(__pyx_v_calout, __pyx_mstate_global->__pyx_kp_u_365_day);

    /* "cftime/_cftime.pyx":1973
 *     if calendar == 'gregorian':
 *         calout = 'standard'
 *     if calendar == 'noleap':             # <<<<<<<<<<<<<<
 *         calout = '365_day'
 *     if calendar == 'all_leap':
*/
  }

  /* "cftime/_cftime.pyx":1975
 *     if calendar == 'noleap':
 *         calout = '365_day'
 *     if calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *         calout = '366_day'
 *     return calout
*/
  __pyx_t_4 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_all_leap, Py_EQ)); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 1975, __pyx_L1_error)
  if (__pyx_t_4) {

    /* "cftime/_cftime.pyx":1976
 *         calout = '365_day'
 *     if calendar == 'all_leap':
 *         calout = '366_day'             # <<<<<<<<<<<<<<
 *     return calout
 * 
*/
    __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_366_day);
    __Pyx_DECREF_SET(__pyx_v_calout, __pyx_mstate_global->__pyx_kp_u_366_day);

    /* "cftime/_cftime.pyx":1975
 *     if calendar == 'noleap':
 *         calout = '365_day'
 *     if calendar == 'all_leap':             # <<<<<<<<<<<<<<
 *         calout = '366_day'
 *     return calout
*/
  }

  /* "cftime/_cftime.pyx":1977
 *     if calendar == 'all_leap':
 *         calout = '366_day'
 *     return calout             # <<<<<<<<<<<<<<
 * 
 * # The following function (_IntJulianDayFromDate) is based on
*/
  __Pyx_XDECREF(__pyx_r);
  __Pyx_INCREF(__pyx_v_calout);
  __pyx_r = __pyx_v_calout;
  goto __pyx_L0;

  /* "cftime/_cftime.pyx":1964
 *     return leap
 * 
 * cdef _check_calendar(calendar):             # <<<<<<<<<<<<<<
 *     """validate calendars, convert to subset of names to get rid of synonyms"""
 *     calendar = calendar.lower()
*/

  /* function exit code */
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_AddTraceback("cftime._cftime._check_calendar", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_calout);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":1986
 * 
 * 
 * cdef _IntJulianDayFromDate(int year,int month,int day,calendar,skip_transition=False,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """Compute integer Julian Day from year,month,day and calendar.
 * 
*/

static PyObject *__pyx_f_6cftime_7_cftime__IntJulianDayFromDate(int __pyx_v_year, int __pyx_v_month, int __pyx_v_day, PyObject *__pyx_v_calendar, struct __pyx_opt_args_6cftime_7_cftime__IntJulianDayFromDate *__pyx_optional_args) {
  PyObject *__pyx_v_skip_transition = ((PyObject *)Py_False);
  PyObject *__pyx_v_has_year_zero = ((PyObject *)Py_None);
  int __pyx_v_jday;
  int __pyx_v_jday_jul;
  int __pyx_v_jday_greg;
  int __pyx_v_leap;
  PyObject *__pyx_v_msg = NULL;
  PyObject *__pyx_r = NULL;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  int __pyx_t_2;
  int __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  PyObject *__pyx_t_5 = NULL;
  PyObject *__pyx_t_6 = NULL;
  PyObject *__pyx_t_7[9];
  PyObject *__pyx_t_8 = NULL;
  size_t __pyx_t_9;
  int __pyx_t_10;
  struct __pyx_opt_args_6cftime_7_cftime__is_leap __pyx_t_11;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("_IntJulianDayFromDate", 0);
  if (__pyx_optional_args) {
    if (__pyx_optional_args->__pyx_n > 0) {
      __pyx_v_skip_transition = __pyx_optional_args->skip_transition;
      if (__pyx_optional_args->__pyx_n > 1) {
        __pyx_v_has_year_zero = __pyx_optional_args->has_year_zero;
      }
    }
  }
  __Pyx_INCREF(__pyx_v_calendar);
  __Pyx_INCREF(__pyx_v_has_year_zero);

  /* "cftime/_cftime.pyx":2026
 * 
 *     # validate inputs.
 *     calendar = _check_calendar(calendar)             # <<<<<<<<<<<<<<
 *     if month < 1 or month > 12 or day < 1 or day > 31:
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\
*/
  __pyx_t_1 = __pyx_f_6cftime_7_cftime__check_calendar(__pyx_v_calendar); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2026, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __Pyx_DECREF_SET(__pyx_v_calendar, __pyx_t_1);
  __pyx_t_1 = 0;

  /* "cftime/_cftime.pyx":2027
 *     # validate inputs.
 *     calendar = _check_calendar(calendar)
 *     if month < 1 or month > 12 or day < 1 or day > 31:             # <<<<<<<<<<<<<<
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\
 *         (year,month,day,calendar)
*/
  __pyx_t_3 = (__pyx_v_month < 1);
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = (__pyx_v_month > 12);
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = (__pyx_v_day < 1);
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L4_bool_binop_done;
  }
  __pyx_t_3 = (__pyx_v_day > 31);
  __pyx_t_2 = __pyx_t_3;
  __pyx_L4_bool_binop_done:;
  if (unlikely(__pyx_t_2)) {

    /* "cftime/_cftime.pyx":2029
 *     if month < 1 or month > 12 or day < 1 or day > 31:
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\
 *         (year,month,day,calendar)             # <<<<<<<<<<<<<<
 *         raise ValueError(msg)
 *     # set calendar-specific defaults for has_year_zero
*/
    __pyx_t_1 = __Pyx_PyUnicode_From_int(__pyx_v_year, 4, '0', 'd'); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2029, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
    __pyx_t_4 = __Pyx_PyUnicode_From_int(__pyx_v_month, 2, '0', 'd'); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2029, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __pyx_t_5 = __Pyx_PyUnicode_From_int(__pyx_v_day, 2, '0', 'd'); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 2029, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_6 = __Pyx_PyObject_FormatSimpleAndDecref(PyObject_Str(__pyx_v_calendar), __pyx_mstate_global->__pyx_empty_unicode); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 2029, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_7[0] = __pyx_mstate_global->__pyx_kp_u_date_2;
    __pyx_t_7[1] = __pyx_t_1;
    __pyx_t_7[2] = __pyx_mstate_global->__pyx_kp_u_;
    __pyx_t_7[3] = __pyx_t_4;
    __pyx_t_7[4] = __pyx_mstate_global->__pyx_kp_u_;
    __pyx_t_7[5] = __pyx_t_5;
    __pyx_t_7[6] = __pyx_mstate_global->__pyx_kp_u_does_not_exist_in_the;
    __pyx_t_7[7] = __pyx_t_6;
    __pyx_t_7[8] = __pyx_mstate_global->__pyx_kp_u_calendar_2;

    /* "cftime/_cftime.pyx":2028
 *     calendar = _check_calendar(calendar)
 *     if month < 1 or month > 12 or day < 1 or day > 31:
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\             # <<<<<<<<<<<<<<
 *         (year,month,day,calendar)
 *         raise ValueError(msg)
*/
    __pyx_t_8 = __Pyx_PyUnicode_Join(__pyx_t_7, 9, 5 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_1) + 1 * 2 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_4) + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_5) + 23 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_6) + 9, 127 | __Pyx_PyUnicode_MAX_CHAR_VALUE(__pyx_t_6));
    if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2028, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __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_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_v_msg = ((PyObject*)__pyx_t_8);
    __pyx_t_8 = 0;

    /* "cftime/_cftime.pyx":2030
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\
 *         (year,month,day,calendar)
 *         raise ValueError(msg)             # <<<<<<<<<<<<<<
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
*/
    __pyx_t_6 = NULL;
    __pyx_t_9 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_msg};
      __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2030, __pyx_L1_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(0, 2030, __pyx_L1_error)

    /* "cftime/_cftime.pyx":2027
 *     # validate inputs.
 *     calendar = _check_calendar(calendar)
 *     if month < 1 or month > 12 or day < 1 or day > 31:             # <<<<<<<<<<<<<<
 *         msg = "date %04d-%02d-%02d does not exist in the %s calendar" %\
 *         (year,month,day,calendar)
*/
  }

  /* "cftime/_cftime.pyx":2032
 *         raise ValueError(msg)
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if calendar == '360_day':
*/
  __pyx_t_2 = (__pyx_v_has_year_zero == Py_None);
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2033
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)             # <<<<<<<<<<<<<<
 *     if calendar == '360_day':
 *         return year*360 + (month-1)*30 + day - 1
*/
    __pyx_t_8 = __pyx_f_6cftime_7_cftime__year_zero_defaults(__pyx_v_calendar); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2033, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __Pyx_DECREF_SET(__pyx_v_has_year_zero, __pyx_t_8);
    __pyx_t_8 = 0;

    /* "cftime/_cftime.pyx":2032
 *         raise ValueError(msg)
 *     # set calendar-specific defaults for has_year_zero
 *     if has_year_zero is None:             # <<<<<<<<<<<<<<
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if calendar == '360_day':
*/
  }

  /* "cftime/_cftime.pyx":2034
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if calendar == '360_day':             # <<<<<<<<<<<<<<
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_360_day, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 2034, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2035
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if calendar == '360_day':
 *         return year*360 + (month-1)*30 + day - 1             # <<<<<<<<<<<<<<
 *     elif calendar == '365_day':
 *         if month == 2 and day == 29:
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __Pyx_PyLong_From_long(((((__pyx_v_year * 0x168) + ((__pyx_v_month - 1) * 30)) + __pyx_v_day) - 1)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2035, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_r = __pyx_t_8;
    __pyx_t_8 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":2034
 *     if has_year_zero is None:
 *         has_year_zero = _year_zero_defaults(calendar)
 *     if calendar == '360_day':             # <<<<<<<<<<<<<<
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':
*/
  }

  /* "cftime/_cftime.pyx":2036
 *     if calendar == '360_day':
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':             # <<<<<<<<<<<<<<
 *         if month == 2 and day == 29:
 *             raise ValueError('no leap days in 365_day calendar')
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_365_day, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 2036, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2037
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':
 *         if month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *             raise ValueError('no leap days in 365_day calendar')
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
*/
    __pyx_t_3 = (__pyx_v_month == 2);
    if (__pyx_t_3) {
    } else {
      __pyx_t_2 = __pyx_t_3;
      goto __pyx_L11_bool_binop_done;
    }
    __pyx_t_3 = (__pyx_v_day == 29);
    __pyx_t_2 = __pyx_t_3;
    __pyx_L11_bool_binop_done:;
    if (unlikely(__pyx_t_2)) {

      /* "cftime/_cftime.pyx":2038
 *     elif calendar == '365_day':
 *         if month == 2 and day == 29:
 *             raise ValueError('no leap days in 365_day calendar')             # <<<<<<<<<<<<<<
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
 *     elif calendar == '366_day':
*/
      __pyx_t_6 = NULL;
      __pyx_t_9 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_no_leap_days_in_365_day_calendar};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2038, __pyx_L1_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(0, 2038, __pyx_L1_error)

      /* "cftime/_cftime.pyx":2037
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':
 *         if month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *             raise ValueError('no leap days in 365_day calendar')
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
*/
    }

    /* "cftime/_cftime.pyx":2039
 *         if month == 2 and day == 29:
 *             raise ValueError('no leap days in 365_day calendar')
 *         return year*365 + _cumdayspermonth[month-1] + day - 1             # <<<<<<<<<<<<<<
 *     elif calendar == '366_day':
 *         return year*366 + _cumdayspermonth_leap[month-1] + day - 1
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __Pyx_PyLong_From_long(((((__pyx_v_year * 0x16D) + (__pyx_v_6cftime_7_cftime__cumdayspermonth[(__pyx_v_month - 1)])) + __pyx_v_day) - 1)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2039, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_r = __pyx_t_8;
    __pyx_t_8 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":2036
 *     if calendar == '360_day':
 *         return year*360 + (month-1)*30 + day - 1
 *     elif calendar == '365_day':             # <<<<<<<<<<<<<<
 *         if month == 2 and day == 29:
 *             raise ValueError('no leap days in 365_day calendar')
*/
  }

  /* "cftime/_cftime.pyx":2040
 *             raise ValueError('no leap days in 365_day calendar')
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
 *     elif calendar == '366_day':             # <<<<<<<<<<<<<<
 *         return year*366 + _cumdayspermonth_leap[month-1] + day - 1
 * 
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_kp_u_366_day, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 2040, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2041
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
 *     elif calendar == '366_day':
 *         return year*366 + _cumdayspermonth_leap[month-1] + day - 1             # <<<<<<<<<<<<<<
 * 
 *     # handle standard, julian, proleptic_gregorian calendars.
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __Pyx_PyLong_From_long(((((__pyx_v_year * 0x16E) + (__pyx_v_6cftime_7_cftime__cumdayspermonth_leap[(__pyx_v_month - 1)])) + __pyx_v_day) - 1)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2041, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_r = __pyx_t_8;
    __pyx_t_8 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":2040
 *             raise ValueError('no leap days in 365_day calendar')
 *         return year*365 + _cumdayspermonth[month-1] + day - 1
 *     elif calendar == '366_day':             # <<<<<<<<<<<<<<
 *         return year*366 + _cumdayspermonth_leap[month-1] + day - 1
 * 
*/
  }

  /* "cftime/_cftime.pyx":2044
 * 
 *     # handle standard, julian, proleptic_gregorian calendars.
 *     if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)
*/
  __pyx_t_3 = (__pyx_v_year == 0);
  if (__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L14_bool_binop_done;
  }
  __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 2044, __pyx_L1_error)
  __pyx_t_10 = (!__pyx_t_3);
  __pyx_t_2 = __pyx_t_10;
  __pyx_L14_bool_binop_done:;
  if (unlikely(__pyx_t_2)) {

    /* "cftime/_cftime.pyx":2045
 *     # handle standard, julian, proleptic_gregorian calendars.
 *     if year == 0 and not has_year_zero:
 *         raise ValueError('year zero does not exist in the %s calendar' %\             # <<<<<<<<<<<<<<
 *                 calendar)
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)
*/
    __pyx_t_6 = NULL;

    /* "cftime/_cftime.pyx":2046
 *     if year == 0 and not has_year_zero:
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)             # <<<<<<<<<<<<<<
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)
 *     if not leap and month == 2 and day == 29:
*/
    __pyx_t_5 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_year_zero_does_not_exist_in_the, __pyx_v_calendar); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 2045, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_5);
    __pyx_t_9 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_5};
      __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
      __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0;
      if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2045, __pyx_L1_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(0, 2045, __pyx_L1_error)

    /* "cftime/_cftime.pyx":2044
 * 
 *     # handle standard, julian, proleptic_gregorian calendars.
 *     if year == 0 and not has_year_zero:             # <<<<<<<<<<<<<<
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)
*/
  }

  /* "cftime/_cftime.pyx":2047
 *         raise ValueError('year zero does not exist in the %s calendar' %\
 *                 calendar)
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)             # <<<<<<<<<<<<<<
 *     if not leap and month == 2 and day == 29:
 *         raise ValueError('%s is not a leap year' % year)
*/
  __pyx_t_11.__pyx_n = 1;
  __pyx_t_11.has_year_zero = __pyx_v_has_year_zero;
  __pyx_t_8 = __pyx_f_6cftime_7_cftime__is_leap(__pyx_v_year, __pyx_v_calendar, &__pyx_t_11); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2047, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_8);
  __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_8); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 2047, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_v_leap = __pyx_t_2;

  /* "cftime/_cftime.pyx":2048
 *                 calendar)
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)
 *     if not leap and month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *         raise ValueError('%s is not a leap year' % year)
 * 
*/
  __pyx_t_10 = (!__pyx_v_leap);
  if (__pyx_t_10) {
  } else {
    __pyx_t_2 = __pyx_t_10;
    goto __pyx_L17_bool_binop_done;
  }
  __pyx_t_10 = (__pyx_v_month == 2);
  if (__pyx_t_10) {
  } else {
    __pyx_t_2 = __pyx_t_10;
    goto __pyx_L17_bool_binop_done;
  }
  __pyx_t_10 = (__pyx_v_day == 29);
  __pyx_t_2 = __pyx_t_10;
  __pyx_L17_bool_binop_done:;
  if (unlikely(__pyx_t_2)) {

    /* "cftime/_cftime.pyx":2049
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)
 *     if not leap and month == 2 and day == 29:
 *         raise ValueError('%s is not a leap year' % year)             # <<<<<<<<<<<<<<
 * 
 *     if leap:
*/
    __pyx_t_5 = NULL;
    __pyx_t_6 = __Pyx_PyLong_From_int(__pyx_v_year); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 2049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
    __pyx_t_4 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_s_is_not_a_leap_year, __pyx_t_6); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2049, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_4);
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    __pyx_t_9 = 1;
    {
      PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_4};
      __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
      __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0;
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
      if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2049, __pyx_L1_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(0, 2049, __pyx_L1_error)

    /* "cftime/_cftime.pyx":2048
 *                 calendar)
 *     leap = _is_leap(year,calendar,has_year_zero=has_year_zero)
 *     if not leap and month == 2 and day == 29:             # <<<<<<<<<<<<<<
 *         raise ValueError('%s is not a leap year' % year)
 * 
*/
  }

  /* "cftime/_cftime.pyx":2051
 *         raise ValueError('%s is not a leap year' % year)
 * 
 *     if leap:             # <<<<<<<<<<<<<<
 *         jday = day + _cumdayspermonth_leap[month-1]
 *     else:
*/
  if (__pyx_v_leap) {

    /* "cftime/_cftime.pyx":2052
 * 
 *     if leap:
 *         jday = day + _cumdayspermonth_leap[month-1]             # <<<<<<<<<<<<<<
 *     else:
 *         jday = day + _cumdayspermonth[month-1]
*/
    __pyx_v_jday = (__pyx_v_day + (__pyx_v_6cftime_7_cftime__cumdayspermonth_leap[(__pyx_v_month - 1)]));

    /* "cftime/_cftime.pyx":2051
 *         raise ValueError('%s is not a leap year' % year)
 * 
 *     if leap:             # <<<<<<<<<<<<<<
 *         jday = day + _cumdayspermonth_leap[month-1]
 *     else:
*/
    goto __pyx_L20;
  }

  /* "cftime/_cftime.pyx":2054
 *         jday = day + _cumdayspermonth_leap[month-1]
 *     else:
 *         jday = day + _cumdayspermonth[month-1]             # <<<<<<<<<<<<<<
 *     if year < 0 and not has_year_zero: year += 1
 *     year += 4800 # add offset so -4800 is year 0.
*/
  /*else*/ {
    __pyx_v_jday = (__pyx_v_day + (__pyx_v_6cftime_7_cftime__cumdayspermonth[(__pyx_v_month - 1)]));
  }
  __pyx_L20:;

  /* "cftime/_cftime.pyx":2055
 *     else:
 *         jday = day + _cumdayspermonth[month-1]
 *     if year < 0 and not has_year_zero: year += 1             # <<<<<<<<<<<<<<
 *     year += 4800 # add offset so -4800 is year 0.
 *     # 1st term is the number of days in the last year
*/
  __pyx_t_10 = (__pyx_v_year < 0);
  if (__pyx_t_10) {
  } else {
    __pyx_t_2 = __pyx_t_10;
    goto __pyx_L22_bool_binop_done;
  }
  __pyx_t_10 = __Pyx_PyObject_IsTrue(__pyx_v_has_year_zero); if (unlikely((__pyx_t_10 < 0))) __PYX_ERR(0, 2055, __pyx_L1_error)
  __pyx_t_3 = (!__pyx_t_10);
  __pyx_t_2 = __pyx_t_3;
  __pyx_L22_bool_binop_done:;
  if (__pyx_t_2) {
    __pyx_v_year = (__pyx_v_year + 1);
  }

  /* "cftime/_cftime.pyx":2056
 *         jday = day + _cumdayspermonth[month-1]
 *     if year < 0 and not has_year_zero: year += 1
 *     year += 4800 # add offset so -4800 is year 0.             # <<<<<<<<<<<<<<
 *     # 1st term is the number of days in the last year
 *     # 2nd term is the number of days in each preceding non-leap year
*/
  __pyx_v_year = (__pyx_v_year + 0x12C0);

  /* "cftime/_cftime.pyx":2060
 *     # 2nd term is the number of days in each preceding non-leap year
 *     # last terms are the number of preceding leap years since -4800
 *     jday_jul = jday + 365*(year-1) + (year-1)//4             # <<<<<<<<<<<<<<
 *     # remove offset for 87 years before -4713 (including leap days)
 *     jday_jul -= 31777
*/
  __pyx_v_jday_jul = ((__pyx_v_jday + (0x16D * (__pyx_v_year - 1))) + __Pyx_div_long((__pyx_v_year - 1), 4, 1));

  /* "cftime/_cftime.pyx":2062
 *     jday_jul = jday + 365*(year-1) + (year-1)//4
 *     # remove offset for 87 years before -4713 (including leap days)
 *     jday_jul -= 31777             # <<<<<<<<<<<<<<
 *     jday_greg = jday + 365*(year-1) + (year-1)//4 - (year-1)//100 + (year-1)//400
 *     # remove offset, and account for the fact that -4713/1/1 is jday=38 in
*/
  __pyx_v_jday_jul = (__pyx_v_jday_jul - 0x7C21);

  /* "cftime/_cftime.pyx":2063
 *     # remove offset for 87 years before -4713 (including leap days)
 *     jday_jul -= 31777
 *     jday_greg = jday + 365*(year-1) + (year-1)//4 - (year-1)//100 + (year-1)//400             # <<<<<<<<<<<<<<
 *     # remove offset, and account for the fact that -4713/1/1 is jday=38 in
 *     # gregorian calendar.
*/
  __pyx_v_jday_greg = ((((__pyx_v_jday + (0x16D * (__pyx_v_year - 1))) + __Pyx_div_long((__pyx_v_year - 1), 4, 1)) - __Pyx_div_long((__pyx_v_year - 1), 0x64, 1)) + __Pyx_div_long((__pyx_v_year - 1), 0x190, 1));

  /* "cftime/_cftime.pyx":2066
 *     # remove offset, and account for the fact that -4713/1/1 is jday=38 in
 *     # gregorian calendar.
 *     jday_greg -= 31739             # <<<<<<<<<<<<<<
 *     if calendar == 'julian':
 *         return jday_jul
*/
  __pyx_v_jday_greg = (__pyx_v_jday_greg - 0x7BFB);

  /* "cftime/_cftime.pyx":2067
 *     # gregorian calendar.
 *     jday_greg -= 31739
 *     if calendar == 'julian':             # <<<<<<<<<<<<<<
 *         return jday_jul
 *     elif calendar == 'proleptic_gregorian':
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_julian, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 2067, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2068
 *     jday_greg -= 31739
 *     if calendar == 'julian':
 *         return jday_jul             # <<<<<<<<<<<<<<
 *     elif calendar == 'proleptic_gregorian':
 *         return jday_greg
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_jday_jul); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2068, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_r = __pyx_t_8;
    __pyx_t_8 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":2067
 *     # gregorian calendar.
 *     jday_greg -= 31739
 *     if calendar == 'julian':             # <<<<<<<<<<<<<<
 *         return jday_jul
 *     elif calendar == 'proleptic_gregorian':
*/
  }

  /* "cftime/_cftime.pyx":2069
 *     if calendar == 'julian':
 *         return jday_jul
 *     elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *         return jday_greg
 *     elif calendar in ['standard','gregorian']:
*/
  __pyx_t_2 = (__Pyx_PyUnicode_Equals(__pyx_v_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, Py_EQ)); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 2069, __pyx_L1_error)
  if (__pyx_t_2) {

    /* "cftime/_cftime.pyx":2070
 *         return jday_jul
 *     elif calendar == 'proleptic_gregorian':
 *         return jday_greg             # <<<<<<<<<<<<<<
 *     elif calendar in ['standard','gregorian']:
 *         # check for invalid days in mixed calendar (there are 10 missing)
*/
    __Pyx_XDECREF(__pyx_r);
    __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_jday_greg); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2070, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_8);
    __pyx_r = __pyx_t_8;
    __pyx_t_8 = 0;
    goto __pyx_L0;

    /* "cftime/_cftime.pyx":2069
 *     if calendar == 'julian':
 *         return jday_jul
 *     elif calendar == 'proleptic_gregorian':             # <<<<<<<<<<<<<<
 *         return jday_greg
 *     elif calendar in ['standard','gregorian']:
*/
  }

  /* "cftime/_cftime.pyx":2071
 *     elif calendar == 'proleptic_gregorian':
 *         return jday_greg
 *     elif calendar in ['standard','gregorian']:             # <<<<<<<<<<<<<<
 *         # check for invalid days in mixed calendar (there are 10 missing)
 *         if jday_jul >= 2299161 and jday_jul < 2299171:
*/
  __Pyx_INCREF(__pyx_v_calendar);
  __pyx_t_8 = __pyx_v_calendar;
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_standard, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 2071, __pyx_L1_error)
  if (!__pyx_t_3) {
  } else {
    __pyx_t_2 = __pyx_t_3;
    goto __pyx_L25_bool_binop_done;
  }
  __pyx_t_3 = (__Pyx_PyUnicode_Equals(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_gregorian, Py_EQ)); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 2071, __pyx_L1_error)
  __pyx_t_2 = __pyx_t_3;
  __pyx_L25_bool_binop_done:;
  __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;
  __pyx_t_3 = __pyx_t_2;
  if (__pyx_t_3) {

    /* "cftime/_cftime.pyx":2073
 *     elif calendar in ['standard','gregorian']:
 *         # check for invalid days in mixed calendar (there are 10 missing)
 *         if jday_jul >= 2299161 and jday_jul < 2299171:             # <<<<<<<<<<<<<<
 *             raise ValueError('invalid date in mixed calendar')
 *         if jday_jul < 2299161: # 1582 October 15
*/
    __pyx_t_2 = (__pyx_v_jday_jul >= 0x231519);
    if (__pyx_t_2) {
    } else {
      __pyx_t_3 = __pyx_t_2;
      goto __pyx_L28_bool_binop_done;
    }
    __pyx_t_2 = (__pyx_v_jday_jul < 0x231523);
    __pyx_t_3 = __pyx_t_2;
    __pyx_L28_bool_binop_done:;
    if (unlikely(__pyx_t_3)) {

      /* "cftime/_cftime.pyx":2074
 *         # check for invalid days in mixed calendar (there are 10 missing)
 *         if jday_jul >= 2299161 and jday_jul < 2299171:
 *             raise ValueError('invalid date in mixed calendar')             # <<<<<<<<<<<<<<
 *         if jday_jul < 2299161: # 1582 October 15
 *             return jday_jul
*/
      __pyx_t_4 = NULL;
      __pyx_t_9 = 1;
      {
        PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_invalid_date_in_mixed_calendar};
        __pyx_t_8 = __Pyx_PyObject_FastCall((PyObject*)(((PyTypeObject*)PyExc_ValueError)), __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
        __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
        if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2074, __pyx_L1_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(0, 2074, __pyx_L1_error)

      /* "cftime/_cftime.pyx":2073
 *     elif calendar in ['standard','gregorian']:
 *         # check for invalid days in mixed calendar (there are 10 missing)
 *         if jday_jul >= 2299161 and jday_jul < 2299171:             # <<<<<<<<<<<<<<
 *             raise ValueError('invalid date in mixed calendar')
 *         if jday_jul < 2299161: # 1582 October 15
*/
    }

    /* "cftime/_cftime.pyx":2075
 *         if jday_jul >= 2299161 and jday_jul < 2299171:
 *             raise ValueError('invalid date in mixed calendar')
 *         if jday_jul < 2299161: # 1582 October 15             # <<<<<<<<<<<<<<
 *             return jday_jul
 *         else:
*/
    __pyx_t_3 = (__pyx_v_jday_jul < 0x231519);
    if (__pyx_t_3) {

      /* "cftime/_cftime.pyx":2076
 *             raise ValueError('invalid date in mixed calendar')
 *         if jday_jul < 2299161: # 1582 October 15
 *             return jday_jul             # <<<<<<<<<<<<<<
 *         else:
 *             if skip_transition:
*/
      __Pyx_XDECREF(__pyx_r);
      __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_jday_jul); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2076, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_8);
      __pyx_r = __pyx_t_8;
      __pyx_t_8 = 0;
      goto __pyx_L0;

      /* "cftime/_cftime.pyx":2075
 *         if jday_jul >= 2299161 and jday_jul < 2299171:
 *             raise ValueError('invalid date in mixed calendar')
 *         if jday_jul < 2299161: # 1582 October 15             # <<<<<<<<<<<<<<
 *             return jday_jul
 *         else:
*/
    }

    /* "cftime/_cftime.pyx":2078
 *             return jday_jul
 *         else:
 *             if skip_transition:             # <<<<<<<<<<<<<<
 *                 return jday_greg+10
 *             else:
*/
    /*else*/ {
      __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_v_skip_transition); if (unlikely((__pyx_t_3 < 0))) __PYX_ERR(0, 2078, __pyx_L1_error)
      if (__pyx_t_3) {

        /* "cftime/_cftime.pyx":2079
 *         else:
 *             if skip_transition:
 *                 return jday_greg+10             # <<<<<<<<<<<<<<
 *             else:
 *                 return jday_greg
*/
        __Pyx_XDECREF(__pyx_r);
        __pyx_t_8 = __Pyx_PyLong_From_long((__pyx_v_jday_greg + 10)); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2079, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __pyx_r = __pyx_t_8;
        __pyx_t_8 = 0;
        goto __pyx_L0;

        /* "cftime/_cftime.pyx":2078
 *             return jday_jul
 *         else:
 *             if skip_transition:             # <<<<<<<<<<<<<<
 *                 return jday_greg+10
 *             else:
*/
      }

      /* "cftime/_cftime.pyx":2081
 *                 return jday_greg+10
 *             else:
 *                 return jday_greg             # <<<<<<<<<<<<<<
 * 
 * # legacy calendar specific sub-classes (will be removed in a future release).
*/
      /*else*/ {
        __Pyx_XDECREF(__pyx_r);
        __pyx_t_8 = __Pyx_PyLong_From_int(__pyx_v_jday_greg); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 2081, __pyx_L1_error)
        __Pyx_GOTREF(__pyx_t_8);
        __pyx_r = __pyx_t_8;
        __pyx_t_8 = 0;
        goto __pyx_L0;
      }
    }

    /* "cftime/_cftime.pyx":2071
 *     elif calendar == 'proleptic_gregorian':
 *         return jday_greg
 *     elif calendar in ['standard','gregorian']:             # <<<<<<<<<<<<<<
 *         # check for invalid days in mixed calendar (there are 10 missing)
 *         if jday_jul >= 2299161 and jday_jul < 2299171:
*/
  }

  /* "cftime/_cftime.pyx":1986
 * 
 * 
 * cdef _IntJulianDayFromDate(int year,int month,int day,calendar,skip_transition=False,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """Compute integer Julian Day from year,month,day and calendar.
 * 
*/

  /* 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_4);
  __Pyx_XDECREF(__pyx_t_5);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_8);
  __Pyx_AddTraceback("cftime._cftime._IntJulianDayFromDate", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = 0;
  __pyx_L0:;
  __Pyx_XDECREF(__pyx_v_msg);
  __Pyx_XDECREF(__pyx_v_calendar);
  __Pyx_XDECREF(__pyx_v_has_year_zero);
  __Pyx_XGIVEREF(__pyx_r);
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2091
 * but uses the "noleap" ("365_day") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='noleap'
 *         super().__init__(*args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_14DatetimeNoLeap_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_14DatetimeNoLeap_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_14DatetimeNoLeap___init__(((struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_14DatetimeNoLeap___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2092
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='noleap'             # <<<<<<<<<<<<<<
 *         super().__init__(*args, **kwargs)
 * 
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_noleap) < 0))) __PYX_ERR(0, 2092, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2093
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='noleap'
 *         super().__init__(*args, **kwargs)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2093, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2093, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2093, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2093, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2091
 * but uses the "noleap" ("365_day") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='noleap'
 *         super().__init__(*args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.DatetimeNoLeap.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2101
 * but uses the "all_leap" ("366_day") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='all_leap'
 *         super().__init__(*args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_15DatetimeAllLeap_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_15DatetimeAllLeap_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_15DatetimeAllLeap___init__(((struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_15DatetimeAllLeap___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2102
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='all_leap'             # <<<<<<<<<<<<<<
 *         super().__init__(*args, **kwargs)
 * 
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_all_leap) < 0))) __PYX_ERR(0, 2102, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2103
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='all_leap'
 *         super().__init__(*args, **kwargs)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2103, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2103, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2101
 * but uses the "all_leap" ("366_day") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='all_leap'
 *         super().__init__(*args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.DatetimeAllLeap.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2111
 * but uses the "360_day" calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='360_day'
 *         super().__init__(*args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_14Datetime360Day_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_14Datetime360Day_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_14Datetime360Day___init__(((struct __pyx_obj_6cftime_7_cftime_Datetime360Day *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_14Datetime360Day___init__(struct __pyx_obj_6cftime_7_cftime_Datetime360Day *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2112
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='360_day'             # <<<<<<<<<<<<<<
 *         super().__init__(*args, **kwargs)
 * 
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_kp_u_360_day) < 0))) __PYX_ERR(0, 2112, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2113
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='360_day'
 *         super().__init__(*args, **kwargs)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_Datetime360Day), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2113, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2113, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2113, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2113, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2111
 * but uses the "360_day" calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='360_day'
 *         super().__init__(*args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.Datetime360Day.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2121
 * but uses the "julian" calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='julian'
 *         super().__init__(*args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_14DatetimeJulian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_14DatetimeJulian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_14DatetimeJulian___init__(((struct __pyx_obj_6cftime_7_cftime_DatetimeJulian *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_14DatetimeJulian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeJulian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2122
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='julian'             # <<<<<<<<<<<<<<
 *         super().__init__(*args, **kwargs)
 * 
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_julian) < 0))) __PYX_ERR(0, 2122, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2123
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='julian'
 *         super().__init__(*args, **kwargs)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeJulian), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2123, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2123, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2121
 * but uses the "julian" calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='julian'
 *         super().__init__(*args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.DatetimeJulian.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2131
 * but uses the mixed Julian-Gregorian ("standard") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='standard'
 *         super().__init__(*args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_17DatetimeGregorian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_17DatetimeGregorian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_17DatetimeGregorian___init__(((struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_17DatetimeGregorian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2132
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='standard'             # <<<<<<<<<<<<<<
 *         super().__init__(*args, **kwargs)
 * 
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_standard) < 0))) __PYX_ERR(0, 2132, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2133
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='standard'
 *         super().__init__(*args, **kwargs)             # <<<<<<<<<<<<<<
 * 
 * @cython.embedsignature(True)
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2133, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2133, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2131
 * but uses the mixed Julian-Gregorian ("standard") calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='standard'
 *         super().__init__(*args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.DatetimeGregorian.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}

/* "cftime/_cftime.pyx":2141
 * but allows for dates that don't exist in the proleptic gregorian calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='proleptic_gregorian'
 *         super().__init__( *args, **kwargs)
*/

/* Python wrapper */
static int __pyx_pw_6cftime_7_cftime_26DatetimeProlepticGregorian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
static int __pyx_pw_6cftime_7_cftime_26DatetimeProlepticGregorian_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
  PyObject *__pyx_v_args = 0;
  PyObject *__pyx_v_kwargs = 0;
  CYTHON_UNUSED Py_ssize_t __pyx_nargs;
  CYTHON_UNUSED PyObject *const *__pyx_kwvalues;
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
  #if CYTHON_ASSUME_SAFE_SIZE
  __pyx_nargs = PyTuple_GET_SIZE(__pyx_args);
  #else
  __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1;
  #endif
  __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs);
  const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0;
  if (unlikely(__pyx_kwds_len < 0)) return -1;
  if (__pyx_kwds_len > 0) {
    if (unlikely(__Pyx_CheckKeywordStrings("__init__", __pyx_kwds) == -1)) return -1;
    __pyx_v_kwargs = __Pyx_KwargsAsDict_VARARGS(__pyx_kwds, __pyx_kwvalues);
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  } else {
    __pyx_v_kwargs = PyDict_New();
    if (unlikely(!__pyx_v_kwargs)) return -1;
    __Pyx_GOTREF(__pyx_v_kwargs);
  }
  __Pyx_INCREF(__pyx_args);
  __pyx_v_args = __pyx_args;
  __pyx_r = __pyx_pf_6cftime_7_cftime_26DatetimeProlepticGregorian___init__(((struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian *)__pyx_v_self), __pyx_v_args, __pyx_v_kwargs);

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

static int __pyx_pf_6cftime_7_cftime_26DatetimeProlepticGregorian___init__(struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian *__pyx_v_self, PyObject *__pyx_v_args, PyObject *__pyx_v_kwargs) {
  int __pyx_r;
  __Pyx_RefNannyDeclarations
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  size_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__init__", 0);

  /* "cftime/_cftime.pyx":2142
 *     """
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='proleptic_gregorian'             # <<<<<<<<<<<<<<
 *         super().__init__( *args, **kwargs)
*/
  if (unlikely((PyDict_SetItem(__pyx_v_kwargs, __pyx_mstate_global->__pyx_n_u_calendar, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian) < 0))) __PYX_ERR(0, 2142, __pyx_L1_error)

  /* "cftime/_cftime.pyx":2143
 *     def __init__(self, *args, **kwargs):
 *         kwargs['calendar']='proleptic_gregorian'
 *         super().__init__( *args, **kwargs)             # <<<<<<<<<<<<<<
*/
  __pyx_t_2 = NULL;
  __pyx_t_3 = 1;
  {
    PyObject *__pyx_callargs[3] = {__pyx_t_2, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian), ((PyObject *)__pyx_v_self)};
    __pyx_t_1 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_super, __pyx_callargs+__pyx_t_3, (3-__pyx_t_3) | (__pyx_t_3*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2143, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_1);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_init); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 2143, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyDict_Copy(__pyx_v_kwargs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2143, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_t_4 = __Pyx_PyObject_Call(__pyx_t_2, __pyx_v_args, __pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 2143, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":2141
 * but allows for dates that don't exist in the proleptic gregorian calendar.
 *     """
 *     def __init__(self, *args, **kwargs):             # <<<<<<<<<<<<<<
 *         kwargs['calendar']='proleptic_gregorian'
 *         super().__init__( *args, **kwargs)
*/

  /* function exit code */
  __pyx_r = 0;
  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_AddTraceback("cftime._cftime.DatetimeProlepticGregorian.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
  __pyx_r = -1;
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  return __pyx_r;
}
/* #### Code section: module_exttypes ### */
static struct __pyx_vtabstruct_6cftime_7_cftime_datetime __pyx_vtable_6cftime_7_cftime_datetime;

static PyObject *__pyx_tp_new_6cftime_7_cftime_datetime(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_datetime *p;
  PyObject *o;
  o = __Pyx_AllocateExtensionType(t, 0);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_datetime *)o);
  p->__pyx_vtab = __pyx_vtabptr_6cftime_7_cftime_datetime;
  p->calendar = ((PyObject*)Py_None); Py_INCREF(Py_None);
  p->tzinfo = Py_None; Py_INCREF(Py_None);
  return o;
}

static void __pyx_tp_dealloc_6cftime_7_cftime_datetime(PyObject *o) {
  struct __pyx_obj_6cftime_7_cftime_datetime *p = (struct __pyx_obj_6cftime_7_cftime_datetime *)o;
  #if CYTHON_USE_TP_FINALIZE
  if (unlikely(__Pyx_PyObject_GetSlot(o, tp_finalize, destructor)) && !__Pyx_PyObject_GC_IsFinalized(o)) {
    if (__Pyx_PyObject_GetSlot(o, tp_dealloc, destructor) == __pyx_tp_dealloc_6cftime_7_cftime_datetime) {
      if (PyObject_CallFinalizerFromDealloc(o)) return;
    }
  }
  #endif
  PyObject_GC_UnTrack(o);
  Py_CLEAR(p->calendar);
  Py_CLEAR(p->tzinfo);
  PyTypeObject *tp = Py_TYPE(o);
  #if CYTHON_USE_TYPE_SLOTS
  (*tp->tp_free)(o);
  #else
  {
    freefunc tp_free = (freefunc)PyType_GetSlot(tp, Py_tp_free);
    if (tp_free) tp_free(o);
  }
  #endif
  #if CYTHON_USE_TYPE_SPECS
  Py_DECREF(tp);
  #endif
}

static int __pyx_tp_traverse_6cftime_7_cftime_datetime(PyObject *o, visitproc v, void *a) {
  int e;
  struct __pyx_obj_6cftime_7_cftime_datetime *p = (struct __pyx_obj_6cftime_7_cftime_datetime *)o;
  {
    e = __Pyx_call_type_traverse(o, 1, v, a);
    if (e) return e;
  }
  if (p->tzinfo) {
    e = (*v)(p->tzinfo, a); if (e) return e;
  }
  return 0;
}

static int __pyx_tp_clear_6cftime_7_cftime_datetime(PyObject *o) {
  PyObject* tmp;
  struct __pyx_obj_6cftime_7_cftime_datetime *p = (struct __pyx_obj_6cftime_7_cftime_datetime *)o;
  tmp = ((PyObject*)p->tzinfo);
  p->tzinfo = Py_None; Py_INCREF(Py_None);
  Py_XDECREF(tmp);
  return 0;
}
#define __pyx_nb_add_6cftime_7_cftime_datetime __pyx_pw_6cftime_7_cftime_8datetime_35__add__
#define __pyx_nb_subtract_6cftime_7_cftime_datetime __pyx_pw_6cftime_7_cftime_8datetime_37__sub__

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_format(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_6format_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_dayofwk(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_7dayofwk_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_dayofyr(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_7dayofyr_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_daysinmonth(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_11daysinmonth_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_year(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_4year_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_month(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_5month_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_day(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_3day_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_hour(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_4hour_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_minute(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_6minute_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_second(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_6second_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_microsecond(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_11microsecond_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_calendar(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_8calendar_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime__dayofwk(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_8_dayofwk_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime__dayofyr(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_8_dayofyr_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_has_year_zero(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_13has_year_zero_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_tzinfo(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_6tzinfo_1__get__(o);
}

static PyObject *__pyx_getprop_6cftime_7_cftime_8datetime_datetime_compatible(PyObject *o, CYTHON_UNUSED void *x) {
  return __pyx_pw_6cftime_7_cftime_8datetime_19datetime_compatible_1__get__(o);
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_datetime[] = {
  {"strftime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_3strftime, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_2strftime},
  {"strptime", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_5strptime, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_4strptime},
  {"__format__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_7__format__, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_6__format__},
  {"replace", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_9replace, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_8replace},
  {"timetuple", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_11timetuple, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_10timetuple},
  {"isoformat", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_19isoformat, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_18isoformat},
  {"to_tuple", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_23to_tuple, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_22to_tuple},
  {"__reduce__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_27__reduce__, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_26__reduce__},
  {"fromordinal", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_29fromordinal, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_28fromordinal},
  {"toordinal", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_31toordinal, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_30toordinal},
  {"change_calendar", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_6cftime_7_cftime_8datetime_33change_calendar, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_6cftime_7_cftime_8datetime_32change_calendar},
  {"__add__", (PyCFunction)__pyx_pw_6cftime_7_cftime_8datetime_35__add__, METH_O|METH_COEXIST, 0},
  {"__sub__", (PyCFunction)__pyx_pw_6cftime_7_cftime_8datetime_37__sub__, METH_O|METH_COEXIST, 0},
  {0, 0, 0, 0}
};

static struct PyGetSetDef __pyx_getsets_6cftime_7_cftime_datetime[] = {
  {"format", __pyx_getprop_6cftime_7_cftime_8datetime_format, 0, 0, 0},
  {"dayofwk", __pyx_getprop_6cftime_7_cftime_8datetime_dayofwk, 0, 0, 0},
  {"dayofyr", __pyx_getprop_6cftime_7_cftime_8datetime_dayofyr, 0, 0, 0},
  {"daysinmonth", __pyx_getprop_6cftime_7_cftime_8datetime_daysinmonth, 0, 0, 0},
  {"year", __pyx_getprop_6cftime_7_cftime_8datetime_year, 0, 0, 0},
  {"month", __pyx_getprop_6cftime_7_cftime_8datetime_month, 0, 0, 0},
  {"day", __pyx_getprop_6cftime_7_cftime_8datetime_day, 0, 0, 0},
  {"hour", __pyx_getprop_6cftime_7_cftime_8datetime_hour, 0, 0, 0},
  {"minute", __pyx_getprop_6cftime_7_cftime_8datetime_minute, 0, 0, 0},
  {"second", __pyx_getprop_6cftime_7_cftime_8datetime_second, 0, 0, 0},
  {"microsecond", __pyx_getprop_6cftime_7_cftime_8datetime_microsecond, 0, 0, 0},
  {"calendar", __pyx_getprop_6cftime_7_cftime_8datetime_calendar, 0, 0, 0},
  {"_dayofwk", __pyx_getprop_6cftime_7_cftime_8datetime__dayofwk, 0, 0, 0},
  {"_dayofyr", __pyx_getprop_6cftime_7_cftime_8datetime__dayofyr, 0, 0, 0},
  {"has_year_zero", __pyx_getprop_6cftime_7_cftime_8datetime_has_year_zero, 0, 0, 0},
  {"tzinfo", __pyx_getprop_6cftime_7_cftime_8datetime_tzinfo, 0, 0, 0},
  {"datetime_compatible", __pyx_getprop_6cftime_7_cftime_8datetime_datetime_compatible, 0, 0, 0},
  {0, 0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_datetime_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_repr, (void *)__pyx_pw_6cftime_7_cftime_8datetime_15__repr__},
  {Py_nb_add, (void *)__pyx_nb_add_6cftime_7_cftime_datetime},
  {Py_nb_subtract, (void *)__pyx_nb_subtract_6cftime_7_cftime_datetime},
  {Py_tp_hash, (void *)__pyx_pw_6cftime_7_cftime_8datetime_21__hash__},
  {Py_tp_str, (void *)__pyx_pw_6cftime_7_cftime_8datetime_17__str__},
  {Py_tp_doc, (void *)PyDoc_STR("datetime(int year, int month, int day, int hour=0, int minute=0, int second=0, int microsecond=0, int dayofwk=-1, int dayofyr=-1, calendar='standard', has_year_zero=None)\n\nThis class mimics datetime.datetime but support calendars other than the proleptic\nGregorian calendar.\n\nSupports timedelta operations by overloading +/-, and\ncomparisons with other instances (even if they use different calendars).\nWhen comparing instances with different calendars, the second instance in the comparison (RHS) is\nconverted to the calendar of the LHS instance.  When comparing a list or array of instances (all using\nthe same calendar) to a single scalar instance,\nit is much faster to convert the single instance to the calendar of the array before doing\nthe comparison.\n\nComparison with native python datetime instances is possible\nfor cftime.datetime instances using\n'gregorian' and 'proleptic_gregorian' calendars.\n\nAll the calendars currently defined in the\n`CF metadata convention <http://cfconventions.org/cf-conventions/cf-conventions#calendar>`__ are supported.\nValid calendars are 'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'.\nDefault is 'standard', which is a mixed Julian/Gregorian calendar.\n'standard' and 'gregorian' are synonyms, as are 'all_leap'/'366_day'\nand 'noleap'/'365_day'.\n\nIf the calendar kwarg is set to a blank string ('') or None (the default is 'standard') the \ninstance will not be calendar-aware and some methods will not work.\n\nIf the has_year_zero kwarg is set to True, astronomical year numbering\nis used and the year zero exists.  If set to False for real-world\ncalendars, then historical year numbering is used and the year 1 is\npreceded by year -1 and no year zero exists.\nThe defaults are set to conform with\nCF version 1.9 conventions (False for 'julian', 'gregorian'/'standard', True\nfor 'proleptic_gregorian' (ISO 8601) and True for the idealized\ncalendars 'noleap'/'365_""day', '360_day', 366_day'/'all_leap')\nThe defaults can only be over-ridden for the real-world calendars,\nfor the the idealized calendars the year zero \nalways exists and the has_year_zero kwarg is ignored.\nThis kwarg is not needed to define calendar systems allowed by CF\n(the calendar-specific defaults do this).\n\nHas isoformat, strftime, timetuple, replace, dayofwk, dayofyr, daysinmonth,\n__repr__,__format__, __add__, __sub__, __str__ and comparison methods. \n\ndayofwk, dayofyr, daysinmonth, __add__ and __sub__ only work for calendar-aware\ninstances.\n\nThe default format of the string produced by strftime is controlled by self.format\n(default %Y-%m-%d %H:%M:%S).\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_richcompare, (void *)__pyx_pw_6cftime_7_cftime_8datetime_25__richcmp__},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_datetime},
  {Py_tp_getset, (void *)__pyx_getsets_6cftime_7_cftime_datetime},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_8datetime_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_datetime},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_datetime_spec = {
  "cftime._cftime.datetime",
  sizeof(struct __pyx_obj_6cftime_7_cftime_datetime),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_datetime_slots,
};
#else

static PyNumberMethods __pyx_tp_as_number_datetime = {
  __pyx_nb_add_6cftime_7_cftime_datetime, /*nb_add*/
  __pyx_nb_subtract_6cftime_7_cftime_datetime, /*nb_subtract*/
  0, /*nb_multiply*/
  0, /*nb_remainder*/
  0, /*nb_divmod*/
  0, /*nb_power*/
  0, /*nb_negative*/
  0, /*nb_positive*/
  0, /*nb_absolute*/
  0, /*nb_bool*/
  0, /*nb_invert*/
  0, /*nb_lshift*/
  0, /*nb_rshift*/
  0, /*nb_and*/
  0, /*nb_xor*/
  0, /*nb_or*/
  0, /*nb_int*/
  0, /*nb_long (reserved)*/
  0, /*nb_float*/
  0, /*nb_inplace_add*/
  0, /*nb_inplace_subtract*/
  0, /*nb_inplace_multiply*/
  0, /*nb_inplace_remainder*/
  0, /*nb_inplace_power*/
  0, /*nb_inplace_lshift*/
  0, /*nb_inplace_rshift*/
  0, /*nb_inplace_and*/
  0, /*nb_inplace_xor*/
  0, /*nb_inplace_or*/
  0, /*nb_floor_divide*/
  0, /*nb_true_divide*/
  0, /*nb_inplace_floor_divide*/
  0, /*nb_inplace_true_divide*/
  0, /*nb_index*/
  0, /*nb_matrix_multiply*/
  0, /*nb_inplace_matrix_multiply*/
};

static PyTypeObject __pyx_type_6cftime_7_cftime_datetime = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""datetime", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_datetime), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  &__pyx_tp_as_number_datetime, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  __pyx_pw_6cftime_7_cftime_8datetime_21__hash__, /*tp_hash*/
  0, /*tp_call*/
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("datetime(int year, int month, int day, int hour=0, int minute=0, int second=0, int microsecond=0, int dayofwk=-1, int dayofyr=-1, calendar='standard', has_year_zero=None)\n\nThis class mimics datetime.datetime but support calendars other than the proleptic\nGregorian calendar.\n\nSupports timedelta operations by overloading +/-, and\ncomparisons with other instances (even if they use different calendars).\nWhen comparing instances with different calendars, the second instance in the comparison (RHS) is\nconverted to the calendar of the LHS instance.  When comparing a list or array of instances (all using\nthe same calendar) to a single scalar instance,\nit is much faster to convert the single instance to the calendar of the array before doing\nthe comparison.\n\nComparison with native python datetime instances is possible\nfor cftime.datetime instances using\n'gregorian' and 'proleptic_gregorian' calendars.\n\nAll the calendars currently defined in the\n`CF metadata convention <http://cfconventions.org/cf-conventions/cf-conventions#calendar>`__ are supported.\nValid calendars are 'standard', 'gregorian', 'proleptic_gregorian'\n'noleap', '365_day', '360_day', 'julian', 'all_leap', '366_day'.\nDefault is 'standard', which is a mixed Julian/Gregorian calendar.\n'standard' and 'gregorian' are synonyms, as are 'all_leap'/'366_day'\nand 'noleap'/'365_day'.\n\nIf the calendar kwarg is set to a blank string ('') or None (the default is 'standard') the \ninstance will not be calendar-aware and some methods will not work.\n\nIf the has_year_zero kwarg is set to True, astronomical year numbering\nis used and the year zero exists.  If set to False for real-world\ncalendars, then historical year numbering is used and the year 1 is\npreceded by year -1 and no year zero exists.\nThe defaults are set to conform with\nCF version 1.9 conventions (False for 'julian', 'gregorian'/'standard', True\nfor 'proleptic_gregorian' (ISO 8601) and True for the idealized\ncalendars 'noleap'/'365_""day', '360_day', 366_day'/'all_leap')\nThe defaults can only be over-ridden for the real-world calendars,\nfor the the idealized calendars the year zero \nalways exists and the has_year_zero kwarg is ignored.\nThis kwarg is not needed to define calendar systems allowed by CF\n(the calendar-specific defaults do this).\n\nHas isoformat, strftime, timetuple, replace, dayofwk, dayofyr, daysinmonth,\n__repr__,__format__, __add__, __sub__, __str__ and comparison methods. \n\ndayofwk, dayofyr, daysinmonth, __add__ and __sub__ only work for calendar-aware\ninstances.\n\nThe default format of the string produced by strftime is controlled by self.format\n(default %Y-%m-%d %H:%M:%S).\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  __pyx_pw_6cftime_7_cftime_8datetime_25__richcmp__, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_datetime, /*tp_methods*/
  0, /*tp_members*/
  __pyx_getsets_6cftime_7_cftime_datetime, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_8datetime_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_datetime, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeNoLeap __pyx_vtable_6cftime_7_cftime_DatetimeNoLeap;

static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeNoLeap(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_DatetimeNoLeap;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_DatetimeNoLeap[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_DatetimeNoLeap_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("DatetimeNoLeap(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"noleap\" (\"365_day\") calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_DatetimeNoLeap},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_14DatetimeNoLeap_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_DatetimeNoLeap},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_DatetimeNoLeap_spec = {
  "cftime._cftime.DatetimeNoLeap",
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_DatetimeNoLeap_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_DatetimeNoLeap = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""DatetimeNoLeap", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeNoLeap), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("DatetimeNoLeap(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"noleap\" (\"365_day\") calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_DatetimeNoLeap, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_14DatetimeNoLeap_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_DatetimeNoLeap, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeAllLeap __pyx_vtable_6cftime_7_cftime_DatetimeAllLeap;

static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeAllLeap(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_DatetimeAllLeap;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_DatetimeAllLeap[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_DatetimeAllLeap_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("DatetimeAllLeap(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"all_leap\" (\"366_day\") calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_DatetimeAllLeap},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_15DatetimeAllLeap_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_DatetimeAllLeap},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_DatetimeAllLeap_spec = {
  "cftime._cftime.DatetimeAllLeap",
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_DatetimeAllLeap_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_DatetimeAllLeap = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""DatetimeAllLeap", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeAllLeap), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("DatetimeAllLeap(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"all_leap\" (\"366_day\") calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_DatetimeAllLeap, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_15DatetimeAllLeap_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_DatetimeAllLeap, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_Datetime360Day __pyx_vtable_6cftime_7_cftime_Datetime360Day;

static PyObject *__pyx_tp_new_6cftime_7_cftime_Datetime360Day(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_Datetime360Day *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_Datetime360Day *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_Datetime360Day;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_Datetime360Day[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_Datetime360Day_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("Datetime360Day(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"360_day\" calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_Datetime360Day},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_14Datetime360Day_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_Datetime360Day},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_Datetime360Day_spec = {
  "cftime._cftime.Datetime360Day",
  sizeof(struct __pyx_obj_6cftime_7_cftime_Datetime360Day),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_Datetime360Day_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_Datetime360Day = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""Datetime360Day", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_Datetime360Day), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("Datetime360Day(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"360_day\" calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_Datetime360Day, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_14Datetime360Day_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_Datetime360Day, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeJulian __pyx_vtable_6cftime_7_cftime_DatetimeJulian;

static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeJulian(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_DatetimeJulian *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_DatetimeJulian *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_DatetimeJulian;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_DatetimeJulian[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_DatetimeJulian_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("DatetimeJulian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"julian\" calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_DatetimeJulian},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_14DatetimeJulian_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_DatetimeJulian},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_DatetimeJulian_spec = {
  "cftime._cftime.DatetimeJulian",
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeJulian),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_DatetimeJulian_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_DatetimeJulian = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""DatetimeJulian", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeJulian), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("DatetimeJulian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the \"julian\" calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_DatetimeJulian, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_14DatetimeJulian_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_DatetimeJulian, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeGregorian __pyx_vtable_6cftime_7_cftime_DatetimeGregorian;

static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeGregorian(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_DatetimeGregorian;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_DatetimeGregorian[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_DatetimeGregorian_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("DatetimeGregorian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the mixed Julian-Gregorian (\"standard\") calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_DatetimeGregorian},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_17DatetimeGregorian_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_DatetimeGregorian},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_DatetimeGregorian_spec = {
  "cftime._cftime.DatetimeGregorian",
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_DatetimeGregorian_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_DatetimeGregorian = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""DatetimeGregorian", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeGregorian), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("DatetimeGregorian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut uses the mixed Julian-Gregorian (\"standard\") calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_DatetimeGregorian, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_17DatetimeGregorian_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_DatetimeGregorian, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif
static struct __pyx_vtabstruct_6cftime_7_cftime_DatetimeProlepticGregorian __pyx_vtable_6cftime_7_cftime_DatetimeProlepticGregorian;

static PyObject *__pyx_tp_new_6cftime_7_cftime_DatetimeProlepticGregorian(PyTypeObject *t, PyObject *a, PyObject *k) {
  struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian *p;
  PyObject *o = __pyx_tp_new_6cftime_7_cftime_datetime(t, a, k);
  if (unlikely(!o)) return 0;
  p = ((struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian *)o);
  p->__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6cftime_7_cftime_datetime*)__pyx_vtabptr_6cftime_7_cftime_DatetimeProlepticGregorian;
  return o;
}

static PyMethodDef __pyx_methods_6cftime_7_cftime_DatetimeProlepticGregorian[] = {
  {0, 0, 0, 0}
};
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime_datetime},
  {Py_tp_doc, (void *)PyDoc_STR("DatetimeProlepticGregorian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut allows for dates that don't exist in the proleptic gregorian calendar.\n    ")},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime_datetime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime_datetime},
  {Py_tp_methods, (void *)__pyx_methods_6cftime_7_cftime_DatetimeProlepticGregorian},
  {Py_tp_init, (void *)__pyx_pw_6cftime_7_cftime_26DatetimeProlepticGregorian_1__init__},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime_DatetimeProlepticGregorian},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian_spec = {
  "cftime._cftime.DatetimeProlepticGregorian",
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""DatetimeProlepticGregorian", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime_DatetimeProlepticGregorian), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime_datetime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_15__repr__, /*tp_repr*/
  #else
  0, /*tp_repr*/
  #endif
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  #if CYTHON_COMPILING_IN_PYPY || 0
  __pyx_pw_6cftime_7_cftime_8datetime_17__str__, /*tp_str*/
  #else
  0, /*tp_str*/
  #endif
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  PyDoc_STR("DatetimeProlepticGregorian(*args, **kwargs)\n\nPhony datetime object which mimics the python datetime object,\nbut allows for dates that don't exist in the proleptic gregorian calendar.\n    "), /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime_datetime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime_datetime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  __pyx_methods_6cftime_7_cftime_DatetimeProlepticGregorian, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  __pyx_pw_6cftime_7_cftime_26DatetimeProlepticGregorian_1__init__, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime_DatetimeProlepticGregorian, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif

static PyObject *__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct__strptime(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) {
  PyObject *o;
  #if CYTHON_USE_FREELISTS
  if (likely((int)(__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct__strptime > 0) & __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(t, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime))))
  {
    o = (PyObject*)__pyx_mstate_global->__pyx_freelist_6cftime_7_cftime___pyx_scope_struct__strptime[--__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct__strptime];
    #if CYTHON_USE_TYPE_SPECS
    Py_DECREF(Py_TYPE(o));
    #endif
    memset(o, 0, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime));
    #if CYTHON_COMPILING_IN_LIMITED_API
    (void) PyObject_Init(o, t);
    #else
    (void) PyObject_INIT(o, t);
    #endif
    PyObject_GC_Track(o);
  } else
  #endif
  {
    o = __Pyx_AllocateExtensionType(t, 1);
    if (unlikely(!o)) return 0;
  }
  return o;
}

static void __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct__strptime(PyObject *o) {
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *p = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)o;
  #if CYTHON_USE_TP_FINALIZE
  if (unlikely(__Pyx_PyObject_GetSlot(o, tp_finalize, destructor)) && !__Pyx_PyObject_GC_IsFinalized(o)) {
    if (__Pyx_PyObject_GetSlot(o, tp_dealloc, destructor) == __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct__strptime) {
      if (PyObject_CallFinalizerFromDealloc(o)) return;
    }
  }
  #endif
  PyObject_GC_UnTrack(o);
  Py_CLEAR(p->__pyx_v_special_fd);
  #if CYTHON_USE_FREELISTS
  if (likely((int)(__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct__strptime < 8) & __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(Py_TYPE(o), __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime))))
  {
    __pyx_mstate_global->__pyx_freelist_6cftime_7_cftime___pyx_scope_struct__strptime[__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct__strptime++] = ((struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)o);
  } else
  #endif
  {
    PyTypeObject *tp = Py_TYPE(o);
    #if CYTHON_USE_TYPE_SLOTS
    (*tp->tp_free)(o);
    #else
    {
      freefunc tp_free = (freefunc)PyType_GetSlot(tp, Py_tp_free);
      if (tp_free) tp_free(o);
    }
    #endif
    #if CYTHON_USE_TYPE_SPECS
    Py_DECREF(tp);
    #endif
  }
}

static int __pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct__strptime(PyObject *o, visitproc v, void *a) {
  int e;
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *p = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)o;
  {
    e = __Pyx_call_type_traverse(o, 1, v, a);
    if (e) return e;
  }
  if (p->__pyx_v_special_fd) {
    e = (*v)(p->__pyx_v_special_fd, a); if (e) return e;
  }
  return 0;
}

static int __pyx_tp_clear_6cftime_7_cftime___pyx_scope_struct__strptime(PyObject *o) {
  PyObject* tmp;
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *p = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime *)o;
  tmp = ((PyObject*)p->__pyx_v_special_fd);
  p->__pyx_v_special_fd = ((PyObject*)Py_None); Py_INCREF(Py_None);
  Py_XDECREF(tmp);
  return 0;
}
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct__strptime},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct__strptime},
  {Py_tp_clear, (void *)__pyx_tp_clear_6cftime_7_cftime___pyx_scope_struct__strptime},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct__strptime},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime_spec = {
  "cftime._cftime.__pyx_scope_struct__strptime",
  sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""__pyx_scope_struct__strptime", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct__strptime), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct__strptime, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  0, /*tp_repr*/
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  0, /*tp_str*/
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  0, /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct__strptime, /*tp_traverse*/
  __pyx_tp_clear_6cftime_7_cftime___pyx_scope_struct__strptime, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  0, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  0, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime___pyx_scope_struct__strptime, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif

static PyObject *__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct_1_genexpr(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) {
  PyObject *o;
  #if CYTHON_USE_FREELISTS
  if (likely((int)(__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct_1_genexpr > 0) & __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(t, __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr))))
  {
    o = (PyObject*)__pyx_mstate_global->__pyx_freelist_6cftime_7_cftime___pyx_scope_struct_1_genexpr[--__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct_1_genexpr];
    #if CYTHON_USE_TYPE_SPECS
    Py_DECREF(Py_TYPE(o));
    #endif
    memset(o, 0, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr));
    #if CYTHON_COMPILING_IN_LIMITED_API
    (void) PyObject_Init(o, t);
    #else
    (void) PyObject_INIT(o, t);
    #endif
    PyObject_GC_Track(o);
  } else
  #endif
  {
    o = __Pyx_AllocateExtensionType(t, 1);
    if (unlikely(!o)) return 0;
  }
  return o;
}

static void __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct_1_genexpr(PyObject *o) {
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *p = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)o;
  #if CYTHON_USE_TP_FINALIZE
  if (unlikely(__Pyx_PyObject_GetSlot(o, tp_finalize, destructor)) && !__Pyx_PyObject_GC_IsFinalized(o)) {
    if (__Pyx_PyObject_GetSlot(o, tp_dealloc, destructor) == __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct_1_genexpr) {
      if (PyObject_CallFinalizerFromDealloc(o)) return;
    }
  }
  #endif
  PyObject_GC_UnTrack(o);
  Py_CLEAR(p->__pyx_outer_scope);
  Py_CLEAR(p->__pyx_genexpr_arg_0);
  Py_CLEAR(p->__pyx_v_x);
  #if CYTHON_USE_FREELISTS
  if (likely((int)(__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct_1_genexpr < 8) & __PYX_CHECK_FINAL_TYPE_FOR_FREELISTS(Py_TYPE(o), __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr, sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr))))
  {
    __pyx_mstate_global->__pyx_freelist_6cftime_7_cftime___pyx_scope_struct_1_genexpr[__pyx_mstate_global->__pyx_freecount_6cftime_7_cftime___pyx_scope_struct_1_genexpr++] = ((struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)o);
  } else
  #endif
  {
    PyTypeObject *tp = Py_TYPE(o);
    #if CYTHON_USE_TYPE_SLOTS
    (*tp->tp_free)(o);
    #else
    {
      freefunc tp_free = (freefunc)PyType_GetSlot(tp, Py_tp_free);
      if (tp_free) tp_free(o);
    }
    #endif
    #if CYTHON_USE_TYPE_SPECS
    Py_DECREF(tp);
    #endif
  }
}

static int __pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct_1_genexpr(PyObject *o, visitproc v, void *a) {
  int e;
  struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *p = (struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr *)o;
  {
    e = __Pyx_call_type_traverse(o, 1, v, a);
    if (e) return e;
  }
  if (p->__pyx_outer_scope) {
    e = (*v)(((PyObject *)p->__pyx_outer_scope), a); if (e) return e;
  }
  if (p->__pyx_genexpr_arg_0) {
    e = (*v)(p->__pyx_genexpr_arg_0, a); if (e) return e;
  }
  if (p->__pyx_v_x) {
    e = (*v)(p->__pyx_v_x, a); if (e) return e;
  }
  return 0;
}
#if CYTHON_USE_TYPE_SPECS
static PyType_Slot __pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr_slots[] = {
  {Py_tp_dealloc, (void *)__pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct_1_genexpr},
  {Py_tp_traverse, (void *)__pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct_1_genexpr},
  {Py_tp_new, (void *)__pyx_tp_new_6cftime_7_cftime___pyx_scope_struct_1_genexpr},
  {0, 0},
};
static PyType_Spec __pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr_spec = {
  "cftime._cftime.__pyx_scope_struct_1_genexpr",
  sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr),
  0,
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC,
  __pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr_slots,
};
#else

static PyTypeObject __pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr = {
  PyVarObject_HEAD_INIT(0, 0)
  "cftime._cftime.""__pyx_scope_struct_1_genexpr", /*tp_name*/
  sizeof(struct __pyx_obj_6cftime_7_cftime___pyx_scope_struct_1_genexpr), /*tp_basicsize*/
  0, /*tp_itemsize*/
  __pyx_tp_dealloc_6cftime_7_cftime___pyx_scope_struct_1_genexpr, /*tp_dealloc*/
  0, /*tp_vectorcall_offset*/
  0, /*tp_getattr*/
  0, /*tp_setattr*/
  0, /*tp_as_async*/
  0, /*tp_repr*/
  0, /*tp_as_number*/
  0, /*tp_as_sequence*/
  0, /*tp_as_mapping*/
  0, /*tp_hash*/
  0, /*tp_call*/
  0, /*tp_str*/
  0, /*tp_getattro*/
  0, /*tp_setattro*/
  0, /*tp_as_buffer*/
  Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
  0, /*tp_doc*/
  __pyx_tp_traverse_6cftime_7_cftime___pyx_scope_struct_1_genexpr, /*tp_traverse*/
  0, /*tp_clear*/
  0, /*tp_richcompare*/
  0, /*tp_weaklistoffset*/
  0, /*tp_iter*/
  0, /*tp_iternext*/
  0, /*tp_methods*/
  0, /*tp_members*/
  0, /*tp_getset*/
  0, /*tp_base*/
  0, /*tp_dict*/
  0, /*tp_descr_get*/
  0, /*tp_descr_set*/
  #if !CYTHON_USE_TYPE_SPECS
  0, /*tp_dictoffset*/
  #endif
  0, /*tp_init*/
  0, /*tp_alloc*/
  __pyx_tp_new_6cftime_7_cftime___pyx_scope_struct_1_genexpr, /*tp_new*/
  0, /*tp_free*/
  0, /*tp_is_gc*/
  0, /*tp_bases*/
  0, /*tp_mro*/
  0, /*tp_cache*/
  0, /*tp_subclasses*/
  0, /*tp_weaklist*/
  0, /*tp_del*/
  0, /*tp_version_tag*/
  #if CYTHON_USE_TP_FINALIZE
  0, /*tp_finalize*/
  #else
  NULL, /*tp_finalize*/
  #endif
  #if !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800
  0, /*tp_vectorcall*/
  #endif
  #if __PYX_NEED_TP_PRINT_SLOT == 1
  0, /*tp_print*/
  #endif
  #if PY_VERSION_HEX >= 0x030C0000
  0, /*tp_watched*/
  #endif
  #if PY_VERSION_HEX >= 0x030d00A4
  0, /*tp_versions_used*/
  #endif
  #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000
  0, /*tp_pypy_flags*/
  #endif
};
#endif

static PyMethodDef __pyx_methods[] = {
  {0, 0, 0, 0}
};
/* #### Code section: initfunc_declarations ### */
static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/
static CYTHON_SMALL_CODE int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate); /*proto*/
/* #### Code section: init_module ### */

static int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0);
  /*--- Global init code ---*/
  __Pyx_RefNannyFinishContext();
  return 0;
}

static int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0);
  /*--- Variable export code ---*/
  __Pyx_RefNannyFinishContext();
  return 0;
}

static int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0);
  /*--- Function export code ---*/
  __Pyx_RefNannyFinishContext();
  return 0;
}

static int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__Pyx_modinit_type_init_code", 0);
  /*--- Type init code ---*/
  __pyx_vtabptr_6cftime_7_cftime_datetime = &__pyx_vtable_6cftime_7_cftime_datetime;
  __pyx_vtable_6cftime_7_cftime_datetime._to_real_datetime = (PyObject *(*)(struct __pyx_obj_6cftime_7_cftime_datetime *, int __pyx_skip_dispatch))__pyx_f_6cftime_7_cftime_8datetime__to_real_datetime;
  __pyx_vtable_6cftime_7_cftime_datetime._getstate = (PyObject *(*)(struct __pyx_obj_6cftime_7_cftime_datetime *))__pyx_f_6cftime_7_cftime_8datetime__getstate;
  __pyx_vtable_6cftime_7_cftime_datetime._add_timedelta = (PyObject *(*)(struct __pyx_obj_6cftime_7_cftime_datetime *, PyObject *))__pyx_f_6cftime_7_cftime_8datetime__add_timedelta;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_datetime_spec, NULL); if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime)) __PYX_ERR(0, 1055, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_datetime_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime) < (0)) __PYX_ERR(0, 1055, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime = &__pyx_type_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime) < (0)) __PYX_ERR(0, 1055, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_vtabptr_6cftime_7_cftime_datetime) < (0)) __PYX_ERR(0, 1055, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime) < (0)) __PYX_ERR(0, 1055, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_datetime, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_datetime) < (0)) __PYX_ERR(0, 1055, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_DatetimeNoLeap = &__pyx_vtable_6cftime_7_cftime_DatetimeNoLeap;
  __pyx_vtable_6cftime_7_cftime_DatetimeNoLeap.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2085, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_DatetimeNoLeap_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap)) __PYX_ERR(0, 2085, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_DatetimeNoLeap_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap) < (0)) __PYX_ERR(0, 2085, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap = &__pyx_type_6cftime_7_cftime_DatetimeNoLeap;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap) < (0)) __PYX_ERR(0, 2085, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap, __pyx_vtabptr_6cftime_7_cftime_DatetimeNoLeap) < (0)) __PYX_ERR(0, 2085, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap) < (0)) __PYX_ERR(0, 2085, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_DatetimeNoLeap, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap) < (0)) __PYX_ERR(0, 2085, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_DatetimeAllLeap = &__pyx_vtable_6cftime_7_cftime_DatetimeAllLeap;
  __pyx_vtable_6cftime_7_cftime_DatetimeAllLeap.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2095, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_DatetimeAllLeap_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap)) __PYX_ERR(0, 2095, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_DatetimeAllLeap_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap) < (0)) __PYX_ERR(0, 2095, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap = &__pyx_type_6cftime_7_cftime_DatetimeAllLeap;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap) < (0)) __PYX_ERR(0, 2095, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap, __pyx_vtabptr_6cftime_7_cftime_DatetimeAllLeap) < (0)) __PYX_ERR(0, 2095, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap) < (0)) __PYX_ERR(0, 2095, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_DatetimeAllLeap, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap) < (0)) __PYX_ERR(0, 2095, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_Datetime360Day = &__pyx_vtable_6cftime_7_cftime_Datetime360Day;
  __pyx_vtable_6cftime_7_cftime_Datetime360Day.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2105, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_Datetime360Day_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day)) __PYX_ERR(0, 2105, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_Datetime360Day_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day) < (0)) __PYX_ERR(0, 2105, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day = &__pyx_type_6cftime_7_cftime_Datetime360Day;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_Datetime360Day->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day) < (0)) __PYX_ERR(0, 2105, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day, __pyx_vtabptr_6cftime_7_cftime_Datetime360Day) < (0)) __PYX_ERR(0, 2105, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day) < (0)) __PYX_ERR(0, 2105, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_Datetime360Day, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_Datetime360Day) < (0)) __PYX_ERR(0, 2105, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_DatetimeJulian = &__pyx_vtable_6cftime_7_cftime_DatetimeJulian;
  __pyx_vtable_6cftime_7_cftime_DatetimeJulian.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2115, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_DatetimeJulian_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian)) __PYX_ERR(0, 2115, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_DatetimeJulian_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian) < (0)) __PYX_ERR(0, 2115, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian = &__pyx_type_6cftime_7_cftime_DatetimeJulian;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeJulian->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian) < (0)) __PYX_ERR(0, 2115, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian, __pyx_vtabptr_6cftime_7_cftime_DatetimeJulian) < (0)) __PYX_ERR(0, 2115, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian) < (0)) __PYX_ERR(0, 2115, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_DatetimeJulian, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeJulian) < (0)) __PYX_ERR(0, 2115, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_DatetimeGregorian = &__pyx_vtable_6cftime_7_cftime_DatetimeGregorian;
  __pyx_vtable_6cftime_7_cftime_DatetimeGregorian.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2125, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_DatetimeGregorian_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian)) __PYX_ERR(0, 2125, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_DatetimeGregorian_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian) < (0)) __PYX_ERR(0, 2125, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian = &__pyx_type_6cftime_7_cftime_DatetimeGregorian;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian) < (0)) __PYX_ERR(0, 2125, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian, __pyx_vtabptr_6cftime_7_cftime_DatetimeGregorian) < (0)) __PYX_ERR(0, 2125, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian) < (0)) __PYX_ERR(0, 2125, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_DatetimeGregorian, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian) < (0)) __PYX_ERR(0, 2125, __pyx_L1_error)
  __pyx_vtabptr_6cftime_7_cftime_DatetimeProlepticGregorian = &__pyx_vtable_6cftime_7_cftime_DatetimeProlepticGregorian;
  __pyx_vtable_6cftime_7_cftime_DatetimeProlepticGregorian.__pyx_base = *__pyx_vtabptr_6cftime_7_cftime_datetime;
  #if CYTHON_USE_TYPE_SPECS
  __pyx_t_1 = PyTuple_Pack(1, (PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 2135, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian_spec, __pyx_t_1);
  __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0;
  if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian)) __PYX_ERR(0, 2135, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian) < (0)) __PYX_ERR(0, 2135, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian = &__pyx_type_6cftime_7_cftime_DatetimeProlepticGregorian;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian->tp_base = __pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime;
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian) < (0)) __PYX_ERR(0, 2135, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian, __pyx_vtabptr_6cftime_7_cftime_DatetimeProlepticGregorian) < (0)) __PYX_ERR(0, 2135, __pyx_L1_error)
  if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian) < (0)) __PYX_ERR(0, 2135, __pyx_L1_error)
  if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_DatetimeProlepticGregorian, (PyObject *) __pyx_mstate->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian) < (0)) __PYX_ERR(0, 2135, __pyx_L1_error)
  #if CYTHON_USE_TYPE_SPECS
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime_spec, NULL); if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime)) __PYX_ERR(0, 1255, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime) < (0)) __PYX_ERR(0, 1255, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime = &__pyx_type_6cftime_7_cftime___pyx_scope_struct__strptime;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime) < (0)) __PYX_ERR(0, 1255, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct__strptime->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  #if CYTHON_USE_TYPE_SPECS
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr_spec, NULL); if (unlikely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr)) __PYX_ERR(0, 1282, __pyx_L1_error)
  if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr_spec, __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr) < (0)) __PYX_ERR(0, 1282, __pyx_L1_error)
  #else
  __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr = &__pyx_type_6cftime_7_cftime___pyx_scope_struct_1_genexpr;
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  #endif
  #if !CYTHON_USE_TYPE_SPECS
  if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr) < (0)) __PYX_ERR(0, 1282, __pyx_L1_error)
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount((PyObject*)__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr);
  #endif
  #if !CYTHON_COMPILING_IN_LIMITED_API
  if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr->tp_dictoffset && __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr->tp_getattro == PyObject_GenericGetAttr)) {
    __pyx_mstate->__pyx_ptype_6cftime_7_cftime___pyx_scope_struct_1_genexpr->tp_getattro = PyObject_GenericGetAttr;
  }
  #endif
  __Pyx_RefNannyFinishContext();
  return 0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_RefNannyFinishContext();
  return -1;
}

static int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  PyObject *__pyx_t_1 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannySetupContext("__Pyx_modinit_type_import_code", 0);
  /*--- Type import code ---*/
  __pyx_t_1 = PyImport_ImportModule(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_t_1)) __PYX_ERR(2, 9, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_7cpython_4type_type = __Pyx_ImportType_3_2_4(__pyx_t_1, __Pyx_BUILTIN_MODULE_NAME, "type",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyTypeObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyTypeObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  0, 0,
  #else
  sizeof(PyHeapTypeObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyHeapTypeObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_7cpython_4type_type) __PYX_ERR(2, 9, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __pyx_t_1 = PyImport_ImportModule("numpy"); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 229, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_1);
  __pyx_mstate->__pyx_ptype_5numpy_dtype = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "dtype",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyArray_Descr), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArray_Descr),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyArray_Descr), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArray_Descr),
  #else
  sizeof(PyArray_Descr), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArray_Descr),
  #endif
  __Pyx_ImportType_CheckSize_Ignore_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_dtype) __PYX_ERR(1, 229, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_flatiter = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "flatiter",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyArrayIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayIterObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyArrayIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayIterObject),
  #else
  sizeof(PyArrayIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayIterObject),
  #endif
  __Pyx_ImportType_CheckSize_Ignore_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_flatiter) __PYX_ERR(1, 274, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_broadcast = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "broadcast",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyArrayMultiIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayMultiIterObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyArrayMultiIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayMultiIterObject),
  #else
  sizeof(PyArrayMultiIterObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayMultiIterObject),
  #endif
  __Pyx_ImportType_CheckSize_Ignore_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_broadcast) __PYX_ERR(1, 278, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_ndarray = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "ndarray",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyArrayObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyArrayObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayObject),
  #else
  sizeof(PyArrayObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyArrayObject),
  #endif
  __Pyx_ImportType_CheckSize_Ignore_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_ndarray) __PYX_ERR(1, 317, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_generic = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "generic",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_generic) __PYX_ERR(1, 826, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_number = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "number",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_number) __PYX_ERR(1, 828, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_integer = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "integer",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_integer) __PYX_ERR(1, 830, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_signedinteger = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "signedinteger",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_signedinteger) __PYX_ERR(1, 832, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_unsignedinteger = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "unsignedinteger",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_unsignedinteger) __PYX_ERR(1, 834, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_inexact = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "inexact",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_inexact) __PYX_ERR(1, 836, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_floating = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "floating",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_floating) __PYX_ERR(1, 838, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_complexfloating = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "complexfloating",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_complexfloating) __PYX_ERR(1, 840, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_flexible = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "flexible",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_flexible) __PYX_ERR(1, 842, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_character = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "character",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #else
  sizeof(PyObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyObject),
  #endif
  __Pyx_ImportType_CheckSize_Warn_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_character) __PYX_ERR(1, 844, __pyx_L1_error)
  __pyx_mstate->__pyx_ptype_5numpy_ufunc = __Pyx_ImportType_3_2_4(__pyx_t_1, "numpy", "ufunc",
  #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000
  sizeof(PyUFuncObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyUFuncObject),
  #elif CYTHON_COMPILING_IN_LIMITED_API
  sizeof(PyUFuncObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyUFuncObject),
  #else
  sizeof(PyUFuncObject), __PYX_GET_STRUCT_ALIGNMENT_3_2_4(PyUFuncObject),
  #endif
  __Pyx_ImportType_CheckSize_Ignore_3_2_4); if (!__pyx_mstate->__pyx_ptype_5numpy_ufunc) __PYX_ERR(1, 908, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
  __Pyx_RefNannyFinishContext();
  return 0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_1);
  __Pyx_RefNannyFinishContext();
  return -1;
}

static int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0);
  /*--- Variable import code ---*/
  __Pyx_RefNannyFinishContext();
  return 0;
}

static int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0);
  /*--- Function import code ---*/
  __Pyx_RefNannyFinishContext();
  return 0;
}

#if CYTHON_PEP489_MULTI_PHASE_INIT
static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/
static int __pyx_pymod_exec__cftime(PyObject* module); /*proto*/
static PyModuleDef_Slot __pyx_moduledef_slots[] = {
  {Py_mod_create, (void*)__pyx_pymod_create},
  {Py_mod_exec, (void*)__pyx_pymod_exec__cftime},
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
  {Py_mod_gil, __Pyx_FREETHREADING_COMPATIBLE},
  #endif
  #if PY_VERSION_HEX >= 0x030C0000 && CYTHON_USE_MODULE_STATE
  {Py_mod_multiple_interpreters, Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED},
  #endif
  {0, NULL}
};
#endif

#ifdef __cplusplus
namespace {
  struct PyModuleDef __pyx_moduledef =
  #else
  static struct PyModuleDef __pyx_moduledef =
  #endif
  {
      PyModuleDef_HEAD_INIT,
      "_cftime",
      __pyx_k_Performs_conversions_of_netCDF, /* m_doc */
    #if CYTHON_USE_MODULE_STATE
      sizeof(__pyx_mstatetype), /* m_size */
    #else
      (CYTHON_PEP489_MULTI_PHASE_INIT) ? 0 : -1, /* m_size */
    #endif
      __pyx_methods /* m_methods */,
    #if CYTHON_PEP489_MULTI_PHASE_INIT
      __pyx_moduledef_slots, /* m_slots */
    #else
      NULL, /* m_reload */
    #endif
    #if CYTHON_USE_MODULE_STATE
      __pyx_m_traverse, /* m_traverse */
      __pyx_m_clear, /* m_clear */
      NULL /* m_free */
    #else
      NULL, /* m_traverse */
      NULL, /* m_clear */
      NULL /* m_free */
    #endif
  };
  #ifdef __cplusplus
} /* anonymous namespace */
#endif

/* PyModInitFuncType */
#ifndef CYTHON_NO_PYINIT_EXPORT
  #define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC
#else
  #ifdef __cplusplus
  #define __Pyx_PyMODINIT_FUNC extern "C" PyObject *
  #else
  #define __Pyx_PyMODINIT_FUNC PyObject *
  #endif
#endif

__Pyx_PyMODINIT_FUNC PyInit__cftime(void) CYTHON_SMALL_CODE; /*proto*/
__Pyx_PyMODINIT_FUNC PyInit__cftime(void)
#if CYTHON_PEP489_MULTI_PHASE_INIT
{
  return PyModuleDef_Init(&__pyx_moduledef);
}
/* ModuleCreationPEP489 */
#if CYTHON_COMPILING_IN_LIMITED_API && (__PYX_LIMITED_VERSION_HEX < 0x03090000\
      || ((defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS)) && __PYX_LIMITED_VERSION_HEX < 0x030A0000))
static PY_INT64_T __Pyx_GetCurrentInterpreterId(void) {
    {
        PyObject *module = PyImport_ImportModule("_interpreters"); // 3.13+ I think
        if (!module) {
            PyErr_Clear(); // just try the 3.8-3.12 version
            module = PyImport_ImportModule("_xxsubinterpreters");
            if (!module) goto bad;
        }
        PyObject *current = PyObject_CallMethod(module, "get_current", NULL);
        Py_DECREF(module);
        if (!current) goto bad;
        if (PyTuple_Check(current)) {
            PyObject *new_current = PySequence_GetItem(current, 0);
            Py_DECREF(current);
            current = new_current;
            if (!new_current) goto bad;
        }
        long long as_c_int = PyLong_AsLongLong(current);
        Py_DECREF(current);
        return as_c_int;
    }
  bad:
    PySys_WriteStderr("__Pyx_GetCurrentInterpreterId failed. Try setting the C define CYTHON_PEP489_MULTI_PHASE_INIT=0\n");
    return -1;
}
#endif
#if !CYTHON_USE_MODULE_STATE
static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) {
    static PY_INT64_T main_interpreter_id = -1;
#if CYTHON_COMPILING_IN_GRAAL && defined(GRAALPY_VERSION_NUM) && GRAALPY_VERSION_NUM > 0x19000000
    PY_INT64_T current_id = GraalPyInterpreterState_GetIDFromThreadState(PyThreadState_Get());
#elif CYTHON_COMPILING_IN_GRAAL
    PY_INT64_T current_id = PyInterpreterState_GetIDFromThreadState(PyThreadState_Get());
#elif CYTHON_COMPILING_IN_LIMITED_API && (__PYX_LIMITED_VERSION_HEX < 0x03090000\
      || ((defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS)) && __PYX_LIMITED_VERSION_HEX < 0x030A0000))
    PY_INT64_T current_id = __Pyx_GetCurrentInterpreterId();
#elif CYTHON_COMPILING_IN_LIMITED_API
    PY_INT64_T current_id = PyInterpreterState_GetID(PyInterpreterState_Get());
#else
    PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp);
#endif
    if (unlikely(current_id == -1)) {
        return -1;
    }
    if (main_interpreter_id == -1) {
        main_interpreter_id = current_id;
        return 0;
    } else if (unlikely(main_interpreter_id != current_id)) {
        PyErr_SetString(
            PyExc_ImportError,
            "Interpreter change detected - this module can only be loaded into one interpreter per process.");
        return -1;
    }
    return 0;
}
#endif
static CYTHON_SMALL_CODE int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name, int allow_none)
{
    PyObject *value = PyObject_GetAttrString(spec, from_name);
    int result = 0;
    if (likely(value)) {
        if (allow_none || value != Py_None) {
            result = PyDict_SetItemString(moddict, to_name, value);
        }
        Py_DECREF(value);
    } else if (PyErr_ExceptionMatches(PyExc_AttributeError)) {
        PyErr_Clear();
    } else {
        result = -1;
    }
    return result;
}
static CYTHON_SMALL_CODE PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def) {
    PyObject *module = NULL, *moddict, *modname;
    CYTHON_UNUSED_VAR(def);
    #if !CYTHON_USE_MODULE_STATE
    if (__Pyx_check_single_interpreter())
        return NULL;
    #endif
    if (__pyx_m)
        return __Pyx_NewRef(__pyx_m);
    modname = PyObject_GetAttrString(spec, "name");
    if (unlikely(!modname)) goto bad;
    module = PyModule_NewObject(modname);
    Py_DECREF(modname);
    if (unlikely(!module)) goto bad;
    moddict = PyModule_GetDict(module);
    if (unlikely(!moddict)) goto bad;
    if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "loader", "__loader__", 1) < 0)) goto bad;
    if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__", 1) < 0)) goto bad;
    if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__", 1) < 0)) goto bad;
    if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__", 0) < 0)) goto bad;
    return module;
bad:
    Py_XDECREF(module);
    return NULL;
}


static CYTHON_SMALL_CODE int __pyx_pymod_exec__cftime(PyObject *__pyx_pyinit_module)
#endif
{
  int stringtab_initialized = 0;
  #if CYTHON_USE_MODULE_STATE
  int pystate_addmodule_run = 0;
  #endif
  __pyx_mstatetype *__pyx_mstate = NULL;
  PyObject *__pyx_t_1 = NULL;
  PyObject *__pyx_t_2 = NULL;
  Py_ssize_t __pyx_t_3;
  PyObject *__pyx_t_4 = NULL;
  int __pyx_t_5;
  PyObject *__pyx_t_6 = NULL;
  static int __pyx_t_7[12];
  static int __pyx_t_8[12];
  static int __pyx_t_9[13];
  static int __pyx_t_10[13];
  PyObject *__pyx_t_11 = NULL;
  size_t __pyx_t_12;
  PyObject *__pyx_t_13 = NULL;
  PyObject *__pyx_t_14 = NULL;
  int __pyx_lineno = 0;
  const char *__pyx_filename = NULL;
  int __pyx_clineno = 0;
  __Pyx_RefNannyDeclarations
  #if CYTHON_PEP489_MULTI_PHASE_INIT
  if (__pyx_m) {
    if (__pyx_m == __pyx_pyinit_module) return 0;
    PyErr_SetString(PyExc_RuntimeError, "Module '_cftime' has already been imported. Re-initialisation is not supported.");
    return -1;
  }
  #else
  if (__pyx_m) return __Pyx_NewRef(__pyx_m);
  #endif
  /*--- Module creation code ---*/
  #if CYTHON_PEP489_MULTI_PHASE_INIT
  __pyx_t_1 = __pyx_pyinit_module;
  Py_INCREF(__pyx_t_1);
  #else
  __pyx_t_1 = PyModule_Create(&__pyx_moduledef); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error)
  #endif
  #if CYTHON_USE_MODULE_STATE
  {
    int add_module_result = __Pyx_State_AddModule(__pyx_t_1, &__pyx_moduledef);
    __pyx_t_1 = 0; /* transfer ownership from __pyx_t_1 to "_cftime" pseudovariable */
    if (unlikely((add_module_result < 0))) __PYX_ERR(0, 1, __pyx_L1_error)
    pystate_addmodule_run = 1;
  }
  #else
  __pyx_m = __pyx_t_1;
  #endif
  #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
  PyUnstable_Module_SetGIL(__pyx_m, Py_MOD_GIL_USED);
  #endif
  __pyx_mstate = __pyx_mstate_global;
  CYTHON_UNUSED_VAR(__pyx_t_1);
  __pyx_mstate->__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_mstate->__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error)
  Py_INCREF(__pyx_mstate->__pyx_d);
  __pyx_mstate->__pyx_b = __Pyx_PyImport_AddModuleRef(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_mstate->__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error)
  __pyx_mstate->__pyx_cython_runtime = __Pyx_PyImport_AddModuleRef("cython_runtime"); if (unlikely(!__pyx_mstate->__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error)
  if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_mstate->__pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error)
  /* ImportRefnannyAPI */
  #if CYTHON_REFNANNY
  __Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny");
  if (!__Pyx_RefNanny) {
    PyErr_Clear();
    __Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny");
    if (!__Pyx_RefNanny)
        Py_FatalError("failed to import 'refnanny' module");
  }
  #endif
  
__Pyx_RefNannySetupContext("PyInit__cftime", 0);
  __Pyx_init_runtime_version();
  if (__Pyx_check_binary_version(__PYX_LIMITED_VERSION_HEX, __Pyx_get_runtime_version(), CYTHON_COMPILING_IN_LIMITED_API) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  __pyx_mstate->__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_mstate->__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error)
  __pyx_mstate->__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error)
  __pyx_mstate->__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error)
  /*--- Library function declarations ---*/
  /*--- Initialize various global constants etc. ---*/
  if (__Pyx_InitConstants(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  stringtab_initialized = 1;
  if (__Pyx_InitGlobals() < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  if (__pyx_module_is_main_cftime___cftime) {
    if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_main) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  }
  {
    PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error)
    if (!PyDict_GetItemString(modules, "cftime._cftime")) {
      if (unlikely((PyDict_SetItemString(modules, "cftime._cftime", __pyx_m) < 0))) __PYX_ERR(0, 1, __pyx_L1_error)
    }
  }
  /*--- Builtin init code ---*/
  if (__Pyx_InitCachedBuiltins(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  /*--- Constants init code ---*/
  if (__Pyx_InitCachedConstants(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  if (__Pyx_CreateCodeObjects(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  /*--- Global type/function init code ---*/
  (void)__Pyx_modinit_global_init_code(__pyx_mstate);
  (void)__Pyx_modinit_variable_export_code(__pyx_mstate);
  (void)__Pyx_modinit_function_export_code(__pyx_mstate);
  if (unlikely((__Pyx_modinit_type_init_code(__pyx_mstate) < 0))) __PYX_ERR(0, 1, __pyx_L1_error)
  if (unlikely((__Pyx_modinit_type_import_code(__pyx_mstate) < 0))) __PYX_ERR(0, 1, __pyx_L1_error)
  (void)__Pyx_modinit_variable_import_code(__pyx_mstate);
  (void)__Pyx_modinit_function_import_code(__pyx_mstate);
  /*--- Execution code ---*/

  /* "cftime/_cftime.pyx":9
 * from numpy cimport int64_t, int32_t
 * import cython
 * import numpy as np             # <<<<<<<<<<<<<<
 * cimport numpy as np
 * import re
*/
  __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_numpy, 0, 0, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 9, __pyx_L1_error)
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_np, __pyx_t_2) < (0)) __PYX_ERR(0, 9, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":11
 * import numpy as np
 * cimport numpy as np
 * import re             # <<<<<<<<<<<<<<
 * import time
 * from datetime import datetime as datetime_python
*/
  __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_re, 0, 0, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 11, __pyx_L1_error)
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_re, __pyx_t_2) < (0)) __PYX_ERR(0, 11, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":12
 * cimport numpy as np
 * import re
 * import time             # <<<<<<<<<<<<<<
 * from datetime import datetime as datetime_python
 * from datetime import timedelta, MINYEAR, MAXYEAR
*/
  __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_time, 0, 0, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 12, __pyx_L1_error)
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_time, __pyx_t_2) < (0)) __PYX_ERR(0, 12, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":13
 * import re
 * import time
 * from datetime import datetime as datetime_python             # <<<<<<<<<<<<<<
 * from datetime import timedelta, MINYEAR, MAXYEAR
 * import warnings
*/
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_datetime};
    __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_datetime, __pyx_imported_names, 1, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 13, __pyx_L1_error)
  }
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_datetime};
    __pyx_t_3 = 0; {
      __pyx_t_4 = __Pyx_ImportFrom(__pyx_t_2, __pyx_imported_names[__pyx_t_3]); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 13, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      switch (__pyx_t_3) {
        case 0:
        if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_datetime_python, __pyx_t_4) < (0)) __PYX_ERR(0, 13, __pyx_L1_error)
        break;
        default:;
      }
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":14
 * import time
 * from datetime import datetime as datetime_python
 * from datetime import timedelta, MINYEAR, MAXYEAR             # <<<<<<<<<<<<<<
 * import warnings
 * from ._strptime import _strptime
*/
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_timedelta,__pyx_mstate_global->__pyx_n_u_MINYEAR,__pyx_mstate_global->__pyx_n_u_MAXYEAR};
    __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_datetime, __pyx_imported_names, 3, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 14, __pyx_L1_error)
  }
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_timedelta,__pyx_mstate_global->__pyx_n_u_MINYEAR,__pyx_mstate_global->__pyx_n_u_MAXYEAR};
    for (__pyx_t_3=0; __pyx_t_3 < 3; __pyx_t_3++) {
      __pyx_t_4 = __Pyx_ImportFrom(__pyx_t_2, __pyx_imported_names[__pyx_t_3]); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 14, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_imported_names[__pyx_t_3], __pyx_t_4) < (0)) __PYX_ERR(0, 14, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":15
 * from datetime import datetime as datetime_python
 * from datetime import timedelta, MINYEAR, MAXYEAR
 * import warnings             # <<<<<<<<<<<<<<
 * from ._strptime import _strptime
 * 
*/
  __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_warnings, 0, 0, NULL, 0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 15, __pyx_L1_error)
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_warnings, __pyx_t_2) < (0)) __PYX_ERR(0, 15, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":16
 * from datetime import timedelta, MINYEAR, MAXYEAR
 * import warnings
 * from ._strptime import _strptime             # <<<<<<<<<<<<<<
 * 
 * np.import_array()
*/
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_strptime_2};
    __pyx_t_1 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_strptime_2, __pyx_imported_names, 1, __pyx_mstate_global->__pyx_kp_u_cftime__strptime, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 16, __pyx_L1_error)
  }
  __pyx_t_2 = __pyx_t_1;
  __Pyx_GOTREF(__pyx_t_2);
  {
    PyObject* const __pyx_imported_names[] = {__pyx_mstate_global->__pyx_n_u_strptime_2};
    __pyx_t_3 = 0; {
      __pyx_t_4 = __Pyx_ImportFrom(__pyx_t_2, __pyx_imported_names[__pyx_t_3]); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 16, __pyx_L1_error)
      __Pyx_GOTREF(__pyx_t_4);
      if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_imported_names[__pyx_t_3], __pyx_t_4) < (0)) __PYX_ERR(0, 16, __pyx_L1_error)
      __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    }
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":18
 * from ._strptime import _strptime
 * 
 * np.import_array()             # <<<<<<<<<<<<<<
 * 
 * microsec_units = ['microseconds','microsecond', 'microsec', 'microsecs']
*/
  __pyx_t_5 = __pyx_f_5numpy_import_array(); if (unlikely(__pyx_t_5 == ((int)-1))) __PYX_ERR(0, 18, __pyx_L1_error)

  /* "cftime/_cftime.pyx":20
 * np.import_array()
 * 
 * microsec_units = ['microseconds','microsecond', 'microsec', 'microsecs']             # <<<<<<<<<<<<<<
 * millisec_units = ['milliseconds', 'millisecond', 'millisec', 'millisecs', 'msec', 'msecs', 'ms']
 * sec_units =      ['second', 'seconds', 'sec', 'secs', 's']
*/
  __pyx_t_2 = __Pyx_PyList_Pack(4, __pyx_mstate_global->__pyx_n_u_microseconds, __pyx_mstate_global->__pyx_n_u_microsecond, __pyx_mstate_global->__pyx_n_u_microsec, __pyx_mstate_global->__pyx_n_u_microsecs); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 20, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_microsec_units, __pyx_t_2) < (0)) __PYX_ERR(0, 20, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":21
 * 
 * microsec_units = ['microseconds','microsecond', 'microsec', 'microsecs']
 * millisec_units = ['milliseconds', 'millisecond', 'millisec', 'millisecs', 'msec', 'msecs', 'ms']             # <<<<<<<<<<<<<<
 * sec_units =      ['second', 'seconds', 'sec', 'secs', 's']
 * min_units =      ['minute', 'minutes', 'min', 'mins']
*/
  __pyx_t_2 = __Pyx_PyList_Pack(7, __pyx_mstate_global->__pyx_n_u_milliseconds, __pyx_mstate_global->__pyx_n_u_millisecond, __pyx_mstate_global->__pyx_n_u_millisec, __pyx_mstate_global->__pyx_n_u_millisecs, __pyx_mstate_global->__pyx_n_u_msec, __pyx_mstate_global->__pyx_n_u_msecs, __pyx_mstate_global->__pyx_n_u_ms); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 21, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_millisec_units, __pyx_t_2) < (0)) __PYX_ERR(0, 21, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":22
 * microsec_units = ['microseconds','microsecond', 'microsec', 'microsecs']
 * millisec_units = ['milliseconds', 'millisecond', 'millisec', 'millisecs', 'msec', 'msecs', 'ms']
 * sec_units =      ['second', 'seconds', 'sec', 'secs', 's']             # <<<<<<<<<<<<<<
 * min_units =      ['minute', 'minutes', 'min', 'mins']
 * hr_units =       ['hour', 'hours', 'hr', 'hrs', 'h']
*/
  __pyx_t_2 = __Pyx_PyList_Pack(5, __pyx_mstate_global->__pyx_n_u_second, __pyx_mstate_global->__pyx_n_u_seconds, __pyx_mstate_global->__pyx_n_u_sec, __pyx_mstate_global->__pyx_n_u_secs, __pyx_mstate_global->__pyx_n_u_s); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 22, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_sec_units, __pyx_t_2) < (0)) __PYX_ERR(0, 22, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":23
 * millisec_units = ['milliseconds', 'millisecond', 'millisec', 'millisecs', 'msec', 'msecs', 'ms']
 * sec_units =      ['second', 'seconds', 'sec', 'secs', 's']
 * min_units =      ['minute', 'minutes', 'min', 'mins']             # <<<<<<<<<<<<<<
 * hr_units =       ['hour', 'hours', 'hr', 'hrs', 'h']
 * day_units =      ['day', 'days', 'd']
*/
  __pyx_t_2 = __Pyx_PyList_Pack(4, __pyx_mstate_global->__pyx_n_u_minute, __pyx_mstate_global->__pyx_n_u_minutes, __pyx_mstate_global->__pyx_n_u_min, __pyx_mstate_global->__pyx_n_u_mins); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 23, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_min_units, __pyx_t_2) < (0)) __PYX_ERR(0, 23, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":24
 * sec_units =      ['second', 'seconds', 'sec', 'secs', 's']
 * min_units =      ['minute', 'minutes', 'min', 'mins']
 * hr_units =       ['hour', 'hours', 'hr', 'hrs', 'h']             # <<<<<<<<<<<<<<
 * day_units =      ['day', 'days', 'd']
 * month_units =    ['month', 'months'] # only allowed for 360_day calendar
*/
  __pyx_t_2 = __Pyx_PyList_Pack(5, __pyx_mstate_global->__pyx_n_u_hour, __pyx_mstate_global->__pyx_n_u_hours, __pyx_mstate_global->__pyx_n_u_hr, __pyx_mstate_global->__pyx_n_u_hrs, __pyx_mstate_global->__pyx_n_u_h); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 24, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_hr_units, __pyx_t_2) < (0)) __PYX_ERR(0, 24, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":25
 * min_units =      ['minute', 'minutes', 'min', 'mins']
 * hr_units =       ['hour', 'hours', 'hr', 'hrs', 'h']
 * day_units =      ['day', 'days', 'd']             # <<<<<<<<<<<<<<
 * month_units =    ['month', 'months'] # only allowed for 360_day calendar
 * year_units =     ['common_year', 'common_years'] # only allowed for 365_day and noleap calendars
*/
  __pyx_t_2 = __Pyx_PyList_Pack(3, __pyx_mstate_global->__pyx_n_u_day, __pyx_mstate_global->__pyx_n_u_days, __pyx_mstate_global->__pyx_n_u_d); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 25, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_day_units, __pyx_t_2) < (0)) __PYX_ERR(0, 25, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":26
 * hr_units =       ['hour', 'hours', 'hr', 'hrs', 'h']
 * day_units =      ['day', 'days', 'd']
 * month_units =    ['month', 'months'] # only allowed for 360_day calendar             # <<<<<<<<<<<<<<
 * year_units =     ['common_year', 'common_years'] # only allowed for 365_day and noleap calendars
 * _units = microsec_units+millisec_units+sec_units+min_units+hr_units+day_units
*/
  __pyx_t_2 = __Pyx_PyList_Pack(2, __pyx_mstate_global->__pyx_n_u_month, __pyx_mstate_global->__pyx_n_u_months); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 26, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_month_units, __pyx_t_2) < (0)) __PYX_ERR(0, 26, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":27
 * day_units =      ['day', 'days', 'd']
 * month_units =    ['month', 'months'] # only allowed for 360_day calendar
 * year_units =     ['common_year', 'common_years'] # only allowed for 365_day and noleap calendars             # <<<<<<<<<<<<<<
 * _units = microsec_units+millisec_units+sec_units+min_units+hr_units+day_units
 * # supported calendars. Includes synonyms ('standard'=='gregorian',
*/
  __pyx_t_2 = __Pyx_PyList_Pack(2, __pyx_mstate_global->__pyx_n_u_common_year, __pyx_mstate_global->__pyx_n_u_common_years); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 27, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_year_units, __pyx_t_2) < (0)) __PYX_ERR(0, 27, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":28
 * month_units =    ['month', 'months'] # only allowed for 360_day calendar
 * year_units =     ['common_year', 'common_years'] # only allowed for 365_day and noleap calendars
 * _units = microsec_units+millisec_units+sec_units+min_units+hr_units+day_units             # <<<<<<<<<<<<<<
 * # supported calendars. Includes synonyms ('standard'=='gregorian',
 * # '366_day'=='all_leap','365_day'=='noleap')
*/
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_microsec_units); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_millisec_units); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyNumber_Add(__pyx_t_2, __pyx_t_4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_sec_units); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = PyNumber_Add(__pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_min_units); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyNumber_Add(__pyx_t_2, __pyx_t_4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_hr_units); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = PyNumber_Add(__pyx_t_6, __pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_day_units); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_6 = PyNumber_Add(__pyx_t_2, __pyx_t_4); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_units, __pyx_t_6) < (0)) __PYX_ERR(0, 28, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":33
 * # see http://cfconventions.org/cf-conventions/cf-conventions#calendar
 * # for definitions.
 * _calendars = ['standard', 'gregorian', 'proleptic_gregorian',             # <<<<<<<<<<<<<<
 *               'noleap', 'julian', 'all_leap', '365_day', '366_day', '360_day']
 * _idealized_calendars= ['all_leap','noleap','366_day','365_day','360_day']
*/
  __pyx_t_6 = __Pyx_PyList_Pack(9, __pyx_mstate_global->__pyx_n_u_standard, __pyx_mstate_global->__pyx_n_u_gregorian, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, __pyx_mstate_global->__pyx_n_u_noleap, __pyx_mstate_global->__pyx_n_u_julian, __pyx_mstate_global->__pyx_n_u_all_leap, __pyx_mstate_global->__pyx_kp_u_365_day, __pyx_mstate_global->__pyx_kp_u_366_day, __pyx_mstate_global->__pyx_kp_u_360_day); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 33, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_calendars, __pyx_t_6) < (0)) __PYX_ERR(0, 33, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":35
 * _calendars = ['standard', 'gregorian', 'proleptic_gregorian',
 *               'noleap', 'julian', 'all_leap', '365_day', '366_day', '360_day']
 * _idealized_calendars= ['all_leap','noleap','366_day','365_day','360_day']             # <<<<<<<<<<<<<<
 * # Following are number of days per month
 * cdef int[12] _dayspermonth      = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
*/
  __pyx_t_6 = __Pyx_PyList_Pack(5, __pyx_mstate_global->__pyx_n_u_all_leap, __pyx_mstate_global->__pyx_n_u_noleap, __pyx_mstate_global->__pyx_kp_u_366_day, __pyx_mstate_global->__pyx_kp_u_365_day, __pyx_mstate_global->__pyx_kp_u_360_day); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 35, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_idealized_calendars, __pyx_t_6) < (0)) __PYX_ERR(0, 35, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":37
 * _idealized_calendars= ['all_leap','noleap','366_day','365_day','360_day']
 * # Following are number of days per month
 * cdef int[12] _dayspermonth      = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]             # <<<<<<<<<<<<<<
 * cdef int[12] _dayspermonth_leap = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
 * # same as above, but including accumulated days of previous months.
*/
  __pyx_t_7[0] = 31;
  __pyx_t_7[1] = 28;
  __pyx_t_7[2] = 31;
  __pyx_t_7[3] = 30;
  __pyx_t_7[4] = 31;
  __pyx_t_7[5] = 30;
  __pyx_t_7[6] = 31;
  __pyx_t_7[7] = 31;
  __pyx_t_7[8] = 30;
  __pyx_t_7[9] = 31;
  __pyx_t_7[10] = 30;
  __pyx_t_7[11] = 31;
  memcpy(&(__pyx_v_6cftime_7_cftime__dayspermonth[0]), __pyx_t_7, sizeof(__pyx_v_6cftime_7_cftime__dayspermonth[0]) * (12));

  /* "cftime/_cftime.pyx":38
 * # Following are number of days per month
 * cdef int[12] _dayspermonth      = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
 * cdef int[12] _dayspermonth_leap = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]             # <<<<<<<<<<<<<<
 * # same as above, but including accumulated days of previous months.
 * cdef int[13] _cumdayspermonth = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365]
*/
  __pyx_t_8[0] = 31;
  __pyx_t_8[1] = 29;
  __pyx_t_8[2] = 31;
  __pyx_t_8[3] = 30;
  __pyx_t_8[4] = 31;
  __pyx_t_8[5] = 30;
  __pyx_t_8[6] = 31;
  __pyx_t_8[7] = 31;
  __pyx_t_8[8] = 30;
  __pyx_t_8[9] = 31;
  __pyx_t_8[10] = 30;
  __pyx_t_8[11] = 31;
  memcpy(&(__pyx_v_6cftime_7_cftime__dayspermonth_leap[0]), __pyx_t_8, sizeof(__pyx_v_6cftime_7_cftime__dayspermonth_leap[0]) * (12));

  /* "cftime/_cftime.pyx":40
 * cdef int[12] _dayspermonth_leap = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
 * # same as above, but including accumulated days of previous months.
 * cdef int[13] _cumdayspermonth = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365]             # <<<<<<<<<<<<<<
 * cdef int[13] _cumdayspermonth_leap = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366]
 * 
*/
  __pyx_t_9[0] = 0;
  __pyx_t_9[1] = 31;
  __pyx_t_9[2] = 59;
  __pyx_t_9[3] = 90;
  __pyx_t_9[4] = 0x78;
  __pyx_t_9[5] = 0x97;
  __pyx_t_9[6] = 0xB5;
  __pyx_t_9[7] = 0xD4;
  __pyx_t_9[8] = 0xF3;
  __pyx_t_9[9] = 0x111;
  __pyx_t_9[10] = 0x130;
  __pyx_t_9[11] = 0x14E;
  __pyx_t_9[12] = 0x16D;
  memcpy(&(__pyx_v_6cftime_7_cftime__cumdayspermonth[0]), __pyx_t_9, sizeof(__pyx_v_6cftime_7_cftime__cumdayspermonth[0]) * (13));

  /* "cftime/_cftime.pyx":41
 * # same as above, but including accumulated days of previous months.
 * cdef int[13] _cumdayspermonth = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365]
 * cdef int[13] _cumdayspermonth_leap = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366]             # <<<<<<<<<<<<<<
 * 
 * # Adapted from http://delete.me.uk/2005/03/iso8601.html
*/
  __pyx_t_10[0] = 0;
  __pyx_t_10[1] = 31;
  __pyx_t_10[2] = 60;
  __pyx_t_10[3] = 91;
  __pyx_t_10[4] = 0x79;
  __pyx_t_10[5] = 0x98;
  __pyx_t_10[6] = 0xB6;
  __pyx_t_10[7] = 0xD5;
  __pyx_t_10[8] = 0xF4;
  __pyx_t_10[9] = 0x112;
  __pyx_t_10[10] = 0x131;
  __pyx_t_10[11] = 0x14F;
  __pyx_t_10[12] = 0x16E;
  memcpy(&(__pyx_v_6cftime_7_cftime__cumdayspermonth_leap[0]), __pyx_t_10, sizeof(__pyx_v_6cftime_7_cftime__cumdayspermonth_leap[0]) * (13));

  /* "cftime/_cftime.pyx":46
 * # Note: This regex ensures that all ISO8601 timezone formats are accepted - but, due to legacy support for other timestrings, not all incorrect formats can be rejected.
 * #       For example, the TZ spec "+01:0" will still work even though the minutes value is only one character long.
 * ISO8601_REGEX = re.compile(r"(?P<year>[+-]?[0-9]+)(-(?P<month>[0-9]{1,2})(-(?P<day>[0-9]{1,2})"             # <<<<<<<<<<<<<<
 *                            r"(((?P<separator1>.)(?P<hour>[0-9]{1,2}):(?P<minute>[0-9]{1,2})(:(?P<second>[0-9]{1,2})(\.(?P<fraction>[0-9]+))?)?)?"
 *                            r"((?P<separator2>.?)(?P<timezone>Z|(([-+])([0-9]{2})((:([0-9]{2}))|([0-9]{2}))?)))?)?)?)?"
*/
  __pyx_t_4 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_re); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 46, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_11 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_compile); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 46, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_P_year_0_9_P_month_0_9_1_2_P_da};
    __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_11, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 46, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_ISO8601_REGEX, __pyx_t_6) < (0)) __PYX_ERR(0, 46, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":52
 * # Note: The re module apparently does not support branch reset groups that allow redefinition of the same group name in alternative branches as PCRE does.
 * #       Using two different group names is also somewhat ugly, but other solutions might hugely inflate the expression. feel free to contribute a better solution.
 * TIMEZONE_REGEX = re.compile(             # <<<<<<<<<<<<<<
 *     "(?P<prefix>[+-])(?P<hours>[0-9]{2})(?:(?::(?P<minutes1>[0-9]{2}))|(?P<minutes2>[0-9]{2}))?")
 * 
*/
  __pyx_t_11 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_re); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 52, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_compile); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 52, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_mstate_global->__pyx_kp_u_P_prefix_P_hours_0_9_2_P_minute};
    __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 52, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_TIMEZONE_REGEX, __pyx_t_6) < (0)) __PYX_ERR(0, 52, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":55
 *     "(?P<prefix>[+-])(?P<hours>[0-9]{2})(?:(?::(?P<minutes1>[0-9]{2}))|(?P<minutes2>[0-9]{2}))?")
 * 
 * class real_datetime(datetime_python):             # <<<<<<<<<<<<<<
 *     """add dayofwk, dayofyr, daysinmonth attributes to python datetime instance"""
 *     @property
*/
  __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_datetime_python); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_2 = PyTuple_Pack(1, __pyx_t_6); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __pyx_t_6 = __Pyx_PEP560_update_bases(__pyx_t_2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_11 = __Pyx_CalculateMetaclass(NULL, __pyx_t_6); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_4 = __Pyx_Py3MetaclassPrepare(__pyx_t_11, __pyx_t_6, __pyx_mstate_global->__pyx_n_u_real_datetime, __pyx_mstate_global->__pyx_n_u_real_datetime, (PyObject *) NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_kp_u_add_dayofwk_dayofyr_daysinmonth); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  if (__pyx_t_6 != __pyx_t_2) {
    if (unlikely((PyDict_SetItemString(__pyx_t_4, "__orig_bases__", __pyx_t_2) < 0))) __PYX_ERR(0, 55, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":57
 * class real_datetime(datetime_python):
 *     """add dayofwk, dayofyr, daysinmonth attributes to python datetime instance"""
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofwk(self):
 *         # 0=Monday, 6=Sunday
*/
  __pyx_t_13 = NULL;
  __pyx_t_14 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_13real_datetime_1dayofwk, 0, __pyx_mstate_global->__pyx_n_u_real_datetime_dayofwk, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[1])); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 57, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_14);
  #endif
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_14};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_property, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 57, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (__Pyx_SetNameInClass(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dayofwk, __pyx_t_2) < (0)) __PYX_ERR(0, 57, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":61
 *         # 0=Monday, 6=Sunday
 *         return self.weekday()
 *     @property             # <<<<<<<<<<<<<<
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
*/
  __pyx_t_14 = NULL;
  __pyx_t_13 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_13real_datetime_3dayofyr, 0, __pyx_mstate_global->__pyx_n_u_real_datetime_dayofyr, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[2])); if (unlikely(!__pyx_t_13)) __PYX_ERR(0, 61, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_13);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_13);
  #endif
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_t_13};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_property, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0;
    __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 61, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (__Pyx_SetNameInClass(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_dayofyr, __pyx_t_2) < (0)) __PYX_ERR(0, 61, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":64
 *     def dayofyr(self):
 *         return self.timetuple().tm_yday
 *     @property             # <<<<<<<<<<<<<<
 *     def daysinmonth(self):
 *         if _is_leap(self.year,'proleptic_gregorian'):
*/
  __pyx_t_13 = NULL;
  __pyx_t_14 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_13real_datetime_5daysinmonth, 0, __pyx_mstate_global->__pyx_n_u_real_datetime_daysinmonth, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[3])); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 64, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_14);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_14);
  #endif
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_13, __pyx_t_14};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_property, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0;
    __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 64, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (__Pyx_SetNameInClass(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_daysinmonth, __pyx_t_2) < (0)) __PYX_ERR(0, 64, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":70
 *         else:
 *             return _dayspermonth[self.month-1]
 *     nanosecond = 0 # workaround for pandas bug (cftime issue #77)             # <<<<<<<<<<<<<<
 * 
 * def _datesplit(timestr):
*/
  if (__Pyx_SetNameInClass(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_nanosecond, __pyx_mstate_global->__pyx_int_0) < (0)) __PYX_ERR(0, 70, __pyx_L1_error)

  /* "cftime/_cftime.pyx":55
 *     "(?P<prefix>[+-])(?P<hours>[0-9]{2})(?:(?::(?P<minutes1>[0-9]{2}))|(?P<minutes2>[0-9]{2}))?")
 * 
 * class real_datetime(datetime_python):             # <<<<<<<<<<<<<<
 *     """add dayofwk, dayofyr, daysinmonth attributes to python datetime instance"""
 *     @property
*/
  __pyx_t_2 = __Pyx_Py3ClassCreate(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_real_datetime, __pyx_t_6, __pyx_t_4, NULL, 0, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_real_datetime, __pyx_t_2) < (0)) __PYX_ERR(0, 55, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":72
 *     nanosecond = 0 # workaround for pandas bug (cftime issue #77)
 * 
 * def _datesplit(timestr):             # <<<<<<<<<<<<<<
 *     """split a time string into two components, units and the remainder
 *     after 'since'
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_1_datesplit, 0, __pyx_mstate_global->__pyx_n_u_datesplit, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[4])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 72, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_datesplit, __pyx_t_6) < (0)) __PYX_ERR(0, 72, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":86
 *     return units.lower(), remainder
 * 
 * def _dateparse(timestr,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """parse a string of the form time-units since yyyy-mm-dd hh:mm:ss,
 *     return a datetime instance"""
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_3_dateparse, 0, __pyx_mstate_global->__pyx_n_u_dateparse, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[5])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 86, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_6, __pyx_mstate_global->__pyx_tuple[4]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_dateparse, __pyx_t_6) < (0)) __PYX_ERR(0, 86, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":128
 *     return basedate
 * 
 * def _can_use_python_datetime(date,calendar):             # <<<<<<<<<<<<<<
 *     #gregorian = datetime(1582,10,15,calendar=calendar,has_year_zero=date.has_year_zero)
 *     #return ((calendar == 'proleptic_gregorian' and date.year >= MINYEAR and date.year <= MAXYEAR) or \
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_5_can_use_python_datetime, 0, __pyx_mstate_global->__pyx_n_u_can_use_python_datetime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[6])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 128, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_can_use_python_datetime, __pyx_t_6) < (0)) __PYX_ERR(0, 128, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":136
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):
 *     """
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_7date2num, 0, __pyx_mstate_global->__pyx_n_u_date2num, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[7])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 136, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_6, __pyx_mstate_global->__pyx_tuple[5]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_date2num, __pyx_t_6) < (0)) __PYX_ERR(0, 136, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":326
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2pydate(times,units,calendar='standard'):
 *     """
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_9num2pydate, 0, __pyx_mstate_global->__pyx_n_u_num2pydate, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[8])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 326, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_6, __pyx_mstate_global->__pyx_tuple[6]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_num2pydate, __pyx_t_6) < (0)) __PYX_ERR(0, 326, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":339
 * 
 * UNIT_CONVERSION_FACTORS = {
 *     "microseconds": 1,             # <<<<<<<<<<<<<<
 *     "microsecond": 1,
 *     "microsec": 1,
*/
  __pyx_t_6 = __Pyx_PyDict_NewPresized(32); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 339, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_microseconds, __pyx_mstate_global->__pyx_int_1) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_microsecond, __pyx_mstate_global->__pyx_int_1) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_microsec, __pyx_mstate_global->__pyx_int_1) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_microsecs, __pyx_mstate_global->__pyx_int_1) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_milliseconds, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_millisecond, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_millisec, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_millisecs, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_msec, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_msecs, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_ms, __pyx_mstate_global->__pyx_int_1000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_seconds, __pyx_mstate_global->__pyx_int_1000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_second, __pyx_mstate_global->__pyx_int_1000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_sec, __pyx_mstate_global->__pyx_int_1000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_secs, __pyx_mstate_global->__pyx_int_1000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_s, __pyx_mstate_global->__pyx_int_1000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_minutes, __pyx_mstate_global->__pyx_int_60000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_minute, __pyx_mstate_global->__pyx_int_60000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_min, __pyx_mstate_global->__pyx_int_60000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_mins, __pyx_mstate_global->__pyx_int_60000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_hours, __pyx_mstate_global->__pyx_int_3600000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_hour, __pyx_mstate_global->__pyx_int_3600000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_hr, __pyx_mstate_global->__pyx_int_3600000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_hrs, __pyx_mstate_global->__pyx_int_3600000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_h, __pyx_mstate_global->__pyx_int_3600000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_day, __pyx_mstate_global->__pyx_int_86400000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_days, __pyx_mstate_global->__pyx_int_86400000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_d, __pyx_mstate_global->__pyx_int_86400000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_month, __pyx_mstate_global->__pyx_int_2592000000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_months, __pyx_mstate_global->__pyx_int_2592000000000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_common_year, __pyx_mstate_global->__pyx_int_0x1cae8c13e000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_common_years, __pyx_mstate_global->__pyx_int_0x1cae8c13e000) < (0)) __PYX_ERR(0, 339, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_UNIT_CONVERSION_FACTORS, __pyx_t_6) < (0)) __PYX_ERR(0, 338, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":375
 * 
 * DATE_TYPES = {
 *      "proleptic_gregorian": DatetimeProlepticGregorian,             # <<<<<<<<<<<<<<
 *      "standard": DatetimeGregorian,
 *      "noleap": DatetimeNoLeap,
*/
  __pyx_t_6 = __Pyx_PyDict_NewPresized(9); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 375, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_proleptic_gregorian, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeProlepticGregorian)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":376
 * DATE_TYPES = {
 *      "proleptic_gregorian": DatetimeProlepticGregorian,
 *      "standard": DatetimeGregorian,             # <<<<<<<<<<<<<<
 *      "noleap": DatetimeNoLeap,
 *      "365_day": DatetimeNoLeap,
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_standard, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":377
 *      "proleptic_gregorian": DatetimeProlepticGregorian,
 *      "standard": DatetimeGregorian,
 *      "noleap": DatetimeNoLeap,             # <<<<<<<<<<<<<<
 *      "365_day": DatetimeNoLeap,
 *      "all_leap": DatetimeAllLeap,
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_noleap, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":378
 *      "standard": DatetimeGregorian,
 *      "noleap": DatetimeNoLeap,
 *      "365_day": DatetimeNoLeap,             # <<<<<<<<<<<<<<
 *      "all_leap": DatetimeAllLeap,
 *      "366_day": DatetimeAllLeap,
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_365_day, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeNoLeap)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":379
 *      "noleap": DatetimeNoLeap,
 *      "365_day": DatetimeNoLeap,
 *      "all_leap": DatetimeAllLeap,             # <<<<<<<<<<<<<<
 *      "366_day": DatetimeAllLeap,
 *      "julian": DatetimeJulian,
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_all_leap, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":380
 *      "365_day": DatetimeNoLeap,
 *      "all_leap": DatetimeAllLeap,
 *      "366_day": DatetimeAllLeap,             # <<<<<<<<<<<<<<
 *      "julian": DatetimeJulian,
 *      "360_day": Datetime360Day,
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_366_day, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeAllLeap)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":381
 *      "all_leap": DatetimeAllLeap,
 *      "366_day": DatetimeAllLeap,
 *      "julian": DatetimeJulian,             # <<<<<<<<<<<<<<
 *      "360_day": Datetime360Day,
 *      "gregorian": DatetimeGregorian
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_julian, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeJulian)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":382
 *      "366_day": DatetimeAllLeap,
 *      "julian": DatetimeJulian,
 *      "360_day": Datetime360Day,             # <<<<<<<<<<<<<<
 *      "gregorian": DatetimeGregorian
 *  }
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_360_day, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_Datetime360Day)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)

  /* "cftime/_cftime.pyx":383
 *      "julian": DatetimeJulian,
 *      "360_day": Datetime360Day,
 *      "gregorian": DatetimeGregorian             # <<<<<<<<<<<<<<
 *  }
 * 
*/
  if (PyDict_SetItem(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_gregorian, ((PyObject *)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_DatetimeGregorian)) < (0)) __PYX_ERR(0, 375, __pyx_L1_error)
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_DATE_TYPES, __pyx_t_6) < (0)) __PYX_ERR(0, 374, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":386
 *  }
 * 
 * def to_calendar_specific_datetime(dt, calendar, use_python_datetime,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     if use_python_datetime:
 *         return real_datetime(
*/
  __pyx_t_6 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_11to_calendar_specific_datetime, 0, __pyx_mstate_global->__pyx_n_u_to_calendar_specific_datetime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[9])); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 386, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_6);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_6, __pyx_mstate_global->__pyx_tuple[4]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_to_calendar_specific_datetime, __pyx_t_6) < (0)) __PYX_ERR(0, 386, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;

  /* "cftime/_cftime.pyx":408
 *                calendar=calendar,has_year_zero=has_year_zero)
 * 
 * _MAX_INT64 = np.iinfo("int64").max             # <<<<<<<<<<<<<<
 * _MIN_INT64 = np.iinfo("int64").min
 * 
*/
  __pyx_t_11 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 408, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_iinfo); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 408, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_mstate_global->__pyx_n_u_int64};
    __pyx_t_6 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_2, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
    if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 408, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_6);
  }
  __pyx_t_2 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_max); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 408, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_MAX_INT64, __pyx_t_2) < (0)) __PYX_ERR(0, 408, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":409
 * 
 * _MAX_INT64 = np.iinfo("int64").max
 * _MIN_INT64 = np.iinfo("int64").min             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_np); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 409, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_iinfo); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 409, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_n_u_int64};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 409, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_2, __pyx_mstate_global->__pyx_n_u_min); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 409, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_MIN_INT64, __pyx_t_4) < (0)) __PYX_ERR(0, 409, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":412
 * 
 * 
 * def cast_to_int(num, units=None):             # <<<<<<<<<<<<<<
 *     if num.dtype.kind in "iu":
 *         return num
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_13cast_to_int, 0, __pyx_mstate_global->__pyx_n_u_cast_to_int, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[10])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 412, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[4]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_cast_to_int, __pyx_t_4) < (0)) __PYX_ERR(0, 412, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":439
 * 
 * 
 * def upcast_times(num):             # <<<<<<<<<<<<<<
 *     """Cast times array to larger float or integer dtype before scaling
 *     to units of microseconds.
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_15upcast_times, 0, __pyx_mstate_global->__pyx_n_u_upcast_times, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[11])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 439, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_upcast_times, __pyx_t_4) < (0)) __PYX_ERR(0, 439, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":449
 * 
 * 
 * def scale_times(num, factor):             # <<<<<<<<<<<<<<
 *     """Scale times by a factor, raise an error if values will not fit in np.int64"""
 *     if num.dtype.kind == "f":
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_17scale_times, 0, __pyx_mstate_global->__pyx_n_u_scale_times, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[12])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 449, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_scale_times, __pyx_t_4) < (0)) __PYX_ERR(0, 449, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":468
 * 
 * 
 * def decode_date_from_scalar(time_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode a date from a scalar input."""
 *     delta = time_in_microseconds.astype("timedelta64[us]").astype(timedelta)
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_19decode_date_from_scalar, 0, __pyx_mstate_global->__pyx_n_u_decode_date_from_scalar, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[13])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 468, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_decode_date_from_scalar, __pyx_t_4) < (0)) __PYX_ERR(0, 468, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":477
 * 
 * 
 * def decode_dates_from_array(times_in_microseconds, basedate):             # <<<<<<<<<<<<<<
 *     """Decode values encoded by an integer array in units of microseconds to dates.
 * 
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_21decode_dates_from_array, 0, __pyx_mstate_global->__pyx_n_u_decode_dates_from_array, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[14])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 477, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_decode_dates_from_array, __pyx_t_4) < (0)) __PYX_ERR(0, 477, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":513
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2date(
 *     times,
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_23num2date, 0, __pyx_mstate_global->__pyx_n_u_num2date, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[15])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 513, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[7]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_num2date, __pyx_t_4) < (0)) __PYX_ERR(0, 513, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":641
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):
 *     """
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_25date2index, 0, __pyx_mstate_global->__pyx_n_u_date2index_2, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[16])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 641, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[8]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_date2index_2, __pyx_t_4) < (0)) __PYX_ERR(0, 641, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":758
 * 
 * 
 * cpdef _parse_date(datestring):             # <<<<<<<<<<<<<<
 *     """Parses ISO 8601 dates into datetime objects
 * 
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_27_parse_date, 0, __pyx_mstate_global->__pyx_n_u_parse_date, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[17])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 758, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_parse_date, __pyx_t_4) < (0)) __PYX_ERR(0, 758, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":855
 * 
 * 
 * def _date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """
 *     Return indices of a netCDF time variable corresponding to the given dates.
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_29_date2index, 0, __pyx_mstate_global->__pyx_n_u_date2index, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[18])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 855, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[8]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_date2index, __pyx_t_4) < (0)) __PYX_ERR(0, 855, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":902
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def time2index(times, nctime, calendar=None, select='exact'):
 *     """
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_31time2index, 0, __pyx_mstate_global->__pyx_n_u_time2index, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[19])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 902, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_4, __pyx_mstate_global->__pyx_tuple[9]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_time2index, __pyx_t_4) < (0)) __PYX_ERR(0, 902, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1029
 *         return a
 * 
 * def to_tuple(dt):             # <<<<<<<<<<<<<<
 *     """Turn a datetime.datetime instance into a tuple of integers. Elements go
 *     in the order of decreasing significance, making it easy to compare
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_33to_tuple, 0, __pyx_mstate_global->__pyx_n_u_to_tuple, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[20])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1029, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_t_4) < (0)) __PYX_ERR(0, 1029, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1049
 * 
 * # factory function without optional kwargs that can be used in datetime.__reduce__
 * def _create_datetime(date_type, args, kwargs): return date_type(*args, **kwargs)             # <<<<<<<<<<<<<<
 * # custorm warning for invalid CF dates.
 * cfwarnmsg="this date/calendar/year zero convention is not supported by CF"
*/
  __pyx_t_4 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_35_create_datetime, 0, __pyx_mstate_global->__pyx_n_u_create_datetime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[21])); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1049, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_create_datetime, __pyx_t_4) < (0)) __PYX_ERR(0, 1049, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;

  /* "cftime/_cftime.pyx":1051
 * def _create_datetime(date_type, args, kwargs): return date_type(*args, **kwargs)
 * # custorm warning for invalid CF dates.
 * cfwarnmsg="this date/calendar/year zero convention is not supported by CF"             # <<<<<<<<<<<<<<
 * class CFWarning(UserWarning):
 *     pass
*/
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_cfwarnmsg, __pyx_mstate_global->__pyx_kp_u_this_date_calendar_year_zero_con) < (0)) __PYX_ERR(0, 1051, __pyx_L1_error)

  /* "cftime/_cftime.pyx":1052
 * # custorm warning for invalid CF dates.
 * cfwarnmsg="this date/calendar/year zero convention is not supported by CF"
 * class CFWarning(UserWarning):             # <<<<<<<<<<<<<<
 *     pass
 * 
*/
  __pyx_t_4 = PyTuple_Pack(1, ((PyObject *)(((PyTypeObject*)PyExc_UserWarning)))); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __pyx_t_2 = __Pyx_PEP560_update_bases(__pyx_t_4); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  __pyx_t_6 = __Pyx_CalculateMetaclass(NULL, __pyx_t_2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_11 = __Pyx_Py3MetaclassPrepare(__pyx_t_6, __pyx_t_2, __pyx_mstate_global->__pyx_n_u_CFWarning, __pyx_mstate_global->__pyx_n_u_CFWarning, (PyObject *) NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, (PyObject *) NULL); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  if (__pyx_t_2 != __pyx_t_4) {
    if (unlikely((PyDict_SetItemString(__pyx_t_11, "__orig_bases__", __pyx_t_4) < 0))) __PYX_ERR(0, 1052, __pyx_L1_error)
  }
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __pyx_t_4 = __Pyx_Py3ClassCreate(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_CFWarning, __pyx_t_2, __pyx_t_11, NULL, 0, 0); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_4);
  #endif
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_CFWarning, __pyx_t_4) < (0)) __PYX_ERR(0, 1052, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1245
 *                 return _dayspermonth[self.month-1]
 * 
 *     def strftime(self, format=None):             # <<<<<<<<<<<<<<
 *         """
 *         Return a string representing the date, controlled by an explicit format
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_3strftime, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_strftime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[22])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1245, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[4]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_strftime, __pyx_t_2) < (0)) __PYX_ERR(0, 1245, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_5strptime, __Pyx_CYFUNCTION_STATICMETHOD | __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_strptime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[23])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1255, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[10]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_strptime, __pyx_t_2) < (0)) __PYX_ERR(0, 1255, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_6 = NULL;
  __Pyx_GetNameInClass(__pyx_t_11, (PyObject*)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_strptime); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1255, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_11};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_staticmethod, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1255, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_strptime, __pyx_t_2) < (0)) __PYX_ERR(0, 1255, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1297
 *                             calendar=calendar,has_year_zero=has_year_zero)
 * 
 *     def __format__(self, format):             # <<<<<<<<<<<<<<
 *         # the string format "{t_obj}".format(t_obj=t_obj)
 *         # without an explicit format gives an empty string (format='')
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_7__format__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime___format, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[24])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1297, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_format_2, __pyx_t_2) < (0)) __PYX_ERR(0, 1297, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1305
 *         return self.strftime(format)
 * 
 *     def replace(self, **kwargs):             # <<<<<<<<<<<<<<
 *         """Return datetime with new specified fields."""
 *         args = {"year": self.year,
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_9replace, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_replace, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[25])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1305, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_replace, __pyx_t_2) < (0)) __PYX_ERR(0, 1305, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1336
 *         return self.__class__(**args)
 * 
 *     def timetuple(self):             # <<<<<<<<<<<<<<
 *         """
 *         Return a time.struct_time such as returned by time.localtime().
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_11timetuple, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_timetuple, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[26])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1336, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_timetuple, __pyx_t_2) < (0)) __PYX_ERR(0, 1336, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1347
 *                 self.minute, self.second, self.dayofwk, self.dayofyr, -1))
 * 
 *     cpdef _to_real_datetime(self):             # <<<<<<<<<<<<<<
 *         return real_datetime(self.year, self.month, self.day,
 *                              self.hour, self.minute, self.second,
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_13_to_real_datetime, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime__to_real_datetime, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[27])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1347, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_to_real_datetime, __pyx_t_2) < (0)) __PYX_ERR(0, 1347, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1369
 *         return self.isoformat(' ')
 * 
 *     def isoformat(self, sep='T', timespec='auto'):             # <<<<<<<<<<<<<<
 *         """
 *         ISO date representation
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_19isoformat, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_isoformat, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[28])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1369, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[11]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_isoformat, __pyx_t_2) < (0)) __PYX_ERR(0, 1369, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1416
 *         return hash(d)
 * 
 *     def to_tuple(self):             # <<<<<<<<<<<<<<
 *         return (self.year, self.month, self.day, self.hour, self.minute,
 *                 self.second, self.microsecond)
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_23to_tuple, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_to_tuple, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[29])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1416, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_to_tuple, __pyx_t_2) < (0)) __PYX_ERR(0, 1416, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1457
 *         return args, kwargs
 * 
 *     def __reduce__(self):             # <<<<<<<<<<<<<<
 *         """special method that allows instance to be pickled"""
 *         args, kwargs = self._getstate()
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_27__reduce__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime___reduce, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[30])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1457, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_reduce, __pyx_t_2) < (0)) __PYX_ERR(0, 1457, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1466
 *         return NotImplemented
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def fromordinal(jday,calendar='standard',has_year_zero=None):
 *         """Create a datetime instance from a julian day ordinal, calendar
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_29fromordinal, __Pyx_CYFUNCTION_STATICMETHOD | __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_fromordinal, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[31])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1466, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[10]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_fromordinal, __pyx_t_2) < (0)) __PYX_ERR(0, 1466, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
  __pyx_t_11 = NULL;
  __Pyx_GetNameInClass(__pyx_t_6, (PyObject*)__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_fromordinal); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 1466, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_6);
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_11, __pyx_t_6};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_builtin_staticmethod, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0;
    __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1466, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_fromordinal, __pyx_t_2) < (0)) __PYX_ERR(0, 1466, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1496
 *         return jd
 * 
 *     def toordinal(self,fractional=False):             # <<<<<<<<<<<<<<
 *         """Return (integer) julian day ordinal.
 * 
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_31toordinal, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_toordinal, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[32])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1496, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[12]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_toordinal, __pyx_t_2) < (0)) __PYX_ERR(0, 1496, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1525
 *             return ijd
 * 
 *     def change_calendar(self,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *         cdef datetime dt
 *         """return a new cftime.datetime instance with a different 'real-world' calendar."""
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_8datetime_33change_calendar, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_datetime_change_calendar, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[33])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1525, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[4]);
  if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_6cftime_7_cftime_datetime, __pyx_mstate_global->__pyx_n_u_change_calendar, __pyx_t_2) < (0)) __PYX_ERR(0, 1525, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1647
 *                 return NotImplemented
 * 
 * _illegal_s = re.compile(r"((^|[^%])(%%)*%s)")             # <<<<<<<<<<<<<<
 * 
 * 
*/
  __pyx_t_6 = NULL;
  __Pyx_GetModuleGlobalName(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_re); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 1647, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_11);
  __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_mstate_global->__pyx_n_u_compile); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 1647, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_4);
  __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0;
  __pyx_t_12 = 1;
  {
    PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_s_2};
    __pyx_t_2 = __Pyx_PyObject_FastCall((PyObject*)__pyx_t_4, __pyx_callargs+__pyx_t_12, (2-__pyx_t_12) | (__pyx_t_12*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET));
    __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0;
    __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
    if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1647, __pyx_L1_error)
    __Pyx_GOTREF(__pyx_t_2);
  }
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_illegal_s, __pyx_t_2) < (0)) __PYX_ERR(0, 1647, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1921
 *     return (year, month, day, hour, minute, second, microsecond, -1, -1)
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def is_leap_year(year, calendar, has_year_zero=None):
 *     """returns `True` if specified year in specified calendar is
*/
  __pyx_t_2 = __Pyx_CyFunction_New(&__pyx_mdef_6cftime_7_cftime_37is_leap_year, 0, __pyx_mstate_global->__pyx_n_u_is_leap_year, NULL, __pyx_mstate_global->__pyx_n_u_cftime__cftime, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[34])); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1921, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030E0000
  PyUnstable_Object_EnableDeferredRefcount(__pyx_t_2);
  #endif
  __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_2, __pyx_mstate_global->__pyx_tuple[4]);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_is_leap_year, __pyx_t_2) < (0)) __PYX_ERR(0, 1921, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /* "cftime/_cftime.pyx":1
 * """             # <<<<<<<<<<<<<<
 * Performs conversions of netCDF time coordinate data to/from datetime objects.
 * """
*/
  __pyx_t_2 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 1, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_t_2);
  if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_2) < (0)) __PYX_ERR(0, 1, __pyx_L1_error)
  __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;

  /*--- Wrapped vars code ---*/

  goto __pyx_L0;
  __pyx_L1_error:;
  __Pyx_XDECREF(__pyx_t_2);
  __Pyx_XDECREF(__pyx_t_4);
  __Pyx_XDECREF(__pyx_t_6);
  __Pyx_XDECREF(__pyx_t_11);
  __Pyx_XDECREF(__pyx_t_13);
  __Pyx_XDECREF(__pyx_t_14);
  if (__pyx_m) {
    if (__pyx_mstate->__pyx_d && stringtab_initialized) {
      __Pyx_AddTraceback("init cftime._cftime", __pyx_clineno, __pyx_lineno, __pyx_filename);
    }
    #if !CYTHON_USE_MODULE_STATE
    Py_CLEAR(__pyx_m);
    #else
    Py_DECREF(__pyx_m);
    if (pystate_addmodule_run) {
      PyObject *tp, *value, *tb;
      PyErr_Fetch(&tp, &value, &tb);
      PyState_RemoveModule(&__pyx_moduledef);
      PyErr_Restore(tp, value, tb);
    }
    #endif
  } else if (!PyErr_Occurred()) {
    PyErr_SetString(PyExc_ImportError, "init cftime._cftime");
  }
  __pyx_L0:;
  __Pyx_RefNannyFinishContext();
  #if CYTHON_PEP489_MULTI_PHASE_INIT
  return (__pyx_m != NULL) ? 0 : -1;
  #else
  return __pyx_m;
  #endif
}
/* #### Code section: pystring_table ### */
/* #### Code section: cached_builtins ### */

static int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate) {
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __pyx_builtin_property = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_property); if (!__pyx_builtin_property) __PYX_ERR(0, 57, __pyx_L1_error)
  __pyx_builtin_staticmethod = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_staticmethod); if (!__pyx_builtin_staticmethod) __PYX_ERR(0, 1255, __pyx_L1_error)
  __pyx_builtin_enumerate = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_enumerate); if (!__pyx_builtin_enumerate) __PYX_ERR(0, 275, __pyx_L1_error)
  __pyx_builtin_round = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_round); if (!__pyx_builtin_round) __PYX_ERR(0, 1396, __pyx_L1_error)
  __pyx_builtin_NotImplemented = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_NotImplemented); if (!__pyx_builtin_NotImplemented) __PYX_ERR(0, 1442, __pyx_L1_error)
  __pyx_builtin_super = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_super); if (!__pyx_builtin_super) __PYX_ERR(0, 2093, __pyx_L1_error)

  /* Cached unbound methods */
  __pyx_mstate->__pyx_umethod_PyDict_Type_items.type = (PyObject*)&PyDict_Type;
  __pyx_mstate->__pyx_umethod_PyDict_Type_items.method_name = &__pyx_mstate->__pyx_n_u_items;
  __pyx_mstate->__pyx_umethod_PyDict_Type_pop.type = (PyObject*)&PyDict_Type;
  __pyx_mstate->__pyx_umethod_PyDict_Type_pop.method_name = &__pyx_mstate->__pyx_n_u_pop;
  __pyx_mstate->__pyx_umethod_PyDict_Type_values.type = (PyObject*)&PyDict_Type;
  __pyx_mstate->__pyx_umethod_PyDict_Type_values.method_name = &__pyx_mstate->__pyx_n_u_values;
  return 0;
  __pyx_L1_error:;
  return -1;
}
/* #### Code section: cached_constants ### */

static int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate) {
  __Pyx_RefNannyDeclarations
  CYTHON_UNUSED_VAR(__pyx_mstate);
  __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0);

  /* "cftime/_cftime.pyx":77
 *     """
 *     try:
 *         (units, sincestring, remainder) = timestr.split(None,2)             # <<<<<<<<<<<<<<
 *     except ValueError as e:
 *         raise ValueError('Incorrectly formatted CF date-time unit_string')
*/
  __pyx_mstate_global->__pyx_tuple[0] = PyTuple_Pack(2, Py_None, __pyx_mstate_global->__pyx_int_2); if (unlikely(!__pyx_mstate_global->__pyx_tuple[0])) __PYX_ERR(0, 77, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[0]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[0]);

  /* "cftime/_cftime.pyx":828
 *     # array so numpy slicing rules can be used.
 *     except IndexError:
 *         nctime = nctime[:]             # <<<<<<<<<<<<<<
 *         t = nctime[indices]
 * # if fancy indexing not available, fall back on this.
*/
  __pyx_mstate_global->__pyx_slice[0] = PySlice_New(Py_None, Py_None, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_slice[0])) __PYX_ERR(0, 828, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_slice[0]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_slice[0]);

  /* "cftime/_cftime.pyx":955
 *     # This assumes that the times are increasing uniformly.
 *     if len(nctime) >= 2:
 *         t0, t1 = nctime[:2]             # <<<<<<<<<<<<<<
 *         dt = t1 - t0
 *     else:
*/
  __pyx_mstate_global->__pyx_slice[1] = PySlice_New(Py_None, __pyx_mstate_global->__pyx_int_2, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_slice[1])) __PYX_ERR(0, 955, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_slice[1]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_slice[1]);

  /* "cftime/_cftime.pyx":1024
 * 
 * cdef _toscalar(a):
 *     if a.shape in [(), (1,)]:             # <<<<<<<<<<<<<<
 *         return a.item()
 *     else:
*/
  __pyx_mstate_global->__pyx_tuple[1] = PyTuple_Pack(1, __pyx_mstate_global->__pyx_int_1); if (unlikely(!__pyx_mstate_global->__pyx_tuple[1])) __PYX_ERR(0, 1024, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[1]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[1]);

  /* "cftime/_cftime.pyx":1167
 *             # proleptic Gregorian dates
 *             self.calendar = 'standard'
 *             if self.to_tuple() >= (1582, 10, 15, 0, 0, 0, 0):             # <<<<<<<<<<<<<<
 *                 self.datetime_compatible = True
 *             else:
*/
  __pyx_mstate_global->__pyx_tuple[2] = PyTuple_Pack(7, __pyx_mstate_global->__pyx_int_1582, __pyx_mstate_global->__pyx_int_10, __pyx_mstate_global->__pyx_int_15, __pyx_mstate_global->__pyx_int_0, __pyx_mstate_global->__pyx_int_0, __pyx_mstate_global->__pyx_int_0, __pyx_mstate_global->__pyx_int_0); if (unlikely(!__pyx_mstate_global->__pyx_tuple[2])) __PYX_ERR(0, 1167, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[2]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[2]);

  /* "cftime/_cftime.pyx":1491
 *             units = 'days since 0-1-1-12'
 *         # suppress warning about invalid CF date (year <= 0)
 *         with warnings.catch_warnings():             # <<<<<<<<<<<<<<
 *             warnings.simplefilter("ignore",category=CFWarning)
 *             jd = num2date(jday,units=units,calendar=calendar,has_year_zero=has_year_zero)
*/
  __pyx_mstate_global->__pyx_tuple[3] = PyTuple_Pack(3, Py_None, Py_None, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[3])) __PYX_ERR(0, 1491, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[3]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[3]);

  /* "cftime/_cftime.pyx":1679
 *         else:
 *             ihavems = True
 *             fmt1 = fmt[:-3]             # <<<<<<<<<<<<<<
 *     else:
 *         ihavems = False
*/
  __pyx_mstate_global->__pyx_slice[2] = PySlice_New(Py_None, __pyx_mstate_global->__pyx_int_neg_3, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_slice[2])) __PYX_ERR(0, 1679, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_slice[2]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_slice[2]);

  /* "cftime/_cftime.pyx":1694
 *     year = year + ((2000 - year) // 28) * 28
 *     timetuple = dt.timetuple()
 *     s1 = time.strftime(fmt1, (year,) + timetuple[1:])             # <<<<<<<<<<<<<<
 *     twodigityear = 'y' in fmt1
 *     if twodigityear:
*/
  __pyx_mstate_global->__pyx_slice[3] = PySlice_New(__pyx_mstate_global->__pyx_int_1, Py_None, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_slice[3])) __PYX_ERR(0, 1694, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_slice[3]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_slice[3]);

  /* "cftime/_cftime.pyx":86
 *     return units.lower(), remainder
 * 
 * def _dateparse(timestr,calendar,has_year_zero=None):             # <<<<<<<<<<<<<<
 *     """parse a string of the form time-units since yyyy-mm-dd hh:mm:ss,
 *     return a datetime instance"""
*/
  __pyx_mstate_global->__pyx_tuple[4] = PyTuple_Pack(1, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[4])) __PYX_ERR(0, 86, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[4]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[4]);

  /* "cftime/_cftime.pyx":136
 *             (date.year == 1582 and date.month >= 10 and date.day > 15)))
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2num(dates, units, calendar=None, has_year_zero=None, longdouble=False):
 *     """
*/
  __pyx_mstate_global->__pyx_tuple[5] = PyTuple_Pack(3, Py_None, Py_None, ((PyObject*)Py_False)); if (unlikely(!__pyx_mstate_global->__pyx_tuple[5])) __PYX_ERR(0, 136, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[5]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[5]);

  /* "cftime/_cftime.pyx":326
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2pydate(times,units,calendar='standard'):
 *     """
*/
  __pyx_mstate_global->__pyx_tuple[6] = PyTuple_Pack(1, ((PyObject*)__pyx_mstate_global->__pyx_n_u_standard)); if (unlikely(!__pyx_mstate_global->__pyx_tuple[6])) __PYX_ERR(0, 326, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[6]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[6]);

  /* "cftime/_cftime.pyx":513
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def num2date(
 *     times,
*/
  __pyx_mstate_global->__pyx_tuple[7] = PyTuple_Pack(4, ((PyObject*)__pyx_mstate_global->__pyx_n_u_standard), ((PyObject*)Py_True), ((PyObject*)Py_False), Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[7])) __PYX_ERR(0, 513, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[7]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[7]);

  /* "cftime/_cftime.pyx":641
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def date2index(dates, nctime, calendar=None, select='exact', has_year_zero=None):
 *     """
*/
  __pyx_mstate_global->__pyx_tuple[8] = PyTuple_Pack(3, Py_None, ((PyObject*)__pyx_mstate_global->__pyx_n_u_exact), Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[8])) __PYX_ERR(0, 641, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[8]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[8]);

  /* "cftime/_cftime.pyx":902
 * 
 * 
 * @cython.embedsignature(True)             # <<<<<<<<<<<<<<
 * def time2index(times, nctime, calendar=None, select='exact'):
 *     """
*/
  __pyx_mstate_global->__pyx_tuple[9] = PyTuple_Pack(2, Py_None, ((PyObject*)__pyx_mstate_global->__pyx_n_u_exact)); if (unlikely(!__pyx_mstate_global->__pyx_tuple[9])) __PYX_ERR(0, 902, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[9]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[9]);

  /* "cftime/_cftime.pyx":1255
 *         return _strftime(self, format)
 * 
 *     @staticmethod             # <<<<<<<<<<<<<<
 *     def strptime(datestring, format, calendar='standard', has_year_zero=None):
 *         """
*/
  __pyx_mstate_global->__pyx_tuple[10] = PyTuple_Pack(2, __pyx_mstate_global->__pyx_n_u_standard, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_tuple[10])) __PYX_ERR(0, 1255, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[10]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[10]);

  /* "cftime/_cftime.pyx":1369
 *         return self.isoformat(' ')
 * 
 *     def isoformat(self, sep='T', timespec='auto'):             # <<<<<<<<<<<<<<
 *         """
 *         ISO date representation
*/
  __pyx_mstate_global->__pyx_tuple[11] = PyTuple_Pack(2, __pyx_mstate_global->__pyx_n_u_T, __pyx_mstate_global->__pyx_n_u_auto); if (unlikely(!__pyx_mstate_global->__pyx_tuple[11])) __PYX_ERR(0, 1369, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[11]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[11]);

  /* "cftime/_cftime.pyx":1496
 *         return jd
 * 
 *     def toordinal(self,fractional=False):             # <<<<<<<<<<<<<<
 *         """Return (integer) julian day ordinal.
 * 
*/
  __pyx_mstate_global->__pyx_tuple[12] = PyTuple_Pack(1, Py_False); if (unlikely(!__pyx_mstate_global->__pyx_tuple[12])) __PYX_ERR(0, 1496, __pyx_L1_error)
  __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[12]);
  __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[12]);
  #if CYTHON_IMMORTAL_CONSTANTS
  {
    PyObject **table = __pyx_mstate->__pyx_tuple;
    for (Py_ssize_t i=0; i<13; ++i) {
      #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
      #if PY_VERSION_HEX < 0x030E0000
      if (_Py_IsOwnedByCurrentThread(table[i]) && Py_REFCNT(table[i]) == 1)
      #else
      if (PyUnstable_Object_IsUniquelyReferenced(table[i]))
      #endif
      {
        Py_SET_REFCNT(table[i], _Py_IMMORTAL_REFCNT_LOCAL);
      }
      #else
      Py_SET_REFCNT(table[i], _Py_IMMORTAL_INITIAL_REFCNT);
      #endif
    }
  }
  #endif
  #if CYTHON_IMMORTAL_CONSTANTS
  {
    PyObject **table = __pyx_mstate->__pyx_slice;
    for (Py_ssize_t i=0; i<4; ++i) {
      #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
      #if PY_VERSION_HEX < 0x030E0000
      if (_Py_IsOwnedByCurrentThread(table[i]) && Py_REFCNT(table[i]) == 1)
      #else
      if (PyUnstable_Object_IsUniquelyReferenced(table[i]))
      #endif
      {
        Py_SET_REFCNT(table[i], _Py_IMMORTAL_REFCNT_LOCAL);
      }
      #else
      Py_SET_REFCNT(table[i], _Py_IMMORTAL_INITIAL_REFCNT);
      #endif
    }
  }
  #endif
  __Pyx_RefNannyFinishContext();
  return 0;
  __pyx_L1_error:;
  __Pyx_RefNannyFinishContext();
  return -1;
}
/* #### Code section: init_constants ### */

static int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate) {
  CYTHON_UNUSED_VAR(__pyx_mstate);
  {
    const struct { const unsigned int length: 10; } index[] = {{1},{6},{3},{7},{3},{20},{3},{20},{7},{76},{78},{61},{59},{4},{7},{7},{7},{242},{21},{63},{310},{46},{67},{90},{268},{54},{64},{62},{64},{70},{47},{30},{48},{38},{17},{0},{1},{1},{1},{1},{1},{72},{9},{24},{30},{52},{73},{76},{75},{72},{16},{51},{5},{19},{23},{25},{23},{25},{7},{23},{6},{2},{3},{2},{7},{65},{27},{54},{16},{30},{36},{30},{37},{32},{31},{32},{30},{9},{56},{51},{21},{32},{25},{39},{34},{84},{10},{17},{24},{22},{17},{21},{48},{60},{22},{63},{62},{51},{15},{20},{85},{43},{44},{61},{85},{62},{1},{9},{10},{14},{15},{17},{14},{14},{26},{1},{13},{7},{10},{7},{10},{11},{1},{14},{1},{20},{1},{14},{1},{23},{1},{1},{1},{1},{3},{5},{3},{8},{20},{3},{6},{4},{7},{6},{5},{10},{6},{18},{10},{4},{8},{6},{6},{11},{12},{8},{10},{27},{24},{23},{11},{7},{14},{8},{4},{6},{14},{9},{15},{9},{17},{18},{4},{5},{11},{12},{15},{7},{4},{16},{1},{2},{4},{11},{10},{8},{9},{10},{5},{10},{10},{10},{8},{19},{19},{26},{24},{19},{20},{18},{15},{16},{17},{17},{18},{17},{18},{3},{9},{7},{7},{4},{11},{23},{23},{5},{6},{8},{4},{19},{7},{2},{5},{1},{5},{8},{9},{9},{5},{8},{1},{6},{2},{6},{4},{4},{5},{4},{5},{6},{10},{7},{8},{10},{11},{8},{7},{7},{7},{9},{9},{6},{1},{13},{4},{5},{2},{8},{3},{1},{20},{6},{5},{3},{10},{5},{8},{5},{7},{4},{13},{12},{9},{8},{8},{9},{9},{8},{4},{5},{2},{1},{2},{4},{6},{4},{6},{4},{10},{5},{2},{8},{4},{12},{14},{5},{3},{7},{13},{8},{14},{11},{12},{9},{8},{14},{11},{12},{9},{3},{9},{7},{4},{6},{7},{8},{10},{5},{11},{6},{15},{2},{4},{5},{3},{3},{5},{1},{8},{4},{10},{5},{6},{4},{7},{15},{4},{6},{7},{2},{3},{8},{10},{5},{25},{25},{13},{14},{11},{3},{11},{19},{8},{10},{14},{12},{8},{5},{2},{13},{21},{21},{25},{10},{9},{7},{7},{4},{5},{1},{9},{11},{12},{6},{3},{9},{6},{7},{4},{6},{4},{4},{3},{12},{10},{5},{12},{5},{11},{4},{12},{10},{5},{7},{8},{12},{8},{5},{8},{9},{25},{11},{5},{2},{2},{2},{8},{5},{4},{10},{20},{9},{5},{21},{8},{7},{9},{8},{7},{29},{17},{8},{9},{6},{1},{4},{14},{6},{5},{14},{12},{19},{10},{9},{5},{6},{1},{4},{8},{7},{5},{1},{1},{4},{10},{148},{197},{64},{21},{31},{138},{29},{46},{39},{189},{34},{331},{34},{13},{13},{48},{36},{112},{371},{2},{703},{339},{366},{105},{73},{34},{941},{73},{45},{43},{115},{301},{13},{383},{492}};
    #if (CYTHON_COMPRESS_STRINGS) == 2 /* compression: bz2 (6224 bytes) */
const char* const cstring = "BZh91AY&SY\370s\224\007\000\005%\377\377\377\377\377\377\377\377\377\377\277\377\377\377\377\377\377\377\300@@@@@@@@@@@@\000@\000`\031Z\271\322\224\264\016\315\013_Cj1m\327\323\274\305\276\373\303^\273mc\255\355\345qf\024%$\366\304\257{\216\366\353\233WW\030\003\334-\343\251\3261@\003\352\300\0344\020\204S&\247\2654\310\032&\323I\346\251\275 4\306\246\311\240`\003D\003Bl\2416\020\217I\246\203\023F\311\250\332@\222A0  B&z\200\024\374\251\262\247\352l\223MO&\223\021\352zA\240\3204h\036\246\203\3244\032mA\243@\003\324\r2\004I4\324\364\247\225\033)\241\223\365M\032hz\2324\362\236\246\217I\351\352\232\007\352@3L\305OP\320=A\240\032\001\243\324\364\324<\232\200\223R\200$\032S\020\003\324\014\201\240\000\032\006\214\214F\321\014\206@\000\003 \000d\006\206\200\322\223P\r\036\243\365@\323\321\000z\217MA\246\236\2044b\000z\200\036\223@zM\r\017B\032\000\000\000\000$HBd\023\002b\032\247\206\252~\005'\352d\304\323M\010\311\352\r\007\250m!\246\200\311\345\r\003@\0004\000\007\376l\277\307)\207\215\257Q\007\304\336NeS\235\276\351\304\3100\343\020\274s\232\313\262,W\224\013\2435\334\t_S\207\335\361\322\372r|\307 \"\010C\374\003\375!\312[-\001\274\250\021\364\016zp\n\304\026\2311^\330$8\005\214FJ\300A\tl\002\034\210\365y3!\201|\307\020\313\221\216<\363 \310\231\031de\376\201\377\010\252\n\260U\031\025\004Q\005\202\2521\214\024\351\022\250\247\024MML3F\\\222Sd\314\202X,-+y\005\342@HV\024\344\244v\020\325\230\200\027\227\314\360\302\351\224&\240\032\312\202\014\203\030\240\214\026,\200\210\306E\202\213\004`1\025\316\004\003;\225\255LrITe\216\001\201\206=\2706@\177\337\345\376/\227C2\365\314\366tSnm\261\326\220DY\"\225U\216\235\306\223\031\270`\240\211\"\310\260\026#\030\310\"\305@X\210#\226d\316&y\240\311\207\327m\320\267\234\\,\305\323\204\353\225,M\221\307k\303\314-\nUWE\243@\0300\n\326\276I\252\230\027\027\212\251\024As\225(*PjeVh\230h2\224)\005Y\"\223'A\211\333\321\242\031\300\265\006o\306\244\227\r\306\204\303\001,\274o)w\013ALA0\336pV8\233\360\224\2016\351\240\201z\225\2211\016""\302i\203!P\322\205\223\000\226\301\226\213NQs\307\023\204\014-T\224$\224dH\246[\007\r\263\261vZ9\314\302\311\220\346\0366FH\317,\242\261\003\022\327\205\330yq\343<\275\356\213\2433\035\026S\246\030{Y\036h\357\226,\233<\221P\251}\336\255\306\325(\014\303\225\003`\250l\212\233\034j\006\307\032\334s\01670\353\253\335hcp\350\275\327\265a\233\333\304\313\025r\366\342}\025r\350u\231\264\322\224[hP)\306\2031\253\032\261\301i{n\251I\006y\301\\P\364\014\306\032\024\222z\372S'\312\332\300\334\245=6\320\306\221\240!\322\310\215\004d\351_E\353\217\327\366\375\307`q\237\020\tY\246Lr|\277\216?\255k\347\344\003\200\300uU\361\267Uk{\221\307\266*s;p1\267\235M/\250\264\214\205\273\2608~\345zz\300\303\342h\rBd7.\376\006#\275o\214j\300\276\256n\225\261{\215\220\3609\330\260\307F\221\3307\3112\010\344A\337\033^\\\0329C\341{\33061~0\243\r\005\246\020\242\033\033\\U\274\214\270wv\211\256\014h\010\274\312w\2426\246g\t(\034\032\203\215\350\313\355E\305\350T\333\356bkV1\031cn\230\220]\000\356\005w\224\026\004\261g\327\253t\2721\207\322\006\3466'\270\267F\212\334h\250\232\000\024T\320p\037M(\023\232\205\255M\315=]\310\004\016T\005\215!\300\340vTq\257h{E\306\203\034\247\271\237\204\344e\214_GI\210\357t\3217\027K\001\342\016gw\313\334\221\263x\\\250\204X\270Rp\311\000\263\314\305N\321\027|\000\370\223\220\37104\323\266\2564F#M\315\007\326O\302Y\351\214\221 =\357O\251\246\025\275\357\366\252\225Q\356\375\255\231{\373\356H\220a\356\036\032+\3420\034\336\327\235\272\035\317!\335\367\373\023\346\231)/\255\321q\346UL\253F\303\351\345\312l\315\223\232\351J\251}Z\024\241Nh\257\243\320\336w\014\343\2233~\r\267<=\306x\217C\013\370\367n[\276\331\261\266\333v\227?\223\346\322\n\035.\357s\336\361\344\241\362\276Dh\347a\007?r\252\327_\310\324\327Xq\3779\257\215\215\237\243=\314C'\036>\323\243\001\230e\302\221\212\211\321\242\270k\241\334\360\022\367j\260\010\027`\240\225\003\303\373\205\227\005\303\342\366\270\237\210\356v\037>]k\261\274}'\326`\342V\231\266\3775\003\001\001\342!\200/\357\373}\213\274^\257S""\223\372\304\030\022\267\370/\010\351\241\2303\020\005\020\261\235F\255\335\335\013\302\367W\267\310\332\352\351\263~\274>\266.\257\351\371\254\311\025\323\301mL\353#+) \312\251\201\001\202\027d\361\342\365\312\223K\022 \224Rh\331\373eQ\004/\260\310\024\037\215\344\240D\333d\013'N\256R\325\336iv\305\"\010?\033CWrqx\357V\275\036^~\334\224\004%\337D\300\336\363\367\343\207\264R\265+\035\342D\021\"\236\204Pl\244@RL\267\271)\251Ye%B\253+\262\035Y\263\031r\345\321DB\027\030K\346\346cl\033X\013%\212\315k\372\277&\332\356\314\347\233\036\351\263\235\326n\325jjjj}\214\303>y\375\023\240\036\2565\325\321t\027\270pGW\347\344\031\034\013+\227W/tY}_\351\363\013\217\360\037\251\340\200c\216+\023\0201X\231\231\373\301\353SSJs8\002\375\350\250\240\210QP\264\315\267J\025\212\304\254U\252\327\275\354a\367<\177+\341v|\006\004\004\332;H\302,!^\363F3\361\234\342l~\257\274\n\206\0109\302 {\270%\211\006\0029\316\350vc\307\203\033\353\022Wn\324}\310\312t\310\357\356\372\236^\350\366\027P\003~k\361\373\237\334\276\357_\211Gn\234\261\347\332PH=\204\24447\220&e\276\r!\277\207\203M\036_l>$\260\320d 3*\334!Oe\036\342\014`\366\233\332\216\030\037\025A`\260\372S\207\207\345c\337w\363X\262V\024\2545k\026\3048\234\305\227\037Y6\024\007]\236a:\010\306\0061\"\020l\214B`y\\o\n\371x?\266t\200n\334\2666\330\377\016\373y~\311\342yUZ\245\320YV\035\037\325\330w-\362\267g\351\342R\367\330\367/\344\226\222$H\323\207>\216GR\360\366\373}\257o\362\277^\334\026\206\206\206\232t\035\022\026\342f\033\3417\376\317\274\326\340\340q`e\374/h0\340\2026\265\037\2264@\246\014\340\276\351\363\340\347j\227\177\255\307\036/c/+\303\316\272\024\001\027o\233&R2W^\221\020\004\013\214\034\321\307\234\333J\252\256\223\222d\341:\345\005l\211\315\250j\032Ssr\234\025\322'W~\323\261\256\370L\347\334\341\302\256F\020\276\030\343\227\373xs\365\364\350\346\305n\310Y\0068\342c\036\3773wk\267\363\262\016\215t\372\035l\333bl\216H\330\330\333\275\342\362\346y{3\306\352\352\367=\276\034\262\272\n\032*.\225\324\246z\335\325\270\366\353\360T""\326\312\306\241\224\305\334,V\201JS.\356\274\231\363\330\241J\024\310\307\037\367\373\224\301h\3273\301\266\005\014m\341=\336\316\346\341J\036\366/\260h\364<\236\371\034\220\221mW\225\270\370\266x\306 \221\324\301\352\236\020egT\353\004\035\303\021\273\261\367 V!\346\327s\004\203\031\215\272]\215\030\261\"EAmyl\321uX\3572\306\260\264\336\272\326\326\3753\322U\032\225&v\232f\235\005\\\264\250\362}N\341%\214[\r\322\021\003L \263\343\367\366T\235b\306g\2455\245\325\301\202d2\"\315i<e\026N$2\216\316\"m\003YF\255\007\335\301\027\332\243\277&\227#\301\334a\022)\271a\236H#\311\211 \354_x\341\352\367DmV\372\357\267E\206\213\264\271\310?\352:\301|\034=q\275\342d}rs\305\205\220\342\034\207\014$\r\363\010\211\237\031\335\0374\372\307\224\242\366\\\263l\014L\031\016Z\017M\325fQ\"\276\263)?\023\\\205\361\351\366i\005@T\212\261!\244\242\207a\325\205\263j#A\247\035\010FN\355I9\264\273\355\336\0356\006k\246\023\232\3016\231\212\t\353<:R\302\026\344UEt\274\302\214\271\"\2140\346\244\202l\000\372\002b\n\3133#\006~\375\365\037s\252\366\313\017\\\210!\356\034\226Os\014\3143\001\270\206n\260n\020\3350\315\304\336\200\034]I3\034T\360d\305M\261\213\037.j\004\340\211\221G:\334\016\267\006\216\255\234\375;\250)\226\003Y(\254\250\\\r\362\276)RC2\334\262[\032\013c_\213\313\321l\373\2566\331wCI7\026G\244d\354\031\3030\231\202Cd\212{\345\210\373p\270V5\303\373\210\350\r\201\200\347\210\036I}\244\336\335\233H\362LF\303\261\364?ZE+\rgeW}\227}\355\261\232\233\026c\356\332\346\352\305\340\300\014\210!\341\262'xE\000f\0102\271T\020M1\263f\300[\021\263a\261l\247\314\355\372|~\0148\023ip=\303\232\010i\316\000\205\003\2018!ch\372\224\234\215l\377\214\222H5n\213Ot\357\307Eqw\300\202\260vR.\237\256\306\324\3467\035:\225\014]\234o\233\224\305\223\306i\213\017\273\034\373\256\202\363[\255\243uTl\003\271\327\211\325m{\270\364\371c;V\300\031\250Y^IgGNN\334\346\251\322\361\207y\225UV\000\236\370\034\"f\306m\n\310:r\212\0131f6iR\204>\307\323\033 \370\330_Q\226\354lP$\002\221 \2069R\345\177\004a\030\010@\357""\201\313E\001L\344&\022\216~(\017\251,\223d\231%Z\203V\373P\257\023\256\337.\311:RA \271\253l*\031\332w\351\260)\007\231\003\020\204\226aE\230\230\000\223\251S\260\232*\210s\270\307\000\305\352\276\032x\240N\206e\202\024d[5\210\r\341\005\276\0033\0139\004%z\265u\350\255[\017\003U\0015qH\251\200X\320\315\260\252(J{j\350\374\306AwS\213\315h\315\262\206A\204\246N\034yd\24305\205\261\004\035\001\323\210\3252\277\207G\005\367\3749\315\026i\016F\017\0236X\351\013f\022\345QF\220\034`\3210\177&\006\363>\263@\371\2024`\010G\217B\264\324\035\025\344\205\326\367\305\233\005\0271\260\352\217\331\346\255\\\367\273\017*\026\370\345-g\310A\302\021\333\0073j\007\312\003\334\275\000\016\372D\354[\233\006wb\206\262\026\324\0148\251\322\236%\330\222yb\330\212$\206\300Va\243\234\231C Ez-\307\272\311-\027\036\264\342\253J\357\033v\243\3176\355\267\273\251\035\306\224\240\267\203\031\030e\215\204\220\3027\220XW\010\236\r\245\036\376U\332(\"l\353z\232\343\344\322\207\320wy\347O\245\265/\351+\354\000\303\344\373\206\314\035'I\322\272\327Q\240Y\205e\213\2710\267e\256\016\226K\014\t?&!$\243\342\224\343\311\356\030f\323CC@\367\366\230&a\254\3135\355~<\005\342\301\314\ty\006f\301\316>/U\036\t\260\355\361\263\265+&`\227\217m\265\016\2408N\205)\006\370\333\033\227C)\"7\337\021\2368\204|9\227\220Y\232\375\300N\326\325\353\254Aq9R\215\354po\235\336+Hc\230\241p@\243J\256\316\353\222\n\321R\\\206SA\026\364\253H\357\033bw\3737\024\2036\363H=\223\231\263\255\235$\332(z\231\322\202Tw\323\024_T\246\330\341\255\272K\000\315j\360\224\246/eb\370\313\310\373\361\207%\2365~\301v\2363\360\245\004(\262)\205F\326F\0306\034\327?'0\354\343\325\273\321\270\363\365\331\001r\272\343)\274\365b\026=\356y\024\323\257\036\002\371\325\177\2147Z\006\3339\002 \222\263^\355\324.\320-\016[lL\310=\373\331\323+\255\3410\273\010R\2210A3\206\370\020\245\301\302\037\241A8y\360\262\270\206\027\232\233M\246\212\230!\205]\244\221r\301\212\021\237Q\241tr\365\351\270\300\363\227OE+\340\226j\240\250%\252/3\223\207x\231\235\013\002hA""\235\261\241\264\003r\3028H.\323\t[\022\262\355\327\214\010E\210A\334X\360K\264\374\034^\360\213\330~I\261k\321W\002\216\315\243\013\026\252U<\354]\341u<2\253\260\207\213\307CLW\217\325\214CyQ\206I\357a\233\024\240\224\306\t\303Q\242B\200\222\205\342\2414I\340\341d\356\311DH,h\202\031\253\r\377mi\252\273/\222\034\201\020\302M\nW\200\2079%\016L\265\224\234$\267_\r\265\227\275-\366\027\332X\204r\n\024.\216QM\206%8\273\000\"\030A&\2369\364\026\361X\234R\350\023\000\314\026{+]\223`\276)\r\266\346\t\2120\305}q\233^\014\030ix\002\320\307\204\216E\311\307\322o\372\231\357\371D\\\022\0340\201\337b\356J\032Y\215[3\034Zf\024\005\273K\347\224\004[\317\204 =\2055\003Ar\304\206+\352$\244\320\2560\366Jb\230\257\340\254I\324\023\005\352S\265*\34432g2w\277\361<\221S\250}\223X\214=\201e\346\363\222A5\005\220\030df\305\230[\243\207\333\226\002\027G\203\246\365\n\211\215\357\200/\244\3735{<`e\344\201\232\007o\004H\301\255\357V\363 \3701\242t\272,\274\020\034\230\214\310\357\302\002\300\274d\227\317\306\027u\036\003\343\215MQ\215\222\361\346\352+\000$M\373\"3\271\213\33741\034\220\212<r\216#\274J\214x<\256cO\306\371\207\325\212\214<a\247\t\221\017&&\024\336.BVC\311\243\020w\207<\202C\026\336:\364D\301\265(A6)\014'\346\221Fq1\034\\\355L\320\346OP\263\311\027;\201\2251\262\030\306\353\227=z$\371\271]vY\301d\353&\216.`\274R\226\241S\202\3139gK\216\324^o\032\235'\001\2374\025\n\245~\010J\251\303$\244\3009'\000so\326\247\020{\262\334\"T\324\251\200\027\202#\352`\343\205\177B\006\224Y\034j\321\350k;+\t\024\254\350\262\267\222\233-\017z\023\256\352\r\2316E\264\343\344\\\233t\335\235\255\271NL\206\332\212\035Y\351\\2\001\242:\031\246qZ%lQE\026\211\235Y\023\226w!\302</\210\350nj\0078\242\345\003\014\002\341\211\317drN\373\270\305T\025a\305,\023d4W\275\203\206#\222\r\27516\273q\\\243\024\031Y\363\213\225V\327kz\360\322\223\361\351\216f\362\007#\014\310J\236\034\334\327vO\213\221\263=\362\303]\352<m\307x\r,\214v\342\3473\247\213\351\rI\021XQ\364\3134`\255h\276\355\026\342_V\374\310\335\3473\266""\034\300 \353\007\tL\303\231Z\274\250C\\h\223x\221S\225\226`$X\256\031\030\256\212\253\362#hm[V\325\305\203\032\314\302\327\235=\304\3039a\301\r\034\020\t\r0\"\211\335\353=tj\254\214 \\`F\334)c+I\351\325\022U\301\016\272\2700p\316\313\224\376E\371O\203L\225M\203\023a}\2310\242\254\243;\027\"\364n\2605.kY\271\214b\364\303\000\232\367\342YU\026\3337\233HY\035\316X\266\010\275$]x\330<\366\006\026^\027\206<\346bS\305\227\214\212E \232\325c,*\212\252\330\325j\367\010\330\312\253M\030JP=s\357j\357\003o%[5v \231\3703\331\234o\303\034\355\2327\350\031\323,\036\373\227\303\033\256\003\234\0032P\311&\340\3532\t\246\245\031\230Z:|q\2471s\0274s\003\255\035h\353:\344K\346\356\334\270>\354\306\260\377\325\360w\370t\016\352q\346a\354\217+\002\330pR\003\247X\032\337\004\345\344\313\027\235\340iB^\316+\302\235\201r\353\341\275\213\204\0311\205\305\254\326\215g\010l=Z\314\r'~\374\026\3576Qz\223\212\246\357\201\217\0020\006\004\270\321\306b\\gY{\027\232]\207\177\243\037%\210\325\234'&s4\247XGU'\230\314\031\221\2303\0136m\03046\240\317\000\373\220\246\325\250\264\264\260\257&\263$\022l\033\346c\202\026\370\303\272\311-$\024\241\032\236\350|\361\365\325\003\353u!d\336\261j`[ \302\022B\220\206a\203\257X\263\206ma\237\321\326\262\006\346-DI\245\242\223\306\317J\370\215\373\203\211\354\271|v\223\370\256\016\204}s\255@\275U1\007]\016TX\273\300\354\355\016R\\[\330\361\3738\217\025(tpW`{\\\035\345\340H\227\244}\342\034\227\256\276Z\361/\022\367\026\350_\265B\010\001\337\006\267\r\301\210]c\247J\370\007\013\354\340\351\371\226\305\312l\350\217c\202#\033x\2571\252\216\036\342\037\02330\210\310\n\"!\267\333\376,\344\225\374\247s\031\315*\202\220\030\304t\262\333*,-J\252\224j\274\3018S\355\251h\330<\244\346\336z\025MJ7IUe\233\212\001\335pJ\347\330\325\252\021FP\324\346\036O\301\3137v\212X\205\210(YT\0022R\r\264\210\226n\320\365\222\034\016\244\320\300\352/\350Lq\213\200\353\341m\330B3\004V\217\3000\330\2451\020\022\234s8q\017\206\345?\317,w\221A\214_\242\302r\354E\353\020\254\224\016=\337Ey\2363""\260Q\004\312G\356\232f\020\337\275|\202%G\331\364_Bq\271\201\000\361y\277\313\223\245\257\247)\234\323Ou\334\300TR\037\322\030\0202\020\371\276\220\307\203\316v\177\366`\t\227\374\235\360/\253\003+\253\214\007i\004d/\001\036\307\316\035\376\262C\364\323/\toBb\3146\004\361\020\210\177\t\007G\037\367\361v\367\273\350}o\366G\312\3675\032\267\235\205\305\213s\311K\356\314\022\241\221V\331\364o\304\337Z?\233\200\276\224\211\034|o@q\237H\002'\217x;\322\016\357\027\030t\210\306\n\365\255\267}\277\345\034\003\016D\340\264\313\304\275\242\274\317\325\234;J\223\367\242V\024_\264\0243\006\373s\272P\226~yQ\302\367\370{\\Nv\321\305\272\213 \3755Q-\242\327\026y\314j\353\204 \253^\270\260\225\321,\017\245\201f\313\310\200-\223h\200\320\364\256\230\343tG\342\266#r\252\247>'\027\3609o\030\252\024\244\370m\343\330q\3160]a\307\034\277\213\261\347ZcS\007w\0056\2328\217hz~\327c\257\335q\014\340\216\271\354\240;\017\000\201\310@\300\256R\240\326m\355\315\014\342\256y{\234\334\334\234\314\024:\346\366\373'\222yG\202$\312\207\221\332\036\tXB$ie\271{\035\237`?k\265\263\233\275\207/e\352\037\030\374q\371\2576\303\326\324\317\210\252A\343\266\360P\315=\261\254\203o`ZKK\355-\267\334\316$\270\242\006\334}\037\346:*\220\323\316\361\215]\266k\354l\243\3144a\033A\265^s\230\355\2269yt\365\001n\347\352\236\326\315\255\267\004\033A\367\2377\266\224\314\366&\374\266-.\255\373\014j\233\031h\005\n\244\014#=;m}\301\371?\310\263\017\252\325\242\217V\236,}\316O\027\233+ \223\353\315\230\363\375\177Pu\375F\344\216\314\360#6]v\005b\036\323\220\365\236\364\014}Xu4\312\364\030M'\201\255\2355\t\004\017\230\324Z\325\241*\353*\312W\275E\324\020\277\247ebE\212\201\032\315\375+<\334\335%\340\323\262\r\225\241d7\233\320\326\025\016\255f3\201\252\036k4\\\037z\225 uPK\246{\251\363\300ms\"\205\317\231\373\340P\361\330*\033\337AR2\327d!\306,\007\267\3258\r\004\t\002\316\273\252)\327\311F\215\352\210\036\250\r\326\003\004\017>\362\033_t\312\265*\0175&n\326\362\327h\257\34771\220\233b\004\242T\356\351\3747Y\013\035\013X""\2527_\001\304N\007`;\214\253Q\261e*V\020\253\325\334\307\215\301\246\345\235W\313\357\261K\316a\325\3413\006O\007\341c1E\032\265\217\314\3173\016\025cI\320\327\306\255:\242\255e\241E\212\303:\205\241;B\2205\237\344\267@S\007j\343\321\014O\036\210\364:i\271B\255\033o?X8\3561\3240}\025iQ\243@w\237\024\225\227:&dz \t\272\023\346\334\320\351\245\274\352\312\254C\234\276\260\263\325\254\235\2357?8\346\256\344\3419\034\356\034?_\004\352\002\333M(N)\371\326\347\316\365\353(\026\321\322\346i\315\033\3723]:V|\3006@\230\314\325Y6\346y\345\363\2153\334%\211Y[\0342\245\333>\320{5\374\234\274\237\311w\346J\332\230\031\270%\345f\000\246\222\331jW\212NA\312\223he\242\317\006%d\352\037\247^\214\241\257\352\247\253\261\310\240/CZO\341*N\267\203\303'(d\306\307\362yr;\262\005\236\363\263\261\236C\\\"\253ECho\017\230\330\331\205l\251\341\322\352\017\031\031J9\211G\220\233+!@I7\216\352\346\001\315\306Bh\024ao\333\275\354/kq\313\274#\346P\223\331\030\231\335\000&y\001>\273QT\262\257\3604\245\346n?\377!;\204\265\327\024bY\210\2502\223\366D\222\t\234Z\3624\340f~\006\205\317\367\245dT\242U?\253\210\332\t9~z\352J^`=G\363\221\016\375H\306f\205\342\261\300c\010\336\\#\0317E\324\243\231\312\264\242\342Ob\272\r\201yTuV7\005\351\250\221\215m\357f%\355\311\003\016\320\344\\\024\026,+\202i\310\204\372'/\026\362\016\255\010\303\027\201\357\361\231+\032\310\247\200m\002tT\224]f\345\303\031/_\251\305\270i\004\375\214O\036\026\255\343\223\234\232\363%_\212^t'\236q\235\334\270\r\203.&]\307F\252\260\034\314\021\222.hn+x!L+\214\364\332\341\270R#\025x|i\026,@*\013\263\024\2449Hv\357\030Qp\337\177*\033\005\344\305\031\017\232\006!\316\375\304\222%f\013\301\2620\014;\217\"\320\234\244\326\367.\343\321\2473\001J\307\214<\325\347\305\336\233\332h\014\312\225\213\020@u3\267\030\367w\215\202-\364\351i\324\334\3156r\305v\177\361w$S\205\t\017\2079@p";
    PyObject *data = __Pyx_DecompressString(cstring, 6224, 2);
    if (unlikely(!data)) __PYX_ERR(0, 1, __pyx_L1_error)
    const char* const bytes = __Pyx_PyBytes_AsString(data);
    #if !CYTHON_ASSUME_SAFE_MACROS
    if (likely(bytes)); else { Py_DECREF(data); __PYX_ERR(0, 1, __pyx_L1_error) }
    #endif
    #elif (CYTHON_COMPRESS_STRINGS) != 0 /* compression: zlib (6466 bytes) */
const char* const cstring = "x\332\255Y\313_\323h\333\246\212\n\nJ\005\005\035G\203Z9\014 EDe<\374*\007e\346\025\207\203\347\231\311\027\332\224V\333\244MR\240*\363\271\3542\313,\263\3142\313.\273d\231e\227\374\t\374\t\337u?O\222\026D\337\231\367\375~#\351\223\347x?\367\341\272\257;3\372iz|\"\265\215\2771\264n\2415\231Bc2\265=\312G\374\237\361\333\324}\373`7-\232Jm\177\032G+\276=\370ib{D\370t\213\036\223\364\270M\217)z\334\241\307]<\222RNVR\222\366\340\323=\274e$],\313\222&~\2245\365\301\247\370\370\366\320\177\262\327\0006\033\370ow;\260\372\036-\356\327\266\205\254.(\252!\0244Y\227\025C\310*\202\221\221\205|vKN\t\277\224rYI\271\371D\223\327U\r\255P\244\361\261\230~kj\\LI\345[S\267\371\317\024\375\234\234\221\024\332.\251\346\013%Cf{\031\331\274,\244\262\351\264\254\311JR\026\326dcS\226\025!%\031\262.lf\215L8j\204'\350c'\237+\262\240\246\331\0264\225m\243\256\275\227\223\206.\344\2452n\264A\233a\247\244\252l\310\232\001\211\rU\220\004E2\262\030*\224\215\214\252\234\014\327f\025\335\220 \300\230 \254je\241\244g\225uAUre\261\244\313b2M\223\304`\266\376`U+\311\302f\206\266\327d\354\210\311\020\345\344\001Q\306\346\266\n\370\241QI\320\r\215\0321m!-\304\322\244Z\354\234\022\322\252\006\205&5U\227!iJ\027\262\206\220/\351\006\204g\267\223\014\366\203{\013\222.\214\305\322\013\212\260.+\262&\345F\204\222\222\245\373\372\323U\256\223\201\346\355\340\032x\317\345\262M\357\373\206\024X\20253jI\243\006\344\031\200\261\364\001a\020M]\316\341\006\202\264\266\246\311\033Y\211\324\010m\352YU\321}\375\353\362\020\2246\217\271$\347\200o\371\201\320Xt\212\252\030\031\235\272\024A\312\351*\tK\227g\207\245\203\225\212\232\223\245Bc\2410\000G\301R\346\231\207\254\036\023\236\300\231\006b\030\"\353\311\022\366\333\314d\223\031A\322d\346\267\032.\272\256d?b\356\202\222T5\274\033\2712\235\230\227\014\272\312\314<\363\236Qf3R\246\310\255\364\034wL\347\324\3159M\203tY%\364\261\021\241\240\352zv\r\273\254\311I\tb\010$\235p?\2341\366la\361\315\\by\360\321o\367\0217\351\354\326\303w?\215\3761D\357L\305\017\337\215\217\336""\373\003A\211\256i\374\233\246\021\337\016\361\306\340\320\347\246\376\211\246\376G\324O\207\262}\037\261\201\237\206\006G\331tR\264?7>BG\260n\330c_\347 u\352rA\322$C\325\342\017\307B\351\232\2475\t\266o\3654_M>\264\257\377\3671\032Hk\022<^U\036\372\202\r=\242\377\366\2378\361p\354\021;\222\024\366\021n\373\360\355\347\301\301w\243?AM\r\355\340\240fm4i`\310\337u\350\321\262\\\310II?\374\032\236\003\317\224\032\270\340\243\230^*\024T\002\202\261\375\253\240\0355]\326\310\027Ys\363\303\277[\277\242\346C\364ax \254\003S\024\346wR\332\220\271C\347$\204\245\017.\302\360\260\222\244\366\360\360wW\257\311pN\036\370\351\254\366w\327\353@\231l:\013\207\336\224}\327O\253% \206\017\330\215\305\302\206\004\254^\313\311c\253\031\\\013\336\236\346'\344\01399\017\214\225\310vBJ\225\371\2353\222\222\312\311BL\177\241\320*\202P\330P\347\240\333\200\264\027\014\207 \023\217t\006\2348*\227\345\370\346cBh\237\261\027J\250L!\214=\035yF\335\310\246\010\027>!\373\214\305\336\214\306\362\243\261\224\020{:\035{6\035[\031\210\tc\217\244T*\260\323H`;\326\000d\263\343\001\231\220k\215\342\206\311\313\220^\370\n\351CiB\2579\200\243\311F\266\"\323\360\214\010}\010\237\342h}\177T\030<$k\r%\377\277\362\337?\336\310\310 \217\004\260\030l3*m\242\353?\023\212\241\036\261\005\236_\025r\233@,\356\216e\204\020\001:\231\206R\027m\014<\364\267dG\260\235\250\237C\177\303\"\314)\307\010\214\013\324J\302\r\327\221\205\303\360&\367\332T\265\017:s/d\340\334(^s\251\206\206\230\177\222S\010p\013\2347>\032\247\377&\232\272F'\357\304'\016\357\2765\032\217\217NL\036:p\330\374\311\306\374\254\316\002%\214 y+\253\207\314IfQ\024K#\215\257'G\204u\312_\373\270\227\360\001&Y\027\262\353\n`\200\007\017\002\002\201\204\034\326\270\2340(\3456I\002\242!C\3737h\030\000x\200\304/\257K\271&`\324\232l\300tDG\034\010\221`\025\003\027\332J\341\241\314\346\343&\234\377\005{6F\313\202R\312\257\001\375\2028\246\311,0\2029\224b\276=\332\304[\2767\211\022\322w\306\031\004|s\370\337m\317\374\372\353Q\235[.\345S\031n\372\001\037\266\230;""J9\360\005\337d_\223 E6\222\2514\367\372\000\202)\257\344\263\272\316\351\341\000\333k\240\001^\212\3320[hPt\0061\245\223t>\301n\234\243\202\336q\3310\332\304h`\231ByL\004\t\222\307\362\245\234\221\2254\r\353\322R6\307\23112\000\360\270yZ\t$)\363\325\014\265A\274\t\303sY~g\314\005b\020\301B.\343\024\234<\021h\n}\353\010\001\302\2570\336\223\031\330\271Q1|\232\326\267yQ\325hM\177\243\343;\375\372\366\340\340\237\237\337\375\031\003\215\210\305\206\206c\372PL\017\262\267\017Fd\337\246NEP\013,\343\005,tx\2303^\244J\004b\211R\342\030\243\230\3376\365mnj\302\376\2578\254\256k\311\233\034\316n\372U\304X\241\274\205\223\210*h2\337\360\326xhP\031\314\263\354;q\250\256\203\371\323\240\334M\321x3\350\271y\030\036\177E\\\204\2652(\257\357\204\271\022\354\244\226\014\035\236.h\004\260d\327\251Ia\r\025\210\016\004b\376o\310\353\240\373\264$%\347\014ij\362]I\377\243\324\224\276\003\tH\200\007\343\302\246\324LGF\205\377N\324\306\324\303\361\024\226l>\237O\325\344\"\256f\020\215@\034\035\250m\347QA\310!P\006\226\204\320R\0230\262\275Xu\367\037.\0369D^^/\023\002\177]2\353\177K\242\222\222\223u\375\200L\224\002\0223\363\257\020\373\010\363\331\304\352\234\270\372\346\267\271\225Y\037\314\341;\263R9xK\344r\377\202\203\006\257\241$A\007\0272x[T\233'\377\246\301\271\021-\311p\325\223\205\225\347w\247\306\343\342\362\334\223\271\327\317\022\257\251\360\021\361+.,\256NM\372\225\220\210_\277C\322?\310\251\004!\317\342\242j,\004\244SN=\027\305\337\312[\370\233\315&\rqQ\3362\226\345\364\352\352\302\263\271\267\317\027\347\370\376/^,.\254\2123\317\027_\316-\257,<_\024\347\0233\253\317\227W^\276z+Ik:#\336P\037\376\211\024\204\364\313\023[\243n\227\224\262T(0\225\257\353\364\007_\2234\242\312\014\016%6\201\267\214rA\226\364\262\222\314\252c\200C\004JV\301\006\006\266\326\r1\236\222J\206\272&\241\014\305\336\234\265\257Q\215m\360'$H\007M-\273\2361\002K\213\315\034\216}[\360e\014\366b\037\032\016\214\005\375\337\354\206D\206*\"Z\251\t7HJF2#nr\237\300I\006\031\254\234Df\347\030\024\020\254\340""\215f\346\365\365\003<K\024\223\250atQ\014\032\3538\316\220\363\364\ne\340<\321@\265'\257I\311\017\350)$s,{\2075{s\371\316x\262\201\302\231\177E\241W\344\025\3123\"\373\202\322\370\270\222J\215\247\202\367\211\254\222\222\267\016\264\220\243\330\004\262\020\233\305*\022\306M\331C\304\237\301\006t\244'\2035X\016\014O\010JuQ\344\231K\024\233\272\300\273JI\271\271\013\252%\212)~\265\376\200\276\032\346\013/\033NMkj^\325RYE\312\205}Y]\345\347\207\013\271a\303\t\032\253S\033\233\004\345ZsGa_\007=\214R\241\351`\010\177\260#\224\243\214\177\"Kl~A\345\227S\224\214\232\n\252\024\354\224\342\252\026\351\036\"<*\207\3536\272u\336\317B\207\345\t\366\200\347\244(\234E*%\302*&K\232\014\206\325$\036F\212L)\313\371\202Q\206\"u\312{\242H\270\240\321\017\222\260\2063\344-\211\366\002\236\342\231N\343E\325\322\2514\221U<\225T:'\031\351\034.G:\245\277\361\300\270\341/\234\025\327\n\276P\004\277R\256\3118\230UR \024}b\333*h\360\370<@k\235\271\250\266\036\000\337:\360\240@wc\r=\263\017\222\211\344\262/=\031-\243q\365f4=+\206D\276\201\001\234\347g\263JZ\315\276O\211>\361\026u\346\354\"\002\214\356\212\260\236\232\304C\204&\262\372\263\204\230\325\305\020\221\320&\260c\247\243\235g\010\233\325\323\264\024\203\301\273\357hh\360P\000\355d6\244p\246?=[z\377>\365\036\332y\3172\300\007H\300J\021\235RNNE\360\250%\3703%'l$\342 D?;\216\037\301m\357\267}2\235'\024\312K[\370\227\315\227\000\033\360M\311\207\224\200\353\007\277\\OM\025@\363G\314\240\255\007_2\203\337`U\370}\263\371Sg\320FC\301\277`\256B\262\340G\347\225\204\377\205-O\272\"\320\024\363j\252\004\224\022\231\353\263\207\277\2221\177\364k*\371\246\226\225\351E\317\2238\354\024}=o\244\3624\027\232Q$\2043{*\222\342\337CI\302\202\374K\214\222\312\346\025\230\014\310\344\377\020\312P\322\200\333\031\234E*\252B\356\244\024hU)?A\201F\277\205\262\337*\224\277\371\201:\0348\230\001\341\276\353\314\317\311T\341\213\236\221\200\245\014G9\242\252\005Q,h\204\25425\374\304/\206\001\200\256\202\254!l\313!v\341\250-q\303\240\312\2062F\261$\345\270\022""\212%\325\310\222\306\244\r9\247\311\373\240t\337\313\230\217B\207t\226\265\257:\003tj \266&\223W\246d\315\307M\250\225\356\005\1777X\216\327u\222\207\\\233\234\037\t\204\024\302\232)\277MI+C\306\014\\\313w%\376\244\001^\035\340\231\326\t\252d\350I\227\r\337\334h\245\344\264\204\362\212\035\254\263\257j@(\203\276\230\203\306\361\007\013@\035@@\354\003\261\002\034\301\321\304\231q\303t\212%-\035\024\026L\223\276TQb\321\351\273\\\022\341\223QSA\022\240}\nA\002\010?\225\004\277c\367s*n\246?\034\363\221\014\003%\340'\233S\"\333\215\033q#%\362d)\032\031M\335d\311\003\177<\327\262m\0216\315\201\030\326\001\374(z\0346Eg\377\327\203\t\023&\244\340S\257\221\027)\355\300\333C\232\341\327\013\311\320\274_e\334 \211\205\271\313\370H\230Y\"\033\261\"7\024\214\233\315\1774+\270T\3404\211\335\377\353\300(\031IQM\303\250\006Z\274\301J$^'m\022A\n\350\324\246,S\242\334\244\032n\253L\300\313\240\237\235\351\265^\265\373\367.\267\264\237\361N_\263\343\366\254s\3021\334\273\325\311\352Fmu'Z\277r\313\235t\213\365\266S\225x\275\343\274\231\262n\330G\354\253\366\274\323\357L:\232\373cU\252\237\277h\r\242\353\261\235v\022\316+\367\261\233\257\305\353\275?Xw\355\t{\325\271\344.\273Z\365|\265X;V[\256\375\345\275xY?\337g\035\267$k\313\326\234\350^[Kg\2179ijV\217\265l\025w;\272\315\370\227\310^_\313\261\363\336\271a\247\277\336z\311\273\024w\317\273\305\335\326ns\302|m-YR\275\365\234\271lnYE;\342\217G\335\376\275\223-\307N{\235W\355\001'J\353.ZW\2559;\212\327^7\342Fw[;*\217+i3A\333\016\2727\252Xz\254\336\326YY\252\310\346=\353\261\225\266\023\366\262\275\351H\016\256\333Q\2313\317\231\222\251[\375\026.\0365\243\346U\363\261)[\267\355\210\335m?\366n\334\253F\253\375\365S\035\365\266\323\225\367V\304\302\001\247*\267\315\210y\305ns\"N\324k\235t\023{\307[\332;*\367\314\031\257w\304\231\201b\247\253+\265H\275\343\2549l%\254\245\335\2663\025\303\274\217{\264\332\277\340\340O\330Q\030r.\270c\265\310\227H\275\377\352\336\351\226c\035\225\273f\334\234\367.N\270\375\350\374\341\322^W\330\tk\264{C3\265)o""!\351%S_\022\365\253?W\343X\325\336c\336\265\246\354\350.\014\367\320\352\266\022\365\016\350\351\246St#d\313{\346\254u\312\276\347\240\373L\245X?\323k\026w\351Q\357<o&\255(\357\355\352\263\"\273\354\321\321c&v;\317\231\242\215\005=\3463hu\310\271\347&H1}V\324\212Y\033\366Kt,T\377\334\211\327q\251\342\227\004\014\213\253\3371\257\231K\365\216sx\260\273\336\243k\177I\220Xt\201Yr\204zG\267\327\035\263\227\354\224s\203Y\n>\360\000j\356\301\236q'\201Ka\3516\026\256\332\275N\253\363\324\235\205\355~\354g/\013\356j5J/Q\332\264\313l\263Zq\327\256\013\360\246\245zW\257i\300z\270\002\353\274h]\307a\301\317\025\313\2601\326\217c0\363\2225kGH\252is\305:a\351\3660\314U\014\r\305\355\3703\327M\320w\262\351\202g*\033\346\222\271\016\027\326\354\036/v\333}U\305\211\347M\311\353\035t\260qGe\336\034\202A\316\333\330\264\013^\002\265q\353O[+v\204\356\330e\266\232O\254I\204\205\341L\271=\330a\026\256\322\325c.\340\342\270^}\354\351Nd\357bK\373i\270\254T)\232G\0216%k\336\276\001w;\347$\241\2706\350\231\371\3501\373\205\023sJ\356\\\365\034\002\264\255\275\336q\301\272\342\264#LF\252\322.\244\335\204o\177\206\003\314\273\003\320_\364\262\365\336i\203\356{\253\307\253k\265\223;\303\336\352\213zG'\031n\305\353\033s$r\214\2245b\347\334\230\373\261v\276\246\355\234\333\221\352\247)\220\223\3669Xn\330}R\235\250\256\326\242\007;oU\223\265\236\332\333\235\222\267\372\322{\371\212Tex\335\327\354ig\211.\307\264\224\001\032\260\320\277k\305\255_\354u\347\255\273U\375\010\364\271t\203\275\224!R?\275(p\261\267\014D\340^]Q\362\277\363\260\361m\373\004\002W\251.\324\226j\037\274\245\345\272\277\325\034\364m8\267\335\023\356&\324p)f\277\301\244\004y\312\351J\026\353\246a\372\266\036x!\302\027\006\360\272\256\331?;i\0273\310\340]\260\016v\241\351\334P\300'\214t\361\221\373di\373\2253\353\266U[\253\363\265\3535)0\326\005\347\272\363\036\235\277\326\212\2002\300R'\220g\235!\226\006\2114\000\322\021\267\277\336ABhV\324k\231\255%\352\255'\276\024}G\257\237\001\336|\377\261\013\261\177!\255\321\222\262\025""\371\033K\352g\372\254v\373\262S\364Z/Y\213N?\367\337I8\3562\002\237\2058=8<\314P\027\240\230\036\223\346&N2\354;\270V\306M\001\243\002\224\3506\247\254\263\326\241\223n\300w\257 \241\374\203\271\364*\375\303\371Y\327\250\306\271s\016zW'H\253\347\220#^\001\313W\035\206ce\353(a\300%k\0060{\214\241\314(OH\004\005C\330\245\337\211\327\243\027\255k\204\030A\317\244S\334\355\242\223\267\221\327\244z\317e+\313R\203\341\306\377\276hpi\037+\234% \367\345Qgio\274\345\330qJ\031\222\237:\024\226\007`\3742\342\031\330\331m\336A\312\271k\337\207\000\350\335\254$\315(9\343I\262\020Y|\323\316`\353\217\265\336\235H\235\0052i\253\213\260;\332\307\257\332\013T\240M\203F\375L\027v8v\252r\265\362\253Y\204\257\264\266U\216V\342\025\202\350cm_\364J?\260\370\226)\361\254w\236\\\222\362\342\212y\304\354\337E\343%\200:\3012e\235I\224\002\222\305\t\257\216\2307\254#@\3235\244\257\307\320k\177\275\275\213\337\202\217E\240\245\333\240\013\327\3555@\365cGv\343\273MCw@\032f\235#P\325\232{\314%<\2054F\345>d<\301\256)A\354\256hc\267(\322]\247\263\004E'\253=\325\027\265\033PA\033!\000\262\364\356\276Y\035`\"\257\335\025\304\340\034\300\252H[\034'E\021\302\3371\257\233\357\355v\247\307Y&sR\026cV\252w\205\303Y\253\314\004N\271\375d\357`\230\"\206\300\227\242\366l\240\202Ab\010@\341~\373\026T\020#\362\020\360\224\264=\003\370A\n\343\373\372\211B7\3739\226\020\362\275\007\203\3519\267\013\n\304\"\216x\306P@8F\201\211|\000z8}\216\317\270\014h\215\";=\206\322\216\273\200\234(\343)\0338n\315W\3651\250\010 \206\314HJ\212\325\212;\035\001\366\322\266#\226\014\236\367\013\326\037q\2572\212\322\331\315/8S\233\250\261TG\227\004\247!\257!\366\2220\271\373z\243\017\252K{\253\221\303]8j\2365\177&H\342\206\374\013\2114\322\004&Q\363\"#O,(?\302J,\336\004d]\230\270\347:\013\263\336\276z\317Ek\330Nx\261\231\332$\004\007\365\010h\013wV\0034\024\236\370\326\367l\226\260\2278`\020\207A\312\352\372\301\232\300Hw\217\257^\257\377\036\364\260\204\264\327z\246\262E\212\252\267r\001n k\224\335\366\352\345Z\221\007`+\002,""\347\214zw\026wR\3362\323\030\343)S\234@!m7\230[\353\t\357\304\025 J\273\023\345\274#b\235\007\013z\005F\362\246\252\3540\316B\207\014\330}\316E\362\3733\225O\360\224;\366 \262\342\323\352\342N\277\327B\254\010\007\353\225\033\334;\031s\342\274i\242\262\312(\347\034\266\270n}p\372\334\313U\275v\2656\273\023\3319\273s\327[Y\365V_{\257A\372>x\037r$\326(c\303\276Bd\350`\205\320\2168\373\032`\341\0018\302Yd\302\010\230\364Fu\271J.\325\331\005\354\177e=\007\330mp\276B\224y\006\267XB\326\345a\026\255_$\344\334F<-c\326\222+W\247jgk\367v\376\375\354\022\\\360\005\000\361Hmh'\276\313\344 \326\257\201\031H\366\206\363\322\235p}\342\364\225\014\024M\204\302w\335[pq\354I\035\023\214\016\316\341\002Z\365B\255\377\2733_\240\3536\342c\255\332^\343j\375\302\034\350t\345\215\231\364.\334D\340OB\017+\265\266\235\326\235Y\3577\330\372\215\367f\315[K\326O\023i\274o\177\306\004\003w\355\256-\354\274`\316\360\273\367\373\237\336\237D\263\353\235\034tb\000\376I\244\205\244\333\rNJXs\266\026\367Z\256X\377\353\215=\254J{\213\207FJ\035\205\310S\304\324K\320\301^p\262\213\325\207`:\255\334p\353\326k\220\224\367\325\023U\244\351\313\226\264\327\261\217E\257r')3o+R50\354\r\323Q\005\034\325\005\316\036\2244\022A\316d\205\221\252\t\034\025\347\226\332\245(\241\260fsO|\321*\335\200\374\2509\300\252/b\275\t\2071\365\022!>\362?\315%\366\362\001~\330O\222cv\275\365\007@\024\222H\233y\314d18\311\\=\006H;\205j\022\227\375\026\004\234\203g\306\255\304\177\017\001\254\034e\021\177\370\246\220\220mz\005\376\026m\336\364\001q\324Z\377!`\320\316\353\256:\022\345\003\353$\334(\376\217Q\201TZ\252<\241\014\310\212B\357B\202\3624\231\227\006f\315\223\240\027\223\000\235\243n<\254\033\251\230}\203\300\330\366Ffjqb\202W\001\022W\275\221\307\265\353\336<\\N\364\304\214\227\3112\310\271\206\345\3100\360\214\206\336\207\251*\353\005SI\330\257Q\177?\255>\255=E|\366^\361\271\302\026\250\016^\212\273\264\014\304\321\353\241zy\270\372Km}\347O\357\335\357d\326\004'\005wY\201\366\0026\364\213\304VVB\367\223\355z\231\260""\035\235\274\026\212\007U\304\206\365\006\205\377\0237\316\313\255\273\310-OP\277\234E\374|\254Q-\347u\2173\330!\312r\032\332#J\361\002\320\306\230\346\255\312\232y\006\2167\304\322$n\241\221c\333G\221L\245\360P:\252\010\336\035\355c\303\232}\tN\332{\301\272\000\002\361\0245,\232Q\252\371.\003V\226\235\317 \204\027\006\240\344#\356 \270*\232E\236\024\336\261:\211\322\336O,\037\240\363\026\222f\244q\016\347\340\001\221\350\265\217C\010\366z\215J_{\311\367\273n\3636\027+H\364\353\366R\310\337K\224.\t\3565V\032s\210\272\353\3049\000\035'\212\324i\375\341\014\320'\215\352\261\352\022E\376C\n\353\3603\302\211/\237p\376Q\010'\035\370\270p\0344\267\377Kd\267\265\303\353\020\220\275\212\336\340tu\200\374\231\005>\001\303\021k\337G\211/\221\200\3445\345\030\035\361N\222\261\302&|\241}\017$\243M`6\253\212oU\322aI@\t\252\033\366\243\252\251\007\276r\315^&\227<\373u\027E\311\204\371\016\326\274\353L8K\273A\226\332e\304Yc\322]\344!M\330\227\263c\240K\223\316\307j\264:R\223\302\030\212\303\231\030\336t2 \373\205\2763\221\272\031\020\370s\246\253W\221<Z;9q\251\267\366\230\317\341\210\363\214\333c\352\006\3723\374V@c\212\232\240\367=\343\314\254\367\263\025\377~o\216a\013\353\375\213>\336\360\006\312w\226\32269#s\267k\217!<bj\0065\372qDH\221L\314 \334L#\272\3369G\341\354\363\214Z\222?U\346\031!\244m\316\333E\247\303\235\201c\034\257J\325bc\0303\333\275\226\233\316\246\233\255j\265\276\035\324\214\200M$\007\0009\20312\235\017\267}^\337O\024Mup\267g\326E\250!\301/\360\022$?\007\206\230\201\240\247\330\007\276\225\235S\336\312+\357\325\377x\377\223\362R\252\247~\364>n\357\265\264\374\025\231=\202\237\331#O\350\347\311\221\247GH\224)\263\333\374\027\250\376\202\263\3426a\236?\362+\222\341=\347\251\373k5\370l\342\375\310S\246\350\227A\204\035m-\317\"\317#; c'+\003@\356\264\365\024!\374\014\314\201\261\3467\364\025\216\203\345\014\002\250\007\t\3572|\342\036\322\353\311\332\310N\236\320\252\215\320\252\001\236\001D\177\000\241\177\t\026\260\206D<[;Z\013|\203>c\370\345\3254j\363\036\356""\232\215!\312\003E0\223u\220\206\033\250\345#\365\276\353\270\342\033W\251%|@\240\252~\t\254y\0324G\"c\206\301\214\250c\377\366>F\276k\212\203If\227\276ZN\202 \275\251J\314\225\275S1V\260\362\254}\220k\236\254\014A\370%\213\n\"\204\313?d\252\027)s#w\320\247\256U\242\253\224=\032\207\366x\243Oj\306\016\245\372\366+\026\321d\357\314\010x\300[\367\243\227\300\326\360\014y\367[\211m\367;\211m\267\265\323\353\274\316p\223}{\r9\304\277\002\2343\300s\337\260\034\262jG\367#mk7+&6\201\300~s\233b\206V}f\327|\214B\350\022\2638\220\002\"\337@\010\376\345.\355\372\014X\001\233H:T:w\376\310\346\366\261\257\302\035?\200\333\361o\274\035H\204d\235E$\t\206\344+V\007\216~\005\212\311\323\3260\320\343a5\372\177\031\t\272L";
    PyObject *data = __Pyx_DecompressString(cstring, 6466, 1);
    if (unlikely(!data)) __PYX_ERR(0, 1, __pyx_L1_error)
    const char* const bytes = __Pyx_PyBytes_AsString(data);
    #if !CYTHON_ASSUME_SAFE_MACROS
    if (likely(bytes)); else { Py_DECREF(data); __PYX_ERR(0, 1, __pyx_L1_error) }
    #endif
    #else /* compression: none (13174 bytes) */
const char* const bytes = "-{:02d}02d.{:03d}04d{:04d}-{:02d}-{:02d}05d{:05d}-{:02d}-{:02d}.{:06d}{0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar={9}, has_year_zero={10}){0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, calendar='{9}', has_year_zero={10}){0}.{1}({2}, {3}, {4}, {5}, {6}, {7}, {8}, has_year_zero={9}){0!r} is not present in the mixed Julian/Gregorian calendar0.%s360_day365_day366_day\nCannot compute the time difference between dates with different calendars.\nOne of the datetime objects may have been converted to a native python\ndatetime instance.  Try using only_use_cftime_datetimes=True when creating the\ndatetime object.Expecting a string %rIf %f is used for microseconds it must be the at the end as .%fIn general, units must be one of 'microseconds', 'milliseconds', 'seconds', 'minutes', 'hours', or 'days' (or select abbreviated versions of these).  For the '360_day' calendar, 'months' can also be used, or for the 'noleap' calendar 'common_years' can also be used. Got '%s' instead, which are not recognized.Incorrectly formatted CF date-time unit_stringOverflowError in datetime, possibly because year < datetime.MINYEAR(?P<prefix>[+-])(?P<hours>[0-9]{2})(?:(?::(?P<minutes1>[0-9]{2}))|(?P<minutes2>[0-9]{2}))?(?P<year>[+-]?[0-9]+)(-(?P<month>[0-9]{1,2})(-(?P<day>[0-9]{1,2})(((?P<separator1>.)(?P<hour>[0-9]{1,2}):(?P<minute>[0-9]{1,2})(:(?P<second>[0-9]{1,2})(\\.(?P<fraction>[0-9]+))?)?)?((?P<separator2>.?)(?P<timezone>Z|(([-+])([0-9]{2})((:([0-9]{2}))|([0-9]{2}))?)))?)?)?)?Replacing the calendar of a datetime is not supported.Replacing the dayofyr or dayofwk of a datetime is not supported.Some of the times given are after the last time in **nctime**.Some of the times given are before the first time in **nctime**.Some of the times specified were not found in the **nctime** variable.This strftime implementation does not handle %sUnable to parse date string %rUnits of months only valid for 360_day calendar.Unsupported time units provided, {!r}.%Y-%m-%d %H:%M:%S'% .?add dayofwk, dayofyr"", daysinmonth attributes to python datetime instance calendarcalendar must be one of cannot compare {0!r} and {1!r}cannot compare {0!r} and {1!r} (different calendars)cannot compute the time difference between dates with different calendarscannot compute the time difference between dates that are not calendar-awarecannot compute the time difference between dates with year zero conventionscannot specify a leap day as the reference time with the noleap calendarcftime._strptimechange_calendar only works for real-world calendarsdate days since 0-1-1-12days since -4712-1-1-12days since -4713-11-24-12days since -4713-1-1-12days since -4714-11-24-12disable does not exist in the enable%f.%fgc, got 'has_year_zero kwarg ignored for idealized calendars (always True)has_year_zero not specifiedillegal calendar or reference date for python datetimeillegal timespecinvalid date in mixed calendarinvalid day number provided in {0!r}invalid hour provided in {0!r}invalid microsecond provided in {0!r}invalid minute provided in {0!r}invalid month provided in {0!r}invalid second provided in {0!r}invalid year provided in {0!r}isenabled'months since' units only allowed for '360_day' calendarnetcdf time variable is missing a 'units' attributeno calendar specifiedno leap days in 365_day calendarno 'since' in unit_stringnumpy._core.multiarray failed to importnumpy._core.umath failed to importone of the supplied format directives may not be consistent with the chosen calendar{:s}{:02d}{:s}{:02d}:{:02d}{:s}{:02d}:{:02d}:{:02d}{:s}{:02d}:{:02d}:{:s}((^|[^%])(%%)*%s)%s is not a leap year%s is not an option for the **select** argument.'%s' units only allowed for '365_day' and 'noleap' calendarssrc/cftime/_cftime.pyxthere are only 30 days in every month with the 360_day calendarthis date/calendar/year zero convention is not supported by CFtime values outside range of 64 bit signed integerstimedelta64[us]unsupported calendaryear=0 was specified - this date/calendar/year zero convention is not support""ed by CFyear zero does not exist in the %s calendaryear zero requested, but has_year_zero=Falsezero not allowed as a reference year when has_year_zero=Falsezero not allowed as a reference year, does not exist in Julian or Gregorian calendarszero not allowed as a reference year unless has_year_zero=TrueACFWarningDATE_TYPESDatetime360DayDatetimeAllLeapDatetimeGregorianDatetimeJulianDatetimeNoLeapDatetimeProlepticGregorianGISO8601_REGEXMAXYEAR_MAX_INT64MINYEAR_MIN_INT64MaskedArrayNNotImplementedO__Pyx_PyDict_NextRefTTIMEZONE_REGEXUUNIT_CONVERSION_FACTORSVWZaabsafterallall_leapall_python_datetimesanyappendargsargsortaroundarrayasanyarrayastypeasyncio.coroutinesatleast_1dautobasedatebeforebisectbisect_leftbisect_rightcalendar_calendarscan_use_python_basedatetime_can_use_python_datetimecan_use_python_datetimecast_to_intcastingcatch_warningscategoryceilcftimecftime._cftimecfwarnmsgchange_calendar__class____class_getitem__cline_in_tracebackclipclosecommon_yearcommon_yearscompatible_datecompilecore_create_datetimedd0date_date2indexdate2indexdate2numdate_type_dateparsedatesdates_test_datesplitdatestringdatetimedatetime.__format__datetime.__reduce__datetime._to_real_datetimedatetime.change_calendardatetime_compatibledatetime.fromordinaldatetime.isoformatdatetime_pythondatetime.replacedatetime.strftimedatetime.strptimedatetime.timetupledatetime.to_tupledatetime.toordinaldayday_unitsdayofwkdayofyrdaysdaysinmonthdecode_date_from_scalardecode_dates_from_arraydeltadeltas__dict__diffdifferential_deltas__doc__dtdtypeeemptyendswith__enter__enumerateexact__exit__ffactorfdfilledfindflatfloorformform0format__format__fracdayfractionfractionalfromordinal__func__genexprgetmaskgreatergregoriangroupdictgroupshhas_year_zerohourhourshrhr_unitshrsi_idealized_calendarsignoreiinfoijd_illegal_sindex__init__int64int_numisMA_is_coroutineis_leap_yearis_maskedisfiniteismaskedisoformatisostringisscalaritemitemsiujjdjdayjuliankindkwargslesslongdoublelowerma__main__maskmasked_arraymasked_invalidmatchmaxma""ximum__metaclass__microsecmicrosec_unitsmicrosecondmicrosecondsmicrosecsmillisecmillisec_unitsmillisecondmillisecondsmillisecsminmin_unitsminimumminsminuteminutesmismatch__module__monthmonth_unitsmonths__mro_entries__msmsecmsecsmsgmtdmunitn__name__namenanosecondncnumnctimendimnearestnearest_to_leftnextnoleapnonzeronpnumnum2datenum2pydatenumpyonly_use_cftime_datetimesonly_use_python_datetimesoriginal_maskoriginal_shape_parse_datepop__prepare__proleptic_gregorianpropertypydatetime__pyx_vtable____qualname__quotientravelrereal_datetimereal_datetime.dayofwkreal_datetime.dayofyrreal_datetime.daysinmonth__reduce__remainderreplacereshaperintroundssame_kindscale_timesscaled_timessearchsecsec_unitssecondsecondssecsselectselfsendsep__set_name__setdefaultshapesimplefiltersincesincestringsizesort_indicesspecial_fdsplitsqueezestandardstaticmethodstrftimestripstrptime_strptimestrptime.<locals>.genexprstruct_timesupert0t1td__test__throwtimetime2indextime_in_microsecondstimedeltatimestimes_in_microsecondstimespectimestrtimetupletimezonetm_ydayto_calendar_specific_datetime_to_real_datetimeto_tupletoordinaltzinfouunitunit_timedelta_unitsunitsunsort_indicesupcast_timesuse_python_datetimeutc_offsetutcoffsetvaluevalueswwarnwarningsweekdaywherexyyearyear_units\320\004\"\240!\360\036\000\t\017\320\016#\2401\240D\250\007\250t\2608\2704\270v\300T\310\021\330\0373\2604\260q\330\010\013\2101\330\014\026\220d\230&\240\002\240\"\240F\250!\2504\250r\260\035\270a\330\026\032\230(\240\"\240B\240f\250A\250W\260B\260m\3001\330\027\033\2308\2402\240T\250\034\260R\260r\270\026\270q\300\005\300R\300~\320UV\330\026\030\230\006\230a\230x\240r\250\021\360\010\000\r\024\2204\220r\230\024\230R\230q\340\014\023\2201\200\001\360\030\000\005\026\320\025*\250!\330\004\034\320\0341\260\026\260q\340\004\023\2202\220X\230Q\230a\330\004\025\220R\220x\230q\240\001\330\004\034\320\0341\260\021\260!\360\n\000\005\016\320\r\"\240'\250\021\250!\330\004\032\230\"\230E\240\021\240'\250\027\260\001\260\021\340\004\014\210B""\210f\220A\320\025*\250(\260&\270\001\330\004\005\330\010\r\210Q\210e\2209\230B\230f\240A\240R\240w\250a\250q\330\010\014\210E\220\025\220a\220s\230!\2301\330\014\021\220\021\220\"\220B\220e\2305\240\001\240\023\240B\320&9\270\021\270!\330\013\014\330\010\016\210j\230\001\230\021\340\004\013\2105\220\001\220\037\240\010\250\001\250\021\320\0044\260A\360\006\000\t\014\2109\220C\320\027,\250C\250t\260:\270S\300\001\330\014\022\220*\230A\230Q\340\010\017\210t\220<\230q\240\004\240J\250a\250{\270!\330 )\250\031\260.\300\001\200\001\330!\"\360\016\000\005\014\2108\2201\220F\320\0322\260!\200\001\330\033\034\360\020\000\005\014\2108\2201\220F\230&\240\t\320)C\3006\320Ic\320cd\200A\330\";\2701\360\016\000\t\024\2208\2306\240\021\340\010\013\210>\230\023\230A\330\014\034\320\034/\250q\260\001\330\010\013\2109\220D\230\013\2409\250A\330\014\017\210q\330\017\027\220q\340\017\027\220q\330\r\026\220c\230\021\330\014\017\210q\330\020\030\230\001\340\020\030\230\001\340\014\024\220A\340\r\025\220_\240A\330\014\024\220M\240\021\240)\2509\260A\330\014\021\220\030\230\021\230%\230v\240V\2509\260I\270^\3101\330\010\017\210q\200A\360\010\000\t\014\2107\220#\220Q\330\014\025\220Q\330\010\017\210t\2209\230A\230Q\200A\340\010\013\2108\2201\220D\230\006\230a\330\014\023\320\023%\240Q\240d\250&\260\001\260\021\340\014\023\220=\240\001\240\024\240V\2501\250A\200A\330\010\017\210}\230A\230T\240\027\250\004\250H\260D\270\001\330\035!\240\027\250\004\250I\260T\270\021\330\035!\240\021\200A\340\010\020\220\010\230\004\230A\330\020\031\230\024\230Q\330\020\027\220t\2301\330\020\030\230\004\230A\330\020\032\230$\230a\330\020\032\230$\230a\330\020\037\230t\2401\330\020!\240\024\240Q\330\020\034\230D\240\001\340\010\013\210:\220S\230\007\230s\240*\250C\250q\330\014\022\220*\230A\230Q\360\006\000\t\014\210;\220c\230\021\330\014\022\220*\230A\230Q\360\n\000\t\014\2107\220#\220Q\330\014\017\210v\220Q\220g\230R\230r\240\024\320%5\260W\270A\330\020\026\220a\320\027(\250\001\340\010\014\210F\220)\2306""\240\026\240q\330\014\020\220\001\220\030\230\021\340\010\017\210t\220:\230S\240\001\200A\330\010\020\220\004\220G\2304\230x\240t\2506\260\024\260W\270D\300\001\330\020\024\220I\230T\240\021\200A\330.H\310\001\360\032\000\t\016\210Q\210a\210q\220\003\2204\220u\230F\240&\250\001\250\025\250c\260\021\340\010\025\220Q\220e\2305\240\005\240U\250%\250u\260E\270\025\270a\330\010\t\330\014\031\230\037\250\t\260\021\260,\270a\340\014\017\210w\220a\220|\2409\250F\260'\270\021\330\021\036\230j\250\010\260\001\260\027\270\006\270b\300\n\310*\320TU\330\014\r\330\014\025\220S\320\030.\250a\330\r\026\220d\230,\240l\260%\260z\300\026\300r\310\025\310a\330\016\030\230\006\230c\240\025\240d\250*\260G\2702\270T\300\021\330\016\030\230\006\230c\240\025\240d\250*\260G\2703\270c\300\024\300Z\310u\320TV\320VW\330\014\017\210t\320\023#\240:\250Q\330\020\024\220A\330\020\026\220h\230a\230q\340\014\023\2208\2301\230J\240g\250Z\260x\270z\310\021\330\034&\240g\250Z\260y\300\n\310!\330\034&\240n\260I\270Z\300~\320UV\360\010\000\020\021\330\014\021\220\026\220t\2305\240\007\240w\250n\270I\300Q\300k\320QR\330\014\023\2208\2301\230E\240\026\240t\2505\260\007\260w\270a\330\034%\240Y\250n\270A\200A\340\010\016\210i\220t\230:\240Q\330\010\024\220D\230\001\230\021\330\010\020\320\020#\240;\250f\260A\200A\360\006\000\t\020\210t\2208\2301\200A\340\010\017\210t\220:\230R\230q\200A\360\020\000\t\020\210t\220<\230r\240\024\240W\250D\260\010\270\004\270F\300$\300a\330\020\024\220I\230T\240\031\250$\250j\270\004\270K\300q\200\001\360\n\000\005\r\210B\210g\220R\220x\230r\240\026\240r\250\027\260\002\260!\330\014\016\210i\220r\230\021\320\000D\300A\330\004\007\200q\330\010\017\210}\230A\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\340\010\024\220J\230a\230q\330\010\017\210y\230\001\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220\021\330\017\021\220""\021\330\017\030\230\t\240\036\250q\320\004\034\230N\250!\360\n\000\t\014\2104\210v\220R\220q\330\014\024\220A\340\014\024\220A\330\010\013\2109\220C\220q\330\014\023\2201\330\014\023\2204\220w\230a\230t\2407\250$\250h\260d\270!\330\r\026\220c\230\021\330\014\023\2206\230\022\2301\330\014\023\2204\220w\230a\230t\2407\250$\250h\260d\270&\300\001\330\037#\2401\330\r\026\220c\230\021\330\014\023\2206\230\022\2301\330\014\023\2204\220w\230a\230t\2407\250$\250h\260d\270&\300\001\330\037#\2407\250$\250a\330\r\026\220c\230\021\330\014\023\2206\230\022\2301\330\014\023\2204\220w\230a\230t\2407\250$\250h\260d\270&\300\001\330\037#\2407\250$\250i\260t\2701\330\r\026\220d\230(\320\"2\260!\330\014\025\220X\230W\240A\240T\250\021\330\014\017\210y\230\003\2301\330\020\034\230C\230q\240\005\240Q\240d\250-\260r\270\026\270q\330\020\032\230)\2407\250!\2501\330\021\032\230#\230Q\330\020\032\230)\2407\250!\2504\250q\340\020\023\2204\220}\240B\240a\330\024\036\230i\240w\250a\250t\2601\330\014\023\2206\230\022\2301\330\014\023\2204\220w\230a\230t\2407\250$\250h\260d\270&\300\001\330\037#\2407\250$\250i\260q\340\014\022\220*\230A\230Q\250Q\200\001\330\036-\250Q\3600\000\005\006\330\010\016\210a\330\013\014\330\010\016\210n\230A\230Q\340\004\007\200y\220\003\2201\330\010\023\2207\230!\2308\240<\250q\340\004\007\200w\210c\220\021\360\006\000\t\n\330\014\024\220J\230a\230w\240h\250i\260z\300\027\310\001\330\014\017\210w\220c\230\021\330\020\027\220q\330\021\030\230\003\2301\330\020\027\220u\230A\230Q\340\020\027\220u\230A\230Q\330\017\020\360\006\000\005\013\210\"\210K\220q\230\001\330\004\010\210\003\2101\210A\360\010\000\005\010\200s\210!\2108\2203\220a\330\010\014\210E\220\026\220r\230\021\330\010\r\210S\220\002\220!\340\010\r\210V\2201\220A\330\010\r\210Q\330\004\007\200w\210d\220)\2301\330\010\020\220\002\220&\230\002\230$\230b\240\004\240B\240d\250!\330\t\020\220\003\2201\330\010\020\220\002\220&\230\001\230\022\2305\240\002\240$\240b\250\004\250B\250e\2601\340\010\020\220\002\220&""\230\001\230\022\2307\240\"\240D\250\002\250$\250b\260\005\260Q\360\n\000\005\010\200t\210<\220q\230\007\230w\240h\250a\360\006\000\020\021\330\010\020\220\002\220&\230\001\230\021\230&\240\r\250Q\250h\260c\270\024\270U\300&\310\001\330\010\021\220\026\220s\230!\340\010\020\220\002\220&\230\001\230\021\230&\240\014\250A\250X\260S\270\004\270E\300\026\300q\330\010\020\220\006\220c\230\021\340\010\013\2107\220$\220j\240\t\250\024\250R\250t\2601\260A\330\014\022\220*\230A\330\020\021\340\010\013\2107\220$\220i\230y\250\004\250B\250d\260!\2601\330\014\022\220*\230A\330\020\021\360\n\000\t\016\210Q\210i\220r\230\022\2301\330\010\020\220\002\220(\230!\2301\230F\240!\2403\240d\250%\250q\330\010\023\2202\220X\230Q\230f\240C\240t\2501\250A\340\010\013\2107\220#\220Q\330\014\017\210s\220!\220:\230R\230q\330\020\026\220j\240\001\330\024\025\340\r\024\220C\220q\330\014\021\220\021\220)\2301\330\014\021\220\021\220-\230q\340\r\024\220C\220q\360\006\000\016\025\220C\220q\330\014\036\230c\240\021\240*\250B\250b\260\006\260a\330\020\021\220\025\220a\220v\230Q\230b\240\002\240$\240b\250\005\250Q\250f\260A\260T\270\024\270U\300%\300q\310\014\320TV\320VW\330\014\021\220\021\220,\230e\2401\240J\250b\260\002\260\"\260A\360\006\000\r\023\220*\230A\330\020C\3002\300Q\360\006\000\t\016\210Q\210j\230\001\360\006\000\005\014\2109\220A\220Q\200\001\330\036-\320-=\270Q\360T\001\000\005\006\330\010\016\210a\330\013\014\330\010\016\210n\230A\230Q\340\004\021\220\022\220;\230a\230q\360\n\000\005\010\200~\220S\230\001\330\010\013\2109\220C\220q\330\014\021\220\032\2305\240\001\240\021\330\014\017\210z\230\021\230#\230Q\330\020 \240\001\340\020\021\330\024$\240B\240a\330\027\030\330\024\032\230*\240A\320%C\3004\300q\310\001\340\014\034\320\034/\250q\260\001\360\010\000\005\010\200t\2101\330\010\r\210Z\220u\230A\230Q\330\010\013\210:\220Q\220c\230\021\330\014\027\220q\340\014\r\330\020\033\2302\230Q\330\023\024\330\020\026\220j\240\001\320!9\270\024\270Q\270a\340\004\017\210x\220v\230Q\330\004\017""\210z\230\021\230&\240\007\240y\260\t\270\036\300q\340\004\007\200y\220\004\220J\230l\250-\3207N\310d\320RV\320VW\330\010\013\2108\2206\230\023\230A\330\014\020\220\001\330\014\022\220*\230A\230Q\340\004\007\320\007\037\230q\240\t\250\021\340\010\020\220\010\230\001\230\026\230v\240W\250I\260Y\270n\310A\330\010\017\210z\230\021\230'\240\030\250\032\2601\340\010\017\210{\230!\2307\240(\250*\260H\270N\310!\320\000\025\220Q\330\004\007\200s\210&\220\006\220c\230\021\330\010\017\210q\360\010\000\t\014\2102\210T\220\021\220\"\220E\230\021\230$\230k\250\030\260\036\270s\300\"\300D\310\001\310\022\3108\320ST\320TX\320Xc\320ck\320kl\330\014\022\220-\230q\240\001\330\010\013\210:\220Q\220e\2302\230S\240\005\240Q\330\014\026\220b\230\003\230=\250\001\250\022\2505\260\001\260\026\260v\270R\270q\360\006\000\r\020\210v\220W\230O\2504\250v\260W\270A\330\020\032\230\"\230C\230v\240Q\240g\250Q\250h\260c\270\021\330\032\034\230C\230}\250A\250R\250v\260Q\260e\2706\300\022\3009\310A\330\020\032\230\"\230C\230v\240Q\240g\250Q\250h\260c\270\021\330\032\034\230C\230}\250A\250R\250u\260A\260U\270&\300\002\300)\3101\340\014\026\220b\230\006\230a\230r\240\025\240a\240v\250V\2602\260Q\330\014\017\210v\220W\230O\2504\250v\260W\270A\330\020\032\230\"\230F\240!\2407\250!\2508\2603\260a\330\032\034\230F\240!\2402\240V\2501\250E\260\026\260r\270\031\300!\330\020\032\230\"\230F\240!\2407\250!\2508\2603\260a\330\032\034\230F\240!\2402\240U\250!\2505\260\006\260b\270\t\300\021\330\010\017\210q\200\001\360\010\000\005\016\210Y\220c\320\031/\250t\2604\260v\270S\300\010\310\004\310D\320PV\320VY\320Yb\320bc\330\016\027\220t\230<\240|\2604\260t\2706\300\023\300I\310U\320RV\320V\\\320\\^\320^c\320cd\330\r\021\220\026\220s\230%\230t\2404\240w\250c\260\023\260D\270\004\270E\300\022\3001\320\000\037\230\177\320.>\270a\360N\001\000\005\006\330\010\016\210a\330\013\014\330\010\016\210n\230A\230Q\330\004\014\210H\220A\220V\2306\240\027\250\t\260\032\270>\310\021\330\004\013\210:\220Q\220g\230X\240Y\250j\270""\007\270q\320\004\036\230a\360\014\000\t\014\2107\220#\220Q\330\014\025\220T\230\021\330\010\017\210y\230\001\230\026\230q\200\001\330\033*\320*>\270a\360p\001\000\005\020\210q\330\004\005\330\010\r\210Q\210a\340\010\013\2104\210q\340\014\023\2202\220V\2301\230C\230v\240Q\340\014\027\220q\360\006\000\005\020\210q\330\004\007\200r\210\023\210E\220\021\220'\230\024\230R\230s\240*\250A\250Q\330\010\017\210u\220A\330\010\023\2201\360\006\000\005\r\210B\210k\230\021\230!\330\004\014\210E\220\021\330\004\033\2301\330\004\010\210\010\220\005\220Q\330\010\013\2104\210z\230\021\230%\230q\330\013\"\240!\330\013\014\360\n\000\005\010\200~\220S\230\001\330\010\013\2109\220C\220q\330\014\021\220\025\220e\2301\230A\330\014\017\210z\230\021\230#\230Q\330\020 \240\001\340\020\021\330\024$\240B\240a\330\027\030\330\024\032\230*\240A\320%C\3004\300q\310\001\340\014\034\320\034/\250q\260\001\360\010\000\005\010\200t\2101\330\010\013\2101\330\014\027\220q\340\014\021\220\025\220e\2301\230A\330\014\017\210z\230\021\230#\230Q\330\020\033\2301\340\020\021\330\024\037\230r\240\021\330\027\030\330\024\032\230*\240A\320%=\270T\300\021\300!\340\004\017\210x\220v\230Q\330\004\017\210z\230\021\230&\240\t\250\031\260.\300\001\330\005\013\210=\230\n\240!\2401\340\004\007\200y\220\004\220J\230l\250-\3207N\310d\320RV\320VW\330\010\013\2108\2206\230\023\230A\330\014\020\220\001\330\014\022\220*\230A\230Q\330\004\007\200u\210G\2201\330\010\016\210j\230\001\320\031A\300\027\310\001\310\021\330\004\007\200u\210D\220\n\230)\2404\240y\260\003\2601\330\010\016\210j\230\001\230\021\330\004\025\220Y\230a\230}\320,C\3001\300A\330\004\"\240(\250\"\320,B\300$\320F^\320^_\320_h\320hi\340\004\007\320\007#\2404\240q\330\010\036\230a\330\010\013\2104\210z\230\021\230*\240A\330\014\027\220}\240A\240X\250W\260H\270H\300H\310A\330\027\037\230w\240h\250i\260x\270q\330\027\037\230q\340\010\036\230a\340\010\024\320\0241\260\021\260*\270J\300g\310^\320[\\\330\004\014\210A\330\004\010\210\003\2108\2209\230A\230U\240!\330""\010\013\2109\220D\230\004\230E\240\021\240!\330\014\021\220\027\230\001\230\021\330\014\r\360\006\000\t\014\2101\340\014\017\210w\220a\220v\230Y\240f\250G\2601\330\020\027\220t\2308\2401\240G\2506\260\022\2604\260z\300\021\340\014\023\320\0230\260\001\260\026\260z\300\027\310\016\320VW\340\010\r\210U\220\"\220A\330\010\013\2103\210b\220\017\230s\240)\2501\250A\340\014\027\220r\230\026\230q\240\003\2403\240a\330\014\021\220\027\230\001\230\021\340\014\017\210q\360\020\000\021\030\220r\230\026\230r\240\034\250Q\330\027\031\230\031\240\"\240H\250A\330\027\031\230\021\330\020\031\230\036\240v\250R\250|\2701\330\031'\240y\260\002\260(\270!\330\031'\240q\330\020\033\2302\230[\250\001\250\025\250b\260\002\260+\270Q\270a\340\020\033\2303\230b\240\001\330\014\021\220\027\230\001\230\021\340\004\007\200q\330\010\020\220\002\220&\230\001\230\027\240\006\240a\330\010\020\220\002\220#\220_\240A\240Q\330\010\013\2101\330\014\023\2205\230\001\230\021\340\014\023\2202\220X\230Q\230g\240Q\330\004\007\200q\330\010\017\210u\220A\220Q\340\010\017\210r\220\030\230\021\230\"\230F\240!\2408\2501\200\001\360\010\000\005\006\330\t\020\220\r\230]\250'\260\026\260q\270\005\270Q\330\004\013\210>\230\021\330\010\016\210j\230\001\230\021\340\004\007\200{\220&\230\003\2303\230a\330\010\016\210j\230\001\230\021\340\004\013\2105\220\006\220d\230!\200\001\340\004\014\320\014 \240\007\240q\320(:\270'\300\021\300!\330\004\005\330\010\017\210y\230\002\230!\330\013\014\330\010\016\210j\230\001\230\021\200\001\360\010\000\005\010\200s\210&\220\006\220c\230\021\330\010\017\210s\220'\230\021\230\"\230A\340\010\017\210s\220'\230\021\230\"\230A\200\001\340\004\007\200s\210&\220\006\220c\230\021\330\010\017\210w\220b\230\001\340\010\013\2103\210f\220C\220q\330\014\023\2201\360\010\000\t\023\220\"\220D\230\001\230\024\230U\240#\240R\240q\330\010\022\220\"\220D\230\001\230\024\230U\240#\240R\240q\330\010\013\2108\2202\220[\240\003\2408\2502\250Q\340\014\022\220-\230q\240\001\340\014\023\2204\220r\230\021\200""\001\360\032\000\005\010\200t\210:\220Q\220l\240%\240t\2504\250z\270\021\270,\300a\330\010\016\210j\230\001\320\0311\260\022\2601\330\004\010\210\r\220V\2301\230J\240f\250A\330\004\007\200t\2101\330\010\016\210j\230\001\320\031:\270\"\270A\330\004\r\210Q\210j\230\001\330\004\024\220O\2401\240F\250!\2501\330\004\007\200v\210Q\210h\220c\230\021\330\010\016\210a\210z\230\021\330\004\007\200v\210Q\210j\230\003\2301\330\010\016\210a\210|\2301\330\004\007\200v\210Q\210j\230\003\2301\330\010\016\210a\210|\2301\330\004\007\200v\210Q\210l\230#\230Q\330\010\016\210a\210~\230Q\340\010\016\210a\210~\230S\240\001\240\025\240a\240w\250b\260\006\260a\260}\300B\300a\330\004\014\210C\210q\220\006\220a\220q\330\004\013\2107\220#\220Q\220f\230A\230[\250\003\2501\250F\260!\2601\330\010\013\2101\210F\220!\220:\230S\240\001\240\026\240q\250\014\260C\260q\270\006\270a\270q\330\010\013\2101\210F\220!\2201\330\010\t\320\000/\250w\260i\270r\300\030\310\021\320\000 \240\001\360\014\000\005\020\210x\220v\230Q\340\004\007\200~\220S\230\001\330\010\030\320\030+\2501\250A\330\005\014\210M\230\032\2401\240A\330\004\007\200v\210V\2203\220l\240$\240h\250b\260\013\2704\270v\300S\310\013\320SW\320W`\320`d\320do\320oz\320z}\360\000\000~\001D\002\360\000\000D\002G\002\360\000\000G\002H\002\330\010\013\2106\220\023\220L\240\004\240I\250S\260\001\330\014\022\220*\230A\230Q\330\010\013\2106\220\023\220K\230t\2409\250H\260K\270q\330\014\022\220*\230A\320\035\\\320\\^\320^_\340\014\022\220*\230A\330\014\r\360\010\000M\001O\001\310a\340\004\n\210'\220\025\220f\230H\240H\250M\270\021\330\010\023\2202\220Y\230f\240A\330\004\007\200u\210C\210r\220\024\220T\230\036\240t\2509\260D\270\n\300,\310m\320[\\\330\010\014\210A\330\010\016\210j\230\001\230\021\330\004\007\200y\220\004\220J\230k\250\024\250V\2603\260b\270\004\270D\300\003\3001\330\010\016\210j\230\001\330\014\r\330\004\007\200y\220\003\220:\230T\240\024\240R\240q\330\010\016\210j\230\001\330\014\r\330\004\017\210x\220q\230\006\230g\240U\250&\260\010\270""\001\330\030$\240I\250Y\260n\300A\340\004\007\200q\330\010\024\220I\230Q\230e\240:\250Q\250a\330\004\013\2101\200\001\360\010\000\005\006\330\004\005\330\004\005\330\004\005\360z\001\000\005\020\210x\220v\230Q\340\004\007\200~\220S\230\001\330\010\030\320\030+\2501\250A\330\004\017\210z\230\021\230&\240\t\250\031\260.\300\001\340\004\034\320\0344\260A\260Y\270a\330\004\007\200t\320\013%\240T\250\021\330\010\013\2104\210q\330\014\020\220\001\330\014\022\220*\230A\230Q\340\004\n\210)\220:\230Q\230a\360\006\000\005\010\200y\220\004\220J\230l\250-\3207N\310d\320RV\320VW\330\010\013\2108\2206\230\023\230A\330\014\020\220\001\330\014\022\220*\230A\230Q\340\004\032\230!\330\004\007\320\007!\240\024\240T\250\021\340\010\036\230a\330\004\007\200t\320\013%\240T\250\024\320-G\300t\3101\360\006\000\t\037\230a\340\004\017\320\017,\250A\250Z\260z\320AV\320Vd\320de\340\004\007\200u\210G\2201\330\010\016\210j\230\001\320\031A\300\027\310\001\310\021\340\004\007\200u\210D\220\n\230)\2404\240y\260\003\2601\330\010\016\210j\230\001\230\021\340\004\r\320\r$\240A\240Q\330\004\014\210B\210k\230\021\230!\330\004\014\210L\230\001\230\021\340\004\007\200t\2102\210Y\220a\220v\230T\240\021\330\010\020\220\002\220#\220_\240A\240Q\330\004\023\220;\230a\230w\240a\330\004\023\220;\230a\230}\250F\260!\340\004\007\200|\2206\230\023\230B\230c\240\034\250V\2603\260a\330\010\017\320\017&\240a\240~\260Q\340\010\013\210:\220Q\220n\240B\240c\250\021\360\006\000\r\035\230B\230c\240\030\250\021\250!\330\014\033\230<\240w\250a\250q\330\014\024\320\024+\2501\250N\270!\330\014\023\2202\220S\230\014\240A\240W\250E\260\021\340\014\023\320\023*\250!\250>\270\021";
    PyObject *data = NULL;
    CYTHON_UNUSED_VAR(__Pyx_DecompressString);
    #endif
    PyObject **stringtab = __pyx_mstate->__pyx_string_tab;
    Py_ssize_t pos = 0;
    for (int i = 0; i < 445; i++) {
      Py_ssize_t bytes_length = index[i].length;
      PyObject *string = PyUnicode_DecodeUTF8(bytes + pos, bytes_length, NULL);
      if (likely(string) && i >= 106) PyUnicode_InternInPlace(&string);
      if (unlikely(!string)) {
        Py_XDECREF(data);
        __PYX_ERR(0, 1, __pyx_L1_error)
      }
      stringtab[i] = string;
      pos += bytes_length;
    }
    for (int i = 445; i < 480; i++) {
      Py_ssize_t bytes_length = index[i].length;
      PyObject *string = PyBytes_FromStringAndSize(bytes + pos, bytes_length);
      stringtab[i] = string;
      pos += bytes_length;
      if (unlikely(!string)) {
        Py_XDECREF(data);
        __PYX_ERR(0, 1, __pyx_L1_error)
      }
    }
    Py_XDECREF(data);
    for (Py_ssize_t i = 0; i < 480; i++) {
      if (unlikely(PyObject_Hash(stringtab[i]) == -1)) {
        __PYX_ERR(0, 1, __pyx_L1_error)
      }
    }
    #if CYTHON_IMMORTAL_CONSTANTS
    {
      PyObject **table = stringtab + 445;
      for (Py_ssize_t i=0; i<35; ++i) {
        #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
        #if PY_VERSION_HEX < 0x030E0000
        if (_Py_IsOwnedByCurrentThread(table[i]) && Py_REFCNT(table[i]) == 1)
        #else
        if (PyUnstable_Object_IsUniquelyReferenced(table[i]))
        #endif
        {
          Py_SET_REFCNT(table[i], _Py_IMMORTAL_REFCNT_LOCAL);
        }
        #else
        Py_SET_REFCNT(table[i], _Py_IMMORTAL_INITIAL_REFCNT);
        #endif
      }
    }
    #endif
  }
  {
    PyObject **numbertab = __pyx_mstate->__pyx_number_tab;
    double const c_constants[] = {1.,2.,0.5,24.,60.,1.e6,1440.,1440.0,86400.0};
    for (int i = 0; i < 9; i++) {
      numbertab[i] = PyFloat_FromDouble(c_constants[i]);
      if (unlikely(!numbertab[i])) __PYX_ERR(0, 1, __pyx_L1_error)
    }
  }
  {
    PyObject **numbertab = __pyx_mstate->__pyx_number_tab + 9;
    int8_t const cint_constants_1[] = {0,-1,1,2,-3,4,6,7,10,15,28,29,30,60,100};
    int16_t const cint_constants_2[] = {400,1000,1582,2000,3600};
    int32_t const cint_constants_4[] = {999999L,1000000L,60000000L};
    int64_t const cint_constants_8[] = {3600000000LL,86400000000LL,2592000000000LL,31536000000000LL};
    for (int i = 0; i < 27; i++) {
      numbertab[i] = PyLong_FromLongLong((i < 15 ? cint_constants_1[i - 0] : (i < 20 ? cint_constants_2[i - 15] : (i < 23 ? cint_constants_4[i - 20] : cint_constants_8[i - 23]))));
      if (unlikely(!numbertab[i])) __PYX_ERR(0, 1, __pyx_L1_error)
    }
  }
  #if CYTHON_IMMORTAL_CONSTANTS
  {
    PyObject **table = __pyx_mstate->__pyx_number_tab;
    for (Py_ssize_t i=0; i<36; ++i) {
      #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
      #if PY_VERSION_HEX < 0x030E0000
      if (_Py_IsOwnedByCurrentThread(table[i]) && Py_REFCNT(table[i]) == 1)
      #else
      if (PyUnstable_Object_IsUniquelyReferenced(table[i]))
      #endif
      {
        Py_SET_REFCNT(table[i], _Py_IMMORTAL_REFCNT_LOCAL);
      }
      #else
      Py_SET_REFCNT(table[i], _Py_IMMORTAL_INITIAL_REFCNT);
      #endif
    }
  }
  #endif
  return 0;
  __pyx_L1_error:;
  return -1;
}
/* #### Code section: init_codeobjects ### */
typedef struct {
    unsigned int argcount : 3;
    unsigned int num_posonly_args : 1;
    unsigned int num_kwonly_args : 1;
    unsigned int nlocals : 5;
    unsigned int flags : 10;
    unsigned int first_line : 11;
} __Pyx_PyCode_New_function_description;
/* NewCodeObj.proto */
static PyObject* __Pyx_PyCode_New(
        const __Pyx_PyCode_New_function_description descr,
        PyObject * const *varnames,
        PyObject *filename,
        PyObject *funcname,
        PyObject *line_table,
        PyObject *tuple_dedup_map
);


static int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate) {
  PyObject* tuple_dedup_map = PyDict_New();
  if (unlikely(!tuple_dedup_map)) return -1;
  {
    const __Pyx_PyCode_New_function_description descr = {0, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_GENERATOR), 1282};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_x};
    __pyx_mstate_global->__pyx_codeobj_tab[0] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_genexpr, __pyx_mstate->__pyx_kp_b_iso88591_Q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[0])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 57};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[1] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_dayofwk, __pyx_mstate->__pyx_kp_b_iso88591_A_t81, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[1])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 61};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[2] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_dayofyr, __pyx_mstate->__pyx_kp_b_iso88591_A_t_Rq, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[2])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 64};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[3] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_daysinmonth, __pyx_mstate->__pyx_kp_b_iso88591_A_81D_a_Qd_V1A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[3])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 72};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_timestr, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_sincestring, __pyx_mstate->__pyx_n_u_remainder, __pyx_mstate->__pyx_n_u_e};
    __pyx_mstate_global->__pyx_codeobj_tab[4] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_datesplit, __pyx_mstate->__pyx_kp_b_iso88591_q_Q_j_3a_j_5_d, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[4])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 15, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 86};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_timestr, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_isostring, __pyx_mstate->__pyx_n_u_year, __pyx_mstate->__pyx_n_u_month, __pyx_mstate->__pyx_n_u_day, __pyx_mstate->__pyx_n_u_hour, __pyx_mstate->__pyx_n_u_minute, __pyx_mstate->__pyx_n_u_second, __pyx_mstate->__pyx_n_u_microsecond, __pyx_mstate->__pyx_n_u_utc_offset, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_basedate};
    __pyx_mstate_global->__pyx_codeobj_tab[5] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_dateparse, __pyx_mstate->__pyx_kp_b_iso88591_xvQ_S_1A_M_1A_vV3l_hb_4vS_SWW_d, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[5])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 128};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_date, __pyx_mstate->__pyx_n_u_calendar};
    __pyx_mstate_global->__pyx_codeobj_tab[6] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_can_use_python_datetime, __pyx_mstate->__pyx_kp_b_iso88591_Yc_t4vS_DPVVYYbbc_t_4t6_IURVV_c, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[6])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {5, 0, 0, 25, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 136};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_dates, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_longdouble, __pyx_mstate->__pyx_n_u_isscalar, __pyx_mstate->__pyx_n_u_ismasked, __pyx_mstate->__pyx_n_u_mask, __pyx_mstate->__pyx_n_u_shape, __pyx_mstate->__pyx_n_u_all_python_datetimes, __pyx_mstate->__pyx_n_u_date, __pyx_mstate->__pyx_n_u_d0, __pyx_mstate->__pyx_n_u_basedate, __pyx_mstate->__pyx_n_u_unit, __pyx_mstate->__pyx_n_u_isostring, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_unit_timedelta, __pyx_mstate->__pyx_n_u_can_use_python_basedatetime, __pyx_mstate->__pyx_n_u_use_python_datetime, __pyx_mstate->__pyx_n_u_times, __pyx_mstate->__pyx_n_u_n, __pyx_mstate->__pyx_n_u_td, __pyx_mstate->__pyx_n_u_quotient, __pyx_mstate->__pyx_n_u_mtd, __pyx_mstate->__pyx_n_u_munit};
    __pyx_mstate_global->__pyx_codeobj_tab[7] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_date2num, __pyx_mstate->__pyx_kp_b_iso88591_ap_q_Qa_4q_2V1CvQ_q_q_r_E_Rs_AQ, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[7])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 3, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 326};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_times, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_calendar};
    __pyx_mstate_global->__pyx_codeobj_tab[8] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_num2pydate, __pyx_mstate->__pyx_kp_b_iso88591_81F_C6Iccd, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[8])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {4, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 386};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_dt, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_use_python_datetime, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_date_type};
    __pyx_mstate_global->__pyx_codeobj_tab[9] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_to_calendar_specific_datetime, __pyx_mstate->__pyx_kp_b_iso88591_DA_q_A_Jaq_y_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[9])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 3, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 412};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_num, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_int_num};
    __pyx_mstate_global->__pyx_codeobj_tab[10] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_cast_to_int, __pyx_mstate->__pyx_kp_b_iso88591_Q_s_c_q_2T_E_k_s_D_8STTXXcckkl, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[10])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 439};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_num};
    __pyx_mstate_global->__pyx_codeobj_tab[11] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_upcast_times, __pyx_mstate->__pyx_kp_b_iso88591_s_c_s_A_s_A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[11])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 449};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_num, __pyx_mstate->__pyx_n_u_factor, __pyx_mstate->__pyx_n_u_minimum, __pyx_mstate->__pyx_n_u_maximum};
    __pyx_mstate_global->__pyx_codeobj_tab[12] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_scale_times, __pyx_mstate->__pyx_kp_b_iso88591_s_c_wb_3fCq_1_D_U_Rq_D_U_Rq_82, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[12])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 3, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 468};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_time_in_microseconds, __pyx_mstate->__pyx_n_u_basedate, __pyx_mstate->__pyx_n_u_delta};
    __pyx_mstate_global->__pyx_codeobj_tab[13] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_decode_date_from_scalar, __pyx_mstate->__pyx_kp_b_iso88591_q_y_j, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[13])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 9, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 477};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_times_in_microseconds, __pyx_mstate->__pyx_n_u_basedate, __pyx_mstate->__pyx_n_u_original_shape, __pyx_mstate->__pyx_n_u_sort_indices, __pyx_mstate->__pyx_n_u_unsort_indices, __pyx_mstate->__pyx_n_u_deltas, __pyx_mstate->__pyx_n_u_differential_deltas, __pyx_mstate->__pyx_n_u_dates, __pyx_mstate->__pyx_n_u_i};
    __pyx_mstate_global->__pyx_codeobj_tab[14] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_decode_dates_from_array, __pyx_mstate->__pyx_kp_b_iso88591_1_q_2XQa_Rxq_1_E_BfA_Qe9BfARwaq, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[14])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {6, 0, 0, 16, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 513};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_times, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_only_use_cftime_datetimes, __pyx_mstate->__pyx_n_u_only_use_python_datetimes, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_basedate, __pyx_mstate->__pyx_n_u_can_use_python_datetime_2, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_unit, __pyx_mstate->__pyx_n_u_ignore, __pyx_mstate->__pyx_n_u_use_python_datetime, __pyx_mstate->__pyx_n_u_factor, __pyx_mstate->__pyx_n_u_scaled_times, __pyx_mstate->__pyx_n_u_original_mask, __pyx_mstate->__pyx_n_u_dates};
    __pyx_mstate_global->__pyx_codeobj_tab[15] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_num2date, __pyx_mstate->__pyx_kp_b_iso88591_z_xvQ_S_1A_z_4AYa_t_T_4q_AQ_Qa, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[15])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {5, 0, 0, 10, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 641};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_dates, __pyx_mstate->__pyx_n_u_nctime, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_select, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_dates_test, __pyx_mstate->__pyx_n_u_d0, __pyx_mstate->__pyx_n_u_basedate, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_times};
    __pyx_mstate_global->__pyx_codeobj_tab[16] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_date2index_2, __pyx_mstate->__pyx_kp_b_iso88591_QT_a_nAQ_aq_S_9Cq_5_z_Q_Ba_A_C4, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[16])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 758};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_datestring};
    __pyx_mstate_global->__pyx_codeobj_tab[17] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_parse_date, __pyx_mstate->__pyx_kp_b_iso88591_t_Ql_t4z_a_j_1_1_V1JfA_t1_j_A_Q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[17])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {5, 0, 0, 6, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 855};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_dates, __pyx_mstate->__pyx_n_u_nctime, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_select, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_times};
    __pyx_mstate_global->__pyx_codeobj_tab[18] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_date2index, __pyx_mstate->__pyx_kp_b_iso88591_aN_a_nAQ_HAV6_QgXYj_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[18])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {4, 0, 0, 20, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 902};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_times, __pyx_mstate->__pyx_n_u_nctime, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_select, __pyx_mstate->__pyx_n_u_index, __pyx_mstate->__pyx_n_u_num, __pyx_mstate->__pyx_n_u_N, __pyx_mstate->__pyx_n_u_t0, __pyx_mstate->__pyx_n_u_t1, __pyx_mstate->__pyx_n_u_dt, __pyx_mstate->__pyx_n_u_bisect, __pyx_mstate->__pyx_n_u_before, __pyx_mstate->__pyx_n_u_after, __pyx_mstate->__pyx_n_u_ncnum, __pyx_mstate->__pyx_n_u_mismatch, __pyx_mstate->__pyx_n_u_nearest_to_left, __pyx_mstate->__pyx_n_u_n, __pyx_mstate->__pyx_n_u_n, __pyx_mstate->__pyx_n_u_i, __pyx_mstate->__pyx_n_u_i};
    __pyx_mstate_global->__pyx_codeobj_tab[19] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_time2index, __pyx_mstate->__pyx_kp_b_iso88591_Q0_a_nAQ_y_1_7_8_q_wc_Jawhiz_wc, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[19])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1029};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_dt};
    __pyx_mstate_global->__pyx_codeobj_tab[20] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_to_tuple, __pyx_mstate->__pyx_kp_b_iso88591_BgRxr_r_ir, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[20])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 3, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1049};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_date_type, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_kwargs};
    __pyx_mstate_global->__pyx_codeobj_tab[21] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_create_datetime, __pyx_mstate->__pyx_kp_b_iso88591_wir, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[21])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1245};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_format};
    __pyx_mstate_global->__pyx_codeobj_tab[22] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_strftime, __pyx_mstate->__pyx_kp_b_iso88591_a_7_Q_T_y_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[22])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {4, 0, 0, 19, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1255};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_datestring, __pyx_mstate->__pyx_n_u_format, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_fd, __pyx_mstate->__pyx_n_u_special_fd, __pyx_mstate->__pyx_n_u_pydatetime, __pyx_mstate->__pyx_n_u_compatible_date, __pyx_mstate->__pyx_n_u_msg, __pyx_mstate->__pyx_n_u_year, __pyx_mstate->__pyx_n_u_month, __pyx_mstate->__pyx_n_u_day, __pyx_mstate->__pyx_n_u_hour, __pyx_mstate->__pyx_n_u_minute, __pyx_mstate->__pyx_n_u_second, __pyx_mstate->__pyx_n_u_microsecond, __pyx_mstate->__pyx_n_u_d, __pyx_mstate->__pyx_n_u_genexpr, __pyx_mstate->__pyx_n_u_genexpr};
    __pyx_mstate_global->__pyx_codeobj_tab[23] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_strptime, __pyx_mstate->__pyx_kp_b_iso88591_A_H_Qaq_4uF_c_Qe5_U_uE_a_a_wa_9F, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[23])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1297};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_format};
    __pyx_mstate_global->__pyx_codeobj_tab[24] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_format_2, __pyx_mstate->__pyx_kp_b_iso88591_A_7_Q_Q_t9AQ, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[24])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARKEYWORDS), 1305};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_kwargs, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_name_2, __pyx_mstate->__pyx_n_u_value};
    __pyx_mstate_global->__pyx_codeobj_tab[25] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_replace, __pyx_mstate->__pyx_kp_b_iso88591_A_A_Q_t1_A_a_a_t1_Q_D_S_s_Cq_AQ, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[25])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1336};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[26] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_timetuple, __pyx_mstate->__pyx_kp_b_iso88591_A_t_r_WD_F_a_IT_j_Kq, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[26])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1347};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[27] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_to_real_datetime, __pyx_mstate->__pyx_kp_b_iso88591_A_AT_HD_IT, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[27])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 7, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1369};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_sep, __pyx_mstate->__pyx_n_u_timespec, __pyx_mstate->__pyx_n_u_form0, __pyx_mstate->__pyx_n_u_form, __pyx_mstate->__pyx_n_u_second, __pyx_mstate->__pyx_n_u_millisecs};
    __pyx_mstate_global->__pyx_codeobj_tab[28] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_isoformat, __pyx_mstate->__pyx_kp_b_iso88591_N_4vRq_A_A_9Cq_1_4wat7_hd_c_6_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[28])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1416};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self};
    __pyx_mstate_global->__pyx_codeobj_tab[29] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_to_tuple, __pyx_mstate->__pyx_kp_b_iso88591_A_G4xt6_WD_IT, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[29])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1457};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_kwargs, __pyx_mstate->__pyx_n_u_date_type};
    __pyx_mstate_global->__pyx_codeobj_tab[30] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_reduce, __pyx_mstate->__pyx_kp_b_iso88591_A_it_Q_D_fA, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[30])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1466};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_jday, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_units_2, __pyx_mstate->__pyx_n_u_jd};
    __pyx_mstate_global->__pyx_codeobj_tab[31] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_fromordinal, __pyx_mstate->__pyx_kp_b_iso88591_A_1_86_A_q_9D_9A_q_q_q_c_q_A__A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[31])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1496};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_fractional, __pyx_mstate->__pyx_n_u_ijd, __pyx_mstate->__pyx_n_u_fracday};
    __pyx_mstate_global->__pyx_codeobj_tab[32] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_toordinal, __pyx_mstate->__pyx_kp_b_iso88591_1D_t84vT_34q_1_d_F_4r_a_BfAWBm1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[32])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1525};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero, __pyx_mstate->__pyx_n_u_dt};
    __pyx_mstate_global->__pyx_codeobj_tab[33] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_change_calendar, __pyx_mstate->__pyx_kp_b_iso88591_4A_9C_Ct_S_AQ_t_q_Ja, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[33])) goto bad;
  }
  {
    const __Pyx_PyCode_New_function_description descr = {3, 0, 0, 3, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1921};
    PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_year, __pyx_mstate->__pyx_n_u_calendar, __pyx_mstate->__pyx_n_u_has_year_zero};
    __pyx_mstate_global->__pyx_codeobj_tab[34] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_src_cftime__cftime_pyx, __pyx_mstate->__pyx_n_u_is_leap_year, __pyx_mstate->__pyx_kp_b_iso88591_81F_2, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[34])) goto bad;
  }
  Py_DECREF(tuple_dedup_map);
  return 0;
  bad:
  Py_DECREF(tuple_dedup_map);
  return -1;
}
/* #### Code section: init_globals ### */

static int __Pyx_InitGlobals(void) {
  /* PythonCompatibility.init */
  if (likely(__Pyx_init_co_variables() == 0)); else
  
  if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error)

  /* CommonTypesMetaclass.init */
  if (likely(__pyx_CommonTypesMetaclass_init(__pyx_m) == 0)); else
  
  if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error)

  /* CachedMethodType.init */
  #if CYTHON_COMPILING_IN_LIMITED_API
  {
      PyObject *typesModule=NULL;
      typesModule = PyImport_ImportModule("types");
      if (typesModule) {
          __pyx_mstate_global->__Pyx_CachedMethodType = PyObject_GetAttrString(typesModule, "MethodType");
          Py_DECREF(typesModule);
      }
  } // error handling follows
  #endif
  
  if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error)

  /* CythonFunctionShared.init */
  if (likely(__pyx_CyFunction_init(__pyx_m) == 0)); else
  
  if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error)

  /* Generator.init */
  if (likely(__pyx_Generator_init(__pyx_m) == 0)); else
  
  if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error)

  return 0;
  __pyx_L1_error:;
  return -1;
}
/* #### Code section: cleanup_globals ### */
/* #### Code section: cleanup_module ### */
/* #### Code section: main_method ### */
/* #### Code section: utility_code_pragmas ### */
#ifdef _MSC_VER
#pragma warning( push )
/* Warning 4127: conditional expression is constant
 * Cython uses constant conditional expressions to allow in inline functions to be optimized at
 * compile-time, so this warning is not useful
 */
#pragma warning( disable : 4127 )
#endif



/* #### Code section: utility_code_def ### */

/* --- Runtime support code --- */
/* Refnanny */
#if CYTHON_REFNANNY
static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) {
    PyObject *m = NULL, *p = NULL;
    void *r = NULL;
    m = PyImport_ImportModule(modname);
    if (!m) goto end;
    p = PyObject_GetAttrString(m, "RefNannyAPI");
    if (!p) goto end;
    r = PyLong_AsVoidPtr(p);
end:
    Py_XDECREF(p);
    Py_XDECREF(m);
    return (__Pyx_RefNannyAPIStruct *)r;
}
#endif

/* PyErrExceptionMatches (used by PyObjectGetAttrStrNoError) */
#if CYTHON_FAST_THREAD_STATE
static int __Pyx_PyErr_ExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) {
    Py_ssize_t i, n;
    n = PyTuple_GET_SIZE(tuple);
    for (i=0; i<n; i++) {
        if (exc_type == PyTuple_GET_ITEM(tuple, i)) return 1;
    }
    for (i=0; i<n; i++) {
        if (__Pyx_PyErr_GivenExceptionMatches(exc_type, PyTuple_GET_ITEM(tuple, i))) return 1;
    }
    return 0;
}
static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err) {
    int result;
    PyObject *exc_type;
#if PY_VERSION_HEX >= 0x030C00A6
    PyObject *current_exception = tstate->current_exception;
    if (unlikely(!current_exception)) return 0;
    exc_type = (PyObject*) Py_TYPE(current_exception);
    if (exc_type == err) return 1;
#else
    exc_type = tstate->curexc_type;
    if (exc_type == err) return 1;
    if (unlikely(!exc_type)) return 0;
#endif
    #if CYTHON_AVOID_BORROWED_REFS
    Py_INCREF(exc_type);
    #endif
    if (unlikely(PyTuple_Check(err))) {
        result = __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err);
    } else {
        result = __Pyx_PyErr_GivenExceptionMatches(exc_type, err);
    }
    #if CYTHON_AVOID_BORROWED_REFS
    Py_DECREF(exc_type);
    #endif
    return result;
}
#endif

/* PyErrFetchRestore (used by PyObjectGetAttrStrNoError) */
#if CYTHON_FAST_THREAD_STATE
static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) {
#if PY_VERSION_HEX >= 0x030C00A6
    PyObject *tmp_value;
    assert(type == NULL || (value != NULL && type == (PyObject*) Py_TYPE(value)));
    if (value) {
        #if CYTHON_COMPILING_IN_CPYTHON
        if (unlikely(((PyBaseExceptionObject*) value)->traceback != tb))
        #endif
            PyException_SetTraceback(value, tb);
    }
    tmp_value = tstate->current_exception;
    tstate->current_exception = value;
    Py_XDECREF(tmp_value);
    Py_XDECREF(type);
    Py_XDECREF(tb);
#else
    PyObject *tmp_type, *tmp_value, *tmp_tb;
    tmp_type = tstate->curexc_type;
    tmp_value = tstate->curexc_value;
    tmp_tb = tstate->curexc_traceback;
    tstate->curexc_type = type;
    tstate->curexc_value = value;
    tstate->curexc_traceback = tb;
    Py_XDECREF(tmp_type);
    Py_XDECREF(tmp_value);
    Py_XDECREF(tmp_tb);
#endif
}
static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) {
#if PY_VERSION_HEX >= 0x030C00A6
    PyObject* exc_value;
    exc_value = tstate->current_exception;
    tstate->current_exception = 0;
    *value = exc_value;
    *type = NULL;
    *tb = NULL;
    if (exc_value) {
        *type = (PyObject*) Py_TYPE(exc_value);
        Py_INCREF(*type);
        #if CYTHON_COMPILING_IN_CPYTHON
        *tb = ((PyBaseExceptionObject*) exc_value)->traceback;
        Py_XINCREF(*tb);
        #else
        *tb = PyException_GetTraceback(exc_value);
        #endif
    }
#else
    *type = tstate->curexc_type;
    *value = tstate->curexc_value;
    *tb = tstate->curexc_traceback;
    tstate->curexc_type = 0;
    tstate->curexc_value = 0;
    tstate->curexc_traceback = 0;
#endif
}
#endif

/* PyObjectGetAttrStr (used by PyObjectGetAttrStrNoError) */
#if CYTHON_USE_TYPE_SLOTS
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name) {
    PyTypeObject* tp = Py_TYPE(obj);
    if (likely(tp->tp_getattro))
        return tp->tp_getattro(obj, attr_name);
    return PyObject_GetAttr(obj, attr_name);
}
#endif

/* PyObjectGetAttrStrNoError (used by GetBuiltinName) */
#if __PYX_LIMITED_VERSION_HEX < 0x030d0000
static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError)))
        __Pyx_PyErr_Clear();
}
#endif
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) {
    PyObject *result;
#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
    (void) PyObject_GetOptionalAttr(obj, attr_name, &result);
    return result;
#else
#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS
    PyTypeObject* tp = Py_TYPE(obj);
    if (likely(tp->tp_getattro == PyObject_GenericGetAttr)) {
        return _PyObject_GenericGetAttrWithDict(obj, attr_name, NULL, 1);
    }
#endif
    result = __Pyx_PyObject_GetAttrStr(obj, attr_name);
    if (unlikely(!result)) {
        __Pyx_PyObject_GetAttrStr_ClearAttributeError();
    }
    return result;
#endif
}

/* GetBuiltinName */
static PyObject *__Pyx_GetBuiltinName(PyObject *name) {
    PyObject* result = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_b, name);
    if (unlikely(!result) && !PyErr_Occurred()) {
        PyErr_Format(PyExc_NameError,
            "name '%U' is not defined", name);
    }
    return result;
}

/* GetTopmostException (used by SaveResetException) */
#if CYTHON_USE_EXC_INFO_STACK && CYTHON_FAST_THREAD_STATE
static _PyErr_StackItem *
__Pyx_PyErr_GetTopmostException(PyThreadState *tstate)
{
    _PyErr_StackItem *exc_info = tstate->exc_info;
    while ((exc_info->exc_value == NULL || exc_info->exc_value == Py_None) &&
           exc_info->previous_item != NULL)
    {
        exc_info = exc_info->previous_item;
    }
    return exc_info;
}
#endif

/* SaveResetException */
#if CYTHON_FAST_THREAD_STATE
static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) {
  #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4
    _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate);
    PyObject *exc_value = exc_info->exc_value;
    if (exc_value == NULL || exc_value == Py_None) {
        *value = NULL;
        *type = NULL;
        *tb = NULL;
    } else {
        *value = exc_value;
        Py_INCREF(*value);
        *type = (PyObject*) Py_TYPE(exc_value);
        Py_INCREF(*type);
        *tb = PyException_GetTraceback(exc_value);
    }
  #elif CYTHON_USE_EXC_INFO_STACK
    _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate);
    *type = exc_info->exc_type;
    *value = exc_info->exc_value;
    *tb = exc_info->exc_traceback;
    Py_XINCREF(*type);
    Py_XINCREF(*value);
    Py_XINCREF(*tb);
  #else
    *type = tstate->exc_type;
    *value = tstate->exc_value;
    *tb = tstate->exc_traceback;
    Py_XINCREF(*type);
    Py_XINCREF(*value);
    Py_XINCREF(*tb);
  #endif
}
static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) {
  #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4
    _PyErr_StackItem *exc_info = tstate->exc_info;
    PyObject *tmp_value = exc_info->exc_value;
    exc_info->exc_value = value;
    Py_XDECREF(tmp_value);
    Py_XDECREF(type);
    Py_XDECREF(tb);
  #else
    PyObject *tmp_type, *tmp_value, *tmp_tb;
    #if CYTHON_USE_EXC_INFO_STACK
    _PyErr_StackItem *exc_info = tstate->exc_info;
    tmp_type = exc_info->exc_type;
    tmp_value = exc_info->exc_value;
    tmp_tb = exc_info->exc_traceback;
    exc_info->exc_type = type;
    exc_info->exc_value = value;
    exc_info->exc_traceback = tb;
    #else
    tmp_type = tstate->exc_type;
    tmp_value = tstate->exc_value;
    tmp_tb = tstate->exc_traceback;
    tstate->exc_type = type;
    tstate->exc_value = value;
    tstate->exc_traceback = tb;
    #endif
    Py_XDECREF(tmp_type);
    Py_XDECREF(tmp_value);
    Py_XDECREF(tmp_tb);
  #endif
}
#endif

/* GetException */
#if CYTHON_FAST_THREAD_STATE
static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb)
#else
static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb)
#endif
{
    PyObject *local_type = NULL, *local_value, *local_tb = NULL;
#if CYTHON_FAST_THREAD_STATE
    PyObject *tmp_type, *tmp_value, *tmp_tb;
  #if PY_VERSION_HEX >= 0x030C0000
    local_value = tstate->current_exception;
    tstate->current_exception = 0;
  #else
    local_type = tstate->curexc_type;
    local_value = tstate->curexc_value;
    local_tb = tstate->curexc_traceback;
    tstate->curexc_type = 0;
    tstate->curexc_value = 0;
    tstate->curexc_traceback = 0;
  #endif
#elif __PYX_LIMITED_VERSION_HEX > 0x030C0000
    local_value = PyErr_GetRaisedException();
#else
    PyErr_Fetch(&local_type, &local_value, &local_tb);
#endif
#if __PYX_LIMITED_VERSION_HEX > 0x030C0000
    if (likely(local_value)) {
        local_type = (PyObject*) Py_TYPE(local_value);
        Py_INCREF(local_type);
        local_tb = PyException_GetTraceback(local_value);
    }
#else
    PyErr_NormalizeException(&local_type, &local_value, &local_tb);
#if CYTHON_FAST_THREAD_STATE
    if (unlikely(tstate->curexc_type))
#else
    if (unlikely(PyErr_Occurred()))
#endif
        goto bad;
    if (local_tb) {
        if (unlikely(PyException_SetTraceback(local_value, local_tb) < 0))
            goto bad;
    }
#endif // __PYX_LIMITED_VERSION_HEX > 0x030C0000
    Py_XINCREF(local_tb);
    Py_XINCREF(local_type);
    Py_XINCREF(local_value);
    *type = local_type;
    *value = local_value;
    *tb = local_tb;
#if CYTHON_FAST_THREAD_STATE
    #if CYTHON_USE_EXC_INFO_STACK
    {
        _PyErr_StackItem *exc_info = tstate->exc_info;
      #if PY_VERSION_HEX >= 0x030B00a4
        tmp_value = exc_info->exc_value;
        exc_info->exc_value = local_value;
        tmp_type = NULL;
        tmp_tb = NULL;
        Py_XDECREF(local_type);
        Py_XDECREF(local_tb);
      #else
        tmp_type = exc_info->exc_type;
        tmp_value = exc_info->exc_value;
        tmp_tb = exc_info->exc_traceback;
        exc_info->exc_type = local_type;
        exc_info->exc_value = local_value;
        exc_info->exc_traceback = local_tb;
      #endif
    }
    #else
    tmp_type = tstate->exc_type;
    tmp_value = tstate->exc_value;
    tmp_tb = tstate->exc_traceback;
    tstate->exc_type = local_type;
    tstate->exc_value = local_value;
    tstate->exc_traceback = local_tb;
    #endif
    Py_XDECREF(tmp_type);
    Py_XDECREF(tmp_value);
    Py_XDECREF(tmp_tb);
#elif __PYX_LIMITED_VERSION_HEX >= 0x030b0000
    PyErr_SetHandledException(local_value);
    Py_XDECREF(local_value);
    Py_XDECREF(local_type);
    Py_XDECREF(local_tb);
#else
    PyErr_SetExcInfo(local_type, local_value, local_tb);
#endif
    return 0;
#if __PYX_LIMITED_VERSION_HEX <= 0x030C0000
bad:
    *type = 0;
    *value = 0;
    *tb = 0;
    Py_XDECREF(local_type);
    Py_XDECREF(local_value);
    Py_XDECREF(local_tb);
    return -1;
#endif
}

/* PyObjectCall (used by PyObjectFastCall) */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) {
    PyObject *result;
    ternaryfunc call = Py_TYPE(func)->tp_call;
    if (unlikely(!call))
        return PyObject_Call(func, arg, kw);
    if (unlikely(Py_EnterRecursiveCall(" while calling a Python object")))
        return NULL;
    result = (*call)(func, arg, kw);
    Py_LeaveRecursiveCall();
    if (unlikely(!result) && unlikely(!PyErr_Occurred())) {
        PyErr_SetString(
            PyExc_SystemError,
            "NULL result without error in PyObject_Call");
    }
    return result;
}
#endif

/* PyObjectCallMethO (used by PyObjectFastCall) */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) {
    PyObject *self, *result;
    PyCFunction cfunc;
    cfunc = __Pyx_CyOrPyCFunction_GET_FUNCTION(func);
    self = __Pyx_CyOrPyCFunction_GET_SELF(func);
    if (unlikely(Py_EnterRecursiveCall(" while calling a Python object")))
        return NULL;
    result = cfunc(self, arg);
    Py_LeaveRecursiveCall();
    if (unlikely(!result) && unlikely(!PyErr_Occurred())) {
        PyErr_SetString(
            PyExc_SystemError,
            "NULL result without error in PyObject_Call");
    }
    return result;
}
#endif

/* PyObjectFastCall */
#if PY_VERSION_HEX < 0x03090000 || CYTHON_COMPILING_IN_LIMITED_API
static PyObject* __Pyx_PyObject_FastCall_fallback(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs) {
    PyObject *argstuple;
    PyObject *result = 0;
    size_t i;
    argstuple = PyTuple_New((Py_ssize_t)nargs);
    if (unlikely(!argstuple)) return NULL;
    for (i = 0; i < nargs; i++) {
        Py_INCREF(args[i]);
        if (__Pyx_PyTuple_SET_ITEM(argstuple, (Py_ssize_t)i, args[i]) != (0)) goto bad;
    }
    result = __Pyx_PyObject_Call(func, argstuple, kwargs);
  bad:
    Py_DECREF(argstuple);
    return result;
}
#endif
#if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API
  #if PY_VERSION_HEX < 0x03090000
    #define __Pyx_PyVectorcall_Function(callable) _PyVectorcall_Function(callable)
  #elif CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE vectorcallfunc __Pyx_PyVectorcall_Function(PyObject *callable) {
    PyTypeObject *tp = Py_TYPE(callable);
    #if defined(__Pyx_CyFunction_USED)
    if (__Pyx_CyFunction_CheckExact(callable)) {
        return __Pyx_CyFunction_func_vectorcall(callable);
    }
    #endif
    if (!PyType_HasFeature(tp, Py_TPFLAGS_HAVE_VECTORCALL)) {
        return NULL;
    }
    assert(PyCallable_Check(callable));
    Py_ssize_t offset = tp->tp_vectorcall_offset;
    assert(offset > 0);
    vectorcallfunc ptr;
    memcpy(&ptr, (char *) callable + offset, sizeof(ptr));
    return ptr;
}
  #else
    #define __Pyx_PyVectorcall_Function(callable) PyVectorcall_Function(callable)
  #endif
#endif
static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject *const *args, size_t _nargs, PyObject *kwargs) {
    Py_ssize_t nargs = __Pyx_PyVectorcall_NARGS(_nargs);
#if CYTHON_COMPILING_IN_CPYTHON
    if (nargs == 0 && kwargs == NULL) {
        if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_NOARGS))
            return __Pyx_PyObject_CallMethO(func, NULL);
    }
    else if (nargs == 1 && kwargs == NULL) {
        if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_O))
            return __Pyx_PyObject_CallMethO(func, args[0]);
    }
#endif
    if (kwargs == NULL) {
        #if CYTHON_VECTORCALL
          #if CYTHON_COMPILING_IN_LIMITED_API
            return PyObject_Vectorcall(func, args, _nargs, NULL);
          #else
            vectorcallfunc f = __Pyx_PyVectorcall_Function(func);
            if (f) {
                return f(func, args, _nargs, NULL);
            }
          #endif
        #endif
    }
    if (nargs == 0) {
        return __Pyx_PyObject_Call(func, __pyx_mstate_global->__pyx_empty_tuple, kwargs);
    }
    #if PY_VERSION_HEX >= 0x03090000 && !CYTHON_COMPILING_IN_LIMITED_API
    return PyObject_VectorcallDict(func, args, (size_t)nargs, kwargs);
    #else
    return __Pyx_PyObject_FastCall_fallback(func, args, (size_t)nargs, kwargs);
    #endif
}

/* RaiseException */
static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) {
    PyObject* owned_instance = NULL;
    if (tb == Py_None) {
        tb = 0;
    } else if (tb && !PyTraceBack_Check(tb)) {
        PyErr_SetString(PyExc_TypeError,
            "raise: arg 3 must be a traceback or None");
        goto bad;
    }
    if (value == Py_None)
        value = 0;
    if (PyExceptionInstance_Check(type)) {
        if (value) {
            PyErr_SetString(PyExc_TypeError,
                "instance exception may not have a separate value");
            goto bad;
        }
        value = type;
        type = (PyObject*) Py_TYPE(value);
    } else if (PyExceptionClass_Check(type)) {
        PyObject *instance_class = NULL;
        if (value && PyExceptionInstance_Check(value)) {
            instance_class = (PyObject*) Py_TYPE(value);
            if (instance_class != type) {
                int is_subclass = PyObject_IsSubclass(instance_class, type);
                if (!is_subclass) {
                    instance_class = NULL;
                } else if (unlikely(is_subclass == -1)) {
                    goto bad;
                } else {
                    type = instance_class;
                }
            }
        }
        if (!instance_class) {
            PyObject *args;
            if (!value)
                args = PyTuple_New(0);
            else if (PyTuple_Check(value)) {
                Py_INCREF(value);
                args = value;
            } else
                args = PyTuple_Pack(1, value);
            if (!args)
                goto bad;
            owned_instance = PyObject_Call(type, args, NULL);
            Py_DECREF(args);
            if (!owned_instance)
                goto bad;
            value = owned_instance;
            if (!PyExceptionInstance_Check(value)) {
                PyErr_Format(PyExc_TypeError,
                             "calling %R should have returned an instance of "
                             "BaseException, not %R",
                             type, Py_TYPE(value));
                goto bad;
            }
        }
    } else {
        PyErr_SetString(PyExc_TypeError,
            "raise: exception class must be a subclass of BaseException");
        goto bad;
    }
    if (cause) {
        PyObject *fixed_cause;
        if (cause == Py_None) {
            fixed_cause = NULL;
        } else if (PyExceptionClass_Check(cause)) {
            fixed_cause = PyObject_CallObject(cause, NULL);
            if (fixed_cause == NULL)
                goto bad;
        } else if (PyExceptionInstance_Check(cause)) {
            fixed_cause = cause;
            Py_INCREF(fixed_cause);
        } else {
            PyErr_SetString(PyExc_TypeError,
                            "exception causes must derive from "
                            "BaseException");
            goto bad;
        }
        PyException_SetCause(value, fixed_cause);
    }
    PyErr_SetObject(type, value);
    if (tb) {
#if PY_VERSION_HEX >= 0x030C00A6
        PyException_SetTraceback(value, tb);
#elif CYTHON_FAST_THREAD_STATE
        PyThreadState *tstate = __Pyx_PyThreadState_Current;
        PyObject* tmp_tb = tstate->curexc_traceback;
        if (tb != tmp_tb) {
            Py_INCREF(tb);
            tstate->curexc_traceback = tb;
            Py_XDECREF(tmp_tb);
        }
#else
        PyObject *tmp_type, *tmp_value, *tmp_tb;
        PyErr_Fetch(&tmp_type, &tmp_value, &tmp_tb);
        Py_INCREF(tb);
        PyErr_Restore(tmp_type, tmp_value, tb);
        Py_XDECREF(tmp_tb);
#endif
    }
bad:
    Py_XDECREF(owned_instance);
    return;
}

/* TupleAndListFromArray (used by fastcall) */
#if !CYTHON_COMPILING_IN_CPYTHON && CYTHON_METH_FASTCALL
static CYTHON_INLINE PyObject *
__Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n)
{
    PyObject *res;
    Py_ssize_t i;
    if (n <= 0) {
        return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple);
    }
    res = PyTuple_New(n);
    if (unlikely(res == NULL)) return NULL;
    for (i = 0; i < n; i++) {
        if (unlikely(__Pyx_PyTuple_SET_ITEM(res, i, src[i]) < (0))) {
            Py_DECREF(res);
            return NULL;
        }
        Py_INCREF(src[i]);
    }
    return res;
}
#elif CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE void __Pyx_copy_object_array(PyObject *const *CYTHON_RESTRICT src, PyObject** CYTHON_RESTRICT dest, Py_ssize_t length) {
    PyObject *v;
    Py_ssize_t i;
    for (i = 0; i < length; i++) {
        v = dest[i] = src[i];
        Py_INCREF(v);
    }
}
static CYTHON_INLINE PyObject *
__Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n)
{
    PyObject *res;
    if (n <= 0) {
        return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple);
    }
    res = PyTuple_New(n);
    if (unlikely(res == NULL)) return NULL;
    __Pyx_copy_object_array(src, ((PyTupleObject*)res)->ob_item, n);
    return res;
}
static CYTHON_INLINE PyObject *
__Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n)
{
    PyObject *res;
    if (n <= 0) {
        return PyList_New(0);
    }
    res = PyList_New(n);
    if (unlikely(res == NULL)) return NULL;
    __Pyx_copy_object_array(src, ((PyListObject*)res)->ob_item, n);
    return res;
}
#endif

/* BytesEquals (used by UnicodeEquals) */
static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals) {
#if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL ||\
        !(CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS)
    return PyObject_RichCompareBool(s1, s2, equals);
#else
    if (s1 == s2) {
        return (equals == Py_EQ);
    } else if (PyBytes_CheckExact(s1) & PyBytes_CheckExact(s2)) {
        const char *ps1, *ps2;
        Py_ssize_t length = PyBytes_GET_SIZE(s1);
        if (length != PyBytes_GET_SIZE(s2))
            return (equals == Py_NE);
        ps1 = PyBytes_AS_STRING(s1);
        ps2 = PyBytes_AS_STRING(s2);
        if (ps1[0] != ps2[0]) {
            return (equals == Py_NE);
        } else if (length == 1) {
            return (equals == Py_EQ);
        } else {
            int result;
#if CYTHON_USE_UNICODE_INTERNALS && (PY_VERSION_HEX < 0x030B0000)
            Py_hash_t hash1, hash2;
            hash1 = ((PyBytesObject*)s1)->ob_shash;
            hash2 = ((PyBytesObject*)s2)->ob_shash;
            if (hash1 != hash2 && hash1 != -1 && hash2 != -1) {
                return (equals == Py_NE);
            }
#endif
            result = memcmp(ps1, ps2, (size_t)length);
            return (equals == Py_EQ) ? (result == 0) : (result != 0);
        }
    } else if ((s1 == Py_None) & PyBytes_CheckExact(s2)) {
        return (equals == Py_NE);
    } else if ((s2 == Py_None) & PyBytes_CheckExact(s1)) {
        return (equals == Py_NE);
    } else {
        int result;
        PyObject* py_result = PyObject_RichCompare(s1, s2, equals);
        if (!py_result)
            return -1;
        result = __Pyx_PyObject_IsTrue(py_result);
        Py_DECREF(py_result);
        return result;
    }
#endif
}

/* UnicodeEquals (used by fastcall) */
static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals) {
#if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL
    return PyObject_RichCompareBool(s1, s2, equals);
#else
    int s1_is_unicode, s2_is_unicode;
    if (s1 == s2) {
        goto return_eq;
    }
    s1_is_unicode = PyUnicode_CheckExact(s1);
    s2_is_unicode = PyUnicode_CheckExact(s2);
    if (s1_is_unicode & s2_is_unicode) {
        Py_ssize_t length, length2;
        int kind;
        void *data1, *data2;
        #if !CYTHON_COMPILING_IN_LIMITED_API
        if (unlikely(__Pyx_PyUnicode_READY(s1) < 0) || unlikely(__Pyx_PyUnicode_READY(s2) < 0))
            return -1;
        #endif
        length = __Pyx_PyUnicode_GET_LENGTH(s1);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(length < 0)) return -1;
        #endif
        length2 = __Pyx_PyUnicode_GET_LENGTH(s2);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(length2 < 0)) return -1;
        #endif
        if (length != length2) {
            goto return_ne;
        }
#if CYTHON_USE_UNICODE_INTERNALS
        {
            Py_hash_t hash1, hash2;
            hash1 = ((PyASCIIObject*)s1)->hash;
            hash2 = ((PyASCIIObject*)s2)->hash;
            if (hash1 != hash2 && hash1 != -1 && hash2 != -1) {
                goto return_ne;
            }
        }
#endif
        kind = __Pyx_PyUnicode_KIND(s1);
        if (kind != __Pyx_PyUnicode_KIND(s2)) {
            goto return_ne;
        }
        data1 = __Pyx_PyUnicode_DATA(s1);
        data2 = __Pyx_PyUnicode_DATA(s2);
        if (__Pyx_PyUnicode_READ(kind, data1, 0) != __Pyx_PyUnicode_READ(kind, data2, 0)) {
            goto return_ne;
        } else if (length == 1) {
            goto return_eq;
        } else {
            int result = memcmp(data1, data2, (size_t)(length * kind));
            return (equals == Py_EQ) ? (result == 0) : (result != 0);
        }
    } else if ((s1 == Py_None) & s2_is_unicode) {
        goto return_ne;
    } else if ((s2 == Py_None) & s1_is_unicode) {
        goto return_ne;
    } else {
        int result;
        PyObject* py_result = PyObject_RichCompare(s1, s2, equals);
        if (!py_result)
            return -1;
        result = __Pyx_PyObject_IsTrue(py_result);
        Py_DECREF(py_result);
        return result;
    }
return_eq:
    return (equals == Py_EQ);
return_ne:
    return (equals == Py_NE);
#endif
}

/* fastcall */
#if CYTHON_METH_FASTCALL
static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s)
{
    Py_ssize_t i, n = __Pyx_PyTuple_GET_SIZE(kwnames);
    #if !CYTHON_ASSUME_SAFE_SIZE
    if (unlikely(n == -1)) return NULL;
    #endif
    for (i = 0; i < n; i++)
    {
        PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i);
        #if !CYTHON_ASSUME_SAFE_MACROS
        if (unlikely(!namei)) return NULL;
        #endif
        if (s == namei) return kwvalues[i];
    }
    for (i = 0; i < n; i++)
    {
        PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i);
        #if !CYTHON_ASSUME_SAFE_MACROS
        if (unlikely(!namei)) return NULL;
        #endif
        int eq = __Pyx_PyUnicode_Equals(s, namei, Py_EQ);
        if (unlikely(eq != 0)) {
            if (unlikely(eq < 0)) return NULL;
            return kwvalues[i];
        }
    }
    return NULL;
}
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API
CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues) {
    Py_ssize_t i, nkwargs;
    PyObject *dict;
#if !CYTHON_ASSUME_SAFE_SIZE
    nkwargs = PyTuple_Size(kwnames);
    if (unlikely(nkwargs < 0)) return NULL;
#else
    nkwargs = PyTuple_GET_SIZE(kwnames);
#endif
    dict = PyDict_New();
    if (unlikely(!dict))
        return NULL;
    for (i=0; i<nkwargs; i++) {
#if !CYTHON_ASSUME_SAFE_MACROS
        PyObject *key = PyTuple_GetItem(kwnames, i);
        if (!key) goto bad;
#else
        PyObject *key = PyTuple_GET_ITEM(kwnames, i);
#endif
        if (unlikely(PyDict_SetItem(dict, key, kwvalues[i]) < 0))
            goto bad;
    }
    return dict;
bad:
    Py_DECREF(dict);
    return NULL;
}
#endif
#endif

/* PyObjectCallOneArg (used by CallUnboundCMethod0) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) {
    PyObject *args[2] = {NULL, arg};
    return __Pyx_PyObject_FastCall(func, args+1, 1 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET);
}

/* UnpackUnboundCMethod (used by CallUnboundCMethod0) */
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000
static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *args, PyObject *kwargs) {
    PyObject *result;
    PyObject *selfless_args = PyTuple_GetSlice(args, 1, PyTuple_Size(args));
    if (unlikely(!selfless_args)) return NULL;
    result = PyObject_Call(method, selfless_args, kwargs);
    Py_DECREF(selfless_args);
    return result;
}
#elif CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX < 0x03090000
static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject **args, Py_ssize_t nargs, PyObject *kwnames) {
        return _PyObject_Vectorcall
            (method, args ? args+1 : NULL, nargs ? nargs-1 : 0, kwnames);
}
#else
static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) {
    return
#if PY_VERSION_HEX < 0x03090000
    _PyObject_Vectorcall
#else
    PyObject_Vectorcall
#endif
        (method, args ? args+1 : NULL, nargs ? (size_t) nargs-1 : 0, kwnames);
}
#endif
static PyMethodDef __Pyx_UnboundCMethod_Def = {
     "CythonUnboundCMethod",
     __PYX_REINTERPRET_FUNCION(PyCFunction, __Pyx_SelflessCall),
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000
     METH_VARARGS | METH_KEYWORDS,
#else
     METH_FASTCALL | METH_KEYWORDS,
#endif
     NULL
};
static int __Pyx_TryUnpackUnboundCMethod(__Pyx_CachedCFunction* target) {
    PyObject *method, *result=NULL;
    method = __Pyx_PyObject_GetAttrStr(target->type, *target->method_name);
    if (unlikely(!method))
        return -1;
    result = method;
#if CYTHON_COMPILING_IN_CPYTHON
    if (likely(__Pyx_TypeCheck(method, &PyMethodDescr_Type)))
    {
        PyMethodDescrObject *descr = (PyMethodDescrObject*) method;
        target->func = descr->d_method->ml_meth;
        target->flag = descr->d_method->ml_flags & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_STACKLESS);
    } else
#endif
#if CYTHON_COMPILING_IN_PYPY
#else
    if (PyCFunction_Check(method))
#endif
    {
        PyObject *self;
        int self_found;
#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY
        self = PyObject_GetAttrString(method, "__self__");
        if (!self) {
            PyErr_Clear();
        }
#else
        self = PyCFunction_GET_SELF(method);
#endif
        self_found = (self && self != Py_None);
#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY
        Py_XDECREF(self);
#endif
        if (self_found) {
            PyObject *unbound_method = PyCFunction_New(&__Pyx_UnboundCMethod_Def, method);
            if (unlikely(!unbound_method)) return -1;
            Py_DECREF(method);
            result = unbound_method;
        }
    }
#if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    if (unlikely(target->method)) {
        Py_DECREF(result);
    } else
#endif
    target->method = result;
    return 0;
}

/* CallUnboundCMethod0 */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject* __Pyx_CallUnboundCMethod0(__Pyx_CachedCFunction* cfunc, PyObject* self) {
    int was_initialized = __Pyx_CachedCFunction_GetAndSetInitializing(cfunc);
    if (likely(was_initialized == 2 && cfunc->func)) {
        if (likely(cfunc->flag == METH_NOARGS))
            return __Pyx_CallCFunction(cfunc, self, NULL);
        if (likely(cfunc->flag == METH_FASTCALL))
            return __Pyx_CallCFunctionFast(cfunc, self, NULL, 0);
        if (cfunc->flag == (METH_FASTCALL | METH_KEYWORDS))
            return __Pyx_CallCFunctionFastWithKeywords(cfunc, self, NULL, 0, NULL);
        if (likely(cfunc->flag == (METH_VARARGS | METH_KEYWORDS)))
            return __Pyx_CallCFunctionWithKeywords(cfunc, self, __pyx_mstate_global->__pyx_empty_tuple, NULL);
        if (cfunc->flag == METH_VARARGS)
            return __Pyx_CallCFunction(cfunc, self, __pyx_mstate_global->__pyx_empty_tuple);
        return __Pyx__CallUnboundCMethod0(cfunc, self);
    }
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    else if (unlikely(was_initialized == 1)) {
        __Pyx_CachedCFunction tmp_cfunc = {
#ifndef __cplusplus
            0
#endif
        };
        tmp_cfunc.type = cfunc->type;
        tmp_cfunc.method_name = cfunc->method_name;
        return __Pyx__CallUnboundCMethod0(&tmp_cfunc, self);
    }
#endif
    PyObject *result = __Pyx__CallUnboundCMethod0(cfunc, self);
    __Pyx_CachedCFunction_SetFinishedInitializing(cfunc);
    return result;
}
#endif
static PyObject* __Pyx__CallUnboundCMethod0(__Pyx_CachedCFunction* cfunc, PyObject* self) {
    PyObject *result;
    if (unlikely(!cfunc->method) && unlikely(__Pyx_TryUnpackUnboundCMethod(cfunc) < 0)) return NULL;
    result = __Pyx_PyObject_CallOneArg(cfunc->method, self);
    return result;
}

/* py_dict_items (used by OwnedDictNext) */
static CYTHON_INLINE PyObject* __Pyx_PyDict_Items(PyObject* d) {
    return __Pyx_CallUnboundCMethod0(&__pyx_mstate_global->__pyx_umethod_PyDict_Type_items, d);
}

/* py_dict_values (used by OwnedDictNext) */
static CYTHON_INLINE PyObject* __Pyx_PyDict_Values(PyObject* d) {
    return __Pyx_CallUnboundCMethod0(&__pyx_mstate_global->__pyx_umethod_PyDict_Type_values, d);
}

/* OwnedDictNext (used by ParseKeywordsImpl) */
#if CYTHON_AVOID_BORROWED_REFS
static int __Pyx_PyDict_NextRef(PyObject *p, PyObject **ppos, PyObject **pkey, PyObject **pvalue) {
    PyObject *next = NULL;
    if (!*ppos) {
        if (pvalue) {
            PyObject *dictview = pkey ? __Pyx_PyDict_Items(p) : __Pyx_PyDict_Values(p);
            if (unlikely(!dictview)) goto bad;
            *ppos = PyObject_GetIter(dictview);
            Py_DECREF(dictview);
        } else {
            *ppos = PyObject_GetIter(p);
        }
        if (unlikely(!*ppos)) goto bad;
    }
    next = PyIter_Next(*ppos);
    if (!next) {
        if (PyErr_Occurred()) goto bad;
        return 0;
    }
    if (pkey && pvalue) {
        *pkey = __Pyx_PySequence_ITEM(next, 0);
        if (unlikely(*pkey)) goto bad;
        *pvalue = __Pyx_PySequence_ITEM(next, 1);
        if (unlikely(*pvalue)) goto bad;
        Py_DECREF(next);
    } else if (pkey) {
        *pkey = next;
    } else {
        assert(pvalue);
        *pvalue = next;
    }
    return 1;
  bad:
    Py_XDECREF(next);
#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000
    PyErr_FormatUnraisable("Exception ignored in __Pyx_PyDict_NextRef");
#else
    PyErr_WriteUnraisable(__pyx_mstate_global->__pyx_n_u_Pyx_PyDict_NextRef);
#endif
    if (pkey) *pkey = NULL;
    if (pvalue) *pvalue = NULL;
    return 0;
}
#else // !CYTHON_AVOID_BORROWED_REFS
static int __Pyx_PyDict_NextRef(PyObject *p, Py_ssize_t *ppos, PyObject **pkey, PyObject **pvalue) {
    int result = PyDict_Next(p, ppos, pkey, pvalue);
    if (likely(result == 1)) {
        if (pkey) Py_INCREF(*pkey);
        if (pvalue) Py_INCREF(*pvalue);
    }
    return result;
}
#endif

/* RaiseDoubleKeywords (used by ParseKeywordsImpl) */
static void __Pyx_RaiseDoubleKeywordsError(
    const char* func_name,
    PyObject* kw_name)
{
    PyErr_Format(PyExc_TypeError,
        "%s() got multiple values for keyword argument '%U'", func_name, kw_name);
}

/* CallUnboundCMethod2 */
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2) {
    int was_initialized = __Pyx_CachedCFunction_GetAndSetInitializing(cfunc);
    if (likely(was_initialized == 2 && cfunc->func)) {
        PyObject *args[2] = {arg1, arg2};
        if (cfunc->flag == METH_FASTCALL) {
            return __Pyx_CallCFunctionFast(cfunc, self, args, 2);
        }
        if (cfunc->flag == (METH_FASTCALL | METH_KEYWORDS))
            return __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, 2, NULL);
    }
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    else if (unlikely(was_initialized == 1)) {
        __Pyx_CachedCFunction tmp_cfunc = {
#ifndef __cplusplus
            0
#endif
        };
        tmp_cfunc.type = cfunc->type;
        tmp_cfunc.method_name = cfunc->method_name;
        return __Pyx__CallUnboundCMethod2(&tmp_cfunc, self, arg1, arg2);
    }
#endif
    PyObject *result = __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2);
    __Pyx_CachedCFunction_SetFinishedInitializing(cfunc);
    return result;
}
#endif
static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2){
    if (unlikely(!cfunc->func && !cfunc->method) && unlikely(__Pyx_TryUnpackUnboundCMethod(cfunc) < 0)) return NULL;
#if CYTHON_COMPILING_IN_CPYTHON
    if (cfunc->func && (cfunc->flag & METH_VARARGS)) {
        PyObject *result = NULL;
        PyObject *args = PyTuple_New(2);
        if (unlikely(!args)) return NULL;
        Py_INCREF(arg1);
        PyTuple_SET_ITEM(args, 0, arg1);
        Py_INCREF(arg2);
        PyTuple_SET_ITEM(args, 1, arg2);
        if (cfunc->flag & METH_KEYWORDS)
            result = __Pyx_CallCFunctionWithKeywords(cfunc, self, args, NULL);
        else
            result = __Pyx_CallCFunction(cfunc, self, args);
        Py_DECREF(args);
        return result;
    }
#endif
    {
        PyObject *args[4] = {NULL, self, arg1, arg2};
        return __Pyx_PyObject_FastCall(cfunc->method, args+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET);
    }
}

/* ParseKeywordsImpl (used by ParseKeywords) */
static int __Pyx_ValidateDuplicatePosArgs(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject ** const *first_kw_arg,
    const char* function_name)
{
    PyObject ** const *name = argnames;
    while (name != first_kw_arg) {
        PyObject *key = **name;
        int found = PyDict_Contains(kwds, key);
        if (unlikely(found)) {
            if (found == 1) __Pyx_RaiseDoubleKeywordsError(function_name, key);
            goto bad;
        }
        name++;
    }
    return 0;
bad:
    return -1;
}
#if CYTHON_USE_UNICODE_INTERNALS
static CYTHON_INLINE int __Pyx_UnicodeKeywordsEqual(PyObject *s1, PyObject *s2) {
    int kind;
    Py_ssize_t len = PyUnicode_GET_LENGTH(s1);
    if (len != PyUnicode_GET_LENGTH(s2)) return 0;
    kind = PyUnicode_KIND(s1);
    if (kind != PyUnicode_KIND(s2)) return 0;
    const void *data1 = PyUnicode_DATA(s1);
    const void *data2 = PyUnicode_DATA(s2);
    return (memcmp(data1, data2, (size_t) len * (size_t) kind) == 0);
}
#endif
static int __Pyx_MatchKeywordArg_str(
    PyObject *key,
    PyObject ** const argnames[],
    PyObject ** const *first_kw_arg,
    size_t *index_found,
    const char *function_name)
{
    PyObject ** const *name;
    #if CYTHON_USE_UNICODE_INTERNALS
    Py_hash_t key_hash = ((PyASCIIObject*)key)->hash;
    if (unlikely(key_hash == -1)) {
        key_hash = PyObject_Hash(key);
        if (unlikely(key_hash == -1))
            goto bad;
    }
    #endif
    name = first_kw_arg;
    while (*name) {
        PyObject *name_str = **name;
        #if CYTHON_USE_UNICODE_INTERNALS
        if (key_hash == ((PyASCIIObject*)name_str)->hash && __Pyx_UnicodeKeywordsEqual(name_str, key)) {
            *index_found = (size_t) (name - argnames);
            return 1;
        }
        #else
        #if CYTHON_ASSUME_SAFE_SIZE
        if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key))
        #endif
        {
            int cmp = PyUnicode_Compare(name_str, key);
            if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
            if (cmp == 0) {
                *index_found = (size_t) (name - argnames);
                return 1;
            }
        }
        #endif
        name++;
    }
    name = argnames;
    while (name != first_kw_arg) {
        PyObject *name_str = **name;
        #if CYTHON_USE_UNICODE_INTERNALS
        if (unlikely(key_hash == ((PyASCIIObject*)name_str)->hash)) {
            if (__Pyx_UnicodeKeywordsEqual(name_str, key))
                goto arg_passed_twice;
        }
        #else
        #if CYTHON_ASSUME_SAFE_SIZE
        if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key))
        #endif
        {
            if (unlikely(name_str == key)) goto arg_passed_twice;
            int cmp = PyUnicode_Compare(name_str, key);
            if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
            if (cmp == 0) goto arg_passed_twice;
        }
        #endif
        name++;
    }
    return 0;
arg_passed_twice:
    __Pyx_RaiseDoubleKeywordsError(function_name, key);
    goto bad;
bad:
    return -1;
}
static int __Pyx_MatchKeywordArg_nostr(
    PyObject *key,
    PyObject ** const argnames[],
    PyObject ** const *first_kw_arg,
    size_t *index_found,
    const char *function_name)
{
    PyObject ** const *name;
    if (unlikely(!PyUnicode_Check(key))) goto invalid_keyword_type;
    name = first_kw_arg;
    while (*name) {
        int cmp = PyObject_RichCompareBool(**name, key, Py_EQ);
        if (cmp == 1) {
            *index_found = (size_t) (name - argnames);
            return 1;
        }
        if (unlikely(cmp == -1)) goto bad;
        name++;
    }
    name = argnames;
    while (name != first_kw_arg) {
        int cmp = PyObject_RichCompareBool(**name, key, Py_EQ);
        if (unlikely(cmp != 0)) {
            if (cmp == 1) goto arg_passed_twice;
            else goto bad;
        }
        name++;
    }
    return 0;
arg_passed_twice:
    __Pyx_RaiseDoubleKeywordsError(function_name, key);
    goto bad;
invalid_keyword_type:
    PyErr_Format(PyExc_TypeError,
        "%.200s() keywords must be strings", function_name);
    goto bad;
bad:
    return -1;
}
static CYTHON_INLINE int __Pyx_MatchKeywordArg(
    PyObject *key,
    PyObject ** const argnames[],
    PyObject ** const *first_kw_arg,
    size_t *index_found,
    const char *function_name)
{
    return likely(PyUnicode_CheckExact(key)) ?
        __Pyx_MatchKeywordArg_str(key, argnames, first_kw_arg, index_found, function_name) :
        __Pyx_MatchKeywordArg_nostr(key, argnames, first_kw_arg, index_found, function_name);
}
static void __Pyx_RejectUnknownKeyword(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject ** const *first_kw_arg,
    const char *function_name)
{
    #if CYTHON_AVOID_BORROWED_REFS
    PyObject *pos = NULL;
    #else
    Py_ssize_t pos = 0;
    #endif
    PyObject *key = NULL;
    __Pyx_BEGIN_CRITICAL_SECTION(kwds);
    while (
        #if CYTHON_AVOID_BORROWED_REFS
        __Pyx_PyDict_NextRef(kwds, &pos, &key, NULL)
        #else
        PyDict_Next(kwds, &pos, &key, NULL)
        #endif
    ) {
        PyObject** const *name = first_kw_arg;
        while (*name && (**name != key)) name++;
        if (!*name) {
            size_t index_found = 0;
            int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name);
            if (cmp != 1) {
                if (cmp == 0) {
                    PyErr_Format(PyExc_TypeError,
                        "%s() got an unexpected keyword argument '%U'",
                        function_name, key);
                }
                #if CYTHON_AVOID_BORROWED_REFS
                Py_DECREF(key);
                #endif
                break;
            }
        }
        #if CYTHON_AVOID_BORROWED_REFS
        Py_DECREF(key);
        #endif
    }
    __Pyx_END_CRITICAL_SECTION();
    #if CYTHON_AVOID_BORROWED_REFS
    Py_XDECREF(pos);
    #endif
    assert(PyErr_Occurred());
}
static int __Pyx_ParseKeywordDict(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject *values[],
    Py_ssize_t num_pos_args,
    Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs)
{
    PyObject** const *name;
    PyObject** const *first_kw_arg = argnames + num_pos_args;
    Py_ssize_t extracted = 0;
#if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments)
    if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1;
#endif
    name = first_kw_arg;
    while (*name && num_kwargs > extracted) {
        PyObject * key = **name;
        PyObject *value;
        int found = 0;
        #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
        found = PyDict_GetItemRef(kwds, key, &value);
        #else
        value = PyDict_GetItemWithError(kwds, key);
        if (value) {
            Py_INCREF(value);
            found = 1;
        } else {
            if (unlikely(PyErr_Occurred())) goto bad;
        }
        #endif
        if (found) {
            if (unlikely(found < 0)) goto bad;
            values[name-argnames] = value;
            extracted++;
        }
        name++;
    }
    if (num_kwargs > extracted) {
        if (ignore_unknown_kwargs) {
            if (unlikely(__Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name) == -1))
                goto bad;
        } else {
            __Pyx_RejectUnknownKeyword(kwds, argnames, first_kw_arg, function_name);
            goto bad;
        }
    }
    return 0;
bad:
    return -1;
}
static int __Pyx_ParseKeywordDictToDict(
    PyObject *kwds,
    PyObject ** const argnames[],
    PyObject *kwds2,
    PyObject *values[],
    Py_ssize_t num_pos_args,
    const char* function_name)
{
    PyObject** const *name;
    PyObject** const *first_kw_arg = argnames + num_pos_args;
    Py_ssize_t len;
#if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments)
    if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1;
#endif
    if (PyDict_Update(kwds2, kwds) < 0) goto bad;
    name = first_kw_arg;
    while (*name) {
        PyObject *key = **name;
        PyObject *value;
#if !CYTHON_COMPILING_IN_LIMITED_API && (PY_VERSION_HEX >= 0x030d00A2 || defined(PyDict_Pop))
        int found = PyDict_Pop(kwds2, key, &value);
        if (found) {
            if (unlikely(found < 0)) goto bad;
            values[name-argnames] = value;
        }
#elif __PYX_LIMITED_VERSION_HEX >= 0x030d0000
        int found = PyDict_GetItemRef(kwds2, key, &value);
        if (found) {
            if (unlikely(found < 0)) goto bad;
            values[name-argnames] = value;
            if (unlikely(PyDict_DelItem(kwds2, key) < 0)) goto bad;
        }
#else
    #if CYTHON_COMPILING_IN_CPYTHON
        value = _PyDict_Pop(kwds2, key, kwds2);
    #else
        value = __Pyx_CallUnboundCMethod2(&__pyx_mstate_global->__pyx_umethod_PyDict_Type_pop, kwds2, key, kwds2);
    #endif
        if (value == kwds2) {
            Py_DECREF(value);
        } else {
            if (unlikely(!value)) goto bad;
            values[name-argnames] = value;
        }
#endif
        name++;
    }
    len = PyDict_Size(kwds2);
    if (len > 0) {
        return __Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name);
    } else if (unlikely(len == -1)) {
        goto bad;
    }
    return 0;
bad:
    return -1;
}
static int __Pyx_ParseKeywordsTuple(
    PyObject *kwds,
    PyObject * const *kwvalues,
    PyObject ** const argnames[],
    PyObject *kwds2,
    PyObject *values[],
    Py_ssize_t num_pos_args,
    Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs)
{
    PyObject *key = NULL;
    PyObject** const * name;
    PyObject** const *first_kw_arg = argnames + num_pos_args;
    for (Py_ssize_t pos = 0; pos < num_kwargs; pos++) {
#if CYTHON_AVOID_BORROWED_REFS
        key = __Pyx_PySequence_ITEM(kwds, pos);
#else
        key = __Pyx_PyTuple_GET_ITEM(kwds, pos);
#endif
#if !CYTHON_ASSUME_SAFE_MACROS
        if (unlikely(!key)) goto bad;
#endif
        name = first_kw_arg;
        while (*name && (**name != key)) name++;
        if (*name) {
            PyObject *value = kwvalues[pos];
            values[name-argnames] = __Pyx_NewRef(value);
        } else {
            size_t index_found = 0;
            int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name);
            if (cmp == 1) {
                PyObject *value = kwvalues[pos];
                values[index_found] = __Pyx_NewRef(value);
            } else {
                if (unlikely(cmp == -1)) goto bad;
                if (kwds2) {
                    PyObject *value = kwvalues[pos];
                    if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad;
                } else if (!ignore_unknown_kwargs) {
                    goto invalid_keyword;
                }
            }
        }
        #if CYTHON_AVOID_BORROWED_REFS
        Py_DECREF(key);
        key = NULL;
        #endif
    }
    return 0;
invalid_keyword:
    PyErr_Format(PyExc_TypeError,
        "%s() got an unexpected keyword argument '%U'",
        function_name, key);
    goto bad;
bad:
    #if CYTHON_AVOID_BORROWED_REFS
    Py_XDECREF(key);
    #endif
    return -1;
}

/* ParseKeywords */
static int __Pyx_ParseKeywords(
    PyObject *kwds,
    PyObject * const *kwvalues,
    PyObject ** const argnames[],
    PyObject *kwds2,
    PyObject *values[],
    Py_ssize_t num_pos_args,
    Py_ssize_t num_kwargs,
    const char* function_name,
    int ignore_unknown_kwargs)
{
    if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kwds)))
        return __Pyx_ParseKeywordsTuple(kwds, kwvalues, argnames, kwds2, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs);
    else if (kwds2)
        return __Pyx_ParseKeywordDictToDict(kwds, argnames, kwds2, values, num_pos_args, function_name);
    else
        return __Pyx_ParseKeywordDict(kwds, argnames, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs);
}

/* RaiseArgTupleInvalid */
static void __Pyx_RaiseArgtupleInvalid(
    const char* func_name,
    int exact,
    Py_ssize_t num_min,
    Py_ssize_t num_max,
    Py_ssize_t num_found)
{
    Py_ssize_t num_expected;
    const char *more_or_less;
    if (num_found < num_min) {
        num_expected = num_min;
        more_or_less = "at least";
    } else {
        num_expected = num_max;
        more_or_less = "at most";
    }
    if (exact) {
        more_or_less = "exactly";
    }
    PyErr_Format(PyExc_TypeError,
                 "%.200s() takes %.8s %" CYTHON_FORMAT_SSIZE_T "d positional argument%.1s (%" CYTHON_FORMAT_SSIZE_T "d given)",
                 func_name, more_or_less, num_expected,
                 (num_expected == 1) ? "" : "s", num_found);
}

/* PyObjectFastCallMethod */
#if !CYTHON_VECTORCALL || PY_VERSION_HEX < 0x03090000
static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf) {
    PyObject *result;
    PyObject *attr = PyObject_GetAttr(args[0], name);
    if (unlikely(!attr))
        return NULL;
    result = __Pyx_PyObject_FastCall(attr, args+1, nargsf - 1);
    Py_DECREF(attr);
    return result;
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceSubtract : PyNumber_Subtract)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    long a;
    const PY_LONG_LONG llb = intval;
    PY_LONG_LONG lla;
    if (unlikely(__Pyx_PyLong_IsZero(op1))) {
        return PyLong_FromLong(-intval);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op1);
    const digit* digits = __Pyx_PyLong_Digits(op1);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
    if (likely(size == 1)) {
        a = (long) digits[0];
        if (!is_positive) a *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) {
                    a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) {
                    a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) {
                    a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_subtract(op1, op2);
    }
    calculate_long:
        {
            long x;
            x = a - b;
            return PyLong_FromLong(x);
        }
    calculate_long_long:
        {
            PY_LONG_LONG llx;
            llx = lla - llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static PyObject* __Pyx_Float___Pyx_PyLong_SubtractObjC(PyObject *float_val, long intval, int zerodivision_check) {
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    double a = __Pyx_PyFloat_AS_DOUBLE(float_val);
        double result;
        
        result = ((double)a) - (double)b;
        return PyFloat_FromDouble(result);
}
static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        return __Pyx_Unpacked___Pyx_PyLong_SubtractObjC(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    if (PyFloat_CheckExact(op1)) {
        return __Pyx_Float___Pyx_PyLong_SubtractObjC(op1, intval, zerodivision_check);
    }
    return __Pyx_Fallback___Pyx_PyLong_SubtractObjC(op1, op2, inplace);
}
#endif

/* RaiseTooManyValuesToUnpack */
static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected) {
    PyErr_Format(PyExc_ValueError,
                 "too many values to unpack (expected %" CYTHON_FORMAT_SSIZE_T "d)", expected);
}

/* RaiseNeedMoreValuesToUnpack */
static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index) {
    PyErr_Format(PyExc_ValueError,
                 "need more than %" CYTHON_FORMAT_SSIZE_T "d value%.1s to unpack",
                 index, (index == 1) ? "" : "s");
}

/* IterFinish */
static CYTHON_INLINE int __Pyx_IterFinish(void) {
    PyObject* exc_type;
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    exc_type = __Pyx_PyErr_CurrentExceptionType();
    if (unlikely(exc_type)) {
        if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)))
            return -1;
        __Pyx_PyErr_Clear();
        return 0;
    }
    return 0;
}

/* UnpackItemEndCheck */
static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected) {
    if (unlikely(retval)) {
        Py_DECREF(retval);
        __Pyx_RaiseTooManyValuesError(expected);
        return -1;
    }
    return __Pyx_IterFinish();
}

/* SwapException */
#if CYTHON_FAST_THREAD_STATE
static CYTHON_INLINE void __Pyx__ExceptionSwap(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) {
    PyObject *tmp_type, *tmp_value, *tmp_tb;
  #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4
    _PyErr_StackItem *exc_info = tstate->exc_info;
    tmp_value = exc_info->exc_value;
    exc_info->exc_value = *value;
    if (tmp_value == NULL || tmp_value == Py_None) {
        Py_XDECREF(tmp_value);
        tmp_value = NULL;
        tmp_type = NULL;
        tmp_tb = NULL;
    } else {
        tmp_type = (PyObject*) Py_TYPE(tmp_value);
        Py_INCREF(tmp_type);
        #if CYTHON_COMPILING_IN_CPYTHON
        tmp_tb = ((PyBaseExceptionObject*) tmp_value)->traceback;
        Py_XINCREF(tmp_tb);
        #else
        tmp_tb = PyException_GetTraceback(tmp_value);
        #endif
    }
  #elif CYTHON_USE_EXC_INFO_STACK
    _PyErr_StackItem *exc_info = tstate->exc_info;
    tmp_type = exc_info->exc_type;
    tmp_value = exc_info->exc_value;
    tmp_tb = exc_info->exc_traceback;
    exc_info->exc_type = *type;
    exc_info->exc_value = *value;
    exc_info->exc_traceback = *tb;
  #else
    tmp_type = tstate->exc_type;
    tmp_value = tstate->exc_value;
    tmp_tb = tstate->exc_traceback;
    tstate->exc_type = *type;
    tstate->exc_value = *value;
    tstate->exc_traceback = *tb;
  #endif
    *type = tmp_type;
    *value = tmp_value;
    *tb = tmp_tb;
}
#else
static CYTHON_INLINE void __Pyx_ExceptionSwap(PyObject **type, PyObject **value, PyObject **tb) {
    PyObject *tmp_type, *tmp_value, *tmp_tb;
    PyErr_GetExcInfo(&tmp_type, &tmp_value, &tmp_tb);
    PyErr_SetExcInfo(*type, *value, *tb);
    *type = tmp_type;
    *value = tmp_value;
    *tb = tmp_tb;
}
#endif

/* PyDictVersioning (used by GetModuleGlobalName) */
#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS
static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj) {
    PyObject *dict = Py_TYPE(obj)->tp_dict;
    return likely(dict) ? __PYX_GET_DICT_VERSION(dict) : 0;
}
static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj) {
    PyObject **dictptr = NULL;
    Py_ssize_t offset = Py_TYPE(obj)->tp_dictoffset;
    if (offset) {
#if CYTHON_COMPILING_IN_CPYTHON
        dictptr = (likely(offset > 0)) ? (PyObject **) ((char *)obj + offset) : _PyObject_GetDictPtr(obj);
#else
        dictptr = _PyObject_GetDictPtr(obj);
#endif
    }
    return (dictptr && *dictptr) ? __PYX_GET_DICT_VERSION(*dictptr) : 0;
}
static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version) {
    PyObject *dict = Py_TYPE(obj)->tp_dict;
    if (unlikely(!dict) || unlikely(tp_dict_version != __PYX_GET_DICT_VERSION(dict)))
        return 0;
    return obj_dict_version == __Pyx_get_object_dict_version(obj);
}
#endif

/* GetModuleGlobalName */
#if CYTHON_USE_DICT_VERSIONS
static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value)
#else
static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name)
#endif
{
    PyObject *result;
#if CYTHON_COMPILING_IN_LIMITED_API
    if (unlikely(!__pyx_m)) {
        if (!PyErr_Occurred())
            PyErr_SetNone(PyExc_NameError);
        return NULL;
    }
    result = PyObject_GetAttr(__pyx_m, name);
    if (likely(result)) {
        return result;
    }
    PyErr_Clear();
#elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS
    if (unlikely(__Pyx_PyDict_GetItemRef(__pyx_mstate_global->__pyx_d, name, &result) == -1)) PyErr_Clear();
    __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version)
    if (likely(result)) {
        return result;
    }
#else
    result = _PyDict_GetItem_KnownHash(__pyx_mstate_global->__pyx_d, name, ((PyASCIIObject *) name)->hash);
    __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version)
    if (likely(result)) {
        return __Pyx_NewRef(result);
    }
    PyErr_Clear();
#endif
    return __Pyx_GetBuiltinName(name);
}

/* PyLongCompare */
static CYTHON_INLINE int __Pyx_PyLong_BoolEqObjC(PyObject *op1, PyObject *op2, long intval, long inplace) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(inplace);
    if (op1 == op2) {
        return 1;
    }
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        int unequal;
        unsigned long uintval;
        Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
        const digit* digits = __Pyx_PyLong_Digits(op1);
        if (intval == 0) {
            return (__Pyx_PyLong_IsZero(op1) == 1);
        } else if (intval < 0) {
            if (__Pyx_PyLong_IsNonNeg(op1))
                return 0;
            intval = -intval;
        } else {
            if (__Pyx_PyLong_IsNeg(op1))
                return 0;
        }
        uintval = (unsigned long) intval;
#if PyLong_SHIFT * 4 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 4)) {
            unequal = (size != 5) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[4] != ((uintval >> (4 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 3 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 3)) {
            unequal = (size != 4) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 2 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 2)) {
            unequal = (size != 3) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 1 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 1)) {
            unequal = (size != 2) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
            unequal = (size != 1) || (((unsigned long) digits[0]) != (uintval & (unsigned long) PyLong_MASK));
        return (unequal == 0);
    }
    #endif
    if (PyFloat_CheckExact(op1)) {
        const long b = intval;
        double a = __Pyx_PyFloat_AS_DOUBLE(op1);
        return ((double)a == (double)b);
    }
    return __Pyx_PyObject_IsTrueAndDecref(
        PyObject_RichCompare(op1, op2, Py_EQ));
}

/* PyObjectVectorCallKwBuilder */
#if CYTHON_VECTORCALL
static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) {
    (void)__Pyx_PyObject_FastCallDict;
    if (__Pyx_PyTuple_SET_ITEM(builder, n, key) != (0)) return -1;
    Py_INCREF(key);
    args[n] = value;
    return 0;
}
CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) {
    (void)__Pyx_VectorcallBuilder_AddArgStr;
    if (unlikely(!PyUnicode_Check(key))) {
        PyErr_SetString(PyExc_TypeError, "keywords must be strings");
        return -1;
    }
    return __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n);
}
static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n) {
    PyObject *pyKey = PyUnicode_FromString(key);
    if (!pyKey) return -1;
    return __Pyx_VectorcallBuilder_AddArg(pyKey, value, builder, args, n);
}
#else // CYTHON_VECTORCALL
CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, CYTHON_UNUSED PyObject **args, CYTHON_UNUSED int n) {
    if (unlikely(!PyUnicode_Check(key))) {
        PyErr_SetString(PyExc_TypeError, "keywords must be strings");
        return -1;
    }
    return PyDict_SetItem(builder, key, value);
}
#endif

/* PyFloatBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_PyFloat_TrueDivideObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check) {
    const double b = floatval;
    double a, result;
    CYTHON_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    if (likely(PyFloat_CheckExact(op1))) {
        a = __Pyx_PyFloat_AS_DOUBLE(op1);
        
    } else
    if (likely(PyLong_CheckExact(op1))) {
        #if CYTHON_USE_PYLONG_INTERNALS
        if (__Pyx_PyLong_IsZero(op1)) {
            a = 0.0;
            
        } else if (__Pyx_PyLong_IsCompact(op1)) {
            a = (double) __Pyx_PyLong_CompactValue(op1);
        } else {
            const digit* digits = __Pyx_PyLong_Digits(op1);
            const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(op1);
            switch (size) {
                case -2:
                case 2:
                    if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (1 * PyLong_SHIFT < 53))) {
                        a = (double) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -2)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                case -3:
                case 3:
                    if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53))) {
                        a = (double) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -3)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                case -4:
                case 4:
                    if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53))) {
                        a = (double) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (4 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -4)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                default:
        #endif
                    a = PyLong_AsDouble(op1);
                    if (unlikely(a == -1.0 && PyErr_Occurred())) return NULL;
        #if CYTHON_USE_PYLONG_INTERNALS
            }
        }
        #endif
    } else {
        return (inplace ? PyNumber_InPlaceTrueDivide : PyNumber_TrueDivide)(op1, op2);
    }
        result = a / b;
        return PyFloat_FromDouble(result);
}
#endif

/* PyLongCompare */
static CYTHON_INLINE PyObject* __Pyx_PyLong_EqObjC(PyObject *op1, PyObject *op2, long intval, long inplace) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(inplace);
    if (op1 == op2) {
        Py_RETURN_TRUE;
    }
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        int unequal;
        unsigned long uintval;
        Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
        const digit* digits = __Pyx_PyLong_Digits(op1);
        if (intval == 0) {
            if (__Pyx_PyLong_IsZero(op1) == 1) Py_RETURN_TRUE; else Py_RETURN_FALSE;
        } else if (intval < 0) {
            if (__Pyx_PyLong_IsNonNeg(op1))
                Py_RETURN_FALSE;
            intval = -intval;
        } else {
            if (__Pyx_PyLong_IsNeg(op1))
                Py_RETURN_FALSE;
        }
        uintval = (unsigned long) intval;
#if PyLong_SHIFT * 4 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 4)) {
            unequal = (size != 5) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[4] != ((uintval >> (4 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 3 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 3)) {
            unequal = (size != 4) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[3] != ((uintval >> (3 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 2 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 2)) {
            unequal = (size != 3) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK)) | (digits[2] != ((uintval >> (2 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
#if PyLong_SHIFT * 1 < SIZEOF_LONG*8
        if (uintval >> (PyLong_SHIFT * 1)) {
            unequal = (size != 2) || (digits[0] != (uintval & (unsigned long) PyLong_MASK))
                 | (digits[1] != ((uintval >> (1 * PyLong_SHIFT)) & (unsigned long) PyLong_MASK));
        } else
#endif
            unequal = (size != 1) || (((unsigned long) digits[0]) != (uintval & (unsigned long) PyLong_MASK));
        if (unequal == 0) Py_RETURN_TRUE; else Py_RETURN_FALSE;
    }
    #endif
    if (PyFloat_CheckExact(op1)) {
        const long b = intval;
        double a = __Pyx_PyFloat_AS_DOUBLE(op1);
        if ((double)a == (double)b) Py_RETURN_TRUE; else Py_RETURN_FALSE;
    }
    return (
        PyObject_RichCompare(op1, op2, Py_EQ));
}

/* GetItemInt */
static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) {
    PyObject *r;
    if (unlikely(!j)) return NULL;
    r = PyObject_GetItem(o, j);
    Py_DECREF(j);
    return r;
}
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i,
                                                              int wraparound, int boundscheck, int unsafe_shared) {
    CYTHON_MAYBE_UNUSED_VAR(unsafe_shared);
#if CYTHON_ASSUME_SAFE_SIZE
    Py_ssize_t wrapped_i = i;
    if (wraparound & unlikely(i < 0)) {
        wrapped_i += PyList_GET_SIZE(o);
    }
    if ((CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS)) {
        return __Pyx_PyList_GetItemRefFast(o, wrapped_i, unsafe_shared);
    } else
    if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyList_GET_SIZE(o)))) {
        return __Pyx_NewRef(PyList_GET_ITEM(o, wrapped_i));
    }
    return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i));
#else
    (void)wraparound;
    (void)boundscheck;
    return PySequence_GetItem(o, i);
#endif
}
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i,
                                                              int wraparound, int boundscheck, int unsafe_shared) {
    CYTHON_MAYBE_UNUSED_VAR(unsafe_shared);
#if CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    Py_ssize_t wrapped_i = i;
    if (wraparound & unlikely(i < 0)) {
        wrapped_i += PyTuple_GET_SIZE(o);
    }
    if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyTuple_GET_SIZE(o)))) {
        return __Pyx_NewRef(PyTuple_GET_ITEM(o, wrapped_i));
    }
    return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i));
#else
    (void)wraparound;
    (void)boundscheck;
    return PySequence_GetItem(o, i);
#endif
}
static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i, int is_list,
                                                     int wraparound, int boundscheck, int unsafe_shared) {
    CYTHON_MAYBE_UNUSED_VAR(unsafe_shared);
#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE
    if (is_list || PyList_CheckExact(o)) {
        Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyList_GET_SIZE(o);
        if ((CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS)) {
            return __Pyx_PyList_GetItemRefFast(o, n, unsafe_shared);
        } else if ((!boundscheck) || (likely(__Pyx_is_valid_index(n, PyList_GET_SIZE(o))))) {
            return __Pyx_NewRef(PyList_GET_ITEM(o, n));
        }
    } else
    #if !CYTHON_AVOID_BORROWED_REFS
    if (PyTuple_CheckExact(o)) {
        Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o);
        if ((!boundscheck) || likely(__Pyx_is_valid_index(n, PyTuple_GET_SIZE(o)))) {
            return __Pyx_NewRef(PyTuple_GET_ITEM(o, n));
        }
    } else
    #endif
#endif
#if CYTHON_USE_TYPE_SLOTS && !CYTHON_COMPILING_IN_PYPY
    {
        PyMappingMethods *mm = Py_TYPE(o)->tp_as_mapping;
        PySequenceMethods *sm = Py_TYPE(o)->tp_as_sequence;
        if (!is_list && mm && mm->mp_subscript) {
            PyObject *r, *key = PyLong_FromSsize_t(i);
            if (unlikely(!key)) return NULL;
            r = mm->mp_subscript(o, key);
            Py_DECREF(key);
            return r;
        }
        if (is_list || likely(sm && sm->sq_item)) {
            if (wraparound && unlikely(i < 0) && likely(sm->sq_length)) {
                Py_ssize_t l = sm->sq_length(o);
                if (likely(l >= 0)) {
                    i += l;
                } else {
                    if (!PyErr_ExceptionMatches(PyExc_OverflowError))
                        return NULL;
                    PyErr_Clear();
                }
            }
            return sm->sq_item(o, i);
        }
    }
#else
    if (is_list || !PyMapping_Check(o)) {
        return PySequence_GetItem(o, i);
    }
#endif
    (void)wraparound;
    (void)boundscheck;
    return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i));
}

/* ObjectGetItem */
#if CYTHON_USE_TYPE_SLOTS
static PyObject *__Pyx_PyObject_GetIndex(PyObject *obj, PyObject *index) {
    PyObject *runerr = NULL;
    Py_ssize_t key_value;
    key_value = __Pyx_PyIndex_AsSsize_t(index);
    if (likely(key_value != -1 || !(runerr = PyErr_Occurred()))) {
        return __Pyx_GetItemInt_Fast(obj, key_value, 0, 1, 1, 1);
    }
    if (PyErr_GivenExceptionMatches(runerr, PyExc_OverflowError)) {
        __Pyx_TypeName index_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(index));
        PyErr_Clear();
        PyErr_Format(PyExc_IndexError,
            "cannot fit '" __Pyx_FMT_TYPENAME "' into an index-sized integer", index_type_name);
        __Pyx_DECREF_TypeName(index_type_name);
    }
    return NULL;
}
static PyObject *__Pyx_PyObject_GetItem_Slow(PyObject *obj, PyObject *key) {
    __Pyx_TypeName obj_type_name;
    if (likely(PyType_Check(obj))) {
        PyObject *meth = __Pyx_PyObject_GetAttrStrNoError(obj, __pyx_mstate_global->__pyx_n_u_class_getitem);
        if (!meth) {
            PyErr_Clear();
        } else {
            PyObject *result = __Pyx_PyObject_CallOneArg(meth, key);
            Py_DECREF(meth);
            return result;
        }
    }
    obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj));
    PyErr_Format(PyExc_TypeError,
        "'" __Pyx_FMT_TYPENAME "' object is not subscriptable", obj_type_name);
    __Pyx_DECREF_TypeName(obj_type_name);
    return NULL;
}
static PyObject *__Pyx_PyObject_GetItem(PyObject *obj, PyObject *key) {
    PyTypeObject *tp = Py_TYPE(obj);
    PyMappingMethods *mm = tp->tp_as_mapping;
    PySequenceMethods *sm = tp->tp_as_sequence;
    if (likely(mm && mm->mp_subscript)) {
        return mm->mp_subscript(obj, key);
    }
    if (likely(sm && sm->sq_item)) {
        return __Pyx_PyObject_GetIndex(obj, key);
    }
    return __Pyx_PyObject_GetItem_Slow(obj, key);
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceAdd : PyNumber_Add)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    long a;
    const PY_LONG_LONG llb = intval;
    PY_LONG_LONG lla;
    if (unlikely(__Pyx_PyLong_IsZero(op1))) {
        return __Pyx_NewRef(op2);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op1);
    const digit* digits = __Pyx_PyLong_Digits(op1);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
    if (likely(size == 1)) {
        a = (long) digits[0];
        if (!is_positive) a *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) {
                    a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) {
                    a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) {
                    a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_add(op1, op2);
    }
    calculate_long:
        {
            long x;
            x = a + b;
            return PyLong_FromLong(x);
        }
    calculate_long_long:
        {
            PY_LONG_LONG llx;
            llx = lla + llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static PyObject* __Pyx_Float___Pyx_PyLong_AddObjC(PyObject *float_val, long intval, int zerodivision_check) {
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    double a = __Pyx_PyFloat_AS_DOUBLE(float_val);
        double result;
        
        result = ((double)a) + (double)b;
        return PyFloat_FromDouble(result);
}
static CYTHON_INLINE PyObject* __Pyx_PyLong_AddObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        return __Pyx_Unpacked___Pyx_PyLong_AddObjC(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    if (PyFloat_CheckExact(op1)) {
        return __Pyx_Float___Pyx_PyLong_AddObjC(op1, intval, zerodivision_check);
    }
    return __Pyx_Fallback___Pyx_PyLong_AddObjC(op1, op2, inplace);
}
#endif

/* RaiseUnboundLocalError */
static void __Pyx_RaiseUnboundLocalError(const char *varname) {
    PyErr_Format(PyExc_UnboundLocalError, "local variable '%s' referenced before assignment", varname);
}

/* PyObjectCall2Args (used by PyObjectCallMethod1) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2) {
    PyObject *args[3] = {NULL, arg1, arg2};
    return __Pyx_PyObject_FastCall(function, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET);
}

/* PyObjectGetMethod (used by PyObjectCallMethod1) */
#if !(CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000)))
static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method) {
    PyObject *attr;
#if CYTHON_UNPACK_METHODS && CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_PYTYPE_LOOKUP
    __Pyx_TypeName type_name;
    PyTypeObject *tp = Py_TYPE(obj);
    PyObject *descr;
    descrgetfunc f = NULL;
    PyObject **dictptr, *dict;
    int meth_found = 0;
    assert (*method == NULL);
    if (unlikely(tp->tp_getattro != PyObject_GenericGetAttr)) {
        attr = __Pyx_PyObject_GetAttrStr(obj, name);
        goto try_unpack;
    }
    if (unlikely(tp->tp_dict == NULL) && unlikely(PyType_Ready(tp) < 0)) {
        return 0;
    }
    descr = _PyType_Lookup(tp, name);
    if (likely(descr != NULL)) {
        Py_INCREF(descr);
#if defined(Py_TPFLAGS_METHOD_DESCRIPTOR) && Py_TPFLAGS_METHOD_DESCRIPTOR
        if (__Pyx_PyType_HasFeature(Py_TYPE(descr), Py_TPFLAGS_METHOD_DESCRIPTOR))
#else
        #ifdef __Pyx_CyFunction_USED
        if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type) || __Pyx_CyFunction_Check(descr)))
        #else
        if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type)))
        #endif
#endif
        {
            meth_found = 1;
        } else {
            f = Py_TYPE(descr)->tp_descr_get;
            if (f != NULL && PyDescr_IsData(descr)) {
                attr = f(descr, obj, (PyObject *)Py_TYPE(obj));
                Py_DECREF(descr);
                goto try_unpack;
            }
        }
    }
    dictptr = _PyObject_GetDictPtr(obj);
    if (dictptr != NULL && (dict = *dictptr) != NULL) {
        Py_INCREF(dict);
        attr = __Pyx_PyDict_GetItemStr(dict, name);
        if (attr != NULL) {
            Py_INCREF(attr);
            Py_DECREF(dict);
            Py_XDECREF(descr);
            goto try_unpack;
        }
        Py_DECREF(dict);
    }
    if (meth_found) {
        *method = descr;
        return 1;
    }
    if (f != NULL) {
        attr = f(descr, obj, (PyObject *)Py_TYPE(obj));
        Py_DECREF(descr);
        goto try_unpack;
    }
    if (likely(descr != NULL)) {
        *method = descr;
        return 0;
    }
    type_name = __Pyx_PyType_GetFullyQualifiedName(tp);
    PyErr_Format(PyExc_AttributeError,
                 "'" __Pyx_FMT_TYPENAME "' object has no attribute '%U'",
                 type_name, name);
    __Pyx_DECREF_TypeName(type_name);
    return 0;
#else
    attr = __Pyx_PyObject_GetAttrStr(obj, name);
    goto try_unpack;
#endif
try_unpack:
#if CYTHON_UNPACK_METHODS
    if (likely(attr) && PyMethod_Check(attr) && likely(PyMethod_GET_SELF(attr) == obj)) {
        PyObject *function = PyMethod_GET_FUNCTION(attr);
        Py_INCREF(function);
        Py_DECREF(attr);
        *method = function;
        return 1;
    }
#endif
    *method = attr;
    return 0;
}
#endif

/* PyObjectCallMethod1 (used by append) */
#if !(CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000)))
static PyObject* __Pyx__PyObject_CallMethod1(PyObject* method, PyObject* arg) {
    PyObject *result = __Pyx_PyObject_CallOneArg(method, arg);
    Py_DECREF(method);
    return result;
}
#endif
static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg) {
#if CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000))
    PyObject *args[2] = {obj, arg};
    (void) __Pyx_PyObject_CallOneArg;
    (void) __Pyx_PyObject_Call2Args;
    return PyObject_VectorcallMethod(method_name, args, 2 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL);
#else
    PyObject *method = NULL, *result;
    int is_method = __Pyx_PyObject_GetMethod(obj, method_name, &method);
    if (likely(is_method)) {
        result = __Pyx_PyObject_Call2Args(method, obj, arg);
        Py_DECREF(method);
        return result;
    }
    if (unlikely(!method)) return NULL;
    return __Pyx__PyObject_CallMethod1(method, arg);
#endif
}

/* append */
static CYTHON_INLINE int __Pyx_PyObject_Append(PyObject* L, PyObject* x) {
    if (likely(PyList_CheckExact(L))) {
        if (unlikely(__Pyx_PyList_Append(L, x) < 0)) return -1;
    } else {
        PyObject* retval = __Pyx_PyObject_CallMethod1(L, __pyx_mstate_global->__pyx_n_u_append, x);
        if (unlikely(!retval))
            return -1;
        Py_DECREF(retval);
    }
    return 0;
}

/* GetAttr3 */
#if __PYX_LIMITED_VERSION_HEX < 0x030d0000
static PyObject *__Pyx_GetAttr3Default(PyObject *d) {
    __Pyx_PyThreadState_declare
    __Pyx_PyThreadState_assign
    if (unlikely(!__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError)))
        return NULL;
    __Pyx_PyErr_Clear();
    Py_INCREF(d);
    return d;
}
#endif
static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *o, PyObject *n, PyObject *d) {
    PyObject *r;
#if __PYX_LIMITED_VERSION_HEX >= 0x030d0000
    int res = PyObject_GetOptionalAttr(o, n, &r);
    return (res != 0) ? r : __Pyx_NewRef(d);
#else
  #if CYTHON_USE_TYPE_SLOTS
    if (likely(PyUnicode_Check(n))) {
        r = __Pyx_PyObject_GetAttrStrNoError(o, n);
        if (unlikely(!r) && likely(!PyErr_Occurred())) {
            r = __Pyx_NewRef(d);
        }
        return r;
    }
  #endif
    r = PyObject_GetAttr(o, n);
    return (likely(r)) ? r : __Pyx_GetAttr3Default(d);
#endif
}

/* PyObjectVectorCallMethodKwBuilder */
#if !CYTHON_VECTORCALL || PY_VERSION_HEX < 0x03090000
static PyObject *__Pyx_Object_VectorcallMethod_CallFromBuilder(PyObject *name, PyObject *const *args, size_t nargsf, PyObject *kwnames) {
    PyObject *result;
    PyObject *obj = PyObject_GetAttr(args[0], name);
    if (unlikely(!obj))
        return NULL;
    result = __Pyx_Object_Vectorcall_CallFromBuilder(obj, args+1, nargsf-1, kwnames);
    Py_DECREF(obj);
    return result;
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_MultiplyObjC(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceMultiply : PyNumber_Multiply)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_MultiplyObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    long a;
    const PY_LONG_LONG llb = intval;
    PY_LONG_LONG lla;
    if (unlikely(__Pyx_PyLong_IsZero(op1))) {
        return __Pyx_NewRef(op1);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op1);
    const digit* digits = __Pyx_PyLong_Digits(op1);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
    if (likely(size == 1)) {
        a = (long) digits[0];
        if (!is_positive) a *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT+30) {
                    a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT+30) {
                    lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT+30) {
                    a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT+30) {
                    lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT+30) {
                    a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT+30) {
                    lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_multiply(op1, op2);
    }
    calculate_long:
        CYTHON_UNUSED_VAR(a);
        CYTHON_UNUSED_VAR(b);
        lla = a;
        goto calculate_long_long;
    calculate_long_long:
        {
            PY_LONG_LONG llx;
            llx = lla * llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static PyObject* __Pyx_Float___Pyx_PyLong_MultiplyObjC(PyObject *float_val, long intval, int zerodivision_check) {
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    double a = __Pyx_PyFloat_AS_DOUBLE(float_val);
        double result;
        
        result = ((double)a) * (double)b;
        return PyFloat_FromDouble(result);
}
static CYTHON_INLINE PyObject* __Pyx_PyLong_MultiplyObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        return __Pyx_Unpacked___Pyx_PyLong_MultiplyObjC(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    if (PyFloat_CheckExact(op1)) {
        return __Pyx_Float___Pyx_PyLong_MultiplyObjC(op1, intval, zerodivision_check);
    }
    return __Pyx_Fallback___Pyx_PyLong_MultiplyObjC(op1, op2, inplace);
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_RemainderObjC(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceRemainder : PyNumber_Remainder)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_RemainderObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    long a;
    const PY_LONG_LONG llb = intval;
    PY_LONG_LONG lla;
    if (unlikely(__Pyx_PyLong_IsZero(op1))) {
        return __Pyx_NewRef(op1);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op1);
    const digit* digits = __Pyx_PyLong_Digits(op1);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
    if (likely(size == 1)) {
        a = (long) digits[0];
        if (!is_positive) a *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) {
                    a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) {
                    a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) {
                    a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_remainder(op1, op2);
    }
    calculate_long:
        {
            long x = a % b;
            x += ((x != 0) & ((x ^ b) < 0)) * b;
            return PyLong_FromLong(x);
        }
    calculate_long_long:
        {
            PY_LONG_LONG llx = lla % llb;
            llx += ((llx != 0) & ((llx ^ llb) < 0)) * llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static CYTHON_INLINE PyObject* __Pyx_PyLong_RemainderObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        return __Pyx_Unpacked___Pyx_PyLong_RemainderObjC(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    return __Pyx_Fallback___Pyx_PyLong_RemainderObjC(op1, op2, inplace);
}
#endif

/* SetItemInt */
static int __Pyx_SetItemInt_Generic(PyObject *o, PyObject *j, PyObject *v) {
    int r;
    if (unlikely(!j)) return -1;
    r = PyObject_SetItem(o, j, v);
    Py_DECREF(j);
    return r;
}
static CYTHON_INLINE int __Pyx_SetItemInt_Fast(PyObject *o, Py_ssize_t i, PyObject *v, int is_list,
                                               int wraparound, int boundscheck, int unsafe_shared) {
    CYTHON_MAYBE_UNUSED_VAR(unsafe_shared);
#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE && !CYTHON_AVOID_BORROWED_REFS
    if (is_list || PyList_CheckExact(o)) {
        Py_ssize_t n = (!wraparound) ? i : ((likely(i >= 0)) ? i : i + PyList_GET_SIZE(o));
        if ((CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS && !__Pyx_IS_UNIQUELY_REFERENCED(o, unsafe_shared))) {
            Py_INCREF(v);
            return PyList_SetItem(o, n, v);
        } else if ((!boundscheck) || likely(__Pyx_is_valid_index(n, PyList_GET_SIZE(o)))) {
            PyObject* old;
            Py_INCREF(v);
            old = PyList_GET_ITEM(o, n);
            PyList_SET_ITEM(o, n, v);
            Py_DECREF(old);
            return 0;
        }
    } else
#endif
#if CYTHON_USE_TYPE_SLOTS && !CYTHON_COMPILING_IN_PYPY
    {
        PyMappingMethods *mm = Py_TYPE(o)->tp_as_mapping;
        PySequenceMethods *sm = Py_TYPE(o)->tp_as_sequence;
        if (!is_list && mm && mm->mp_ass_subscript) {
            int r;
            PyObject *key = PyLong_FromSsize_t(i);
            if (unlikely(!key)) return -1;
            r = mm->mp_ass_subscript(o, key, v);
            Py_DECREF(key);
            return r;
        }
        if (is_list || likely(sm && sm->sq_ass_item)) {
            if (wraparound && unlikely(i < 0) && likely(sm->sq_length)) {
                Py_ssize_t l = sm->sq_length(o);
                if (likely(l >= 0)) {
                    i += l;
                } else {
                    if (!PyErr_ExceptionMatches(PyExc_OverflowError))
                        return -1;
                    PyErr_Clear();
                }
            }
            return sm->sq_ass_item(o, i, v);
        }
    }
#else
    if (is_list || !PyMapping_Check(o)) {
        return PySequence_SetItem(o, i, v);
    }
#endif
    (void)wraparound;
    (void)boundscheck;
    return __Pyx_SetItemInt_Generic(o, PyLong_FromSsize_t(i), v);
}

/* pybuiltin_invalid (used by pyint_simplify) */
static void __Pyx_PyBuiltin_Invalid(PyObject *obj, const char *type_name, const char *argname) {
    __Pyx_TypeName obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj));
    if (argname) {
        PyErr_Format(PyExc_TypeError,
            "Argument '%.200s' has incorrect type (expected %.200s, got " __Pyx_FMT_TYPENAME ")",
            argname, type_name, obj_type_name
        );
    } else {
        PyErr_Format(PyExc_TypeError,
            "Expected %.200s, got " __Pyx_FMT_TYPENAME,
            type_name, obj_type_name
        );
    }
    __Pyx_DECREF_TypeName(obj_type_name);
}

/* pyint_simplify */
static CYTHON_INLINE int __Pyx_PyInt_FromNumber(PyObject **number_var, const char *argname, int accept_none) {
    PyObject *number = *number_var;
    if (likely((accept_none && number == Py_None) || PyLong_CheckExact(number))) {
        return 0;
    }
    PyObject *int_object;
    if (likely(PyNumber_Check(number))) {
        int_object = PyNumber_Long(number);
        if (unlikely(!int_object)) goto bad;
    } else {
        __Pyx_PyBuiltin_Invalid(number, "int", argname);
        goto bad;
    }
    *number_var = int_object;
    Py_DECREF(number);
    return 0;
bad:
    *number_var = NULL;
    Py_DECREF(number);
    return -1;
}

/* DictGetItem */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject *__Pyx_PyDict_GetItem(PyObject *d, PyObject* key) {
    PyObject *value;
    if (unlikely(__Pyx_PyDict_GetItemRef(d, key, &value) == 0)) { // no value, no error
        if (unlikely(PyTuple_Check(key))) {
            PyObject* args = PyTuple_Pack(1, key);
            if (likely(args)) {
                PyErr_SetObject(PyExc_KeyError, args);
                Py_DECREF(args);
            }
        } else {
            PyErr_SetObject(PyExc_KeyError, key);
        }
    }
    return value;
}
#endif

/* pybytes_as_double (used by pyunicode_as_double) */
static double __Pyx_SlowPyString_AsDouble(PyObject *obj) {
    PyObject *float_value = PyFloat_FromString(obj);
    if (likely(float_value)) {
        double value = __Pyx_PyFloat_AS_DOUBLE(float_value);
        Py_DECREF(float_value);
        return value;
    }
    return (double)-1;
}
static const char* __Pyx__PyBytes_AsDouble_Copy(const char* start, char* buffer, Py_ssize_t length) {
    int last_was_punctuation = 1;
    int parse_error_found = 0;
    Py_ssize_t i;
    for (i=0; i < length; i++) {
        char chr = start[i];
        int is_punctuation = (chr == '_') | (chr == '.') | (chr == 'e') | (chr == 'E');
        *buffer = chr;
        buffer += (chr != '_');
        parse_error_found |= last_was_punctuation & is_punctuation;
        last_was_punctuation = is_punctuation;
    }
    parse_error_found |= last_was_punctuation;
    *buffer = '\0';
    return unlikely(parse_error_found) ? NULL : buffer;
}
static double __Pyx__PyBytes_AsDouble_inf_nan(const char* start, Py_ssize_t length) {
    int matches = 1;
    char sign = start[0];
    int is_signed = (sign == '+') | (sign == '-');
    start += is_signed;
    length -= is_signed;
    switch (start[0]) {
        #ifdef Py_NAN
        case 'n':
        case 'N':
            if (unlikely(length != 3)) goto parse_failure;
            matches &= (start[1] == 'a' || start[1] == 'A');
            matches &= (start[2] == 'n' || start[2] == 'N');
            if (unlikely(!matches)) goto parse_failure;
            return (sign == '-') ? -Py_NAN : Py_NAN;
        #endif
        case 'i':
        case 'I':
            if (unlikely(length < 3)) goto parse_failure;
            matches &= (start[1] == 'n' || start[1] == 'N');
            matches &= (start[2] == 'f' || start[2] == 'F');
            if (likely(length == 3 && matches))
                return (sign == '-') ? -Py_HUGE_VAL : Py_HUGE_VAL;
            if (unlikely(length != 8)) goto parse_failure;
            matches &= (start[3] == 'i' || start[3] == 'I');
            matches &= (start[4] == 'n' || start[4] == 'N');
            matches &= (start[5] == 'i' || start[5] == 'I');
            matches &= (start[6] == 't' || start[6] == 'T');
            matches &= (start[7] == 'y' || start[7] == 'Y');
            if (unlikely(!matches)) goto parse_failure;
            return (sign == '-') ? -Py_HUGE_VAL : Py_HUGE_VAL;
        case '.': case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':
            break;
        default:
            goto parse_failure;
    }
    return 0.0;
parse_failure:
    return -1.0;
}
static CYTHON_INLINE int __Pyx__PyBytes_AsDouble_IsSpace(char ch) {
    return (ch == 0x20) | !((ch < 0x9) | (ch > 0xd));
}
CYTHON_UNUSED static double __Pyx__PyBytes_AsDouble(PyObject *obj, const char* start, Py_ssize_t length) {
    double value;
    Py_ssize_t i, digits;
    const char *last = start + length;
    char *end;
    while (__Pyx__PyBytes_AsDouble_IsSpace(*start))
        start++;
    while (start < last - 1 && __Pyx__PyBytes_AsDouble_IsSpace(last[-1]))
        last--;
    length = last - start;
    if (unlikely(length <= 0)) goto fallback;
    value = __Pyx__PyBytes_AsDouble_inf_nan(start, length);
    if (unlikely(value == -1.0)) goto fallback;
    if (value != 0.0) return value;
    digits = 0;
    for (i=0; i < length; digits += start[i++] != '_');
    if (likely(digits == length)) {
        value = PyOS_string_to_double(start, &end, NULL);
    } else if (digits < 40) {
        char number[40];
        last = __Pyx__PyBytes_AsDouble_Copy(start, number, length);
        if (unlikely(!last)) goto fallback;
        value = PyOS_string_to_double(number, &end, NULL);
    } else {
        char *number = (char*) PyMem_Malloc((digits + 1) * sizeof(char));
        if (unlikely(!number)) goto fallback;
        last = __Pyx__PyBytes_AsDouble_Copy(start, number, length);
        if (unlikely(!last)) {
            PyMem_Free(number);
            goto fallback;
        }
        value = PyOS_string_to_double(number, &end, NULL);
        PyMem_Free(number);
    }
    if (likely(end == last) || (value == (double)-1 && PyErr_Occurred())) {
        return value;
    }
fallback:
    return __Pyx_SlowPyString_AsDouble(obj);
}

/* SliceObject */
static CYTHON_INLINE PyObject* __Pyx_PyObject_GetSlice(PyObject* obj,
        Py_ssize_t cstart, Py_ssize_t cstop,
        PyObject** _py_start, PyObject** _py_stop, PyObject** _py_slice,
        int has_cstart, int has_cstop, CYTHON_UNUSED int wraparound) {
    __Pyx_TypeName obj_type_name;
#if CYTHON_USE_TYPE_SLOTS
    PyMappingMethods* mp = Py_TYPE(obj)->tp_as_mapping;
    if (likely(mp && mp->mp_subscript))
#endif
    {
        PyObject* result;
        PyObject *py_slice, *py_start, *py_stop;
        if (_py_slice) {
            py_slice = *_py_slice;
        } else {
            PyObject* owned_start = NULL;
            PyObject* owned_stop = NULL;
            if (_py_start) {
                py_start = *_py_start;
            } else {
                if (has_cstart) {
                    owned_start = py_start = PyLong_FromSsize_t(cstart);
                    if (unlikely(!py_start)) goto bad;
                } else
                    py_start = Py_None;
            }
            if (_py_stop) {
                py_stop = *_py_stop;
            } else {
                if (has_cstop) {
                    owned_stop = py_stop = PyLong_FromSsize_t(cstop);
                    if (unlikely(!py_stop)) {
                        Py_XDECREF(owned_start);
                        goto bad;
                    }
                } else
                    py_stop = Py_None;
            }
            py_slice = PySlice_New(py_start, py_stop, Py_None);
            Py_XDECREF(owned_start);
            Py_XDECREF(owned_stop);
            if (unlikely(!py_slice)) goto bad;
        }
#if CYTHON_USE_TYPE_SLOTS
        result = mp->mp_subscript(obj, py_slice);
#else
        result = PyObject_GetItem(obj, py_slice);
#endif
        if (!_py_slice) {
            Py_DECREF(py_slice);
        }
        return result;
    }
    obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj));
    PyErr_Format(PyExc_TypeError,
        "'" __Pyx_FMT_TYPENAME "' object is unsliceable", obj_type_name);
    __Pyx_DECREF_TypeName(obj_type_name);
bad:
    return NULL;
}

/* HasAttr (used by ImportImpl) */
#if __PYX_LIMITED_VERSION_HEX < 0x030d0000
static CYTHON_INLINE int __Pyx_HasAttr(PyObject *o, PyObject *n) {
    PyObject *r;
    if (unlikely(!PyUnicode_Check(n))) {
        PyErr_SetString(PyExc_TypeError,
                        "hasattr(): attribute name must be string");
        return -1;
    }
    r = __Pyx_PyObject_GetAttrStrNoError(o, n);
    if (!r) {
        return (unlikely(PyErr_Occurred())) ? -1 : 0;
    } else {
        Py_DECREF(r);
        return 1;
    }
}
#endif

/* ImportImpl (used by Import) */
static int __Pyx__Import_GetModule(PyObject *qualname, PyObject **module) {
    PyObject *imported_module = PyImport_GetModule(qualname);
    if (unlikely(!imported_module)) {
        *module = NULL;
        if (PyErr_Occurred()) {
            return -1;
        }
        return 0;
    }
    *module = imported_module;
    return 1;
}
static int __Pyx__Import_Lookup(PyObject *qualname, PyObject *const *imported_names, Py_ssize_t len_imported_names, PyObject **module) {
    PyObject *imported_module;
    PyObject *top_level_package_name;
    Py_ssize_t i;
    int status, module_found;
    Py_ssize_t dot_index;
    module_found = __Pyx__Import_GetModule(qualname, &imported_module);
    if (unlikely(!module_found || module_found == -1)) {
        *module = NULL;
        return module_found;
    }
    if (imported_names) {
        for (i = 0; i < len_imported_names; i++) {
            PyObject *imported_name = imported_names[i];
#if __PYX_LIMITED_VERSION_HEX < 0x030d0000
            int has_imported_attribute = PyObject_HasAttr(imported_module, imported_name);
#else
            int has_imported_attribute = PyObject_HasAttrWithError(imported_module, imported_name);
            if (unlikely(has_imported_attribute == -1)) goto error;
#endif
            if (!has_imported_attribute) {
                goto not_found;
            }
        }
        *module = imported_module;
        return 1;
    }
    dot_index = PyUnicode_FindChar(qualname, '.', 0, PY_SSIZE_T_MAX, 1);
    if (dot_index == -1) {
        *module = imported_module;
        return 1;
    }
    if (unlikely(dot_index == -2)) goto error;
    top_level_package_name = PyUnicode_Substring(qualname, 0, dot_index);
    if (unlikely(!top_level_package_name)) goto error;
    Py_DECREF(imported_module);
    status = __Pyx__Import_GetModule(top_level_package_name, module);
    Py_DECREF(top_level_package_name);
    return status;
error:
    Py_DECREF(imported_module);
    *module = NULL;
    return -1;
not_found:
    Py_DECREF(imported_module);
    *module = NULL;
    return 0;
}
static PyObject *__Pyx__Import(PyObject *name, PyObject *const *imported_names, Py_ssize_t len_imported_names, PyObject *qualname, PyObject *moddict, int level) {
    PyObject *module = 0;
    PyObject *empty_dict = 0;
    PyObject *from_list = 0;
    int module_found;
    if (!qualname) {
        qualname = name;
    }
    module_found = __Pyx__Import_Lookup(qualname, imported_names, len_imported_names, &module);
    if (likely(module_found == 1)) {
        return module;
    } else if (unlikely(module_found == -1)) {
        return NULL;
    }
    empty_dict = PyDict_New();
    if (unlikely(!empty_dict))
        goto bad;
    if (imported_names) {
#if CYTHON_COMPILING_IN_CPYTHON
        from_list = __Pyx_PyList_FromArray(imported_names, len_imported_names);
        if (unlikely(!from_list))
            goto bad;
#else
        from_list = PyList_New(len_imported_names);
        if (unlikely(!from_list)) goto bad;
        for (Py_ssize_t i=0; i<len_imported_names; ++i) {
            if (PyList_SetItem(from_list, i, __Pyx_NewRef(imported_names[i])) < 0) goto bad;
        }
#endif
    }
    if (level == -1) {
        const char* package_sep = strchr(__Pyx_MODULE_NAME, '.');
        if (package_sep != (0)) {
            module = PyImport_ImportModuleLevelObject(
                name, moddict, empty_dict, from_list, 1);
            if (unlikely(!module)) {
                if (unlikely(!PyErr_ExceptionMatches(PyExc_ImportError)))
                    goto bad;
                PyErr_Clear();
            }
        }
        level = 0;
    }
    if (!module) {
        module = PyImport_ImportModuleLevelObject(
            name, moddict, empty_dict, from_list, level);
    }
bad:
    Py_XDECREF(from_list);
    Py_XDECREF(empty_dict);
    return module;
}

/* Import */
static PyObject *__Pyx_Import(PyObject *name, PyObject *const *imported_names, Py_ssize_t len_imported_names, PyObject *qualname, int level) {
    return __Pyx__Import(name, imported_names, len_imported_names, qualname, __pyx_mstate_global->__pyx_d, level);
}

/* pyobject_as_double */
static double __Pyx__PyObject_AsDouble(PyObject* obj) {
    if (PyUnicode_CheckExact(obj)) {
        return __Pyx_PyUnicode_AsDouble(obj);
    } else if (PyBytes_CheckExact(obj)) {
        return __Pyx_PyBytes_AsDouble(obj);
    } else if (PyByteArray_CheckExact(obj)) {
        return __Pyx_PyByteArray_AsDouble(obj);
    } else {
        PyObject* float_value;
#if !CYTHON_USE_TYPE_SLOTS
        float_value = PyNumber_Float(obj);  if ((0)) goto bad;
        (void)__Pyx_PyObject_CallOneArg;
#else
        PyNumberMethods *nb = Py_TYPE(obj)->tp_as_number;
        if (likely(nb) && likely(nb->nb_float)) {
            float_value = nb->nb_float(obj);
            if (likely(float_value) && unlikely(!PyFloat_Check(float_value))) {
                __Pyx_TypeName float_value_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(float_value));
                PyErr_Format(PyExc_TypeError,
                    "__float__ returned non-float (type " __Pyx_FMT_TYPENAME ")",
                    float_value_type_name);
                __Pyx_DECREF_TypeName(float_value_type_name);
                Py_DECREF(float_value);
                goto bad;
            }
        } else {
            float_value = __Pyx_PyObject_CallOneArg((PyObject*)&PyFloat_Type, obj);
        }
#endif
        if (likely(float_value)) {
            double value = __Pyx_PyFloat_AS_DOUBLE(float_value);
            Py_DECREF(float_value);
            return value;
        }
    }
bad:
    return (double)-1;
}

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_MultiplyCObj(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceMultiply : PyNumber_Multiply)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_MultiplyCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long a = intval;
    long b;
    const PY_LONG_LONG lla = intval;
    PY_LONG_LONG llb;
    if (unlikely(__Pyx_PyLong_IsZero(op2))) {
        return __Pyx_NewRef(op2);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op2);
    const digit* digits = __Pyx_PyLong_Digits(op2);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op2);
    if (likely(size == 1)) {
        b = (long) digits[0];
        if (!is_positive) b *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT+30) {
                    b = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT+30) {
                    llb = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT+30) {
                    b = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT+30) {
                    llb = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT+30) {
                    b = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT+30) {
                    llb = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_multiply(op1, op2);
    }
    calculate_long:
        CYTHON_UNUSED_VAR(a);
        CYTHON_UNUSED_VAR(b);
        llb = b;
        goto calculate_long_long;
    calculate_long_long:
        {
            PY_LONG_LONG llx;
            llx = lla * llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static PyObject* __Pyx_Float___Pyx_PyLong_MultiplyCObj(PyObject *float_val, long intval, int zerodivision_check) {
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long a = intval;
    double b = __Pyx_PyFloat_AS_DOUBLE(float_val);
        double result;
        
        result = ((double)a) * (double)b;
        return PyFloat_FromDouble(result);
}
static CYTHON_INLINE PyObject* __Pyx_PyLong_MultiplyCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op2))) {
        return __Pyx_Unpacked___Pyx_PyLong_MultiplyCObj(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    if (PyFloat_CheckExact(op2)) {
        return __Pyx_Float___Pyx_PyLong_MultiplyCObj(op2, intval, zerodivision_check);
    }
    return __Pyx_Fallback___Pyx_PyLong_MultiplyCObj(op1, op2, inplace);
}
#endif

/* RaiseUnexpectedTypeError */
static int
__Pyx_RaiseUnexpectedTypeError(const char *expected, PyObject *obj)
{
    __Pyx_TypeName obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj));
    PyErr_Format(PyExc_TypeError, "Expected %s, got " __Pyx_FMT_TYPENAME,
                 expected, obj_type_name);
    __Pyx_DECREF_TypeName(obj_type_name);
    return 0;
}

/* PyObjectFormatAndDecref */
static CYTHON_INLINE PyObject* __Pyx_PyObject_FormatSimpleAndDecref(PyObject* s, PyObject* f) {
    if (unlikely(!s)) return NULL;
    if (likely(PyUnicode_CheckExact(s))) return s;
    return __Pyx_PyObject_FormatAndDecref(s, f);
}
static CYTHON_INLINE PyObject* __Pyx_PyObject_FormatAndDecref(PyObject* s, PyObject* f) {
    PyObject *result;
    if (unlikely(!s)) return NULL;
    result = PyObject_Format(s, f);
    Py_DECREF(s);
    return result;
}

/* JoinPyUnicode */
static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength,
                                      Py_UCS4 max_char) {
#if CYTHON_USE_UNICODE_INTERNALS && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    PyObject *result_uval;
    int result_ukind, kind_shift;
    Py_ssize_t i, char_pos;
    void *result_udata;
    if (max_char > 1114111) max_char = 1114111;
    result_uval = PyUnicode_New(result_ulength, max_char);
    if (unlikely(!result_uval)) return NULL;
    result_ukind = (max_char <= 255) ? PyUnicode_1BYTE_KIND : (max_char <= 65535) ? PyUnicode_2BYTE_KIND : PyUnicode_4BYTE_KIND;
    kind_shift = (result_ukind == PyUnicode_4BYTE_KIND) ? 2 : result_ukind - 1;
    result_udata = PyUnicode_DATA(result_uval);
    assert(kind_shift == 2 || kind_shift == 1 || kind_shift == 0);
    if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - result_ulength < 0))
        goto overflow;
    char_pos = 0;
    for (i=0; i < value_count; i++) {
        int ukind;
        Py_ssize_t ulength;
        void *udata;
        PyObject *uval = values[i];
        #if !CYTHON_COMPILING_IN_LIMITED_API
        if (__Pyx_PyUnicode_READY(uval) == (-1))
            goto bad;
        #endif
        ulength = __Pyx_PyUnicode_GET_LENGTH(uval);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(ulength < 0)) goto bad;
        #endif
        if (unlikely(!ulength))
            continue;
        if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - ulength < char_pos))
            goto overflow;
        ukind = __Pyx_PyUnicode_KIND(uval);
        udata = __Pyx_PyUnicode_DATA(uval);
        if (ukind == result_ukind) {
            memcpy((char *)result_udata + (char_pos << kind_shift), udata, (size_t) (ulength << kind_shift));
        } else {
            #if PY_VERSION_HEX >= 0x030d0000
            if (unlikely(PyUnicode_CopyCharacters(result_uval, char_pos, uval, 0, ulength) < 0)) goto bad;
            #elif CYTHON_COMPILING_IN_CPYTHON || defined(_PyUnicode_FastCopyCharacters)
            _PyUnicode_FastCopyCharacters(result_uval, char_pos, uval, 0, ulength);
            #else
            Py_ssize_t j;
            for (j=0; j < ulength; j++) {
                Py_UCS4 uchar = __Pyx_PyUnicode_READ(ukind, udata, j);
                __Pyx_PyUnicode_WRITE(result_ukind, result_udata, char_pos+j, uchar);
            }
            #endif
        }
        char_pos += ulength;
    }
    return result_uval;
overflow:
    PyErr_SetString(PyExc_OverflowError, "join() result is too long for a Python string");
bad:
    Py_DECREF(result_uval);
    return NULL;
#else
    Py_ssize_t i;
    PyObject *result = NULL;
    PyObject *value_tuple = PyTuple_New(value_count);
    if (unlikely(!value_tuple)) return NULL;
    CYTHON_UNUSED_VAR(max_char);
    CYTHON_UNUSED_VAR(result_ulength);
    for (i=0; i<value_count; i++) {
        if (__Pyx_PyTuple_SET_ITEM(value_tuple, i, values[i]) != (0)) goto bad;
        Py_INCREF(values[i]);
    }
    result = PyUnicode_Join(__pyx_mstate_global->__pyx_empty_unicode, value_tuple);
bad:
    Py_DECREF(value_tuple);
    return result;
#endif
}

/* RaiseClosureNameError */
static void __Pyx_RaiseClosureNameError(const char *varname) {
    PyErr_Format(PyExc_NameError, "free variable '%s' referenced before assignment in enclosing scope", varname);
}

/* pep479 */
static void __Pyx_Generator_Replace_StopIteration(int in_async_gen) {
    PyObject *exc, *val, *tb, *cur_exc, *new_exc;
    __Pyx_PyThreadState_declare
    int is_async_stopiteration = 0;
    CYTHON_MAYBE_UNUSED_VAR(in_async_gen);
    __Pyx_PyThreadState_assign
    cur_exc = __Pyx_PyErr_CurrentExceptionType();
    if (likely(!__Pyx_PyErr_GivenExceptionMatches(cur_exc, PyExc_StopIteration))) {
        if (in_async_gen && unlikely(__Pyx_PyErr_GivenExceptionMatches(cur_exc, PyExc_StopAsyncIteration))) {
            is_async_stopiteration = 1;
        } else {
            return;
        }
    }
    __Pyx_GetException(&exc, &val, &tb);
    Py_XDECREF(exc);
    Py_XDECREF(tb);
    new_exc = PyObject_CallFunction(PyExc_RuntimeError, "s",
        is_async_stopiteration ? "async generator raised StopAsyncIteration" :
        in_async_gen ? "async generator raised StopIteration" :
        "generator raised StopIteration");
    if (!new_exc) {
        Py_XDECREF(val);
        return;
    }
    PyException_SetCause(new_exc, val); // steals ref to val
    PyErr_SetObject(PyExc_RuntimeError, new_exc);
}

/* KeywordStringCheck */
static int __Pyx_CheckKeywordStrings(
    const char* function_name,
    PyObject *kw)
{
#if CYTHON_COMPILING_IN_PYPY && !defined(PyArg_ValidateKeywordArguments)
    CYTHON_UNUSED_VAR(function_name);
    CYTHON_UNUSED_VAR(kw);
    return 0;
#else
    if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kw))) {
#if PY_VERSION_HEX >= 0x03090000
        CYTHON_UNUSED_VAR(function_name);
#else
        Py_ssize_t kwsize;
        #if CYTHON_ASSUME_SAFE_SIZE
        kwsize = PyTuple_GET_SIZE(kw);
        #else
        kwsize = PyTuple_Size(kw);
        if (unlikely(kwsize < 0)) return -1;
        #endif
        for (Py_ssize_t pos = 0; pos < kwsize; pos++) {
            PyObject* key = NULL;
            #if CYTHON_ASSUME_SAFE_MACROS
            key = PyTuple_GET_ITEM(kw, pos);
            #else
            key = PyTuple_GetItem(kw, pos);
            if (unlikely(!key)) return -1;
            #endif
            if (unlikely(!PyUnicode_Check(key))) {
                PyErr_Format(PyExc_TypeError,
                    "%.200s() keywords must be strings", function_name);
                return -1;
            }
        }
#endif
    } else {
        if (unlikely(!PyArg_ValidateKeywordArguments(kw))) return -1;
    }
    return 0;
#endif
}

/* PyObjectCallNoArg (used by PyObjectCallMethod0) */
static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func) {
    PyObject *arg[2] = {NULL, NULL};
    return __Pyx_PyObject_FastCall(func, arg + 1, 0 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET);
}

/* PyObjectCallMethod0 (used by dict_iter) */
static PyObject* __Pyx_PyObject_CallMethod0(PyObject* obj, PyObject* method_name) {
#if CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000))
    PyObject *args[1] = {obj};
    (void) __Pyx_PyObject_CallOneArg;
    (void) __Pyx_PyObject_CallNoArg;
    return PyObject_VectorcallMethod(method_name, args, 1 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL);
#else
    PyObject *method = NULL, *result = NULL;
    int is_method = __Pyx_PyObject_GetMethod(obj, method_name, &method);
    if (likely(is_method)) {
        result = __Pyx_PyObject_CallOneArg(method, obj);
        Py_DECREF(method);
        return result;
    }
    if (unlikely(!method)) goto bad;
    result = __Pyx_PyObject_CallNoArg(method);
    Py_DECREF(method);
bad:
    return result;
#endif
}

/* RaiseNoneIterError (used by UnpackTupleError) */
static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void) {
    PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable");
}

/* UnpackTupleError (used by UnpackTuple2) */
static void __Pyx_UnpackTupleError(PyObject *t, Py_ssize_t index) {
    if (t == Py_None) {
      __Pyx_RaiseNoneNotIterableError();
    } else {
      Py_ssize_t size = __Pyx_PyTuple_GET_SIZE(t);
 #if !CYTHON_ASSUME_SAFE_SIZE
      if (unlikely(size < 0)) return;
 #endif
      if (size < index) {
        __Pyx_RaiseNeedMoreValuesError(size);
      } else {
        __Pyx_RaiseTooManyValuesError(index);
      }
    }
}

/* UnpackTuple2 (used by dict_iter) */
static CYTHON_INLINE int __Pyx_unpack_tuple2(
        PyObject* tuple, PyObject** value1, PyObject** value2, int is_tuple, int has_known_size, int decref_tuple) {
    if (likely(is_tuple || PyTuple_Check(tuple))) {
        Py_ssize_t size;
        if (has_known_size) {
            return __Pyx_unpack_tuple2_exact(tuple, value1, value2, decref_tuple);
        }
        size = __Pyx_PyTuple_GET_SIZE(tuple);
        if (likely(size == 2)) {
            return __Pyx_unpack_tuple2_exact(tuple, value1, value2, decref_tuple);
        }
        if (size >= 0) {
            __Pyx_UnpackTupleError(tuple, 2);
        }
        return -1;
    } else {
        return __Pyx_unpack_tuple2_generic(tuple, value1, value2, has_known_size, decref_tuple);
    }
}
static CYTHON_INLINE int __Pyx_unpack_tuple2_exact(
        PyObject* tuple, PyObject** pvalue1, PyObject** pvalue2, int decref_tuple) {
    PyObject *value1 = NULL, *value2 = NULL;
#if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS
    value1 = __Pyx_PySequence_ITEM(tuple, 0);  if (unlikely(!value1)) goto bad;
    value2 = __Pyx_PySequence_ITEM(tuple, 1);  if (unlikely(!value2)) goto bad;
#else
    value1 = PyTuple_GET_ITEM(tuple, 0);  Py_INCREF(value1);
    value2 = PyTuple_GET_ITEM(tuple, 1);  Py_INCREF(value2);
#endif
    if (decref_tuple) {
        Py_DECREF(tuple);
    }
    *pvalue1 = value1;
    *pvalue2 = value2;
    return 0;
#if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS
bad:
    Py_XDECREF(value1);
    Py_XDECREF(value2);
    if (decref_tuple) { Py_XDECREF(tuple); }
    return -1;
#endif
}
static int __Pyx_unpack_tuple2_generic(PyObject* tuple, PyObject** pvalue1, PyObject** pvalue2,
                                       int has_known_size, int decref_tuple) {
    Py_ssize_t index;
    PyObject *value1 = NULL, *value2 = NULL, *iter = NULL;
    iternextfunc iternext;
    iter = PyObject_GetIter(tuple);
    if (unlikely(!iter)) goto bad;
    if (decref_tuple) { Py_DECREF(tuple); tuple = NULL; }
    iternext = __Pyx_PyObject_GetIterNextFunc(iter);
    value1 = iternext(iter); if (unlikely(!value1)) { index = 0; goto unpacking_failed; }
    value2 = iternext(iter); if (unlikely(!value2)) { index = 1; goto unpacking_failed; }
    if (!has_known_size && unlikely(__Pyx_IternextUnpackEndCheck(iternext(iter), 2))) goto bad;
    Py_DECREF(iter);
    *pvalue1 = value1;
    *pvalue2 = value2;
    return 0;
unpacking_failed:
    if (!has_known_size && __Pyx_IterFinish() == 0)
        __Pyx_RaiseNeedMoreValuesError(index);
bad:
    Py_XDECREF(iter);
    Py_XDECREF(value1);
    Py_XDECREF(value2);
    if (decref_tuple) { Py_XDECREF(tuple); }
    return -1;
}

/* dict_iter */
#if CYTHON_COMPILING_IN_PYPY
#include <string.h>
#endif
static CYTHON_INLINE PyObject* __Pyx_dict_iterator(PyObject* iterable, int is_dict, PyObject* method_name,
                                                   Py_ssize_t* p_orig_length, int* p_source_is_dict) {
    is_dict = is_dict || likely(PyDict_CheckExact(iterable));
    *p_source_is_dict = is_dict;
    if (is_dict) {
#if !CYTHON_COMPILING_IN_PYPY
        *p_orig_length = PyDict_Size(iterable);
        Py_INCREF(iterable);
        return iterable;
#else
        static PyObject *py_items = NULL, *py_keys = NULL, *py_values = NULL;
        PyObject **pp = NULL;
        if (method_name) {
            const char *name = PyUnicode_AsUTF8(method_name);
            if (strcmp(name, "iteritems") == 0) pp = &py_items;
            else if (strcmp(name, "iterkeys") == 0) pp = &py_keys;
            else if (strcmp(name, "itervalues") == 0) pp = &py_values;
            if (pp) {
                if (!*pp) {
                    *pp = PyUnicode_FromString(name + 4);
                    if (!*pp)
                        return NULL;
                }
                method_name = *pp;
            }
        }
#endif
    }
    *p_orig_length = 0;
    if (method_name) {
        PyObject* iter;
        iterable = __Pyx_PyObject_CallMethod0(iterable, method_name);
        if (!iterable)
            return NULL;
#if !CYTHON_COMPILING_IN_PYPY
        if (PyTuple_CheckExact(iterable) || PyList_CheckExact(iterable))
            return iterable;
#endif
        iter = PyObject_GetIter(iterable);
        Py_DECREF(iterable);
        return iter;
    }
    return PyObject_GetIter(iterable);
}
#if !CYTHON_AVOID_BORROWED_REFS
static CYTHON_INLINE int __Pyx_dict_iter_next_source_is_dict(
        PyObject* iter_obj, CYTHON_NCP_UNUSED Py_ssize_t orig_length, CYTHON_NCP_UNUSED Py_ssize_t* ppos,
        PyObject** pkey, PyObject** pvalue, PyObject** pitem) {
    PyObject *key, *value;
    if (unlikely(orig_length != PyDict_Size(iter_obj))) {
        PyErr_SetString(PyExc_RuntimeError, "dictionary changed size during iteration");
        return -1;
    }
    if (unlikely(!PyDict_Next(iter_obj, ppos, &key, &value))) {
        return 0;
    }
    if (pitem) {
        PyObject* tuple = PyTuple_New(2);
        if (unlikely(!tuple)) {
            return -1;
        }
        Py_INCREF(key);
        Py_INCREF(value);
        #if CYTHON_ASSUME_SAFE_MACROS
        PyTuple_SET_ITEM(tuple, 0, key);
        PyTuple_SET_ITEM(tuple, 1, value);
        #else
        if (unlikely(PyTuple_SetItem(tuple, 0, key) < 0)) {
            Py_DECREF(value);
            Py_DECREF(tuple);
            return -1;
        }
        if (unlikely(PyTuple_SetItem(tuple, 1, value) < 0)) {
            Py_DECREF(tuple);
            return -1;
        }
        #endif
        *pitem = tuple;
    } else {
        if (pkey) {
            Py_INCREF(key);
            *pkey = key;
        }
        if (pvalue) {
            Py_INCREF(value);
            *pvalue = value;
        }
    }
    return 1;
}
#endif
static CYTHON_INLINE int __Pyx_dict_iter_next(
        PyObject* iter_obj, CYTHON_NCP_UNUSED Py_ssize_t orig_length, CYTHON_NCP_UNUSED Py_ssize_t* ppos,
        PyObject** pkey, PyObject** pvalue, PyObject** pitem, int source_is_dict) {
    PyObject* next_item;
#if !CYTHON_AVOID_BORROWED_REFS
    if (source_is_dict) {
        int result;
#if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
        Py_BEGIN_CRITICAL_SECTION(iter_obj);
#endif
        result = __Pyx_dict_iter_next_source_is_dict(iter_obj, orig_length, ppos, pkey, pvalue, pitem);
#if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
        Py_END_CRITICAL_SECTION();
#endif
        return result;
    } else if (PyTuple_CheckExact(iter_obj)) {
        Py_ssize_t pos = *ppos;
        Py_ssize_t tuple_size = __Pyx_PyTuple_GET_SIZE(iter_obj);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(tuple_size < 0)) return -1;
        #endif
        if (unlikely(pos >= tuple_size)) return 0;
        *ppos = pos + 1;
        #if CYTHON_ASSUME_SAFE_MACROS
        next_item = PyTuple_GET_ITEM(iter_obj, pos);
        #else
        next_item = PyTuple_GetItem(iter_obj, pos);
        if (unlikely(!next_item)) return -1;
        #endif
        Py_INCREF(next_item);
    } else if (PyList_CheckExact(iter_obj)) {
        Py_ssize_t pos = *ppos;
        Py_ssize_t list_size = __Pyx_PyList_GET_SIZE(iter_obj);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(list_size < 0)) return -1;
        #endif
        if (unlikely(pos >= list_size)) return 0;
        *ppos = pos + 1;
        next_item = __Pyx_PyList_GetItemRef(iter_obj, pos);
        if (unlikely(!next_item)) return -1;
    } else
#endif
    {
        next_item = PyIter_Next(iter_obj);
        if (unlikely(!next_item)) {
            return __Pyx_IterFinish();
        }
    }
    if (pitem) {
        *pitem = next_item;
    } else if (pkey && pvalue) {
        if (__Pyx_unpack_tuple2(next_item, pkey, pvalue, source_is_dict, source_is_dict, 1))
            return -1;
    } else if (pkey) {
        *pkey = next_item;
    } else {
        *pvalue = next_item;
    }
    return 1;
}

/* RejectKeywords */
static void __Pyx_RejectKeywords(const char* function_name, PyObject *kwds) {
    PyObject *key = NULL;
    if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kwds))) {
        key = __Pyx_PySequence_ITEM(kwds, 0);
    } else {
#if CYTHON_AVOID_BORROWED_REFS
        PyObject *pos = NULL;
#else
        Py_ssize_t pos = 0;
#endif
#if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments)
        if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return;
#endif
        __Pyx_PyDict_NextRef(kwds, &pos, &key, NULL);
#if CYTHON_AVOID_BORROWED_REFS
        Py_XDECREF(pos);
#endif
    }
    if (likely(key)) {
        PyErr_Format(PyExc_TypeError,
            "%s() got an unexpected keyword argument '%U'",
            function_name, key);
        Py_DECREF(key);
    }
}

/* UnicodeConcatInPlace */
# if CYTHON_COMPILING_IN_CPYTHON
static int
__Pyx_unicode_modifiable(PyObject *unicode, int unsafe_shared)
{
    if (!__Pyx_IS_UNIQUELY_REFERENCED(unicode, unsafe_shared))
        return 0;
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX > 0x030F0000
    if (PyUnstable_Unicode_GET_CACHED_HASH(unicode) != -1)
        return 0;
#endif
    if (!PyUnicode_CheckExact(unicode))
        return 0;
    if (PyUnicode_CHECK_INTERNED(unicode))
        return 0;
    return 1;
}
static CYTHON_INLINE PyObject *__Pyx_PyUnicode_ConcatInPlaceImpl(PyObject **p_left, PyObject *right, int unsafe_shared
        #if CYTHON_REFNANNY
        , void* __pyx_refnanny
        #endif
    ) {
    PyObject *left = *p_left;
    Py_ssize_t left_len, right_len, new_len;
    if (unlikely(__Pyx_PyUnicode_READY(left) == -1))
        return NULL;
    if (unlikely(__Pyx_PyUnicode_READY(right) == -1))
        return NULL;
    left_len = PyUnicode_GET_LENGTH(left);
    if (left_len == 0) {
        Py_INCREF(right);
        return right;
    }
    right_len = PyUnicode_GET_LENGTH(right);
    if (right_len == 0) {
        Py_INCREF(left);
        return left;
    }
    if (unlikely(left_len > PY_SSIZE_T_MAX - right_len)) {
        PyErr_SetString(PyExc_OverflowError,
                        "strings are too large to concat");
        return NULL;
    }
    new_len = left_len + right_len;
    if (__Pyx_unicode_modifiable(left, unsafe_shared)
            && PyUnicode_CheckExact(right)
            && PyUnicode_KIND(right) <= PyUnicode_KIND(left)
            && !(PyUnicode_IS_ASCII(left) && !PyUnicode_IS_ASCII(right))) {
        int ret;
        __Pyx_GIVEREF(*p_left);
        ret = PyUnicode_Resize(p_left, new_len);
        __Pyx_GOTREF(*p_left);
        if (unlikely(ret != 0))
            return NULL;
        #if PY_VERSION_HEX >= 0x030d0000
        if (unlikely(PyUnicode_CopyCharacters(*p_left, left_len, right, 0, right_len) < 0)) return NULL;
        #else
        _PyUnicode_FastCopyCharacters(*p_left, left_len, right, 0, right_len);
        #endif
        __Pyx_INCREF(*p_left);
        __Pyx_GIVEREF(*p_left);
        return *p_left;
    } else {
        return __Pyx_PyUnicode_Concat(left, right);
    }
  }
#endif

/* ExtTypeTest */
static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) {
    __Pyx_TypeName obj_type_name;
    __Pyx_TypeName type_name;
    if (unlikely(!type)) {
        PyErr_SetString(PyExc_SystemError, "Missing type object");
        return 0;
    }
    if (likely(__Pyx_TypeCheck(obj, type)))
        return 1;
    obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj));
    type_name = __Pyx_PyType_GetFullyQualifiedName(type);
    PyErr_Format(PyExc_TypeError,
                 "Cannot convert " __Pyx_FMT_TYPENAME " to " __Pyx_FMT_TYPENAME,
                 obj_type_name, type_name);
    __Pyx_DECREF_TypeName(obj_type_name);
    __Pyx_DECREF_TypeName(type_name);
    return 0;
}

/* PyObjectLookupSpecial */
#if CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS
static CYTHON_INLINE PyObject* __Pyx__PyObject_LookupSpecial(PyObject* obj, PyObject* attr_name, int with_error) {
    PyObject *res;
    PyTypeObject *tp = Py_TYPE(obj);
    res = _PyType_Lookup(tp, attr_name);
    if (likely(res)) {
        descrgetfunc f = Py_TYPE(res)->tp_descr_get;
        if (!f) {
            Py_INCREF(res);
        } else {
            res = f(res, obj, (PyObject *)tp);
        }
    } else if (with_error) {
        PyErr_SetObject(PyExc_AttributeError, attr_name);
    }
    return res;
}
#endif

/* PyFloatBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_PyFloat_SubtractObjC(PyObject *op1, PyObject *op2, double floatval, int inplace, int zerodivision_check) {
    const double b = floatval;
    double a, result;
    CYTHON_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    if (likely(PyFloat_CheckExact(op1))) {
        a = __Pyx_PyFloat_AS_DOUBLE(op1);
        
    } else
    if (likely(PyLong_CheckExact(op1))) {
        #if CYTHON_USE_PYLONG_INTERNALS
        if (__Pyx_PyLong_IsZero(op1)) {
            a = 0.0;
            
        } else if (__Pyx_PyLong_IsCompact(op1)) {
            a = (double) __Pyx_PyLong_CompactValue(op1);
        } else {
            const digit* digits = __Pyx_PyLong_Digits(op1);
            const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(op1);
            switch (size) {
                case -2:
                case 2:
                    if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (1 * PyLong_SHIFT < 53))) {
                        a = (double) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -2)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                case -3:
                case 3:
                    if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (2 * PyLong_SHIFT < 53))) {
                        a = (double) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -3)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                case -4:
                case 4:
                    if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT && ((8 * sizeof(unsigned long) < 53) || (3 * PyLong_SHIFT < 53))) {
                        a = (double) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                        if ((8 * sizeof(unsigned long) < 53) || (4 * PyLong_SHIFT < 53) || (a < (double) ((PY_LONG_LONG)1 << 53))) {
                            if (size == -4)
                                a = -a;
                            break;
                        }
                    }
                    CYTHON_FALLTHROUGH;
                default:
        #endif
                    a = PyLong_AsDouble(op1);
                    if (unlikely(a == -1.0 && PyErr_Occurred())) return NULL;
        #if CYTHON_USE_PYLONG_INTERNALS
            }
        }
        #endif
    } else {
        return (inplace ? PyNumber_InPlaceSubtract : PyNumber_Subtract)(op1, op2);
    }
        result = a - b;
        return PyFloat_FromDouble(result);
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_SubtractCObj(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceSubtract : PyNumber_Subtract)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_SubtractCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long a = intval;
    long b;
    const PY_LONG_LONG lla = intval;
    PY_LONG_LONG llb;
    if (unlikely(__Pyx_PyLong_IsZero(op2))) {
        return __Pyx_NewRef(op1);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op2);
    const digit* digits = __Pyx_PyLong_Digits(op2);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op2);
    if (likely(size == 1)) {
        b = (long) digits[0];
        if (!is_positive) b *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) {
                    b = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) {
                    llb = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) {
                    b = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) {
                    llb = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) {
                    b = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) b *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) {
                    llb = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) llb *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_subtract(op1, op2);
    }
    calculate_long:
        {
            long x;
            x = a - b;
            return PyLong_FromLong(x);
        }
    calculate_long_long:
        {
            PY_LONG_LONG llx;
            llx = lla - llb;
            return PyLong_FromLongLong(llx);
        }
    
}
#endif
static PyObject* __Pyx_Float___Pyx_PyLong_SubtractCObj(PyObject *float_val, long intval, int zerodivision_check) {
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long a = intval;
    double b = __Pyx_PyFloat_AS_DOUBLE(float_val);
        double result;
        
        result = ((double)a) - (double)b;
        return PyFloat_FromDouble(result);
}
static CYTHON_INLINE PyObject* __Pyx_PyLong_SubtractCObj(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op2))) {
        return __Pyx_Unpacked___Pyx_PyLong_SubtractCObj(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    if (PyFloat_CheckExact(op2)) {
        return __Pyx_Float___Pyx_PyLong_SubtractCObj(op2, intval, zerodivision_check);
    }
    return __Pyx_Fallback___Pyx_PyLong_SubtractCObj(op1, op2, inplace);
}
#endif

/* PyLongBinop */
#if !CYTHON_COMPILING_IN_PYPY
static PyObject* __Pyx_Fallback___Pyx_PyLong_FloorDivideObjC(PyObject *op1, PyObject *op2, int inplace) {
    return (inplace ? PyNumber_InPlaceFloorDivide : PyNumber_FloorDivide)(op1, op2);
}
#if CYTHON_USE_PYLONG_INTERNALS
static PyObject* __Pyx_Unpacked___Pyx_PyLong_FloorDivideObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(inplace);
    CYTHON_UNUSED_VAR(zerodivision_check);
    const long b = intval;
    long a;
    const PY_LONG_LONG llb = intval;
    PY_LONG_LONG lla;
    if (unlikely(__Pyx_PyLong_IsZero(op1))) {
        return __Pyx_NewRef(op1);
    }
    const int is_positive = __Pyx_PyLong_IsPos(op1);
    const digit* digits = __Pyx_PyLong_Digits(op1);
    const Py_ssize_t size = __Pyx_PyLong_DigitCount(op1);
    if (likely(size == 1)) {
        a = (long) digits[0];
        if (!is_positive) a *= -1;
    } else {
        switch (size) {
            case 2:
                if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) {
                    a = (long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 2 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 3:
                if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) {
                    a = (long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 3 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
            case 4:
                if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) {
                    a = (long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]));
                    if (!is_positive) a *= -1;
                    goto calculate_long;
                } else if (8 * sizeof(PY_LONG_LONG) - 1 > 4 * PyLong_SHIFT) {
                    lla = (PY_LONG_LONG) (((((((((unsigned PY_LONG_LONG)digits[3]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[2]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[1]) << PyLong_SHIFT) | (unsigned PY_LONG_LONG)digits[0]));
                    if (!is_positive) lla *= -1;
                    goto calculate_long_long;
                }
                break;
        }
        return PyLong_Type.tp_as_number->nb_floor_divide(op1, op2);
    }
    calculate_long:
        {
            long q, r;
            q = a / b;
            r = a - q*b;
            q -= ((r != 0) & ((r ^ b) < 0));
            return PyLong_FromLong(q);
        }
    calculate_long_long:
        {
            PY_LONG_LONG q, r;
            q = lla / llb;
            r = lla - q*llb;
            q -= ((r != 0) & ((r ^ llb) < 0));
            return PyLong_FromLongLong(q);
        }
    
}
#endif
static CYTHON_INLINE PyObject* __Pyx_PyLong_FloorDivideObjC(PyObject *op1, PyObject *op2, long intval, int inplace, int zerodivision_check) {
    CYTHON_MAYBE_UNUSED_VAR(intval);
    CYTHON_UNUSED_VAR(zerodivision_check);
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(PyLong_CheckExact(op1))) {
        return __Pyx_Unpacked___Pyx_PyLong_FloorDivideObjC(op1, op2, intval, inplace, zerodivision_check);
    }
    #endif
    return __Pyx_Fallback___Pyx_PyLong_FloorDivideObjC(op1, op2, inplace);
}
#endif

/* PyUnicode_Substring */
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring(
            PyObject* text, Py_ssize_t start, Py_ssize_t stop) {
    Py_ssize_t length;
    #if !CYTHON_COMPILING_IN_LIMITED_API
    if (unlikely(__Pyx_PyUnicode_READY(text) == -1)) return NULL;
    #endif
    length = __Pyx_PyUnicode_GET_LENGTH(text);
    #if !CYTHON_ASSUME_SAFE_SIZE
    if (unlikely(length < 0)) return NULL;
    #endif
    if (start < 0) {
        start += length;
        if (start < 0)
            start = 0;
    }
    if (stop < 0)
        stop += length;
    else if (stop > length)
        stop = length;
    if (stop <= start)
        return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_unicode);
    if (start == 0 && stop == length)
        return __Pyx_NewRef(text);
#if CYTHON_COMPILING_IN_LIMITED_API
    return PyUnicode_Substring(text, start, stop);
#else
    return PyUnicode_FromKindAndData(PyUnicode_KIND(text),
        PyUnicode_1BYTE_DATA(text) + start*PyUnicode_KIND(text), stop-start);
#endif
}

/* CIntToDigits (used by CIntToPyUnicode) */
static const char DIGIT_PAIRS_10[2*10*10+1] = {
    "00010203040506070809"
    "10111213141516171819"
    "20212223242526272829"
    "30313233343536373839"
    "40414243444546474849"
    "50515253545556575859"
    "60616263646566676869"
    "70717273747576777879"
    "80818283848586878889"
    "90919293949596979899"
};
static const char DIGIT_PAIRS_8[2*8*8+1] = {
    "0001020304050607"
    "1011121314151617"
    "2021222324252627"
    "3031323334353637"
    "4041424344454647"
    "5051525354555657"
    "6061626364656667"
    "7071727374757677"
};
static const char DIGITS_HEX[2*16+1] = {
    "0123456789abcdef"
    "0123456789ABCDEF"
};

/* BuildPyUnicode (used by COrdinalToPyUnicode) */
static PyObject* __Pyx_PyUnicode_BuildFromAscii(Py_ssize_t ulength, const char* chars, int clength,
                                                int prepend_sign, char padding_char) {
    PyObject *uval;
    Py_ssize_t uoffset = ulength - clength;
#if CYTHON_USE_UNICODE_INTERNALS
    Py_ssize_t i;
    void *udata;
    uval = PyUnicode_New(ulength, 127);
    if (unlikely(!uval)) return NULL;
    udata = PyUnicode_DATA(uval);
    if (uoffset > 0) {
        i = 0;
        if (prepend_sign) {
            __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, 0, '-');
            i++;
        }
        for (; i < uoffset; i++) {
            __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, i, padding_char);
        }
    }
    for (i=0; i < clength; i++) {
        __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, uoffset+i, chars[i]);
    }
#else
    {
        PyObject *sign = NULL, *padding = NULL;
        uval = NULL;
        if (uoffset > 0) {
            prepend_sign = !!prepend_sign;
            if (uoffset > prepend_sign) {
                padding = PyUnicode_FromOrdinal(padding_char);
                if (likely(padding) && uoffset > prepend_sign + 1) {
                    PyObject *tmp = PySequence_Repeat(padding, uoffset - prepend_sign);
                    Py_DECREF(padding);
                    padding = tmp;
                }
                if (unlikely(!padding)) goto done_or_error;
            }
            if (prepend_sign) {
                sign = PyUnicode_FromOrdinal('-');
                if (unlikely(!sign)) goto done_or_error;
            }
        }
        uval = PyUnicode_DecodeASCII(chars, clength, NULL);
        if (likely(uval) && padding) {
            PyObject *tmp = PyUnicode_Concat(padding, uval);
            Py_DECREF(uval);
            uval = tmp;
        }
        if (likely(uval) && sign) {
            PyObject *tmp = PyUnicode_Concat(sign, uval);
            Py_DECREF(uval);
            uval = tmp;
        }
done_or_error:
        Py_XDECREF(padding);
        Py_XDECREF(sign);
    }
#endif
    return uval;
}

/* COrdinalToPyUnicode (used by CIntToPyUnicode) */
static CYTHON_INLINE int __Pyx_CheckUnicodeValue(int value) {
    return value <= 1114111;
}
static PyObject* __Pyx_PyUnicode_FromOrdinal_Padded(int value, Py_ssize_t ulength, char padding_char) {
    Py_ssize_t padding_length = ulength - 1;
    if (likely((padding_length <= 250) && (value < 0xD800 || value > 0xDFFF))) {
        char chars[256];
        if (value <= 255) {
            memset(chars, padding_char, (size_t) padding_length);
            chars[ulength-1] = (char) value;
            return PyUnicode_DecodeLatin1(chars, ulength, NULL);
        }
        char *cpos = chars + sizeof(chars);
        if (value < 0x800) {
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0xc0 | (value & 0x1f));
        } else if (value < 0x10000) {
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0xe0 | (value & 0x0f));
        } else {
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0x80 | (value & 0x3f));
            value >>= 6;
            *--cpos = (char) (0xf0 | (value & 0x07));
        }
        cpos -= padding_length;
        memset(cpos, padding_char, (size_t) padding_length);
        return PyUnicode_DecodeUTF8(cpos, chars + sizeof(chars) - cpos, NULL);
    }
    if (value <= 127 && CYTHON_USE_UNICODE_INTERNALS) {
        const char chars[1] = {(char) value};
        return __Pyx_PyUnicode_BuildFromAscii(ulength, chars, 1, 0, padding_char);
    }
    {
        PyObject *uchar, *padding_uchar, *padding, *result;
        padding_uchar = PyUnicode_FromOrdinal(padding_char);
        if (unlikely(!padding_uchar)) return NULL;
        padding = PySequence_Repeat(padding_uchar, padding_length);
        Py_DECREF(padding_uchar);
        if (unlikely(!padding)) return NULL;
        uchar = PyUnicode_FromOrdinal(value);
        if (unlikely(!uchar)) {
            Py_DECREF(padding);
            return NULL;
        }
        result = PyUnicode_Concat(padding, uchar);
        Py_DECREF(padding);
        Py_DECREF(uchar);
        return result;
    }
}

/* CIntToPyUnicode */
static CYTHON_INLINE PyObject* __Pyx_uchar___Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char) {
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const int neg_one = (int) -1, const_zero = (int) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (unlikely(!(is_unsigned || value == 0 || value > 0) ||
                    !(sizeof(value) <= 2 || value & ~ (int) 0x01fffff || __Pyx_CheckUnicodeValue((int) value)))) {
        PyErr_SetString(PyExc_OverflowError, "%c arg not in range(0x110000)");
        return NULL;
    }
    if (width <= 1) {
        return PyUnicode_FromOrdinal((int) value);
    }
    return __Pyx_PyUnicode_FromOrdinal_Padded((int) value, width, padding_char);
}
static CYTHON_INLINE PyObject* __Pyx____Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char, char format_char) {
    char digits[sizeof(int)*3+2];
    char *dpos, *end = digits + sizeof(int)*3+2;
    const char *hex_digits = DIGITS_HEX;
    Py_ssize_t length, ulength;
    int prepend_sign, last_one_off;
    int remaining;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const int neg_one = (int) -1, const_zero = (int) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (format_char == 'X') {
        hex_digits += 16;
        format_char = 'x';
    }
    remaining = value;
    last_one_off = 0;
    dpos = end;
    do {
        int digit_pos;
        switch (format_char) {
        case 'o':
            digit_pos = abs((int)(remaining % (8*8)));
            remaining = (int) (remaining / (8*8));
            dpos -= 2;
            memcpy(dpos, DIGIT_PAIRS_8 + digit_pos * 2, 2);
            last_one_off = (digit_pos < 8);
            break;
        case 'd':
            digit_pos = abs((int)(remaining % (10*10)));
            remaining = (int) (remaining / (10*10));
            dpos -= 2;
            memcpy(dpos, DIGIT_PAIRS_10 + digit_pos * 2, 2);
            last_one_off = (digit_pos < 10);
            break;
        case 'x':
            *(--dpos) = hex_digits[abs((int)(remaining % 16))];
            remaining = (int) (remaining / 16);
            break;
        default:
            assert(0);
            break;
        }
    } while (unlikely(remaining != 0));
    assert(!last_one_off || *dpos == '0');
    dpos += last_one_off;
    length = end - dpos;
    ulength = length;
    prepend_sign = 0;
    if (!is_unsigned && value <= neg_one) {
        if (padding_char == ' ' || width <= length + 1) {
            *(--dpos) = '-';
            ++length;
        } else {
            prepend_sign = 1;
        }
        ++ulength;
    }
    if (width > ulength) {
        ulength = width;
    }
    if (ulength == 1) {
        return PyUnicode_FromOrdinal(*dpos);
    }
    return __Pyx_PyUnicode_BuildFromAscii(ulength, dpos, (int) length, prepend_sign, padding_char);
}

/* DivInt[long] */
static CYTHON_INLINE long __Pyx_div_long(long a, long b, int b_is_constant) {
    long q = a / b;
    long r = a - q*b;
    long adapt_python = (b_is_constant ?
        ((r != 0) & ((r < 0) ^ (b < 0))) :
        ((r != 0) & ((r ^ b) < 0))
    );
    return q - adapt_python;
}

/* ModInt[long] */
static CYTHON_INLINE long __Pyx_mod_long(long a, long b, int b_is_constant) {
    long r = a % b;
    long adapt_python = (b_is_constant ?
        ((r != 0) & ((r < 0) ^ (b < 0))) :
        ((r != 0) & ((r ^ b) < 0))
    );
    return r + adapt_python * b;
}

/* AllocateExtensionType */
static PyObject *__Pyx_AllocateExtensionType(PyTypeObject *t, int is_final) {
    if (is_final || likely(!__Pyx_PyType_HasFeature(t, Py_TPFLAGS_IS_ABSTRACT))) {
        allocfunc alloc_func = __Pyx_PyType_GetSlot(t, tp_alloc, allocfunc);
        return alloc_func(t, 0);
    } else {
        newfunc tp_new = __Pyx_PyType_TryGetSlot(&PyBaseObject_Type, tp_new, newfunc);
    #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
        if (!tp_new) {
            PyObject *new_str = PyUnicode_FromString("__new__");
            if (likely(new_str)) {
                PyObject *o = PyObject_CallMethodObjArgs((PyObject *)&PyBaseObject_Type, new_str, t, NULL);
                Py_DECREF(new_str);
                return o;
            } else
                return NULL;
        } else
    #endif
        return tp_new(t, __pyx_mstate_global->__pyx_empty_tuple, 0);
    }
}

/* CallTypeTraverse */
#if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000)
#else
static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg) {
    #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000
    if (__Pyx_get_runtime_version() < 0x03090000) return 0;
    #endif
    if (!always_call) {
        PyTypeObject *base = __Pyx_PyObject_GetSlot(o, tp_base, PyTypeObject*);
        unsigned long flags = PyType_GetFlags(base);
        if (flags & Py_TPFLAGS_HEAPTYPE) {
            return 0;
        }
    }
    Py_VISIT((PyObject*)Py_TYPE(o));
    return 0;
}
#endif

/* LimitedApiGetTypeDict (used by SetItemOnTypeDict) */
#if CYTHON_COMPILING_IN_LIMITED_API
static Py_ssize_t __Pyx_GetTypeDictOffset(void) {
    PyObject *tp_dictoffset_o;
    Py_ssize_t tp_dictoffset;
    tp_dictoffset_o = PyObject_GetAttrString((PyObject*)(&PyType_Type), "__dictoffset__");
    if (unlikely(!tp_dictoffset_o)) return -1;
    tp_dictoffset = PyLong_AsSsize_t(tp_dictoffset_o);
    Py_DECREF(tp_dictoffset_o);
    if (unlikely(tp_dictoffset == 0)) {
        PyErr_SetString(
            PyExc_TypeError,
            "'type' doesn't have a dictoffset");
        return -1;
    } else if (unlikely(tp_dictoffset < 0)) {
        PyErr_SetString(
            PyExc_TypeError,
            "'type' has an unexpected negative dictoffset. "
            "Please report this as Cython bug");
        return -1;
    }
    return tp_dictoffset;
}
static PyObject *__Pyx_GetTypeDict(PyTypeObject *tp) {
    static Py_ssize_t tp_dictoffset = 0;
    if (unlikely(tp_dictoffset == 0)) {
        tp_dictoffset = __Pyx_GetTypeDictOffset();
        if (unlikely(tp_dictoffset == -1 && PyErr_Occurred())) {
            tp_dictoffset = 0; // try again next time?
            return NULL;
        }
    }
    return *(PyObject**)((char*)tp + tp_dictoffset);
}
#endif

/* SetItemOnTypeDict (used by FixUpExtensionType) */
static int __Pyx__SetItemOnTypeDict(PyTypeObject *tp, PyObject *k, PyObject *v) {
    int result;
    PyObject *tp_dict;
#if CYTHON_COMPILING_IN_LIMITED_API
    tp_dict = __Pyx_GetTypeDict(tp);
    if (unlikely(!tp_dict)) return -1;
#else
    tp_dict = tp->tp_dict;
#endif
    result = PyDict_SetItem(tp_dict, k, v);
    if (likely(!result)) {
        PyType_Modified(tp);
        if (unlikely(PyObject_HasAttr(v, __pyx_mstate_global->__pyx_n_u_set_name))) {
            PyObject *setNameResult = PyObject_CallMethodObjArgs(v, __pyx_mstate_global->__pyx_n_u_set_name,  (PyObject *) tp, k, NULL);
            if (!setNameResult) return -1;
            Py_DECREF(setNameResult);
        }
    }
    return result;
}

/* FixUpExtensionType */
static int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type) {
#if __PYX_LIMITED_VERSION_HEX > 0x030900B1
    CYTHON_UNUSED_VAR(spec);
    CYTHON_UNUSED_VAR(type);
    CYTHON_UNUSED_VAR(__Pyx__SetItemOnTypeDict);
#else
    const PyType_Slot *slot = spec->slots;
    int changed = 0;
#if !CYTHON_COMPILING_IN_LIMITED_API
    while (slot && slot->slot && slot->slot != Py_tp_members)
        slot++;
    if (slot && slot->slot == Py_tp_members) {
#if !CYTHON_COMPILING_IN_CPYTHON
        const
#endif  // !CYTHON_COMPILING_IN_CPYTHON)
            PyMemberDef *memb = (PyMemberDef*) slot->pfunc;
        while (memb && memb->name) {
            if (memb->name[0] == '_' && memb->name[1] == '_') {
                if (strcmp(memb->name, "__weaklistoffset__") == 0) {
                    assert(memb->type == T_PYSSIZET);
                    assert(memb->flags == READONLY);
                    type->tp_weaklistoffset = memb->offset;
                    changed = 1;
                }
                else if (strcmp(memb->name, "__dictoffset__") == 0) {
                    assert(memb->type == T_PYSSIZET);
                    assert(memb->flags == READONLY);
                    type->tp_dictoffset = memb->offset;
                    changed = 1;
                }
#if CYTHON_METH_FASTCALL
                else if (strcmp(memb->name, "__vectorcalloffset__") == 0) {
                    assert(memb->type == T_PYSSIZET);
                    assert(memb->flags == READONLY);
                    type->tp_vectorcall_offset = memb->offset;
                    changed = 1;
                }
#endif  // CYTHON_METH_FASTCALL
#if !CYTHON_COMPILING_IN_PYPY
                else if (strcmp(memb->name, "__module__") == 0) {
                    PyObject *descr;
                    assert(memb->type == T_OBJECT);
                    assert(memb->flags == 0 || memb->flags == READONLY);
                    descr = PyDescr_NewMember(type, memb);
                    if (unlikely(!descr))
                        return -1;
                    int set_item_result = PyDict_SetItem(type->tp_dict, PyDescr_NAME(descr), descr);
                    Py_DECREF(descr);
                    if (unlikely(set_item_result < 0)) {
                        return -1;
                    }
                    changed = 1;
                }
#endif  // !CYTHON_COMPILING_IN_PYPY
            }
            memb++;
        }
    }
#endif  // !CYTHON_COMPILING_IN_LIMITED_API
#if !CYTHON_COMPILING_IN_PYPY
    slot = spec->slots;
    while (slot && slot->slot && slot->slot != Py_tp_getset)
        slot++;
    if (slot && slot->slot == Py_tp_getset) {
        PyGetSetDef *getset = (PyGetSetDef*) slot->pfunc;
        while (getset && getset->name) {
            if (getset->name[0] == '_' && getset->name[1] == '_' && strcmp(getset->name, "__module__") == 0) {
                PyObject *descr = PyDescr_NewGetSet(type, getset);
                if (unlikely(!descr))
                    return -1;
                #if CYTHON_COMPILING_IN_LIMITED_API
                PyObject *pyname = PyUnicode_FromString(getset->name);
                if (unlikely(!pyname)) {
                    Py_DECREF(descr);
                    return -1;
                }
                int set_item_result = __Pyx_SetItemOnTypeDict(type, pyname, descr);
                Py_DECREF(pyname);
                #else
                CYTHON_UNUSED_VAR(__Pyx__SetItemOnTypeDict);
                int set_item_result = PyDict_SetItem(type->tp_dict, PyDescr_NAME(descr), descr);
                #endif
                Py_DECREF(descr);
                if (unlikely(set_item_result < 0)) {
                    return -1;
                }
                changed = 1;
            }
            ++getset;
        }
    }
#else
    CYTHON_UNUSED_VAR(__Pyx__SetItemOnTypeDict);
#endif  // !CYTHON_COMPILING_IN_PYPY
    if (changed)
        PyType_Modified(type);
#endif  // PY_VERSION_HEX > 0x030900B1
    return 0;
}

/* ValidateBasesTuple (used by PyType_Ready) */
#if CYTHON_COMPILING_IN_CPYTHON || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_USE_TYPE_SPECS
static int __Pyx_validate_bases_tuple(const char *type_name, Py_ssize_t dictoffset, PyObject *bases) {
    Py_ssize_t i, n;
#if CYTHON_ASSUME_SAFE_SIZE
    n = PyTuple_GET_SIZE(bases);
#else
    n = PyTuple_Size(bases);
    if (unlikely(n < 0)) return -1;
#endif
    for (i = 1; i < n; i++)
    {
        PyTypeObject *b;
#if CYTHON_AVOID_BORROWED_REFS
        PyObject *b0 = PySequence_GetItem(bases, i);
        if (!b0) return -1;
#elif CYTHON_ASSUME_SAFE_MACROS
        PyObject *b0 = PyTuple_GET_ITEM(bases, i);
#else
        PyObject *b0 = PyTuple_GetItem(bases, i);
        if (!b0) return -1;
#endif
        b = (PyTypeObject*) b0;
        if (!__Pyx_PyType_HasFeature(b, Py_TPFLAGS_HEAPTYPE))
        {
            __Pyx_TypeName b_name = __Pyx_PyType_GetFullyQualifiedName(b);
            PyErr_Format(PyExc_TypeError,
                "base class '" __Pyx_FMT_TYPENAME "' is not a heap type", b_name);
            __Pyx_DECREF_TypeName(b_name);
#if CYTHON_AVOID_BORROWED_REFS
            Py_DECREF(b0);
#endif
            return -1;
        }
        if (dictoffset == 0)
        {
            Py_ssize_t b_dictoffset = 0;
#if CYTHON_USE_TYPE_SLOTS
            b_dictoffset = b->tp_dictoffset;
#else
            PyObject *py_b_dictoffset = PyObject_GetAttrString((PyObject*)b, "__dictoffset__");
            if (!py_b_dictoffset) goto dictoffset_return;
            b_dictoffset = PyLong_AsSsize_t(py_b_dictoffset);
            Py_DECREF(py_b_dictoffset);
            if (b_dictoffset == -1 && PyErr_Occurred()) goto dictoffset_return;
#endif
            if (b_dictoffset) {
                {
                    __Pyx_TypeName b_name = __Pyx_PyType_GetFullyQualifiedName(b);
                    PyErr_Format(PyExc_TypeError,
                        "extension type '%.200s' has no __dict__ slot, "
                        "but base type '" __Pyx_FMT_TYPENAME "' has: "
                        "either add 'cdef dict __dict__' to the extension type "
                        "or add '__slots__ = [...]' to the base type",
                        type_name, b_name);
                    __Pyx_DECREF_TypeName(b_name);
                }
#if !CYTHON_USE_TYPE_SLOTS
              dictoffset_return:
#endif
#if CYTHON_AVOID_BORROWED_REFS
                Py_DECREF(b0);
#endif
                return -1;
            }
        }
#if CYTHON_AVOID_BORROWED_REFS
        Py_DECREF(b0);
#endif
    }
    return 0;
}
#endif

/* PyType_Ready */
CYTHON_UNUSED static int __Pyx_PyType_HasMultipleInheritance(PyTypeObject *t) {
    while (t) {
        PyObject *bases = __Pyx_PyType_GetSlot(t, tp_bases, PyObject*);
        if (bases) {
            return 1;
        }
        t = __Pyx_PyType_GetSlot(t, tp_base, PyTypeObject*);
    }
    return 0;
}
static int __Pyx_PyType_Ready(PyTypeObject *t) {
#if CYTHON_USE_TYPE_SPECS || !CYTHON_COMPILING_IN_CPYTHON || defined(PYSTON_MAJOR_VERSION)
    (void)__Pyx_PyObject_CallMethod0;
#if CYTHON_USE_TYPE_SPECS
    (void)__Pyx_validate_bases_tuple;
#endif
    return PyType_Ready(t);
#else
    int r;
    if (!__Pyx_PyType_HasMultipleInheritance(t)) {
        return PyType_Ready(t);
    }
    PyObject *bases = __Pyx_PyType_GetSlot(t, tp_bases, PyObject*);
    if (bases && unlikely(__Pyx_validate_bases_tuple(t->tp_name, t->tp_dictoffset, bases) == -1))
        return -1;
#if !defined(PYSTON_MAJOR_VERSION)
    {
        int gc_was_enabled;
    #if PY_VERSION_HEX >= 0x030A00b1
        gc_was_enabled = PyGC_Disable();
        (void)__Pyx_PyObject_CallMethod0;
    #else
        PyObject *ret, *py_status;
        PyObject *gc = NULL;
        #if (!CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM+0 >= 0x07030400) &&\
                !CYTHON_COMPILING_IN_GRAAL
        gc = PyImport_GetModule(__pyx_mstate_global->__pyx_kp_u_gc);
        #endif
        if (unlikely(!gc)) gc = PyImport_Import(__pyx_mstate_global->__pyx_kp_u_gc);
        if (unlikely(!gc)) return -1;
        py_status = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_isenabled);
        if (unlikely(!py_status)) {
            Py_DECREF(gc);
            return -1;
        }
        gc_was_enabled = __Pyx_PyObject_IsTrue(py_status);
        Py_DECREF(py_status);
        if (gc_was_enabled > 0) {
            ret = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_disable);
            if (unlikely(!ret)) {
                Py_DECREF(gc);
                return -1;
            }
            Py_DECREF(ret);
        } else if (unlikely(gc_was_enabled == -1)) {
            Py_DECREF(gc);
            return -1;
        }
    #endif
        t->tp_flags |= Py_TPFLAGS_HEAPTYPE;
#if PY_VERSION_HEX >= 0x030A0000
        t->tp_flags |= Py_TPFLAGS_IMMUTABLETYPE;
#endif
#else
        (void)__Pyx_PyObject_CallMethod0;
#endif
    r = PyType_Ready(t);
#if !defined(PYSTON_MAJOR_VERSION)
        t->tp_flags &= ~Py_TPFLAGS_HEAPTYPE;
    #if PY_VERSION_HEX >= 0x030A00b1
        if (gc_was_enabled)
            PyGC_Enable();
    #else
        if (gc_was_enabled) {
            PyObject *tp, *v, *tb;
            PyErr_Fetch(&tp, &v, &tb);
            ret = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_enable);
            if (likely(ret || r == -1)) {
                Py_XDECREF(ret);
                PyErr_Restore(tp, v, tb);
            } else {
                Py_XDECREF(tp);
                Py_XDECREF(v);
                Py_XDECREF(tb);
                r = -1;
            }
        }
        Py_DECREF(gc);
    #endif
    }
#endif
    return r;
#endif
}

/* SetVTable */
static int __Pyx_SetVtable(PyTypeObject *type, void *vtable) {
    PyObject *ob = PyCapsule_New(vtable, 0, 0);
    if (unlikely(!ob))
        goto bad;
#if CYTHON_COMPILING_IN_LIMITED_API
    if (unlikely(PyObject_SetAttr((PyObject *) type, __pyx_mstate_global->__pyx_n_u_pyx_vtable, ob) < 0))
#else
    if (unlikely(PyDict_SetItem(type->tp_dict, __pyx_mstate_global->__pyx_n_u_pyx_vtable, ob) < 0))
#endif
        goto bad;
    Py_DECREF(ob);
    return 0;
bad:
    Py_XDECREF(ob);
    return -1;
}

/* GetVTable (used by MergeVTables) */
static void* __Pyx_GetVtable(PyTypeObject *type) {
    void* ptr;
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *ob = PyObject_GetAttr((PyObject *)type, __pyx_mstate_global->__pyx_n_u_pyx_vtable);
#else
    PyObject *ob = PyObject_GetItem(type->tp_dict, __pyx_mstate_global->__pyx_n_u_pyx_vtable);
#endif
    if (!ob)
        goto bad;
    ptr = PyCapsule_GetPointer(ob, 0);
    if (!ptr && !PyErr_Occurred())
        PyErr_SetString(PyExc_RuntimeError, "invalid vtable found for imported type");
    Py_DECREF(ob);
    return ptr;
bad:
    Py_XDECREF(ob);
    return NULL;
}

/* MergeVTables */
static int __Pyx_MergeVtables(PyTypeObject *type) {
    int i=0;
    Py_ssize_t size;
    void** base_vtables;
    __Pyx_TypeName tp_base_name = NULL;
    __Pyx_TypeName base_name = NULL;
    void* unknown = (void*)-1;
    PyObject* bases = __Pyx_PyType_GetSlot(type, tp_bases, PyObject*);
    int base_depth = 0;
    {
        PyTypeObject* base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*);
        while (base) {
            base_depth += 1;
            base = __Pyx_PyType_GetSlot(base, tp_base, PyTypeObject*);
        }
    }
    base_vtables = (void**) PyMem_Malloc(sizeof(void*) * (size_t)(base_depth + 1));
    base_vtables[0] = unknown;
#if CYTHON_COMPILING_IN_LIMITED_API
    size = PyTuple_Size(bases);
    if (size < 0) goto other_failure;
#else
    size = PyTuple_GET_SIZE(bases);
#endif
    for (i = 1; i < size; i++) {
        PyObject *basei;
        void* base_vtable;
#if CYTHON_AVOID_BORROWED_REFS
        basei = PySequence_GetItem(bases, i);
        if (unlikely(!basei)) goto other_failure;
#elif !CYTHON_ASSUME_SAFE_MACROS
        basei = PyTuple_GetItem(bases, i);
        if (unlikely(!basei)) goto other_failure;
#else
        basei = PyTuple_GET_ITEM(bases, i);
#endif
        base_vtable = __Pyx_GetVtable((PyTypeObject*)basei);
#if CYTHON_AVOID_BORROWED_REFS
        Py_DECREF(basei);
#endif
        if (base_vtable != NULL) {
            int j;
            PyTypeObject* base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*);
            for (j = 0; j < base_depth; j++) {
                if (base_vtables[j] == unknown) {
                    base_vtables[j] = __Pyx_GetVtable(base);
                    base_vtables[j + 1] = unknown;
                }
                if (base_vtables[j] == base_vtable) {
                    break;
                } else if (base_vtables[j] == NULL) {
                    goto bad;
                }
                base = __Pyx_PyType_GetSlot(base, tp_base, PyTypeObject*);
            }
        }
    }
    PyErr_Clear();
    PyMem_Free(base_vtables);
    return 0;
bad:
    {
        PyTypeObject* basei = NULL;
        PyTypeObject* tp_base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*);
        tp_base_name = __Pyx_PyType_GetFullyQualifiedName(tp_base);
#if CYTHON_AVOID_BORROWED_REFS
        basei = (PyTypeObject*)PySequence_GetItem(bases, i);
        if (unlikely(!basei)) goto really_bad;
#elif !CYTHON_ASSUME_SAFE_MACROS
        basei = (PyTypeObject*)PyTuple_GetItem(bases, i);
        if (unlikely(!basei)) goto really_bad;
#else
        basei = (PyTypeObject*)PyTuple_GET_ITEM(bases, i);
#endif
        base_name = __Pyx_PyType_GetFullyQualifiedName(basei);
#if CYTHON_AVOID_BORROWED_REFS
        Py_DECREF(basei);
#endif
    }
    PyErr_Format(PyExc_TypeError,
        "multiple bases have vtable conflict: '" __Pyx_FMT_TYPENAME "' and '" __Pyx_FMT_TYPENAME "'", tp_base_name, base_name);
#if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS
really_bad: // bad has failed!
#endif
    __Pyx_DECREF_TypeName(tp_base_name);
    __Pyx_DECREF_TypeName(base_name);
#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS
other_failure:
#endif
    PyMem_Free(base_vtables);
    return -1;
}

/* TypeImport */
#ifndef __PYX_HAVE_RT_ImportType_3_2_4
#define __PYX_HAVE_RT_ImportType_3_2_4
static PyTypeObject *__Pyx_ImportType_3_2_4(PyObject *module, const char *module_name, const char *class_name,
    size_t size, size_t alignment, enum __Pyx_ImportType_CheckSize_3_2_4 check_size)
{
    PyObject *result = 0;
    Py_ssize_t basicsize;
    Py_ssize_t itemsize;
#if defined(Py_LIMITED_API) || (defined(CYTHON_COMPILING_IN_LIMITED_API) && CYTHON_COMPILING_IN_LIMITED_API)
    PyObject *py_basicsize;
    PyObject *py_itemsize;
#endif
    result = PyObject_GetAttrString(module, class_name);
    if (!result)
        goto bad;
    if (!PyType_Check(result)) {
        PyErr_Format(PyExc_TypeError,
            "%.200s.%.200s is not a type object",
            module_name, class_name);
        goto bad;
    }
#if !( defined(Py_LIMITED_API) || (defined(CYTHON_COMPILING_IN_LIMITED_API) && CYTHON_COMPILING_IN_LIMITED_API) )
    basicsize = ((PyTypeObject *)result)->tp_basicsize;
    itemsize = ((PyTypeObject *)result)->tp_itemsize;
#else
    if (size == 0) {
        return (PyTypeObject *)result;
    }
    py_basicsize = PyObject_GetAttrString(result, "__basicsize__");
    if (!py_basicsize)
        goto bad;
    basicsize = PyLong_AsSsize_t(py_basicsize);
    Py_DECREF(py_basicsize);
    py_basicsize = 0;
    if (basicsize == (Py_ssize_t)-1 && PyErr_Occurred())
        goto bad;
    py_itemsize = PyObject_GetAttrString(result, "__itemsize__");
    if (!py_itemsize)
        goto bad;
    itemsize = PyLong_AsSsize_t(py_itemsize);
    Py_DECREF(py_itemsize);
    py_itemsize = 0;
    if (itemsize == (Py_ssize_t)-1 && PyErr_Occurred())
        goto bad;
#endif
    if (itemsize) {
        if (size % alignment) {
            alignment = size % alignment;
        }
        if (itemsize < (Py_ssize_t)alignment)
            itemsize = (Py_ssize_t)alignment;
    }
    if ((size_t)(basicsize + itemsize) < size) {
        PyErr_Format(PyExc_ValueError,
            "%.200s.%.200s size changed, may indicate binary incompatibility. "
            "Expected %zd from C header, got %zd from PyObject",
            module_name, class_name, size, basicsize+itemsize);
        goto bad;
    }
    if (check_size == __Pyx_ImportType_CheckSize_Error_3_2_4 &&
            ((size_t)basicsize > size || (size_t)(basicsize + itemsize) < size)) {
        PyErr_Format(PyExc_ValueError,
            "%.200s.%.200s size changed, may indicate binary incompatibility. "
            "Expected %zd from C header, got %zd-%zd from PyObject",
            module_name, class_name, size, basicsize, basicsize+itemsize);
        goto bad;
    }
    else if (check_size == __Pyx_ImportType_CheckSize_Warn_3_2_4 && (size_t)basicsize > size) {
        if (PyErr_WarnFormat(NULL, 0,
                "%.200s.%.200s size changed, may indicate binary incompatibility. "
                "Expected %zd from C header, got %zd from PyObject",
                module_name, class_name, size, basicsize) < 0) {
            goto bad;
        }
    }
    return (PyTypeObject *)result;
bad:
    Py_XDECREF(result);
    return NULL;
}
#endif

/* ImportFrom */
static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name) {
    PyObject* value = __Pyx_PyObject_GetAttrStr(module, name);
    if (unlikely(!value) && PyErr_ExceptionMatches(PyExc_AttributeError)) {
        const char* module_name_str = 0;
        PyObject* module_name = 0;
        PyObject* module_dot = 0;
        PyObject* full_name = 0;
        PyErr_Clear();
        module_name_str = PyModule_GetName(module);
        if (unlikely(!module_name_str)) { goto modbad; }
        module_name = PyUnicode_FromString(module_name_str);
        if (unlikely(!module_name)) { goto modbad; }
        module_dot = PyUnicode_Concat(module_name, __pyx_mstate_global->__pyx_kp_u__6);
        if (unlikely(!module_dot)) { goto modbad; }
        full_name = PyUnicode_Concat(module_dot, name);
        if (unlikely(!full_name)) { goto modbad; }
        #if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM  < 0x07030400) ||\
                CYTHON_COMPILING_IN_GRAAL
        {
            PyObject *modules = PyImport_GetModuleDict();
            if (unlikely(!modules))
                goto modbad;
            value = PyObject_GetItem(modules, full_name);
        }
        #else
        value = PyImport_GetModule(full_name);
        #endif
      modbad:
        Py_XDECREF(full_name);
        Py_XDECREF(module_dot);
        Py_XDECREF(module_name);
    }
    if (unlikely(!value)) {
        PyErr_Format(PyExc_ImportError, "cannot import name %S", name);
    }
    return value;
}

/* ListPack */
static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...) {
    va_list va;
    PyObject *l = PyList_New(n);
    va_start(va, n);
    if (unlikely(!l)) goto end;
    for (Py_ssize_t i=0; i<n; ++i) {
        PyObject *arg = va_arg(va, PyObject*);
        Py_INCREF(arg);
        if (__Pyx_PyList_SET_ITEM(l, i, arg) != (0)) {
            Py_CLEAR(l);
            goto end;
        }
    }
    end:
    va_end(va);
    return l;
}

/* Py3UpdateBases */
static PyObject*
__Pyx_PEP560_update_bases(PyObject *bases)
{
    Py_ssize_t i, j, size_bases;
    PyObject *base = NULL, *meth, *new_base, *result, *new_bases = NULL;
#if CYTHON_ASSUME_SAFE_SIZE
    size_bases = PyTuple_GET_SIZE(bases);
#else
    size_bases = PyTuple_Size(bases);
    if (size_bases < 0) return NULL;
#endif
    for (i = 0; i < size_bases; i++) {
#if CYTHON_AVOID_BORROWED_REFS
        Py_CLEAR(base);
#endif
#if CYTHON_ASSUME_SAFE_MACROS
        base = PyTuple_GET_ITEM(bases, i);
#else
        base = PyTuple_GetItem(bases, i);
        if (!base) goto error;
#endif
#if CYTHON_AVOID_BORROWED_REFS
        Py_INCREF(base);
#endif
        if (PyType_Check(base)) {
            if (new_bases) {
                if (PyList_Append(new_bases, base) < 0) {
                    goto error;
                }
            }
            continue;
        }
        meth = __Pyx_PyObject_GetAttrStrNoError(base, __pyx_mstate_global->__pyx_n_u_mro_entries);
        if (!meth && PyErr_Occurred()) {
            goto error;
        }
        if (!meth) {
            if (new_bases) {
                if (PyList_Append(new_bases, base) < 0) {
                    goto error;
                }
            }
            continue;
        }
        new_base = __Pyx_PyObject_CallOneArg(meth, bases);
        Py_DECREF(meth);
        if (!new_base) {
            goto error;
        }
        if (!PyTuple_Check(new_base)) {
            PyErr_SetString(PyExc_TypeError,
                            "__mro_entries__ must return a tuple");
            Py_DECREF(new_base);
            goto error;
        }
        if (!new_bases) {
            if (!(new_bases = PyList_New(i))) {
                goto error;
            }
            for (j = 0; j < i; j++) {
                PyObject *base_from_list;
#if CYTHON_ASSUME_SAFE_MACROS
                base_from_list = PyTuple_GET_ITEM(bases, j);
                PyList_SET_ITEM(new_bases, j, base_from_list);
                Py_INCREF(base_from_list);
#else
                base_from_list = PyTuple_GetItem(bases, j);
                if (!base_from_list) goto error;
                Py_INCREF(base_from_list);
                if (PyList_SetItem(new_bases, j, base_from_list) < 0) goto error;
#endif
            }
        }
#if CYTHON_ASSUME_SAFE_SIZE
        j = PyList_GET_SIZE(new_bases);
#else
        j = PyList_Size(new_bases);
        if (j < 0) goto error;
#endif
        if (PyList_SetSlice(new_bases, j, j, new_base) < 0) {
            goto error;
        }
        Py_DECREF(new_base);
    }
    if (!new_bases) {
        Py_INCREF(bases);
        return bases;
    }
    result = PyList_AsTuple(new_bases);
    Py_DECREF(new_bases);
#if CYTHON_AVOID_BORROWED_REFS
    Py_XDECREF(base);
#endif
    return result;
error:
    Py_XDECREF(new_bases);
#if CYTHON_AVOID_BORROWED_REFS
    Py_XDECREF(base);
#endif
    return NULL;
}

/* CalculateMetaclass */
static PyObject *__Pyx_CalculateMetaclass(PyTypeObject *metaclass, PyObject *bases) {
    Py_ssize_t i, nbases;
#if CYTHON_ASSUME_SAFE_SIZE
    nbases = PyTuple_GET_SIZE(bases);
#else
    nbases = PyTuple_Size(bases);
    if (nbases < 0) return NULL;
#endif
    for (i=0; i < nbases; i++) {
        PyTypeObject *tmptype;
#if CYTHON_ASSUME_SAFE_MACROS
        PyObject *tmp = PyTuple_GET_ITEM(bases, i);
#else
        PyObject *tmp = PyTuple_GetItem(bases, i);
        if (!tmp) return NULL;
#endif
        tmptype = Py_TYPE(tmp);
        if (!metaclass) {
            metaclass = tmptype;
            continue;
        }
        if (PyType_IsSubtype(metaclass, tmptype))
            continue;
        if (PyType_IsSubtype(tmptype, metaclass)) {
            metaclass = tmptype;
            continue;
        }
        PyErr_SetString(PyExc_TypeError,
                        "metaclass conflict: "
                        "the metaclass of a derived class "
                        "must be a (non-strict) subclass "
                        "of the metaclasses of all its bases");
        return NULL;
    }
    if (!metaclass) {
        metaclass = &PyType_Type;
    }
    Py_INCREF((PyObject*) metaclass);
    return (PyObject*) metaclass;
}

/* dict_setdefault (used by FetchCommonType) */
static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value) {
    PyObject* value;
#if __PYX_LIMITED_VERSION_HEX >= 0x030F0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4)
    PyDict_SetDefaultRef(d, key, default_value, &value);
#elif CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX >= 0x030C0000
    PyObject *args[] = {d, key, default_value};
    value = PyObject_VectorcallMethod(__pyx_mstate_global->__pyx_n_u_setdefault, args, 3 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL);
#elif CYTHON_COMPILING_IN_LIMITED_API
    value = PyObject_CallMethodObjArgs(d, __pyx_mstate_global->__pyx_n_u_setdefault, key, default_value, NULL);
#else
    value = PyDict_SetDefault(d, key, default_value);
    if (unlikely(!value)) return NULL;
    Py_INCREF(value);
#endif
    return value;
}

/* AddModuleRef (used by FetchSharedCythonModule) */
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
  static PyObject *__Pyx_PyImport_AddModuleObjectRef(PyObject *name) {
      PyObject *module_dict = PyImport_GetModuleDict();
      PyObject *m;
      if (PyMapping_GetOptionalItem(module_dict, name, &m) < 0) {
          return NULL;
      }
      if (m != NULL && PyModule_Check(m)) {
          return m;
      }
      Py_XDECREF(m);
      m = PyModule_NewObject(name);
      if (m == NULL)
          return NULL;
      if (PyDict_CheckExact(module_dict)) {
          PyObject *new_m;
          (void)PyDict_SetDefaultRef(module_dict, name, m, &new_m);
          Py_DECREF(m);
          return new_m;
      } else {
           if (PyObject_SetItem(module_dict, name, m) != 0) {
                Py_DECREF(m);
                return NULL;
            }
            return m;
      }
  }
  static PyObject *__Pyx_PyImport_AddModuleRef(const char *name) {
      PyObject *py_name = PyUnicode_FromString(name);
      if (!py_name) return NULL;
      PyObject *module = __Pyx_PyImport_AddModuleObjectRef(py_name);
      Py_DECREF(py_name);
      return module;
  }
#elif __PYX_LIMITED_VERSION_HEX >= 0x030d0000
  #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name)
#else
  static PyObject *__Pyx_PyImport_AddModuleRef(const char *name) {
      PyObject *module = PyImport_AddModule(name);
      Py_XINCREF(module);
      return module;
  }
#endif

/* FetchSharedCythonModule (used by FetchCommonType) */
static PyObject *__Pyx_FetchSharedCythonABIModule(void) {
    return __Pyx_PyImport_AddModuleRef(__PYX_ABI_MODULE_NAME);
}

/* FetchCommonType (used by CommonTypesMetaclass) */
#if __PYX_LIMITED_VERSION_HEX < 0x030C0000
static PyObject* __Pyx_PyType_FromMetaclass(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases) {
    PyObject *result = __Pyx_PyType_FromModuleAndSpec(module, spec, bases);
    if (result && metaclass) {
        PyObject *old_tp = (PyObject*)Py_TYPE(result);
    Py_INCREF((PyObject*)metaclass);
#if __PYX_LIMITED_VERSION_HEX >= 0x03090000
        Py_SET_TYPE(result, metaclass);
#else
        result->ob_type = metaclass;
#endif
        Py_DECREF(old_tp);
    }
    return result;
}
#else
#define __Pyx_PyType_FromMetaclass(me, mo, s, b) PyType_FromMetaclass(me, mo, s, b)
#endif
static int __Pyx_VerifyCachedType(PyObject *cached_type,
                               const char *name,
                               Py_ssize_t expected_basicsize) {
    Py_ssize_t basicsize;
    if (!PyType_Check(cached_type)) {
        PyErr_Format(PyExc_TypeError,
            "Shared Cython type %.200s is not a type object", name);
        return -1;
    }
    if (expected_basicsize == 0) {
        return 0; // size is inherited, nothing useful to check
    }
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *py_basicsize;
    py_basicsize = PyObject_GetAttrString(cached_type, "__basicsize__");
    if (unlikely(!py_basicsize)) return -1;
    basicsize = PyLong_AsSsize_t(py_basicsize);
    Py_DECREF(py_basicsize);
    py_basicsize = NULL;
    if (unlikely(basicsize == (Py_ssize_t)-1) && PyErr_Occurred()) return -1;
#else
    basicsize = ((PyTypeObject*) cached_type)->tp_basicsize;
#endif
    if (basicsize != expected_basicsize) {
        PyErr_Format(PyExc_TypeError,
            "Shared Cython type %.200s has the wrong size, try recompiling",
            name);
        return -1;
    }
    return 0;
}
static PyTypeObject *__Pyx_FetchCommonTypeFromSpec(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases) {
    PyObject *abi_module = NULL, *cached_type = NULL, *abi_module_dict, *new_cached_type, *py_object_name;
    int get_item_ref_result;
    const char* object_name = strrchr(spec->name, '.');
    object_name = object_name ? object_name+1 : spec->name;
    py_object_name = PyUnicode_FromString(object_name);
    if (!py_object_name) return NULL;
    abi_module = __Pyx_FetchSharedCythonABIModule();
    if (!abi_module) goto done;
    abi_module_dict = PyModule_GetDict(abi_module);
    if (!abi_module_dict) goto done;
    get_item_ref_result = __Pyx_PyDict_GetItemRef(abi_module_dict, py_object_name, &cached_type);
    if (get_item_ref_result == 1) {
        if (__Pyx_VerifyCachedType(
              cached_type,
              object_name,
              spec->basicsize) < 0) {
            goto bad;
        }
        goto done;
    } else if (unlikely(get_item_ref_result == -1)) {
        goto bad;
    }
    cached_type = __Pyx_PyType_FromMetaclass(
        metaclass,
        CYTHON_USE_MODULE_STATE ? module : abi_module,
        spec, bases);
    if (unlikely(!cached_type)) goto bad;
    if (unlikely(__Pyx_fix_up_extension_type_from_spec(spec, (PyTypeObject *) cached_type) < 0)) goto bad;
    new_cached_type = __Pyx_PyDict_SetDefault(abi_module_dict, py_object_name, cached_type);
    if (unlikely(new_cached_type != cached_type)) {
        if (unlikely(!new_cached_type)) goto bad;
        Py_DECREF(cached_type);
        cached_type = new_cached_type;
        if (__Pyx_VerifyCachedType(
                cached_type,
                object_name,
                spec->basicsize) < 0) {
            goto bad;
        }
        goto done;
    } else {
        Py_DECREF(new_cached_type);
    }
done:
    Py_XDECREF(abi_module);
    Py_DECREF(py_object_name);
    assert(cached_type == NULL || PyType_Check(cached_type));
    return (PyTypeObject *) cached_type;
bad:
    Py_XDECREF(cached_type);
    cached_type = NULL;
    goto done;
}

/* CommonTypesMetaclass (used by CythonFunctionShared) */
static PyObject* __pyx_CommonTypesMetaclass_get_module(CYTHON_UNUSED PyObject *self, CYTHON_UNUSED void* context) {
    return PyUnicode_FromString(__PYX_ABI_MODULE_NAME);
}
#if __PYX_LIMITED_VERSION_HEX < 0x030A0000
static PyObject* __pyx_CommonTypesMetaclass_call(CYTHON_UNUSED PyObject *self, CYTHON_UNUSED PyObject *args, CYTHON_UNUSED PyObject *kwds) {
    PyErr_SetString(PyExc_TypeError, "Cannot instantiate Cython internal types");
    return NULL;
}
static int __pyx_CommonTypesMetaclass_setattr(CYTHON_UNUSED PyObject *self, CYTHON_UNUSED PyObject *attr, CYTHON_UNUSED PyObject *value) {
    PyErr_SetString(PyExc_TypeError, "Cython internal types are immutable");
    return -1;
}
#endif
static PyGetSetDef __pyx_CommonTypesMetaclass_getset[] = {
    {"__module__", __pyx_CommonTypesMetaclass_get_module, NULL, NULL, NULL},
    {0, 0, 0, 0, 0}
};
static PyType_Slot __pyx_CommonTypesMetaclass_slots[] = {
    {Py_tp_getset, (void *)__pyx_CommonTypesMetaclass_getset},
    #if __PYX_LIMITED_VERSION_HEX < 0x030A0000
    {Py_tp_call, (void*)__pyx_CommonTypesMetaclass_call},
    {Py_tp_new, (void*)__pyx_CommonTypesMetaclass_call},
    {Py_tp_setattro, (void*)__pyx_CommonTypesMetaclass_setattr},
    #endif
    {0, 0}
};
static PyType_Spec __pyx_CommonTypesMetaclass_spec = {
    __PYX_TYPE_MODULE_PREFIX "_common_types_metatype",
    0,
    0,
    Py_TPFLAGS_IMMUTABLETYPE |
    Py_TPFLAGS_DISALLOW_INSTANTIATION |
    Py_TPFLAGS_DEFAULT,
    __pyx_CommonTypesMetaclass_slots
};
static int __pyx_CommonTypesMetaclass_init(PyObject *module) {
    __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module);
    PyObject *bases = PyTuple_Pack(1, &PyType_Type);
    if (unlikely(!bases)) {
        return -1;
    }
    mstate->__pyx_CommonTypesMetaclassType = __Pyx_FetchCommonTypeFromSpec(NULL, module, &__pyx_CommonTypesMetaclass_spec, bases);
    Py_DECREF(bases);
    if (unlikely(mstate->__pyx_CommonTypesMetaclassType == NULL)) {
        return -1;
    }
    return 0;
}

/* PyMethodNew (used by CythonFunctionShared) */
#if CYTHON_COMPILING_IN_LIMITED_API
static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) {
    PyObject *result;
    CYTHON_UNUSED_VAR(typ);
    if (!self)
        return __Pyx_NewRef(func);
    #if __PYX_LIMITED_VERSION_HEX >= 0x030C0000
    {
        PyObject *args[] = {func, self};
        result = PyObject_Vectorcall(__pyx_mstate_global->__Pyx_CachedMethodType, args, 2, NULL);
    }
    #else
    result = PyObject_CallFunctionObjArgs(__pyx_mstate_global->__Pyx_CachedMethodType, func, self, NULL);
    #endif
    return result;
}
#else
static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) {
    CYTHON_UNUSED_VAR(typ);
    if (!self)
        return __Pyx_NewRef(func);
    return PyMethod_New(func, self);
}
#endif

/* PyVectorcallFastCallDict (used by CythonFunctionShared) */
#if CYTHON_METH_FASTCALL && CYTHON_VECTORCALL
static PyObject *__Pyx_PyVectorcall_FastCallDict_kw(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw)
{
    PyObject *res = NULL;
    PyObject *kwnames;
    PyObject **newargs;
    PyObject **kwvalues;
    Py_ssize_t i;
    #if CYTHON_AVOID_BORROWED_REFS
    PyObject *pos;
    #else
    Py_ssize_t pos;
    #endif
    size_t j;
    PyObject *key, *value;
    unsigned long keys_are_strings;
    #if !CYTHON_ASSUME_SAFE_SIZE
    Py_ssize_t nkw = PyDict_Size(kw);
    if (unlikely(nkw == -1)) return NULL;
    #else
    Py_ssize_t nkw = PyDict_GET_SIZE(kw);
    #endif
    newargs = (PyObject **)PyMem_Malloc((nargs + (size_t)nkw) * sizeof(args[0]));
    if (unlikely(newargs == NULL)) {
        PyErr_NoMemory();
        return NULL;
    }
    for (j = 0; j < nargs; j++) newargs[j] = args[j];
    kwnames = PyTuple_New(nkw);
    if (unlikely(kwnames == NULL)) {
        PyMem_Free(newargs);
        return NULL;
    }
    kwvalues = newargs + nargs;
    pos = 0;
    i = 0;
    keys_are_strings = Py_TPFLAGS_UNICODE_SUBCLASS;
    while (__Pyx_PyDict_NextRef(kw, &pos, &key, &value)) {
        keys_are_strings &=
        #if CYTHON_COMPILING_IN_LIMITED_API
            PyType_GetFlags(Py_TYPE(key));
        #else
            Py_TYPE(key)->tp_flags;
        #endif
        #if !CYTHON_ASSUME_SAFE_MACROS
        if (unlikely(PyTuple_SetItem(kwnames, i, key) < 0)) goto cleanup;
        #else
        PyTuple_SET_ITEM(kwnames, i, key);
        #endif
        kwvalues[i] = value;
        i++;
    }
    if (unlikely(!keys_are_strings)) {
        PyErr_SetString(PyExc_TypeError, "keywords must be strings");
        goto cleanup;
    }
    res = vc(func, newargs, nargs, kwnames);
cleanup:
    #if CYTHON_AVOID_BORROWED_REFS
    Py_DECREF(pos);
    #endif
    Py_DECREF(kwnames);
    for (i = 0; i < nkw; i++)
        Py_DECREF(kwvalues[i]);
    PyMem_Free(newargs);
    return res;
}
static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw)
{
    Py_ssize_t kw_size =
        likely(kw == NULL) ?
        0 :
#if !CYTHON_ASSUME_SAFE_SIZE
        PyDict_Size(kw);
#else
        PyDict_GET_SIZE(kw);
#endif
    if (kw_size == 0) {
        return vc(func, args, nargs, NULL);
    }
#if !CYTHON_ASSUME_SAFE_SIZE
    else if (unlikely(kw_size == -1)) {
        return NULL;
    }
#endif
    return __Pyx_PyVectorcall_FastCallDict_kw(func, vc, args, nargs, kw);
}
#endif

/* CythonFunctionShared (used by CythonFunction) */
#if CYTHON_COMPILING_IN_LIMITED_API
static CYTHON_INLINE int __Pyx__IsSameCyOrCFunctionNoMethod(PyObject *func, void (*cfunc)(void)) {
    if (__Pyx_CyFunction_Check(func)) {
        return PyCFunction_GetFunction(((__pyx_CyFunctionObject*)func)->func) == (PyCFunction) cfunc;
    } else if (PyCFunction_Check(func)) {
        return PyCFunction_GetFunction(func) == (PyCFunction) cfunc;
    }
    return 0;
}
static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) {
    if ((PyObject*)Py_TYPE(func) == __pyx_mstate_global->__Pyx_CachedMethodType) {
        int result;
        PyObject *newFunc = PyObject_GetAttr(func, __pyx_mstate_global->__pyx_n_u_func);
        if (unlikely(!newFunc)) {
            PyErr_Clear(); // It's only an optimization, so don't throw an error
            return 0;
        }
        result = __Pyx__IsSameCyOrCFunctionNoMethod(newFunc, cfunc);
        Py_DECREF(newFunc);
        return result;
    }
    return __Pyx__IsSameCyOrCFunctionNoMethod(func, cfunc);
}
#else
static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) {
    if (PyMethod_Check(func)) {
        func = PyMethod_GET_FUNCTION(func);
    }
    return __Pyx_CyOrPyCFunction_Check(func) && __Pyx_CyOrPyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc;
}
#endif
static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj) {
#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API
    __Pyx_Py_XDECREF_SET(
        __Pyx_CyFunction_GetClassObj(f),
            ((classobj) ? __Pyx_NewRef(classobj) : NULL));
#else
    __Pyx_Py_XDECREF_SET(
        ((PyCMethodObject *) (f))->mm_class,
        (PyTypeObject*)((classobj) ? __Pyx_NewRef(classobj) : NULL));
#endif
}
static PyObject *
__Pyx_CyFunction_get_doc_locked(__pyx_CyFunctionObject *op)
{
    if (unlikely(op->func_doc == NULL)) {
#if CYTHON_COMPILING_IN_LIMITED_API
        op->func_doc = PyObject_GetAttrString(op->func, "__doc__");
        if (unlikely(!op->func_doc)) return NULL;
#else
        if (((PyCFunctionObject*)op)->m_ml->ml_doc) {
            op->func_doc = PyUnicode_FromString(((PyCFunctionObject*)op)->m_ml->ml_doc);
            if (unlikely(op->func_doc == NULL))
                return NULL;
        } else {
            Py_INCREF(Py_None);
            return Py_None;
        }
#endif
    }
    Py_INCREF(op->func_doc);
    return op->func_doc;
}
static PyObject *
__Pyx_CyFunction_get_doc(__pyx_CyFunctionObject *op, void *closure) {
    PyObject *result;
    CYTHON_UNUSED_VAR(closure);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    result = __Pyx_CyFunction_get_doc_locked(op);
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static int
__Pyx_CyFunction_set_doc(__pyx_CyFunctionObject *op, PyObject *value, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (value == NULL) {
        value = Py_None;
    }
    Py_INCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->func_doc, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
static PyObject *
__Pyx_CyFunction_get_name_locked(__pyx_CyFunctionObject *op)
{
    if (unlikely(op->func_name == NULL)) {
#if CYTHON_COMPILING_IN_LIMITED_API
        op->func_name = PyObject_GetAttrString(op->func, "__name__");
#else
        op->func_name = PyUnicode_InternFromString(((PyCFunctionObject*)op)->m_ml->ml_name);
#endif
        if (unlikely(op->func_name == NULL))
            return NULL;
    }
    Py_INCREF(op->func_name);
    return op->func_name;
}
static PyObject *
__Pyx_CyFunction_get_name(__pyx_CyFunctionObject *op, void *context)
{
    PyObject *result = NULL;
    CYTHON_UNUSED_VAR(context);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    result = __Pyx_CyFunction_get_name_locked(op);
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static int
__Pyx_CyFunction_set_name(__pyx_CyFunctionObject *op, PyObject *value, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (unlikely(value == NULL || !PyUnicode_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__name__ must be set to a string object");
        return -1;
    }
    Py_INCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->func_name, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
static PyObject *
__Pyx_CyFunction_get_qualname(__pyx_CyFunctionObject *op, void *context)
{
    CYTHON_UNUSED_VAR(context);
    PyObject *result;
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    Py_INCREF(op->func_qualname);
    result = op->func_qualname;
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static int
__Pyx_CyFunction_set_qualname(__pyx_CyFunctionObject *op, PyObject *value, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (unlikely(value == NULL || !PyUnicode_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__qualname__ must be set to a string object");
        return -1;
    }
    Py_INCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->func_qualname, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
static PyObject *
__Pyx_CyFunction_get_dict(__pyx_CyFunctionObject *op, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (unlikely(op->func_dict == NULL)) {
        op->func_dict = PyDict_New();
        if (unlikely(op->func_dict == NULL))
            return NULL;
    }
    Py_INCREF(op->func_dict);
    return op->func_dict;
}
#endif
static PyObject *
__Pyx_CyFunction_get_globals(__pyx_CyFunctionObject *op, void *context)
{
    CYTHON_UNUSED_VAR(context);
    Py_INCREF(op->func_globals);
    return op->func_globals;
}
static PyObject *
__Pyx_CyFunction_get_closure(__pyx_CyFunctionObject *op, void *context)
{
    CYTHON_UNUSED_VAR(op);
    CYTHON_UNUSED_VAR(context);
    Py_INCREF(Py_None);
    return Py_None;
}
static PyObject *
__Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op, void *context)
{
    PyObject* result = (op->func_code) ? op->func_code : Py_None;
    CYTHON_UNUSED_VAR(context);
    Py_INCREF(result);
    return result;
}
static int
__Pyx_CyFunction_init_defaults(__pyx_CyFunctionObject *op) {
    int result = 0;
    PyObject *res = op->defaults_getter((PyObject *) op);
    if (unlikely(!res))
        return -1;
    #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
    op->defaults_tuple = PyTuple_GET_ITEM(res, 0);
    Py_INCREF(op->defaults_tuple);
    op->defaults_kwdict = PyTuple_GET_ITEM(res, 1);
    Py_INCREF(op->defaults_kwdict);
    #else
    op->defaults_tuple = __Pyx_PySequence_ITEM(res, 0);
    if (unlikely(!op->defaults_tuple)) result = -1;
    else {
        op->defaults_kwdict = __Pyx_PySequence_ITEM(res, 1);
        if (unlikely(!op->defaults_kwdict)) result = -1;
    }
    #endif
    Py_DECREF(res);
    return result;
}
static int
__Pyx_CyFunction_set_defaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) {
    CYTHON_UNUSED_VAR(context);
    if (!value) {
        value = Py_None;
    } else if (unlikely(value != Py_None && !PyTuple_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__defaults__ must be set to a tuple object");
        return -1;
    }
    PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__defaults__ will not "
                 "currently affect the values used in function calls", 1);
    Py_INCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->defaults_tuple, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
static PyObject *
__Pyx_CyFunction_get_defaults_locked(__pyx_CyFunctionObject *op) {
    PyObject* result = op->defaults_tuple;
    if (unlikely(!result)) {
        if (op->defaults_getter) {
            if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL;
            result = op->defaults_tuple;
        } else {
            result = Py_None;
        }
    }
    Py_INCREF(result);
    return result;
}
static PyObject *
__Pyx_CyFunction_get_defaults(__pyx_CyFunctionObject *op, void *context) {
    PyObject* result = NULL;
    CYTHON_UNUSED_VAR(context);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    result = __Pyx_CyFunction_get_defaults_locked(op);
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static int
__Pyx_CyFunction_set_kwdefaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) {
    CYTHON_UNUSED_VAR(context);
    if (!value) {
        value = Py_None;
    } else if (unlikely(value != Py_None && !PyDict_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__kwdefaults__ must be set to a dict object");
        return -1;
    }
    PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__kwdefaults__ will not "
                 "currently affect the values used in function calls", 1);
    Py_INCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->defaults_kwdict, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
static PyObject *
__Pyx_CyFunction_get_kwdefaults_locked(__pyx_CyFunctionObject *op) {
    PyObject* result = op->defaults_kwdict;
    if (unlikely(!result)) {
        if (op->defaults_getter) {
            if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL;
            result = op->defaults_kwdict;
        } else {
            result = Py_None;
        }
    }
    Py_INCREF(result);
    return result;
}
static PyObject *
__Pyx_CyFunction_get_kwdefaults(__pyx_CyFunctionObject *op, void *context) {
    PyObject* result;
    CYTHON_UNUSED_VAR(context);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    result = __Pyx_CyFunction_get_kwdefaults_locked(op);
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static int
__Pyx_CyFunction_set_annotations(__pyx_CyFunctionObject *op, PyObject* value, void *context) {
    CYTHON_UNUSED_VAR(context);
    if (!value || value == Py_None) {
        value = NULL;
    } else if (unlikely(!PyDict_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__annotations__ must be set to a dict object");
        return -1;
    }
    Py_XINCREF(value);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    __Pyx_Py_XDECREF_SET(op->func_annotations, value);
    __Pyx_END_CRITICAL_SECTION();
    return 0;
}
static PyObject *
__Pyx_CyFunction_get_annotations_locked(__pyx_CyFunctionObject *op) {
    PyObject* result = op->func_annotations;
    if (unlikely(!result)) {
        result = PyDict_New();
        if (unlikely(!result)) return NULL;
        op->func_annotations = result;
    }
    Py_INCREF(result);
    return result;
}
static PyObject *
__Pyx_CyFunction_get_annotations(__pyx_CyFunctionObject *op, void *context) {
    PyObject *result;
    CYTHON_UNUSED_VAR(context);
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    result = __Pyx_CyFunction_get_annotations_locked(op);
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static PyObject *
__Pyx_CyFunction_get_is_coroutine_value(__pyx_CyFunctionObject *op) {
    int is_coroutine = op->flags & __Pyx_CYFUNCTION_COROUTINE;
    if (is_coroutine) {
        PyObject *is_coroutine_value, *module, *fromlist, *marker = __pyx_mstate_global->__pyx_n_u_is_coroutine;
        fromlist = PyList_New(1);
        if (unlikely(!fromlist)) return NULL;
        Py_INCREF(marker);
#if CYTHON_ASSUME_SAFE_MACROS
        PyList_SET_ITEM(fromlist, 0, marker);
#else
        if (unlikely(PyList_SetItem(fromlist, 0, marker) < 0)) {
            Py_DECREF(marker);
            Py_DECREF(fromlist);
            return NULL;
        }
#endif
        module = PyImport_ImportModuleLevelObject(__pyx_mstate_global->__pyx_n_u_asyncio_coroutines, NULL, NULL, fromlist, 0);
        Py_DECREF(fromlist);
        if (unlikely(!module)) goto ignore;
        is_coroutine_value = __Pyx_PyObject_GetAttrStr(module, marker);
        Py_DECREF(module);
        if (likely(is_coroutine_value)) {
            return is_coroutine_value;
        }
ignore:
        PyErr_Clear();
    }
    return __Pyx_PyBool_FromLong(is_coroutine);
}
static PyObject *
__Pyx_CyFunction_get_is_coroutine(__pyx_CyFunctionObject *op, void *context) {
    PyObject *result;
    CYTHON_UNUSED_VAR(context);
    if (op->func_is_coroutine) {
        return __Pyx_NewRef(op->func_is_coroutine);
    }
    result = __Pyx_CyFunction_get_is_coroutine_value(op);
    if (unlikely(!result))
        return NULL;
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    if (op->func_is_coroutine) {
        Py_DECREF(result);
        result = __Pyx_NewRef(op->func_is_coroutine);
    } else {
        op->func_is_coroutine = __Pyx_NewRef(result);
    }
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static void __Pyx_CyFunction_raise_argument_count_error(__pyx_CyFunctionObject *func, const char* message, Py_ssize_t size) {
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL);
    if (!py_name) return;
    PyErr_Format(PyExc_TypeError,
        "%.200S() %s (%" CYTHON_FORMAT_SSIZE_T "d given)",
        py_name, message, size);
    Py_DECREF(py_name);
#else
    const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name;
    PyErr_Format(PyExc_TypeError,
        "%.200s() %s (%" CYTHON_FORMAT_SSIZE_T "d given)",
        name, message, size);
#endif
}
static void __Pyx_CyFunction_raise_type_error(__pyx_CyFunctionObject *func, const char* message) {
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL);
    if (!py_name) return;
    PyErr_Format(PyExc_TypeError,
        "%.200S() %s",
        py_name, message);
    Py_DECREF(py_name);
#else
    const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name;
    PyErr_Format(PyExc_TypeError,
        "%.200s() %s",
        name, message);
#endif
}
#if CYTHON_COMPILING_IN_LIMITED_API
static PyObject *
__Pyx_CyFunction_get_module(__pyx_CyFunctionObject *op, void *context) {
    CYTHON_UNUSED_VAR(context);
    return PyObject_GetAttrString(op->func, "__module__");
}
static int
__Pyx_CyFunction_set_module(__pyx_CyFunctionObject *op, PyObject* value, void *context) {
    CYTHON_UNUSED_VAR(context);
    return PyObject_SetAttrString(op->func, "__module__", value);
}
#endif
static PyGetSetDef __pyx_CyFunction_getsets[] = {
    {"func_doc", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0},
    {"__doc__",  (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0},
    {"func_name", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0},
    {"__name__", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0},
    {"__qualname__", (getter)__Pyx_CyFunction_get_qualname, (setter)__Pyx_CyFunction_set_qualname, 0, 0},
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
    {"func_dict", (getter)__Pyx_CyFunction_get_dict, (setter)PyObject_GenericSetDict, 0, 0},
    {"__dict__", (getter)__Pyx_CyFunction_get_dict, (setter)PyObject_GenericSetDict, 0, 0},
#else
    {"func_dict", (getter)PyObject_GenericGetDict, (setter)PyObject_GenericSetDict, 0, 0},
    {"__dict__", (getter)PyObject_GenericGetDict, (setter)PyObject_GenericSetDict, 0, 0},
#endif
    {"func_globals", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0},
    {"__globals__", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0},
    {"func_closure", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0},
    {"__closure__", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0},
    {"func_code", (getter)__Pyx_CyFunction_get_code, 0, 0, 0},
    {"__code__", (getter)__Pyx_CyFunction_get_code, 0, 0, 0},
    {"func_defaults", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0},
    {"__defaults__", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0},
    {"__kwdefaults__", (getter)__Pyx_CyFunction_get_kwdefaults, (setter)__Pyx_CyFunction_set_kwdefaults, 0, 0},
    {"__annotations__", (getter)__Pyx_CyFunction_get_annotations, (setter)__Pyx_CyFunction_set_annotations, 0, 0},
    {"_is_coroutine", (getter)__Pyx_CyFunction_get_is_coroutine, 0, 0, 0},
#if CYTHON_COMPILING_IN_LIMITED_API
    {"__module__", (getter)__Pyx_CyFunction_get_module, (setter)__Pyx_CyFunction_set_module, 0, 0},
#endif
    {0, 0, 0, 0, 0}
};
static PyMemberDef __pyx_CyFunction_members[] = {
#if !CYTHON_COMPILING_IN_LIMITED_API
    {"__module__", T_OBJECT, offsetof(PyCFunctionObject, m_module), 0, 0},
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    {"__dictoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_dict), READONLY, 0},
#endif
#if CYTHON_METH_FASTCALL
#if CYTHON_COMPILING_IN_LIMITED_API
    {"__vectorcalloffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_vectorcall), READONLY, 0},
#else
    {"__vectorcalloffset__", T_PYSSIZET, offsetof(PyCFunctionObject, vectorcall), READONLY, 0},
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
    {"__weaklistoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_weakreflist), READONLY, 0},
#else
    {"__weaklistoffset__", T_PYSSIZET, offsetof(PyCFunctionObject, m_weakreflist), READONLY, 0},
#endif
#endif
    {0, 0, 0,  0, 0}
};
static PyObject *
__Pyx_CyFunction_reduce(__pyx_CyFunctionObject *m, PyObject *args)
{
    PyObject *result = NULL;
    CYTHON_UNUSED_VAR(args);
    __Pyx_BEGIN_CRITICAL_SECTION(m);
    Py_INCREF(m->func_qualname);
    result = m->func_qualname;
    __Pyx_END_CRITICAL_SECTION();
    return result;
}
static PyMethodDef __pyx_CyFunction_methods[] = {
    {"__reduce__", (PyCFunction)__Pyx_CyFunction_reduce, METH_VARARGS, 0},
    {0, 0, 0, 0}
};
#if CYTHON_COMPILING_IN_LIMITED_API
#define __Pyx_CyFunction_weakreflist(cyfunc) ((cyfunc)->func_weakreflist)
#else
#define __Pyx_CyFunction_weakreflist(cyfunc) (((PyCFunctionObject*)cyfunc)->m_weakreflist)
#endif
static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject *op, PyMethodDef *ml, int flags, PyObject* qualname,
                                       PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) {
#if !CYTHON_COMPILING_IN_LIMITED_API
    PyCFunctionObject *cf = (PyCFunctionObject*) op;
#endif
    if (unlikely(op == NULL))
        return NULL;
#if CYTHON_COMPILING_IN_LIMITED_API
    op->func = PyCFunction_NewEx(ml, (PyObject*)op, module);
    if (unlikely(!op->func)) return NULL;
#endif
    op->flags = flags;
    __Pyx_CyFunction_weakreflist(op) = NULL;
#if !CYTHON_COMPILING_IN_LIMITED_API
    cf->m_ml = ml;
    cf->m_self = (PyObject *) op;
#endif
    Py_XINCREF(closure);
    op->func_closure = closure;
#if !CYTHON_COMPILING_IN_LIMITED_API
    Py_XINCREF(module);
    cf->m_module = module;
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    op->func_dict = NULL;
#endif
    op->func_name = NULL;
    Py_INCREF(qualname);
    op->func_qualname = qualname;
    op->func_doc = NULL;
#if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API
    op->func_classobj = NULL;
#else
    ((PyCMethodObject*)op)->mm_class = NULL;
#endif
    op->func_globals = globals;
    Py_INCREF(op->func_globals);
    Py_XINCREF(code);
    op->func_code = code;
    op->defaults = NULL;
    op->defaults_tuple = NULL;
    op->defaults_kwdict = NULL;
    op->defaults_getter = NULL;
    op->func_annotations = NULL;
    op->func_is_coroutine = NULL;
#if CYTHON_METH_FASTCALL
    switch (ml->ml_flags & (METH_VARARGS | METH_FASTCALL | METH_NOARGS | METH_O | METH_KEYWORDS | METH_METHOD)) {
    case METH_NOARGS:
        __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_NOARGS;
        break;
    case METH_O:
        __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_O;
        break;
    case METH_METHOD | METH_FASTCALL | METH_KEYWORDS:
        __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD;
        break;
    case METH_FASTCALL | METH_KEYWORDS:
        __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS;
        break;
    case METH_VARARGS | METH_KEYWORDS:
        __Pyx_CyFunction_func_vectorcall(op) = NULL;
        break;
    default:
        PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction");
        Py_DECREF(op);
        return NULL;
    }
#endif
    return (PyObject *) op;
}
static int
__Pyx_CyFunction_clear(__pyx_CyFunctionObject *m)
{
    Py_CLEAR(m->func_closure);
#if CYTHON_COMPILING_IN_LIMITED_API
    Py_CLEAR(m->func);
#else
    Py_CLEAR(((PyCFunctionObject*)m)->m_module);
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    Py_CLEAR(m->func_dict);
#elif PY_VERSION_HEX < 0x030d0000
    _PyObject_ClearManagedDict((PyObject*)m);
#else
    PyObject_ClearManagedDict((PyObject*)m);
#endif
    Py_CLEAR(m->func_name);
    Py_CLEAR(m->func_qualname);
    Py_CLEAR(m->func_doc);
    Py_CLEAR(m->func_globals);
    Py_CLEAR(m->func_code);
#if !CYTHON_COMPILING_IN_LIMITED_API
#if PY_VERSION_HEX < 0x030900B1
    Py_CLEAR(__Pyx_CyFunction_GetClassObj(m));
#else
    {
        PyObject *cls = (PyObject*) ((PyCMethodObject *) (m))->mm_class;
        ((PyCMethodObject *) (m))->mm_class = NULL;
        Py_XDECREF(cls);
    }
#endif
#endif
    Py_CLEAR(m->defaults_tuple);
    Py_CLEAR(m->defaults_kwdict);
    Py_CLEAR(m->func_annotations);
    Py_CLEAR(m->func_is_coroutine);
    Py_CLEAR(m->defaults);
    return 0;
}
static void __Pyx__CyFunction_dealloc(__pyx_CyFunctionObject *m)
{
    if (__Pyx_CyFunction_weakreflist(m) != NULL)
        PyObject_ClearWeakRefs((PyObject *) m);
    __Pyx_CyFunction_clear(m);
    __Pyx_PyHeapTypeObject_GC_Del(m);
}
static void __Pyx_CyFunction_dealloc(__pyx_CyFunctionObject *m)
{
    PyObject_GC_UnTrack(m);
    __Pyx__CyFunction_dealloc(m);
}
static int __Pyx_CyFunction_traverse(__pyx_CyFunctionObject *m, visitproc visit, void *arg)
{
    {
        int e = __Pyx_call_type_traverse((PyObject*)m, 1, visit, arg);
        if (e) return e;
    }
    Py_VISIT(m->func_closure);
#if CYTHON_COMPILING_IN_LIMITED_API
    Py_VISIT(m->func);
#else
    Py_VISIT(((PyCFunctionObject*)m)->m_module);
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    Py_VISIT(m->func_dict);
#else
    {
        int e =
#if PY_VERSION_HEX < 0x030d0000
            _PyObject_VisitManagedDict
#else
            PyObject_VisitManagedDict
#endif
                ((PyObject*)m, visit, arg);
        if (e != 0) return e;
    }
#endif
    __Pyx_VISIT_CONST(m->func_name);
    __Pyx_VISIT_CONST(m->func_qualname);
    Py_VISIT(m->func_doc);
    Py_VISIT(m->func_globals);
    __Pyx_VISIT_CONST(m->func_code);
#if !CYTHON_COMPILING_IN_LIMITED_API
    Py_VISIT(__Pyx_CyFunction_GetClassObj(m));
#endif
    Py_VISIT(m->defaults_tuple);
    Py_VISIT(m->defaults_kwdict);
    Py_VISIT(m->func_is_coroutine);
    Py_VISIT(m->defaults);
    return 0;
}
static PyObject*
__Pyx_CyFunction_repr(__pyx_CyFunctionObject *op)
{
    PyObject *repr;
    __Pyx_BEGIN_CRITICAL_SECTION(op);
    repr = PyUnicode_FromFormat("<cyfunction %U at %p>",
                                op->func_qualname, (void *)op);
    __Pyx_END_CRITICAL_SECTION();
    return repr;
}
static PyObject * __Pyx_CyFunction_CallMethod(PyObject *func, PyObject *self, PyObject *arg, PyObject *kw) {
#if CYTHON_COMPILING_IN_LIMITED_API
    PyObject *f = ((__pyx_CyFunctionObject*)func)->func;
    PyCFunction meth;
    int flags;
    meth = PyCFunction_GetFunction(f);
    if (unlikely(!meth)) return NULL;
    flags = PyCFunction_GetFlags(f);
    if (unlikely(flags < 0)) return NULL;
#else
    PyCFunctionObject* f = (PyCFunctionObject*)func;
    PyCFunction meth = f->m_ml->ml_meth;
    int flags = f->m_ml->ml_flags;
#endif
    Py_ssize_t size;
    switch (flags & (METH_VARARGS | METH_KEYWORDS | METH_NOARGS | METH_O)) {
    case METH_VARARGS:
        if (likely(kw == NULL || PyDict_Size(kw) == 0))
            return (*meth)(self, arg);
        break;
    case METH_VARARGS | METH_KEYWORDS:
        return (*(PyCFunctionWithKeywords)(void(*)(void))meth)(self, arg, kw);
    case METH_NOARGS:
        if (likely(kw == NULL || PyDict_Size(kw) == 0)) {
#if CYTHON_ASSUME_SAFE_SIZE
            size = PyTuple_GET_SIZE(arg);
#else
            size = PyTuple_Size(arg);
            if (unlikely(size < 0)) return NULL;
#endif
            if (likely(size == 0))
                return (*meth)(self, NULL);
            __Pyx_CyFunction_raise_argument_count_error(
                (__pyx_CyFunctionObject*)func,
                "takes no arguments", size);
            return NULL;
        }
        break;
    case METH_O:
        if (likely(kw == NULL || PyDict_Size(kw) == 0)) {
#if CYTHON_ASSUME_SAFE_SIZE
            size = PyTuple_GET_SIZE(arg);
#else
            size = PyTuple_Size(arg);
            if (unlikely(size < 0)) return NULL;
#endif
            if (likely(size == 1)) {
                PyObject *result, *arg0;
                #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
                arg0 = PyTuple_GET_ITEM(arg, 0);
                #else
                arg0 = __Pyx_PySequence_ITEM(arg, 0); if (unlikely(!arg0)) return NULL;
                #endif
                result = (*meth)(self, arg0);
                #if !(CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS)
                Py_DECREF(arg0);
                #endif
                return result;
            }
            __Pyx_CyFunction_raise_argument_count_error(
                (__pyx_CyFunctionObject*)func,
                "takes exactly one argument", size);
            return NULL;
        }
        break;
    default:
        PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction");
        return NULL;
    }
    __Pyx_CyFunction_raise_type_error(
        (__pyx_CyFunctionObject*)func, "takes no keyword arguments");
    return NULL;
}
static CYTHON_INLINE PyObject *__Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject *kw) {
    PyObject *self, *result;
#if CYTHON_COMPILING_IN_LIMITED_API
    self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)func)->func);
    if (unlikely(!self) && PyErr_Occurred()) return NULL;
#else
    self = ((PyCFunctionObject*)func)->m_self;
#endif
    result = __Pyx_CyFunction_CallMethod(func, self, arg, kw);
    return result;
}
static PyObject *__Pyx_CyFunction_CallAsMethod(PyObject *func, PyObject *args, PyObject *kw) {
    PyObject *result;
    __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *) func;
#if CYTHON_METH_FASTCALL && CYTHON_VECTORCALL
     __pyx_vectorcallfunc vc = __Pyx_CyFunction_func_vectorcall(cyfunc);
    if (vc) {
#if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE
        return __Pyx_PyVectorcall_FastCallDict(func, vc, &PyTuple_GET_ITEM(args, 0), (size_t)PyTuple_GET_SIZE(args), kw);
#else
        (void) &__Pyx_PyVectorcall_FastCallDict;
        return PyVectorcall_Call(func, args, kw);
#endif
    }
#endif
    if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) {
        Py_ssize_t argc;
        PyObject *new_args;
        PyObject *self;
#if CYTHON_ASSUME_SAFE_SIZE
        argc = PyTuple_GET_SIZE(args);
#else
        argc = PyTuple_Size(args);
        if (unlikely(argc < 0)) return NULL;
#endif
        new_args = PyTuple_GetSlice(args, 1, argc);
        if (unlikely(!new_args))
            return NULL;
        self = PyTuple_GetItem(args, 0);
        if (unlikely(!self)) {
            Py_DECREF(new_args);
            PyErr_Format(PyExc_TypeError,
                         "unbound method %.200S() needs an argument",
                         cyfunc->func_qualname);
            return NULL;
        }
        result = __Pyx_CyFunction_CallMethod(func, self, new_args, kw);
        Py_DECREF(new_args);
    } else {
        result = __Pyx_CyFunction_Call(func, args, kw);
    }
    return result;
}
#if CYTHON_METH_FASTCALL && CYTHON_VECTORCALL
static CYTHON_INLINE int __Pyx_CyFunction_Vectorcall_CheckArgs(__pyx_CyFunctionObject *cyfunc, Py_ssize_t nargs, PyObject *kwnames)
{
    int ret = 0;
    if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) {
        if (unlikely(nargs < 1)) {
            __Pyx_CyFunction_raise_type_error(
                cyfunc, "needs an argument");
            return -1;
        }
        ret = 1;
    }
    if (unlikely(kwnames) && unlikely(__Pyx_PyTuple_GET_SIZE(kwnames))) {
        __Pyx_CyFunction_raise_type_error(
            cyfunc, "takes no keyword arguments");
        return -1;
    }
    return ret;
}
static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
{
    __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func;
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
    PyObject *self;
#if CYTHON_COMPILING_IN_LIMITED_API
    PyCFunction meth = PyCFunction_GetFunction(cyfunc->func);
    if (unlikely(!meth)) return NULL;
#else
    PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth;
#endif
    switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) {
    case 1:
        self = args[0];
        args += 1;
        nargs -= 1;
        break;
    case 0:
#if CYTHON_COMPILING_IN_LIMITED_API
        self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func);
        if (unlikely(!self) && PyErr_Occurred()) return NULL;
#else
        self = ((PyCFunctionObject*)cyfunc)->m_self;
#endif
        break;
    default:
        return NULL;
    }
    if (unlikely(nargs != 0)) {
        __Pyx_CyFunction_raise_argument_count_error(
            cyfunc, "takes no arguments", nargs);
        return NULL;
    }
    return meth(self, NULL);
}
static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
{
    __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func;
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
    PyObject *self;
#if CYTHON_COMPILING_IN_LIMITED_API
    PyCFunction meth = PyCFunction_GetFunction(cyfunc->func);
    if (unlikely(!meth)) return NULL;
#else
    PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth;
#endif
    switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) {
    case 1:
        self = args[0];
        args += 1;
        nargs -= 1;
        break;
    case 0:
#if CYTHON_COMPILING_IN_LIMITED_API
        self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func);
        if (unlikely(!self) && PyErr_Occurred()) return NULL;
#else
        self = ((PyCFunctionObject*)cyfunc)->m_self;
#endif
        break;
    default:
        return NULL;
    }
    if (unlikely(nargs != 1)) {
        __Pyx_CyFunction_raise_argument_count_error(
            cyfunc, "takes exactly one argument", nargs);
        return NULL;
    }
    return meth(self, args[0]);
}
static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
{
    __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func;
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
    PyObject *self;
#if CYTHON_COMPILING_IN_LIMITED_API
    PyCFunction meth = PyCFunction_GetFunction(cyfunc->func);
    if (unlikely(!meth)) return NULL;
#else
    PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth;
#endif
    switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) {
    case 1:
        self = args[0];
        args += 1;
        nargs -= 1;
        break;
    case 0:
#if CYTHON_COMPILING_IN_LIMITED_API
        self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func);
        if (unlikely(!self) && PyErr_Occurred()) return NULL;
#else
        self = ((PyCFunctionObject*)cyfunc)->m_self;
#endif
        break;
    default:
        return NULL;
    }
    return ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))meth)(self, args, nargs, kwnames);
}
static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
{
    __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func;
    PyTypeObject *cls = (PyTypeObject *) __Pyx_CyFunction_GetClassObj(cyfunc);
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
    PyObject *self;
#if CYTHON_COMPILING_IN_LIMITED_API
    PyCFunction meth = PyCFunction_GetFunction(cyfunc->func);
    if (unlikely(!meth)) return NULL;
#else
    PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth;
#endif
    switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) {
    case 1:
        self = args[0];
        args += 1;
        nargs -= 1;
        break;
    case 0:
#if CYTHON_COMPILING_IN_LIMITED_API
        self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func);
        if (unlikely(!self) && PyErr_Occurred()) return NULL;
#else
        self = ((PyCFunctionObject*)cyfunc)->m_self;
#endif
        break;
    default:
        return NULL;
    }
    #if PY_VERSION_HEX < 0x030e00A6
    size_t nargs_value = (size_t) nargs;
    #else
    Py_ssize_t nargs_value = nargs;
    #endif
    return ((__Pyx_PyCMethod)(void(*)(void))meth)(self, cls, args, nargs_value, kwnames);
}
#endif
static PyType_Slot __pyx_CyFunctionType_slots[] = {
    {Py_tp_dealloc, (void *)__Pyx_CyFunction_dealloc},
    {Py_tp_repr, (void *)__Pyx_CyFunction_repr},
    {Py_tp_call, (void *)__Pyx_CyFunction_CallAsMethod},
    {Py_tp_traverse, (void *)__Pyx_CyFunction_traverse},
    {Py_tp_clear, (void *)__Pyx_CyFunction_clear},
    {Py_tp_methods, (void *)__pyx_CyFunction_methods},
    {Py_tp_members, (void *)__pyx_CyFunction_members},
    {Py_tp_getset, (void *)__pyx_CyFunction_getsets},
    {Py_tp_descr_get, (void *)__Pyx_PyMethod_New},
    {0, 0},
};
static PyType_Spec __pyx_CyFunctionType_spec = {
    __PYX_TYPE_MODULE_PREFIX "cython_function_or_method",
    sizeof(__pyx_CyFunctionObject),
    0,
#ifdef Py_TPFLAGS_METHOD_DESCRIPTOR
    Py_TPFLAGS_METHOD_DESCRIPTOR |
#endif
#if CYTHON_METH_FASTCALL
#if defined(Py_TPFLAGS_HAVE_VECTORCALL)
    Py_TPFLAGS_HAVE_VECTORCALL |
#elif defined(_Py_TPFLAGS_HAVE_VECTORCALL)
    _Py_TPFLAGS_HAVE_VECTORCALL |
#endif
#endif // CYTHON_METH_FASTCALL
#if PY_VERSION_HEX >= 0x030C0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_TPFLAGS_MANAGED_DICT |
#endif
    Py_TPFLAGS_IMMUTABLETYPE | Py_TPFLAGS_DISALLOW_INSTANTIATION |
    Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | Py_TPFLAGS_BASETYPE,
    __pyx_CyFunctionType_slots
};
static int __pyx_CyFunction_init(PyObject *module) {
    __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module);
    mstate->__pyx_CyFunctionType = __Pyx_FetchCommonTypeFromSpec(
        mstate->__pyx_CommonTypesMetaclassType, module, &__pyx_CyFunctionType_spec, NULL);
    if (unlikely(mstate->__pyx_CyFunctionType == NULL)) {
        return -1;
    }
    return 0;
}
static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func, PyTypeObject *defaults_type) {
    __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
    m->defaults = PyObject_CallObject((PyObject*)defaults_type, NULL); // _PyObject_New(defaults_type);
    if (unlikely(!m->defaults))
        return NULL;
    return m->defaults;
}
static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *func, PyObject *tuple) {
    __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
    m->defaults_tuple = tuple;
    Py_INCREF(tuple);
}
static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *func, PyObject *dict) {
    __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
    m->defaults_kwdict = dict;
    Py_INCREF(dict);
}
static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *func, PyObject *dict) {
    __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
    m->func_annotations = dict;
    Py_INCREF(dict);
}

/* CythonFunction */
static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml, int flags, PyObject* qualname,
                                      PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) {
    PyObject *op = __Pyx_CyFunction_Init(
        PyObject_GC_New(__pyx_CyFunctionObject, __pyx_mstate_global->__pyx_CyFunctionType),
        ml, flags, qualname, closure, module, globals, code
    );
    if (likely(op)) {
        PyObject_GC_Track(op);
    }
    return op;
}

/* Py3ClassCreate */
static PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObject *name,
                                           PyObject *qualname, PyObject *mkw, PyObject *modname, PyObject *doc) {
    PyObject *ns;
    if (metaclass) {
        PyObject *prep = __Pyx_PyObject_GetAttrStrNoError(metaclass, __pyx_mstate_global->__pyx_n_u_prepare);
        if (prep) {
            PyObject *pargs[3] = {NULL, name, bases};
            ns = __Pyx_PyObject_FastCallDict(prep, pargs+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, mkw);
            Py_DECREF(prep);
        } else {
            if (unlikely(PyErr_Occurred()))
                return NULL;
            ns = PyDict_New();
        }
    } else {
        ns = PyDict_New();
    }
    if (unlikely(!ns))
        return NULL;
    if (unlikely(PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_module, modname) < 0)) goto bad;
    if (unlikely(PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_qualname, qualname) < 0)) goto bad;
    if (unlikely(doc && PyObject_SetItem(ns, __pyx_mstate_global->__pyx_n_u_doc, doc) < 0)) goto bad;
    return ns;
bad:
    Py_DECREF(ns);
    return NULL;
}
static PyObject *__Pyx_Py3ClassCreate(PyObject *metaclass, PyObject *name, PyObject *bases,
                                      PyObject *dict, PyObject *mkw,
                                      int calculate_metaclass, int allow_py2_metaclass) {
    PyObject *result;
    PyObject *owned_metaclass = NULL;
    PyObject *margs[4] = {NULL, name, bases, dict};
    if (allow_py2_metaclass) {
        owned_metaclass = PyObject_GetItem(dict, __pyx_mstate_global->__pyx_n_u_metaclass);
        if (owned_metaclass) {
            metaclass = owned_metaclass;
        } else if (likely(PyErr_ExceptionMatches(PyExc_KeyError))) {
            PyErr_Clear();
        } else {
            return NULL;
        }
    }
    if (calculate_metaclass && (!metaclass || PyType_Check(metaclass))) {
        metaclass = __Pyx_CalculateMetaclass((PyTypeObject*) metaclass, bases);
        Py_XDECREF(owned_metaclass);
        if (unlikely(!metaclass))
            return NULL;
        owned_metaclass = metaclass;
    }
    result = __Pyx_PyObject_FastCallDict(metaclass, margs+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, mkw);
    Py_XDECREF(owned_metaclass);
    return result;
}

/* GetNameInClass */
static PyObject *__Pyx__GetNameInClass(PyObject *nmspace, PyObject *name) {
    PyObject *result;
    PyObject *dict;
    assert(PyType_Check(nmspace));
#if CYTHON_USE_TYPE_SLOTS
    dict = ((PyTypeObject*)nmspace)->tp_dict;
    Py_XINCREF(dict);
#else
    dict = PyObject_GetAttr(nmspace, __pyx_mstate_global->__pyx_n_u_dict);
#endif
    if (likely(dict)) {
        result = PyObject_GetItem(dict, name);
        Py_DECREF(dict);
        if (result) {
            return result;
        }
    }
    PyErr_Clear();
    __Pyx_GetModuleGlobalNameUncached(result, name);
    return result;
}

/* CLineInTraceback (used by AddTraceback) */
#if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
#define __Pyx_PyProbablyModule_GetDict(o) __Pyx_XNewRef(PyModule_GetDict(o))
#elif !CYTHON_COMPILING_IN_CPYTHON || CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
#define __Pyx_PyProbablyModule_GetDict(o) PyObject_GenericGetDict(o, NULL);
#else
PyObject* __Pyx_PyProbablyModule_GetDict(PyObject *o) {
    PyObject **dict_ptr = _PyObject_GetDictPtr(o);
    return dict_ptr ? __Pyx_XNewRef(*dict_ptr) : NULL;
}
#endif
static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line) {
    PyObject *use_cline = NULL;
    PyObject *ptype, *pvalue, *ptraceback;
    PyObject *cython_runtime_dict;
    CYTHON_MAYBE_UNUSED_VAR(tstate);
    if (unlikely(!__pyx_mstate_global->__pyx_cython_runtime)) {
        return c_line;
    }
    __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback);
    cython_runtime_dict = __Pyx_PyProbablyModule_GetDict(__pyx_mstate_global->__pyx_cython_runtime);
    if (likely(cython_runtime_dict)) {
        __PYX_PY_DICT_LOOKUP_IF_MODIFIED(
            use_cline, cython_runtime_dict,
            __Pyx_PyDict_SetDefault(cython_runtime_dict, __pyx_mstate_global->__pyx_n_u_cline_in_traceback, Py_False))
    }
    if (use_cline == NULL || use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) {
        c_line = 0;
    }
    Py_XDECREF(use_cline);
    Py_XDECREF(cython_runtime_dict);
    __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback);
    return c_line;
}
#endif

/* CodeObjectCache (used by AddTraceback) */
static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) {
    int start = 0, mid = 0, end = count - 1;
    if (end >= 0 && code_line > entries[end].code_line) {
        return count;
    }
    while (start < end) {
        mid = start + (end - start) / 2;
        if (code_line < entries[mid].code_line) {
            end = mid;
        } else if (code_line > entries[mid].code_line) {
             start = mid + 1;
        } else {
            return mid;
        }
    }
    if (code_line <= entries[mid].code_line) {
        return mid;
    } else {
        return mid + 1;
    }
}
static __Pyx_CachedCodeObjectType *__pyx__find_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line) {
    __Pyx_CachedCodeObjectType* code_object;
    int pos;
    if (unlikely(!code_line) || unlikely(!code_cache->entries)) {
        return NULL;
    }
    pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line);
    if (unlikely(pos >= code_cache->count) || unlikely(code_cache->entries[pos].code_line != code_line)) {
        return NULL;
    }
    code_object = code_cache->entries[pos].code_object;
    Py_INCREF(code_object);
    return code_object;
}
static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line) {
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS
    (void)__pyx__find_code_object;
    return NULL; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just miss.
#else
    struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache;
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    __pyx_nonatomic_int_type old_count = __pyx_atomic_incr_acq_rel(&code_cache->accessor_count);
    if (old_count < 0) {
        __pyx_atomic_decr_acq_rel(&code_cache->accessor_count);
        return NULL;
    }
#endif
    __Pyx_CachedCodeObjectType *result = __pyx__find_code_object(code_cache, code_line);
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    __pyx_atomic_decr_acq_rel(&code_cache->accessor_count);
#endif
    return result;
#endif
}
static void __pyx__insert_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line, __Pyx_CachedCodeObjectType* code_object)
{
    int pos, i;
    __Pyx_CodeObjectCacheEntry* entries = code_cache->entries;
    if (unlikely(!code_line)) {
        return;
    }
    if (unlikely(!entries)) {
        entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry));
        if (likely(entries)) {
            code_cache->entries = entries;
            code_cache->max_count = 64;
            code_cache->count = 1;
            entries[0].code_line = code_line;
            entries[0].code_object = code_object;
            Py_INCREF(code_object);
        }
        return;
    }
    pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line);
    if ((pos < code_cache->count) && unlikely(code_cache->entries[pos].code_line == code_line)) {
        __Pyx_CachedCodeObjectType* tmp = entries[pos].code_object;
        entries[pos].code_object = code_object;
        Py_INCREF(code_object);
        Py_DECREF(tmp);
        return;
    }
    if (code_cache->count == code_cache->max_count) {
        int new_max = code_cache->max_count + 64;
        entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc(
            code_cache->entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry));
        if (unlikely(!entries)) {
            return;
        }
        code_cache->entries = entries;
        code_cache->max_count = new_max;
    }
    for (i=code_cache->count; i>pos; i--) {
        entries[i] = entries[i-1];
    }
    entries[pos].code_line = code_line;
    entries[pos].code_object = code_object;
    code_cache->count++;
    Py_INCREF(code_object);
}
static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object) {
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS
    (void)__pyx__insert_code_object;
    return; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just fail.
#else
    struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache;
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    __pyx_nonatomic_int_type expected = 0;
    if (!__pyx_atomic_int_cmp_exchange(&code_cache->accessor_count, &expected, INT_MIN)) {
        return;
    }
#endif
    __pyx__insert_code_object(code_cache, code_line, code_object);
#if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING
    __pyx_atomic_sub(&code_cache->accessor_count, INT_MIN);
#endif
#endif
}

/* AddTraceback */
#include "compile.h"
#include "frameobject.h"
#include "traceback.h"
#if PY_VERSION_HEX >= 0x030b00a6 && !CYTHON_COMPILING_IN_LIMITED_API && !defined(PYPY_VERSION)
  #ifndef Py_BUILD_CORE
    #define Py_BUILD_CORE 1
  #endif
  #include "internal/pycore_frame.h"
#endif
#if CYTHON_COMPILING_IN_LIMITED_API
static PyObject *__Pyx_PyCode_Replace_For_AddTraceback(PyObject *code, PyObject *scratch_dict,
                                                       PyObject *firstlineno, PyObject *name) {
    PyObject *replace = NULL;
    if (unlikely(PyDict_SetItemString(scratch_dict, "co_firstlineno", firstlineno))) return NULL;
    if (unlikely(PyDict_SetItemString(scratch_dict, "co_name", name))) return NULL;
    replace = PyObject_GetAttrString(code, "replace");
    if (likely(replace)) {
        PyObject *result = PyObject_Call(replace, __pyx_mstate_global->__pyx_empty_tuple, scratch_dict);
        Py_DECREF(replace);
        return result;
    }
    PyErr_Clear();
    return NULL;
}
static void __Pyx_AddTraceback(const char *funcname, int c_line,
                               int py_line, const char *filename) {
    PyObject *code_object = NULL, *py_py_line = NULL, *py_funcname = NULL, *dict = NULL;
    PyObject *replace = NULL, *getframe = NULL, *frame = NULL;
    PyObject *exc_type, *exc_value, *exc_traceback;
    int success = 0;
    if (c_line) {
        c_line = __Pyx_CLineForTraceback(__Pyx_PyThreadState_Current, c_line);
    }
    PyErr_Fetch(&exc_type, &exc_value, &exc_traceback);
    code_object = __pyx_find_code_object(c_line ? -c_line : py_line);
    if (!code_object) {
        code_object = Py_CompileString("_getframe()", filename, Py_eval_input);
        if (unlikely(!code_object)) goto bad;
        py_py_line = PyLong_FromLong(py_line);
        if (unlikely(!py_py_line)) goto bad;
        if (c_line) {
            py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
        } else {
            py_funcname = PyUnicode_FromString(funcname);
        }
        if (unlikely(!py_funcname)) goto bad;
        dict = PyDict_New();
        if (unlikely(!dict)) goto bad;
        {
            PyObject *old_code_object = code_object;
            code_object = __Pyx_PyCode_Replace_For_AddTraceback(code_object, dict, py_py_line, py_funcname);
            Py_DECREF(old_code_object);
        }
        if (unlikely(!code_object)) goto bad;
        __pyx_insert_code_object(c_line ? -c_line : py_line, code_object);
    } else {
        dict = PyDict_New();
    }
    getframe = PySys_GetObject("_getframe");
    if (unlikely(!getframe)) goto bad;
    if (unlikely(PyDict_SetItemString(dict, "_getframe", getframe))) goto bad;
    frame = PyEval_EvalCode(code_object, dict, dict);
    if (unlikely(!frame) || frame == Py_None) goto bad;
    success = 1;
  bad:
    PyErr_Restore(exc_type, exc_value, exc_traceback);
    Py_XDECREF(code_object);
    Py_XDECREF(py_py_line);
    Py_XDECREF(py_funcname);
    Py_XDECREF(dict);
    Py_XDECREF(replace);
    if (success) {
        PyTraceBack_Here(
            (struct _frame*)frame);
    }
    Py_XDECREF(frame);
}
#else
static PyCodeObject* __Pyx_CreateCodeObjectForTraceback(
            const char *funcname, int c_line,
            int py_line, const char *filename) {
    PyCodeObject *py_code = NULL;
    PyObject *py_funcname = NULL;
    if (c_line) {
        py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
        if (!py_funcname) goto bad;
        funcname = PyUnicode_AsUTF8(py_funcname);
        if (!funcname) goto bad;
    }
    py_code = PyCode_NewEmpty(filename, funcname, py_line);
    Py_XDECREF(py_funcname);
    return py_code;
bad:
    Py_XDECREF(py_funcname);
    return NULL;
}
static void __Pyx_AddTraceback(const char *funcname, int c_line,
                               int py_line, const char *filename) {
    PyCodeObject *py_code = 0;
    PyFrameObject *py_frame = 0;
    PyThreadState *tstate = __Pyx_PyThreadState_Current;
    PyObject *ptype, *pvalue, *ptraceback;
    if (c_line) {
        c_line = __Pyx_CLineForTraceback(tstate, c_line);
    }
    py_code = __pyx_find_code_object(c_line ? -c_line : py_line);
    if (!py_code) {
        __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback);
        py_code = __Pyx_CreateCodeObjectForTraceback(
            funcname, c_line, py_line, filename);
        if (!py_code) {
            /* If the code object creation fails, then we should clear the
               fetched exception references and propagate the new exception */
            Py_XDECREF(ptype);
            Py_XDECREF(pvalue);
            Py_XDECREF(ptraceback);
            goto bad;
        }
        __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback);
        __pyx_insert_code_object(c_line ? -c_line : py_line, py_code);
    }
    py_frame = PyFrame_New(
        tstate,            /*PyThreadState *tstate,*/
        py_code,           /*PyCodeObject *code,*/
        __pyx_mstate_global->__pyx_d,    /*PyObject *globals,*/
        0                  /*PyObject *locals*/
    );
    if (!py_frame) goto bad;
    __Pyx_PyFrame_SetLineNumber(py_frame, py_line);
    PyTraceBack_Here(py_frame);
bad:
    Py_XDECREF(py_code);
    Py_XDECREF(py_frame);
}
#endif

/* CIntFromPyVerify */
#define __PYX_VERIFY_RETURN_INT(target_type, func_type, func_value)\
    __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 0)
#define __PYX_VERIFY_RETURN_INT_EXC(target_type, func_type, func_value)\
    __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 1)
#define __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, exc)\
    {\
        func_type value = func_value;\
        if (sizeof(target_type) < sizeof(func_type)) {\
            if (unlikely(value != (func_type) (target_type) value)) {\
                func_type zero = 0;\
                if (exc && unlikely(value == (func_type)-1 && PyErr_Occurred()))\
                    return (target_type) -1;\
                if (is_unsigned && unlikely(value < zero))\
                    goto raise_neg_overflow;\
                else\
                    goto raise_overflow;\
            }\
        }\
        return (target_type) value;\
    }

/* Declarations */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) {
      return ::std::complex< float >(x, y);
    }
  #else
    static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) {
      return x + y*(__pyx_t_float_complex)_Complex_I;
    }
  #endif
#else
    static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) {
      __pyx_t_float_complex z;
      z.real = x;
      z.imag = y;
      return z;
    }
#endif

/* Arithmetic */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
#else
    static CYTHON_INLINE int __Pyx_c_eq_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
       return (a.real == b.real) && (a.imag == b.imag);
    }
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_sum_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
        __pyx_t_float_complex z;
        z.real = a.real + b.real;
        z.imag = a.imag + b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_diff_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
        __pyx_t_float_complex z;
        z.real = a.real - b.real;
        z.imag = a.imag - b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_prod_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
        __pyx_t_float_complex z;
        z.real = a.real * b.real - a.imag * b.imag;
        z.imag = a.real * b.imag + a.imag * b.real;
        return z;
    }
    #if 1
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_quot_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
        if (b.imag == 0) {
            return __pyx_t_float_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else if (fabsf(b.real) >= fabsf(b.imag)) {
            if (b.real == 0 && b.imag == 0) {
                return __pyx_t_float_complex_from_parts(a.real / b.real, a.imag / b.imag);
            } else {
                float r = b.imag / b.real;
                float s = (float)(1.0) / (b.real + b.imag * r);
                return __pyx_t_float_complex_from_parts(
                    (a.real + a.imag * r) * s, (a.imag - a.real * r) * s);
            }
        } else {
            float r = b.real / b.imag;
            float s = (float)(1.0) / (b.imag + b.real * r);
            return __pyx_t_float_complex_from_parts(
                (a.real * r + a.imag) * s, (a.imag * r - a.real) * s);
        }
    }
    #else
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_quot_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
        if (b.imag == 0) {
            return __pyx_t_float_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else {
            float denom = b.real * b.real + b.imag * b.imag;
            return __pyx_t_float_complex_from_parts(
                (a.real * b.real + a.imag * b.imag) / denom,
                (a.imag * b.real - a.real * b.imag) / denom);
        }
    }
    #endif
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_neg_float(__pyx_t_float_complex a) {
        __pyx_t_float_complex z;
        z.real = -a.real;
        z.imag = -a.imag;
        return z;
    }
    static CYTHON_INLINE int __Pyx_c_is_zero_float(__pyx_t_float_complex a) {
       return (a.real == 0) && (a.imag == 0);
    }
    static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_conj_float(__pyx_t_float_complex a) {
        __pyx_t_float_complex z;
        z.real =  a.real;
        z.imag = -a.imag;
        return z;
    }
    #if 1
        static CYTHON_INLINE float __Pyx_c_abs_float(__pyx_t_float_complex z) {
          #if !defined(HAVE_HYPOT) || defined(_MSC_VER)
            return sqrtf(z.real*z.real + z.imag*z.imag);
          #else
            return hypotf(z.real, z.imag);
          #endif
        }
        static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_pow_float(__pyx_t_float_complex a, __pyx_t_float_complex b) {
            __pyx_t_float_complex z;
            float r, lnr, theta, z_r, z_theta;
            if (b.imag == 0 && b.real == (int)b.real) {
                if (b.real < 0) {
                    float denom = a.real * a.real + a.imag * a.imag;
                    a.real = a.real / denom;
                    a.imag = -a.imag / denom;
                    b.real = -b.real;
                }
                switch ((int)b.real) {
                    case 0:
                        z.real = 1;
                        z.imag = 0;
                        return z;
                    case 1:
                        return a;
                    case 2:
                        return __Pyx_c_prod_float(a, a);
                    case 3:
                        z = __Pyx_c_prod_float(a, a);
                        return __Pyx_c_prod_float(z, a);
                    case 4:
                        z = __Pyx_c_prod_float(a, a);
                        return __Pyx_c_prod_float(z, z);
                }
            }
            if (a.imag == 0) {
                if (a.real == 0) {
                    return a;
                } else if ((b.imag == 0) && (a.real >= 0)) {
                    z.real = powf(a.real, b.real);
                    z.imag = 0;
                    return z;
                } else if (a.real > 0) {
                    r = a.real;
                    theta = 0;
                } else {
                    r = -a.real;
                    theta = atan2f(0.0, -1.0);
                }
            } else {
                r = __Pyx_c_abs_float(a);
                theta = atan2f(a.imag, a.real);
            }
            lnr = logf(r);
            z_r = expf(lnr * b.real - theta * b.imag);
            z_theta = theta * b.real + lnr * b.imag;
            z.real = z_r * cosf(z_theta);
            z.imag = z_r * sinf(z_theta);
            return z;
        }
    #endif
#endif

/* Declarations */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) {
      return ::std::complex< double >(x, y);
    }
  #else
    static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) {
      return x + y*(__pyx_t_double_complex)_Complex_I;
    }
  #endif
#else
    static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) {
      __pyx_t_double_complex z;
      z.real = x;
      z.imag = y;
      return z;
    }
#endif

/* Arithmetic */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
#else
    static CYTHON_INLINE int __Pyx_c_eq_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
       return (a.real == b.real) && (a.imag == b.imag);
    }
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_sum_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
        __pyx_t_double_complex z;
        z.real = a.real + b.real;
        z.imag = a.imag + b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_diff_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
        __pyx_t_double_complex z;
        z.real = a.real - b.real;
        z.imag = a.imag - b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_prod_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
        __pyx_t_double_complex z;
        z.real = a.real * b.real - a.imag * b.imag;
        z.imag = a.real * b.imag + a.imag * b.real;
        return z;
    }
    #if 1
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_quot_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
        if (b.imag == 0) {
            return __pyx_t_double_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else if (fabs(b.real) >= fabs(b.imag)) {
            if (b.real == 0 && b.imag == 0) {
                return __pyx_t_double_complex_from_parts(a.real / b.real, a.imag / b.imag);
            } else {
                double r = b.imag / b.real;
                double s = (double)(1.0) / (b.real + b.imag * r);
                return __pyx_t_double_complex_from_parts(
                    (a.real + a.imag * r) * s, (a.imag - a.real * r) * s);
            }
        } else {
            double r = b.real / b.imag;
            double s = (double)(1.0) / (b.imag + b.real * r);
            return __pyx_t_double_complex_from_parts(
                (a.real * r + a.imag) * s, (a.imag * r - a.real) * s);
        }
    }
    #else
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_quot_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
        if (b.imag == 0) {
            return __pyx_t_double_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else {
            double denom = b.real * b.real + b.imag * b.imag;
            return __pyx_t_double_complex_from_parts(
                (a.real * b.real + a.imag * b.imag) / denom,
                (a.imag * b.real - a.real * b.imag) / denom);
        }
    }
    #endif
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_neg_double(__pyx_t_double_complex a) {
        __pyx_t_double_complex z;
        z.real = -a.real;
        z.imag = -a.imag;
        return z;
    }
    static CYTHON_INLINE int __Pyx_c_is_zero_double(__pyx_t_double_complex a) {
       return (a.real == 0) && (a.imag == 0);
    }
    static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_conj_double(__pyx_t_double_complex a) {
        __pyx_t_double_complex z;
        z.real =  a.real;
        z.imag = -a.imag;
        return z;
    }
    #if 1
        static CYTHON_INLINE double __Pyx_c_abs_double(__pyx_t_double_complex z) {
          #if !defined(HAVE_HYPOT) || defined(_MSC_VER)
            return sqrt(z.real*z.real + z.imag*z.imag);
          #else
            return hypot(z.real, z.imag);
          #endif
        }
        static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_pow_double(__pyx_t_double_complex a, __pyx_t_double_complex b) {
            __pyx_t_double_complex z;
            double r, lnr, theta, z_r, z_theta;
            if (b.imag == 0 && b.real == (int)b.real) {
                if (b.real < 0) {
                    double denom = a.real * a.real + a.imag * a.imag;
                    a.real = a.real / denom;
                    a.imag = -a.imag / denom;
                    b.real = -b.real;
                }
                switch ((int)b.real) {
                    case 0:
                        z.real = 1;
                        z.imag = 0;
                        return z;
                    case 1:
                        return a;
                    case 2:
                        return __Pyx_c_prod_double(a, a);
                    case 3:
                        z = __Pyx_c_prod_double(a, a);
                        return __Pyx_c_prod_double(z, a);
                    case 4:
                        z = __Pyx_c_prod_double(a, a);
                        return __Pyx_c_prod_double(z, z);
                }
            }
            if (a.imag == 0) {
                if (a.real == 0) {
                    return a;
                } else if ((b.imag == 0) && (a.real >= 0)) {
                    z.real = pow(a.real, b.real);
                    z.imag = 0;
                    return z;
                } else if (a.real > 0) {
                    r = a.real;
                    theta = 0;
                } else {
                    r = -a.real;
                    theta = atan2(0.0, -1.0);
                }
            } else {
                r = __Pyx_c_abs_double(a);
                theta = atan2(a.imag, a.real);
            }
            lnr = log(r);
            z_r = exp(lnr * b.real - theta * b.imag);
            z_theta = theta * b.real + lnr * b.imag;
            z.real = z_r * cos(z_theta);
            z.imag = z_r * sin(z_theta);
            return z;
        }
    #endif
#endif

/* Declarations */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
  #ifdef __cplusplus
    static CYTHON_INLINE __pyx_t_long_double_complex __pyx_t_long_double_complex_from_parts(long double x, long double y) {
      return ::std::complex< long double >(x, y);
    }
  #else
    static CYTHON_INLINE __pyx_t_long_double_complex __pyx_t_long_double_complex_from_parts(long double x, long double y) {
      return x + y*(__pyx_t_long_double_complex)_Complex_I;
    }
  #endif
#else
    static CYTHON_INLINE __pyx_t_long_double_complex __pyx_t_long_double_complex_from_parts(long double x, long double y) {
      __pyx_t_long_double_complex z;
      z.real = x;
      z.imag = y;
      return z;
    }
#endif

/* Arithmetic */
#if CYTHON_CCOMPLEX && (1) && (!0 || __cplusplus)
#else
    static CYTHON_INLINE int __Pyx_c_eq_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
       return (a.real == b.real) && (a.imag == b.imag);
    }
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_sum_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
        __pyx_t_long_double_complex z;
        z.real = a.real + b.real;
        z.imag = a.imag + b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_diff_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
        __pyx_t_long_double_complex z;
        z.real = a.real - b.real;
        z.imag = a.imag - b.imag;
        return z;
    }
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_prod_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
        __pyx_t_long_double_complex z;
        z.real = a.real * b.real - a.imag * b.imag;
        z.imag = a.real * b.imag + a.imag * b.real;
        return z;
    }
    #if 1
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_quot_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
        if (b.imag == 0) {
            return __pyx_t_long_double_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else if (fabsl(b.real) >= fabsl(b.imag)) {
            if (b.real == 0 && b.imag == 0) {
                return __pyx_t_long_double_complex_from_parts(a.real / b.real, a.imag / b.imag);
            } else {
                long double r = b.imag / b.real;
                long double s = (long double)(1.0) / (b.real + b.imag * r);
                return __pyx_t_long_double_complex_from_parts(
                    (a.real + a.imag * r) * s, (a.imag - a.real * r) * s);
            }
        } else {
            long double r = b.real / b.imag;
            long double s = (long double)(1.0) / (b.imag + b.real * r);
            return __pyx_t_long_double_complex_from_parts(
                (a.real * r + a.imag) * s, (a.imag * r - a.real) * s);
        }
    }
    #else
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_quot_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
        if (b.imag == 0) {
            return __pyx_t_long_double_complex_from_parts(a.real / b.real, a.imag / b.real);
        } else {
            long double denom = b.real * b.real + b.imag * b.imag;
            return __pyx_t_long_double_complex_from_parts(
                (a.real * b.real + a.imag * b.imag) / denom,
                (a.imag * b.real - a.real * b.imag) / denom);
        }
    }
    #endif
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_neg_long__double(__pyx_t_long_double_complex a) {
        __pyx_t_long_double_complex z;
        z.real = -a.real;
        z.imag = -a.imag;
        return z;
    }
    static CYTHON_INLINE int __Pyx_c_is_zero_long__double(__pyx_t_long_double_complex a) {
       return (a.real == 0) && (a.imag == 0);
    }
    static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_conj_long__double(__pyx_t_long_double_complex a) {
        __pyx_t_long_double_complex z;
        z.real =  a.real;
        z.imag = -a.imag;
        return z;
    }
    #if 1
        static CYTHON_INLINE long double __Pyx_c_abs_long__double(__pyx_t_long_double_complex z) {
          #if !defined(HAVE_HYPOT) || defined(_MSC_VER)
            return sqrtl(z.real*z.real + z.imag*z.imag);
          #else
            return hypotl(z.real, z.imag);
          #endif
        }
        static CYTHON_INLINE __pyx_t_long_double_complex __Pyx_c_pow_long__double(__pyx_t_long_double_complex a, __pyx_t_long_double_complex b) {
            __pyx_t_long_double_complex z;
            long double r, lnr, theta, z_r, z_theta;
            if (b.imag == 0 && b.real == (int)b.real) {
                if (b.real < 0) {
                    long double denom = a.real * a.real + a.imag * a.imag;
                    a.real = a.real / denom;
                    a.imag = -a.imag / denom;
                    b.real = -b.real;
                }
                switch ((int)b.real) {
                    case 0:
                        z.real = 1;
                        z.imag = 0;
                        return z;
                    case 1:
                        return a;
                    case 2:
                        return __Pyx_c_prod_long__double(a, a);
                    case 3:
                        z = __Pyx_c_prod_long__double(a, a);
                        return __Pyx_c_prod_long__double(z, a);
                    case 4:
                        z = __Pyx_c_prod_long__double(a, a);
                        return __Pyx_c_prod_long__double(z, z);
                }
            }
            if (a.imag == 0) {
                if (a.real == 0) {
                    return a;
                } else if ((b.imag == 0) && (a.real >= 0)) {
                    z.real = powl(a.real, b.real);
                    z.imag = 0;
                    return z;
                } else if (a.real > 0) {
                    r = a.real;
                    theta = 0;
                } else {
                    r = -a.real;
                    theta = atan2l(0.0, -1.0);
                }
            } else {
                r = __Pyx_c_abs_long__double(a);
                theta = atan2l(a.imag, a.real);
            }
            lnr = logl(r);
            z_r = expl(lnr * b.real - theta * b.imag);
            z_theta = theta * b.real + lnr * b.imag;
            z.real = z_r * cosl(z_theta);
            z.imag = z_r * sinl(z_theta);
            return z;
        }
    #endif
#endif

/* CIntFromPy */
static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *x) {
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const int neg_one = (int) -1, const_zero = (int) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (unlikely(!PyLong_Check(x))) {
        int val;
        PyObject *tmp = __Pyx_PyNumber_Long(x);
        if (!tmp) return (int) -1;
        val = __Pyx_PyLong_As_int(tmp);
        Py_DECREF(tmp);
        return val;
    }
    if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
        if (unlikely(__Pyx_PyLong_IsNeg(x))) {
            goto raise_neg_overflow;
        } else if (__Pyx_PyLong_IsCompact(x)) {
            __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x))
        } else {
            const digit* digits = __Pyx_PyLong_Digits(x);
            assert(__Pyx_PyLong_DigitCount(x) > 1);
            switch (__Pyx_PyLong_DigitCount(x)) {
                case 2:
                    if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) >= 2 * PyLong_SHIFT)) {
                            return (int) (((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]));
                        }
                    }
                    break;
                case 3:
                    if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) >= 3 * PyLong_SHIFT)) {
                            return (int) (((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]));
                        }
                    }
                    break;
                case 4:
                    if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) >= 4 * PyLong_SHIFT)) {
                            return (int) (((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]));
                        }
                    }
                    break;
            }
        }
#endif
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7
        if (unlikely(Py_SIZE(x) < 0)) {
            goto raise_neg_overflow;
        }
#else
        {
            int result = PyObject_RichCompareBool(x, Py_False, Py_LT);
            if (unlikely(result < 0))
                return (int) -1;
            if (unlikely(result == 1))
                goto raise_neg_overflow;
        }
#endif
        if ((sizeof(int) <= sizeof(unsigned long))) {
            __PYX_VERIFY_RETURN_INT_EXC(int, unsigned long, PyLong_AsUnsignedLong(x))
        } else if ((sizeof(int) <= sizeof(unsigned PY_LONG_LONG))) {
            __PYX_VERIFY_RETURN_INT_EXC(int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x))
        }
    } else {
#if CYTHON_USE_PYLONG_INTERNALS
        if (__Pyx_PyLong_IsCompact(x)) {
            __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x))
        } else {
            const digit* digits = __Pyx_PyLong_Digits(x);
            assert(__Pyx_PyLong_DigitCount(x) > 1);
            switch (__Pyx_PyLong_SignedDigitCount(x)) {
                case -2:
                    if ((8 * sizeof(int) - 1 > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) {
                            return (int) (((int)-1)*(((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
                case 2:
                    if ((8 * sizeof(int) > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) {
                            return (int) ((((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
                case -3:
                    if ((8 * sizeof(int) - 1 > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) {
                            return (int) (((int)-1)*(((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
                case 3:
                    if ((8 * sizeof(int) > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) {
                            return (int) ((((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
                case -4:
                    if ((8 * sizeof(int) - 1 > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) {
                            return (int) (((int)-1)*(((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
                case 4:
                    if ((8 * sizeof(int) > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(int) - 1 > 4 * PyLong_SHIFT)) {
                            return (int) ((((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])));
                        }
                    }
                    break;
            }
        }
#endif
        if ((sizeof(int) <= sizeof(long))) {
            __PYX_VERIFY_RETURN_INT_EXC(int, long, PyLong_AsLong(x))
        } else if ((sizeof(int) <= sizeof(PY_LONG_LONG))) {
            __PYX_VERIFY_RETURN_INT_EXC(int, PY_LONG_LONG, PyLong_AsLongLong(x))
        }
    }
    {
        int val;
        int ret = -1;
#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API
        Py_ssize_t bytes_copied = PyLong_AsNativeBytes(
            x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0));
        if (unlikely(bytes_copied == -1)) {
        } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) {
            goto raise_overflow;
        } else {
            ret = 0;
        }
#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray)
        int one = 1; int is_little = (int)*(unsigned char *)&one;
        unsigned char *bytes = (unsigned char *)&val;
        ret = _PyLong_AsByteArray((PyLongObject *)x,
                                    bytes, sizeof(val),
                                    is_little, !is_unsigned);
#else
        PyObject *v;
        PyObject *stepval = NULL, *mask = NULL, *shift = NULL;
        int bits, remaining_bits, is_negative = 0;
        int chunk_size = (sizeof(long) < 8) ? 30 : 62;
        if (likely(PyLong_CheckExact(x))) {
            v = __Pyx_NewRef(x);
        } else {
            v = PyNumber_Long(x);
            if (unlikely(!v)) return (int) -1;
            assert(PyLong_CheckExact(v));
        }
        {
            int result = PyObject_RichCompareBool(v, Py_False, Py_LT);
            if (unlikely(result < 0)) {
                Py_DECREF(v);
                return (int) -1;
            }
            is_negative = result == 1;
        }
        if (is_unsigned && unlikely(is_negative)) {
            Py_DECREF(v);
            goto raise_neg_overflow;
        } else if (is_negative) {
            stepval = PyNumber_Invert(v);
            Py_DECREF(v);
            if (unlikely(!stepval))
                return (int) -1;
        } else {
            stepval = v;
        }
        v = NULL;
        val = (int) 0;
        mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done;
        shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done;
        for (bits = 0; bits < (int) sizeof(int) * 8 - chunk_size; bits += chunk_size) {
            PyObject *tmp, *digit;
            long idigit;
            digit = PyNumber_And(stepval, mask);
            if (unlikely(!digit)) goto done;
            idigit = PyLong_AsLong(digit);
            Py_DECREF(digit);
            if (unlikely(idigit < 0)) goto done;
            val |= ((int) idigit) << bits;
            tmp = PyNumber_Rshift(stepval, shift);
            if (unlikely(!tmp)) goto done;
            Py_DECREF(stepval); stepval = tmp;
        }
        Py_DECREF(shift); shift = NULL;
        Py_DECREF(mask); mask = NULL;
        {
            long idigit = PyLong_AsLong(stepval);
            if (unlikely(idigit < 0)) goto done;
            remaining_bits = ((int) sizeof(int) * 8) - bits - (is_unsigned ? 0 : 1);
            if (unlikely(idigit >= (1L << remaining_bits)))
                goto raise_overflow;
            val |= ((int) idigit) << bits;
        }
        if (!is_unsigned) {
            if (unlikely(val & (((int) 1) << (sizeof(int) * 8 - 1))))
                goto raise_overflow;
            if (is_negative)
                val = ~val;
        }
        ret = 0;
    done:
        Py_XDECREF(shift);
        Py_XDECREF(mask);
        Py_XDECREF(stepval);
#endif
        if (unlikely(ret))
            return (int) -1;
        return val;
    }
raise_overflow:
    PyErr_SetString(PyExc_OverflowError,
        "value too large to convert to int");
    return (int) -1;
raise_neg_overflow:
    PyErr_SetString(PyExc_OverflowError,
        "can't convert negative value to int");
    return (int) -1;
}

/* CIntToPy */
static CYTHON_INLINE PyObject* __Pyx_PyLong_From_int(int value) {
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const int neg_one = (int) -1, const_zero = (int) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (is_unsigned) {
        if (sizeof(int) < sizeof(long)) {
            return PyLong_FromLong((long) value);
        } else if (sizeof(int) <= sizeof(unsigned long)) {
            return PyLong_FromUnsignedLong((unsigned long) value);
#if !CYTHON_COMPILING_IN_PYPY
        } else if (sizeof(int) <= sizeof(unsigned PY_LONG_LONG)) {
            return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value);
#endif
        }
    } else {
        if (sizeof(int) <= sizeof(long)) {
            return PyLong_FromLong((long) value);
        } else if (sizeof(int) <= sizeof(PY_LONG_LONG)) {
            return PyLong_FromLongLong((PY_LONG_LONG) value);
        }
    }
    {
        unsigned char *bytes = (unsigned char *)&value;
#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4
        if (is_unsigned) {
            return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1);
        } else {
            return PyLong_FromNativeBytes(bytes, sizeof(value), -1);
        }
#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000
        int one = 1; int little = (int)*(unsigned char *)&one;
        return _PyLong_FromByteArray(bytes, sizeof(int),
                                     little, !is_unsigned);
#else
        int one = 1; int little = (int)*(unsigned char *)&one;
        PyObject *from_bytes, *result = NULL, *kwds = NULL;
        PyObject *py_bytes = NULL, *order_str = NULL;
        from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes");
        if (!from_bytes) return NULL;
        py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(int));
        if (!py_bytes) goto limited_bad;
        order_str = PyUnicode_FromString(little ? "little" : "big");
        if (!order_str) goto limited_bad;
        {
            PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str };
            if (!is_unsigned) {
                kwds = __Pyx_MakeVectorcallBuilderKwds(1);
                if (!kwds) goto limited_bad;
                if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad;
            }
            result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds);
        }
        limited_bad:
        Py_XDECREF(kwds);
        Py_XDECREF(order_str);
        Py_XDECREF(py_bytes);
        Py_XDECREF(from_bytes);
        return result;
#endif
    }
}

/* CIntToPy */
static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value) {
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const long neg_one = (long) -1, const_zero = (long) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (is_unsigned) {
        if (sizeof(long) < sizeof(long)) {
            return PyLong_FromLong((long) value);
        } else if (sizeof(long) <= sizeof(unsigned long)) {
            return PyLong_FromUnsignedLong((unsigned long) value);
#if !CYTHON_COMPILING_IN_PYPY
        } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) {
            return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value);
#endif
        }
    } else {
        if (sizeof(long) <= sizeof(long)) {
            return PyLong_FromLong((long) value);
        } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) {
            return PyLong_FromLongLong((PY_LONG_LONG) value);
        }
    }
    {
        unsigned char *bytes = (unsigned char *)&value;
#if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4
        if (is_unsigned) {
            return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1);
        } else {
            return PyLong_FromNativeBytes(bytes, sizeof(value), -1);
        }
#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000
        int one = 1; int little = (int)*(unsigned char *)&one;
        return _PyLong_FromByteArray(bytes, sizeof(long),
                                     little, !is_unsigned);
#else
        int one = 1; int little = (int)*(unsigned char *)&one;
        PyObject *from_bytes, *result = NULL, *kwds = NULL;
        PyObject *py_bytes = NULL, *order_str = NULL;
        from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes");
        if (!from_bytes) return NULL;
        py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(long));
        if (!py_bytes) goto limited_bad;
        order_str = PyUnicode_FromString(little ? "little" : "big");
        if (!order_str) goto limited_bad;
        {
            PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str };
            if (!is_unsigned) {
                kwds = __Pyx_MakeVectorcallBuilderKwds(1);
                if (!kwds) goto limited_bad;
                if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad;
            }
            result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds);
        }
        limited_bad:
        Py_XDECREF(kwds);
        Py_XDECREF(order_str);
        Py_XDECREF(py_bytes);
        Py_XDECREF(from_bytes);
        return result;
#endif
    }
}

/* FormatTypeName */
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030d0000
static __Pyx_TypeName
__Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp)
{
    PyObject *module = NULL, *name = NULL, *result = NULL;
    #if __PYX_LIMITED_VERSION_HEX < 0x030b0000
    name = __Pyx_PyObject_GetAttrStr((PyObject *)tp,
                                               __pyx_mstate_global->__pyx_n_u_qualname);
    #else
    name = PyType_GetQualName(tp);
    #endif
    if (unlikely(name == NULL) || unlikely(!PyUnicode_Check(name))) goto bad;
    module = __Pyx_PyObject_GetAttrStr((PyObject *)tp,
                                               __pyx_mstate_global->__pyx_n_u_module);
    if (unlikely(module == NULL) || unlikely(!PyUnicode_Check(module))) goto bad;
    if (PyUnicode_CompareWithASCIIString(module, "builtins") == 0) {
        result = name;
        name = NULL;
        goto done;
    }
    result = PyUnicode_FromFormat("%U.%U", module, name);
    if (unlikely(result == NULL)) goto bad;
  done:
    Py_XDECREF(name);
    Py_XDECREF(module);
    return result;
  bad:
    PyErr_Clear();
    if (name) {
        result = name;
        name = NULL;
    } else {
        result = __Pyx_NewRef(__pyx_mstate_global->__pyx_kp_u__7);
    }
    goto done;
}
#endif

/* CIntFromPy */
static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *x) {
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wconversion"
#endif
    const long neg_one = (long) -1, const_zero = (long) 0;
#ifdef __Pyx_HAS_GCC_DIAGNOSTIC
#pragma GCC diagnostic pop
#endif
    const int is_unsigned = neg_one > const_zero;
    if (unlikely(!PyLong_Check(x))) {
        long val;
        PyObject *tmp = __Pyx_PyNumber_Long(x);
        if (!tmp) return (long) -1;
        val = __Pyx_PyLong_As_long(tmp);
        Py_DECREF(tmp);
        return val;
    }
    if (is_unsigned) {
#if CYTHON_USE_PYLONG_INTERNALS
        if (unlikely(__Pyx_PyLong_IsNeg(x))) {
            goto raise_neg_overflow;
        } else if (__Pyx_PyLong_IsCompact(x)) {
            __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x))
        } else {
            const digit* digits = __Pyx_PyLong_Digits(x);
            assert(__Pyx_PyLong_DigitCount(x) > 1);
            switch (__Pyx_PyLong_DigitCount(x)) {
                case 2:
                    if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) >= 2 * PyLong_SHIFT)) {
                            return (long) (((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]));
                        }
                    }
                    break;
                case 3:
                    if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) >= 3 * PyLong_SHIFT)) {
                            return (long) (((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]));
                        }
                    }
                    break;
                case 4:
                    if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) >= 4 * PyLong_SHIFT)) {
                            return (long) (((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]));
                        }
                    }
                    break;
            }
        }
#endif
#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7
        if (unlikely(Py_SIZE(x) < 0)) {
            goto raise_neg_overflow;
        }
#else
        {
            int result = PyObject_RichCompareBool(x, Py_False, Py_LT);
            if (unlikely(result < 0))
                return (long) -1;
            if (unlikely(result == 1))
                goto raise_neg_overflow;
        }
#endif
        if ((sizeof(long) <= sizeof(unsigned long))) {
            __PYX_VERIFY_RETURN_INT_EXC(long, unsigned long, PyLong_AsUnsignedLong(x))
        } else if ((sizeof(long) <= sizeof(unsigned PY_LONG_LONG))) {
            __PYX_VERIFY_RETURN_INT_EXC(long, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x))
        }
    } else {
#if CYTHON_USE_PYLONG_INTERNALS
        if (__Pyx_PyLong_IsCompact(x)) {
            __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x))
        } else {
            const digit* digits = __Pyx_PyLong_Digits(x);
            assert(__Pyx_PyLong_DigitCount(x) > 1);
            switch (__Pyx_PyLong_SignedDigitCount(x)) {
                case -2:
                    if ((8 * sizeof(long) - 1 > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) {
                            return (long) (((long)-1)*(((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
                case 2:
                    if ((8 * sizeof(long) > 1 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) {
                            return (long) ((((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
                case -3:
                    if ((8 * sizeof(long) - 1 > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) {
                            return (long) (((long)-1)*(((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
                case 3:
                    if ((8 * sizeof(long) > 2 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) {
                            return (long) ((((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
                case -4:
                    if ((8 * sizeof(long) - 1 > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) {
                            return (long) (((long)-1)*(((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
                case 4:
                    if ((8 * sizeof(long) > 3 * PyLong_SHIFT)) {
                        if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) {
                            __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0])))
                        } else if ((8 * sizeof(long) - 1 > 4 * PyLong_SHIFT)) {
                            return (long) ((((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])));
                        }
                    }
                    break;
            }
        }
#endif
        if ((sizeof(long) <= sizeof(long))) {
            __PYX_VERIFY_RETURN_INT_EXC(long, long, PyLong_AsLong(x))
        } else if ((sizeof(long) <= sizeof(PY_LONG_LONG))) {
            __PYX_VERIFY_RETURN_INT_EXC(long, PY_LONG_LONG, PyLong_AsLongLong(x))
        }
    }
    {
        long val;
        int ret = -1;
#if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API
        Py_ssize_t bytes_copied = PyLong_AsNativeBytes(
            x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0));
        if (unlikely(bytes_copied == -1)) {
        } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) {
            goto raise_overflow;
        } else {
            ret = 0;
        }
#elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray)
        int one = 1; int is_little = (int)*(unsigned char *)&one;
        unsigned char *bytes = (unsigned char *)&val;
        ret = _PyLong_AsByteArray((PyLongObject *)x,
                                    bytes, sizeof(val),
                                    is_little, !is_unsigned);
#else
        PyObject *v;
        PyObject *stepval = NULL, *mask = NULL, *shift = NULL;
        int bits, remaining_bits, is_negative = 0;
        int chunk_size = (sizeof(long) < 8) ? 30 : 62;
        if (likely(PyLong_CheckExact(x))) {
            v = __Pyx_NewRef(x);
        } else {
            v = PyNumber_Long(x);
            if (unlikely(!v)) return (long) -1;
            assert(PyLong_CheckExact(v));
        }
        {
            int result = PyObject_RichCompareBool(v, Py_False, Py_LT);
            if (unlikely(result < 0)) {
                Py_DECREF(v);
                return (long) -1;
            }
            is_negative = result == 1;
        }
        if (is_unsigned && unlikely(is_negative)) {
            Py_DECREF(v);
            goto raise_neg_overflow;
        } else if (is_negative) {
            stepval = PyNumber_Invert(v);
            Py_DECREF(v);
            if (unlikely(!stepval))
                return (long) -1;
        } else {
            stepval = v;
        }
        v = NULL;
        val = (long) 0;
        mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done;
        shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done;
        for (bits = 0; bits < (int) sizeof(long) * 8 - chunk_size; bits += chunk_size) {
            PyObject *tmp, *digit;
            long idigit;
            digit = PyNumber_And(stepval, mask);
            if (unlikely(!digit)) goto done;
            idigit = PyLong_AsLong(digit);
            Py_DECREF(digit);
            if (unlikely(idigit < 0)) goto done;
            val |= ((long) idigit) << bits;
            tmp = PyNumber_Rshift(stepval, shift);
            if (unlikely(!tmp)) goto done;
            Py_DECREF(stepval); stepval = tmp;
        }
        Py_DECREF(shift); shift = NULL;
        Py_DECREF(mask); mask = NULL;
        {
            long idigit = PyLong_AsLong(stepval);
            if (unlikely(idigit < 0)) goto done;
            remaining_bits = ((int) sizeof(long) * 8) - bits - (is_unsigned ? 0 : 1);
            if (unlikely(idigit >= (1L << remaining_bits)))
                goto raise_overflow;
            val |= ((long) idigit) << bits;
        }
        if (!is_unsigned) {
            if (unlikely(val & (((long) 1) << (sizeof(long) * 8 - 1))))
                goto raise_overflow;
            if (is_negative)
                val = ~val;
        }
        ret = 0;
    done:
        Py_XDECREF(shift);
        Py_XDECREF(mask);
        Py_XDECREF(stepval);
#endif
        if (unlikely(ret))
            return (long) -1;
        return val;
    }
raise_overflow:
    PyErr_SetString(PyExc_OverflowError,
        "value too large to convert to long");
    return (long) -1;
raise_neg_overflow:
    PyErr_SetString(PyExc_OverflowError,
        "can't convert negative value to long");
    return (long) -1;
}

/* FastTypeChecks */
#if CYTHON_COMPILING_IN_CPYTHON
static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) {
    while (a) {
        a = __Pyx_PyType_GetSlot(a, tp_base, PyTypeObject*);
        if (a == b)
            return 1;
    }
    return b == &PyBaseObject_Type;
}
static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b) {
    PyObject *mro;
    if (a == b) return 1;
    mro = a->tp_mro;
    if (likely(mro)) {
        Py_ssize_t i, n;
        n = PyTuple_GET_SIZE(mro);
        for (i = 0; i < n; i++) {
            if (PyTuple_GET_ITEM(mro, i) == (PyObject *)b)
                return 1;
        }
        return 0;
    }
    return __Pyx_InBases(a, b);
}
static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b) {
    PyObject *mro;
    if (cls == a || cls == b) return 1;
    mro = cls->tp_mro;
    if (likely(mro)) {
        Py_ssize_t i, n;
        n = PyTuple_GET_SIZE(mro);
        for (i = 0; i < n; i++) {
            PyObject *base = PyTuple_GET_ITEM(mro, i);
            if (base == (PyObject *)a || base == (PyObject *)b)
                return 1;
        }
        return 0;
    }
    return __Pyx_InBases(cls, a) || __Pyx_InBases(cls, b);
}
static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) {
    if (exc_type1) {
        return __Pyx_IsAnySubtype2((PyTypeObject*)err, (PyTypeObject*)exc_type1, (PyTypeObject*)exc_type2);
    } else {
        return __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2);
    }
}
static int __Pyx_PyErr_GivenExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) {
    Py_ssize_t i, n;
    assert(PyExceptionClass_Check(exc_type));
    n = PyTuple_GET_SIZE(tuple);
    for (i=0; i<n; i++) {
        if (exc_type == PyTuple_GET_ITEM(tuple, i)) return 1;
    }
    for (i=0; i<n; i++) {
        PyObject *t = PyTuple_GET_ITEM(tuple, i);
        if (likely(PyExceptionClass_Check(t))) {
            if (__Pyx_inner_PyErr_GivenExceptionMatches2(exc_type, NULL, t)) return 1;
        } else {
        }
    }
    return 0;
}
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject* exc_type) {
    if (likely(err == exc_type)) return 1;
    if (likely(PyExceptionClass_Check(err))) {
        if (likely(PyExceptionClass_Check(exc_type))) {
            return __Pyx_inner_PyErr_GivenExceptionMatches2(err, NULL, exc_type);
        } else if (likely(PyTuple_Check(exc_type))) {
            return __Pyx_PyErr_GivenExceptionMatchesTuple(err, exc_type);
        } else {
        }
    }
    return PyErr_GivenExceptionMatches(err, exc_type);
}
static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *exc_type1, PyObject *exc_type2) {
    assert(PyExceptionClass_Check(exc_type1));
    assert(PyExceptionClass_Check(exc_type2));
    if (likely(err == exc_type1 || err == exc_type2)) return 1;
    if (likely(PyExceptionClass_Check(err))) {
        return __Pyx_inner_PyErr_GivenExceptionMatches2(err, exc_type1, exc_type2);
    }
    return (PyErr_GivenExceptionMatches(err, exc_type1) || PyErr_GivenExceptionMatches(err, exc_type2));
}
#endif

/* GetRuntimeVersion */
#if __PYX_LIMITED_VERSION_HEX < 0x030b0000
void __Pyx_init_runtime_version(void) {
    if (__Pyx_cached_runtime_version == 0) {
        const char* rt_version = Py_GetVersion();
        unsigned long version = 0;
        unsigned long factor = 0x01000000UL;
        unsigned int digit = 0;
        int i = 0;
        while (factor) {
            while ('0' <= rt_version[i] && rt_version[i] <= '9') {
                digit = digit * 10 + (unsigned int) (rt_version[i] - '0');
                ++i;
            }
            version += factor * digit;
            if (rt_version[i] != '.')
                break;
            digit = 0;
            factor >>= 8;
            ++i;
        }
        __Pyx_cached_runtime_version = version;
    }
}
#endif
static unsigned long __Pyx_get_runtime_version(void) {
#if __PYX_LIMITED_VERSION_HEX >= 0x030b0000
    return Py_Version & ~0xFFUL;
#else
    return __Pyx_cached_runtime_version;
#endif
}

/* IterNextPlain (used by CoroutineBase) */
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
static PyObject *__Pyx_GetBuiltinNext_LimitedAPI(void) {
    if (unlikely(!__pyx_mstate_global->__Pyx_GetBuiltinNext_LimitedAPI_cache))
        __pyx_mstate_global->__Pyx_GetBuiltinNext_LimitedAPI_cache = __Pyx_GetBuiltinName(__pyx_mstate_global->__pyx_n_u_next);
    return __pyx_mstate_global->__Pyx_GetBuiltinNext_LimitedAPI_cache;
}
#endif
static CYTHON_INLINE PyObject *__Pyx_PyIter_Next_Plain(PyObject *iterator) {
#if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030A0000
    PyObject *result;
    PyObject *next = __Pyx_GetBuiltinNext_LimitedAPI();
    if (unlikely(!next)) return NULL;
    result = PyObject_CallFunctionObjArgs(next, iterator, NULL);
    return result;
#else
    (void)__Pyx_GetBuiltinName; // only for early limited API
    iternextfunc iternext = __Pyx_PyObject_GetIterNextFunc(iterator);
    assert(iternext);
    return iternext(iterator);
#endif
}

/* ReturnWithStopIteration (used by CoroutineBase) */
static void __Pyx__ReturnWithStopIteration(PyObject* value, int async);
static CYTHON_INLINE void __Pyx_ReturnWithStopIteration(PyObject* value, int async, int iternext) {
    if (value == Py_None) {
        if (async || !iternext)
            PyErr_SetNone(async ? PyExc_StopAsyncIteration : PyExc_StopIteration);
        return;
    }
    __Pyx__ReturnWithStopIteration(value, async);
}
static void __Pyx__ReturnWithStopIteration(PyObject* value, int async) {
#if CYTHON_COMPILING_IN_CPYTHON
    __Pyx_PyThreadState_declare
#endif
    PyObject *exc;
    PyObject *exc_type = async ? PyExc_StopAsyncIteration : PyExc_StopIteration;
#if CYTHON_COMPILING_IN_CPYTHON
    if ((PY_VERSION_HEX >= (0x030C00A6)) || unlikely(PyTuple_Check(value) || PyExceptionInstance_Check(value))) {
        if (PY_VERSION_HEX >= (0x030e00A1)) {
            exc = __Pyx_PyObject_CallOneArg(exc_type, value);
        } else {
            PyObject *args_tuple = PyTuple_New(1);
            if (unlikely(!args_tuple)) return;
            Py_INCREF(value);
            PyTuple_SET_ITEM(args_tuple, 0, value);
            exc = PyObject_Call(exc_type, args_tuple, NULL);
            Py_DECREF(args_tuple);
        }
        if (unlikely(!exc)) return;
    } else {
        Py_INCREF(value);
        exc = value;
    }
    #if CYTHON_FAST_THREAD_STATE
    __Pyx_PyThreadState_assign
    #if CYTHON_USE_EXC_INFO_STACK
    if (!__pyx_tstate->exc_info->exc_value)
    #else
    if (!__pyx_tstate->exc_type)
    #endif
    {
        Py_INCREF(exc_type);
        __Pyx_ErrRestore(exc_type, exc, NULL);
        return;
    }
    #endif
#else
    exc = __Pyx_PyObject_CallOneArg(exc_type, value);
    if (unlikely(!exc)) return;
#endif
    PyErr_SetObject(exc_type, exc);
    Py_DECREF(exc);
}

/* CoroutineBase (used by Generator) */
#if !CYTHON_COMPILING_IN_LIMITED_API
#include <frameobject.h>
#if PY_VERSION_HEX >= 0x030b00a6 && !defined(PYPY_VERSION)
  #ifndef Py_BUILD_CORE
    #define Py_BUILD_CORE 1
  #endif
  #include "internal/pycore_frame.h"
#endif
#endif // CYTHON_COMPILING_IN_LIMITED_API
static CYTHON_INLINE void
__Pyx_Coroutine_Undelegate(__pyx_CoroutineObject *gen) {
#if CYTHON_USE_AM_SEND
    gen->yieldfrom_am_send = NULL;
#endif
    Py_CLEAR(gen->yieldfrom);
}
static int __Pyx_PyGen__FetchStopIterationValue(PyThreadState *__pyx_tstate, PyObject **pvalue) {
    PyObject *et, *ev, *tb;
    PyObject *value = NULL;
    CYTHON_UNUSED_VAR(__pyx_tstate);
    __Pyx_ErrFetch(&et, &ev, &tb);
    if (!et) {
        Py_XDECREF(tb);
        Py_XDECREF(ev);
        Py_INCREF(Py_None);
        *pvalue = Py_None;
        return 0;
    }
    if (likely(et == PyExc_StopIteration)) {
        if (!ev) {
            Py_INCREF(Py_None);
            value = Py_None;
        }
        else if (likely(__Pyx_IS_TYPE(ev, (PyTypeObject*)PyExc_StopIteration))) {
            #if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL
            value = PyObject_GetAttr(ev, __pyx_mstate_global->__pyx_n_u_value);
            if (unlikely(!value)) goto limited_api_failure;
            #else
            value = ((PyStopIterationObject *)ev)->value;
            Py_INCREF(value);
            #endif
            Py_DECREF(ev);
        }
        else if (unlikely(PyTuple_Check(ev))) {
            Py_ssize_t tuple_size = __Pyx_PyTuple_GET_SIZE(ev);
            #if !CYTHON_ASSUME_SAFE_SIZE
            if (unlikely(tuple_size < 0)) {
                Py_XDECREF(tb);
                Py_DECREF(ev);
                Py_DECREF(et);
                return -1;
            }
            #endif
            if (tuple_size >= 1) {
#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
                value = PyTuple_GET_ITEM(ev, 0);
                Py_INCREF(value);
#elif CYTHON_ASSUME_SAFE_MACROS
                value = PySequence_ITEM(ev, 0);
#else
                value = PySequence_GetItem(ev, 0);
                if (!value) goto limited_api_failure;
#endif
            } else {
                Py_INCREF(Py_None);
                value = Py_None;
            }
            Py_DECREF(ev);
        }
        else if (!__Pyx_TypeCheck(ev, (PyTypeObject*)PyExc_StopIteration)) {
            value = ev;
        }
        if (likely(value)) {
            Py_XDECREF(tb);
            Py_DECREF(et);
            *pvalue = value;
            return 0;
        }
    } else if (!__Pyx_PyErr_GivenExceptionMatches(et, PyExc_StopIteration)) {
        __Pyx_ErrRestore(et, ev, tb);
        return -1;
    }
    PyErr_NormalizeException(&et, &ev, &tb);
    if (unlikely(!PyObject_TypeCheck(ev, (PyTypeObject*)PyExc_StopIteration))) {
        __Pyx_ErrRestore(et, ev, tb);
        return -1;
    }
    Py_XDECREF(tb);
    Py_DECREF(et);
#if CYTHON_COMPILING_IN_LIMITED_API
    value = PyObject_GetAttr(ev, __pyx_mstate_global->__pyx_n_u_value);
#else
    value = ((PyStopIterationObject *)ev)->value;
    Py_INCREF(value);
#endif
    Py_DECREF(ev);
#if CYTHON_COMPILING_IN_LIMITED_API
    if (unlikely(!value)) return -1;
#endif
    *pvalue = value;
    return 0;
#if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL || !CYTHON_ASSUME_SAFE_MACROS
  limited_api_failure:
    Py_XDECREF(et);
    Py_XDECREF(tb);
    Py_XDECREF(ev);
    return -1;
#endif
}
static CYTHON_INLINE
__Pyx_PySendResult __Pyx_Coroutine_status_from_result(PyObject **retval) {
    if (*retval) {
        return PYGEN_NEXT;
    } else if (likely(__Pyx_PyGen__FetchStopIterationValue(__Pyx_PyThreadState_Current, retval) == 0)) {
        return PYGEN_RETURN;
    } else {
        return PYGEN_ERROR;
    }
}
static CYTHON_INLINE
void __Pyx_Coroutine_ExceptionClear(__Pyx_ExcInfoStruct *exc_state) {
#if PY_VERSION_HEX >= 0x030B00a4
    Py_CLEAR(exc_state->exc_value);
#else
    PyObject *t, *v, *tb;
    t = exc_state->exc_type;
    v = exc_state->exc_value;
    tb = exc_state->exc_traceback;
    exc_state->exc_type = NULL;
    exc_state->exc_value = NULL;
    exc_state->exc_traceback = NULL;
    Py_XDECREF(t);
    Py_XDECREF(v);
    Py_XDECREF(tb);
#endif
}
#define __Pyx_Coroutine_AlreadyRunningError(gen)  (__Pyx__Coroutine_AlreadyRunningError(gen), (PyObject*)NULL)
static void __Pyx__Coroutine_AlreadyRunningError(__pyx_CoroutineObject *gen) {
    const char *msg;
    CYTHON_MAYBE_UNUSED_VAR(gen);
    if ((0)) {
    #ifdef __Pyx_Coroutine_USED
    } else if (__Pyx_Coroutine_Check((PyObject*)gen)) {
        msg = "coroutine already executing";
    #endif
    #ifdef __Pyx_AsyncGen_USED
    } else if (__Pyx_AsyncGen_CheckExact((PyObject*)gen)) {
        msg = "async generator already executing";
    #endif
    } else {
        msg = "generator already executing";
    }
    PyErr_SetString(PyExc_ValueError, msg);
}
static void __Pyx_Coroutine_AlreadyTerminatedError(PyObject *gen, PyObject *value, int closing) {
    CYTHON_MAYBE_UNUSED_VAR(gen);
    CYTHON_MAYBE_UNUSED_VAR(closing);
    #ifdef __Pyx_Coroutine_USED
    if (!closing && __Pyx_Coroutine_Check(gen)) {
        PyErr_SetString(PyExc_RuntimeError, "cannot reuse already awaited coroutine");
    } else
    #endif
    if (value) {
        #ifdef __Pyx_AsyncGen_USED
        if (__Pyx_AsyncGen_CheckExact(gen))
            PyErr_SetNone(PyExc_StopAsyncIteration);
        else
        #endif
        PyErr_SetNone(PyExc_StopIteration);
    }
}
static
__Pyx_PySendResult __Pyx_Coroutine_SendEx(__pyx_CoroutineObject *self, PyObject *value, PyObject **result, int closing) {
    __Pyx_PyThreadState_declare
    PyThreadState *tstate;
    __Pyx_ExcInfoStruct *exc_state;
    PyObject *retval;
    assert(__Pyx_Coroutine_get_is_running(self));  // Callers should ensure is_running
    if (unlikely(self->resume_label == -1)) {
        __Pyx_Coroutine_AlreadyTerminatedError((PyObject*)self, value, closing);
        return PYGEN_ERROR;
    }
#if CYTHON_FAST_THREAD_STATE
    __Pyx_PyThreadState_assign
    tstate = __pyx_tstate;
#else
    tstate = __Pyx_PyThreadState_Current;
#endif
    exc_state = &self->gi_exc_state;
    if (exc_state->exc_value) {
        #if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY
        #else
        PyObject *exc_tb;
        #if PY_VERSION_HEX >= 0x030B00a4 && !CYTHON_COMPILING_IN_CPYTHON
        exc_tb = PyException_GetTraceback(exc_state->exc_value);
        #elif PY_VERSION_HEX >= 0x030B00a4
        exc_tb = ((PyBaseExceptionObject*) exc_state->exc_value)->traceback;
        #else
        exc_tb = exc_state->exc_traceback;
        #endif
        if (exc_tb) {
            PyTracebackObject *tb = (PyTracebackObject *) exc_tb;
            PyFrameObject *f = tb->tb_frame;
            assert(f->f_back == NULL);
            #if PY_VERSION_HEX >= 0x030B00A1
            f->f_back = PyThreadState_GetFrame(tstate);
            #else
            Py_XINCREF(tstate->frame);
            f->f_back = tstate->frame;
            #endif
            #if PY_VERSION_HEX >= 0x030B00a4 && !CYTHON_COMPILING_IN_CPYTHON
            Py_DECREF(exc_tb);
            #endif
        }
        #endif
    }
#if CYTHON_USE_EXC_INFO_STACK
    exc_state->previous_item = tstate->exc_info;
    tstate->exc_info = exc_state;
#else
    if (exc_state->exc_type) {
        __Pyx_ExceptionSwap(&exc_state->exc_type, &exc_state->exc_value, &exc_state->exc_traceback);
    } else {
        __Pyx_Coroutine_ExceptionClear(exc_state);
        __Pyx_ExceptionSave(&exc_state->exc_type, &exc_state->exc_value, &exc_state->exc_traceback);
    }
#endif
    retval = self->body(self, tstate, value);
#if CYTHON_USE_EXC_INFO_STACK
    exc_state = &self->gi_exc_state;
    tstate->exc_info = exc_state->previous_item;
    exc_state->previous_item = NULL;
    __Pyx_Coroutine_ResetFrameBackpointer(exc_state);
#endif
    *result = retval;
    if (self->resume_label == -1) {
        return likely(retval) ? PYGEN_RETURN : PYGEN_ERROR;
    }
    return PYGEN_NEXT;
}
static CYTHON_INLINE void __Pyx_Coroutine_ResetFrameBackpointer(__Pyx_ExcInfoStruct *exc_state) {
#if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API
    CYTHON_UNUSED_VAR(exc_state);
#else
    PyObject *exc_tb;
    #if PY_VERSION_HEX >= 0x030B00a4
    if (!exc_state->exc_value) return;
    exc_tb = PyException_GetTraceback(exc_state->exc_value);
    #else
    exc_tb = exc_state->exc_traceback;
    #endif
    if (likely(exc_tb)) {
        PyTracebackObject *tb = (PyTracebackObject *) exc_tb;
        PyFrameObject *f = tb->tb_frame;
        Py_CLEAR(f->f_back);
        #if PY_VERSION_HEX >= 0x030B00a4
        Py_DECREF(exc_tb);
        #endif
    }
#endif
}
#define __Pyx_Coroutine_MethodReturnFromResult(gen, result, retval, iternext)\
    ((result) == PYGEN_NEXT ? (retval) : __Pyx__Coroutine_MethodReturnFromResult(gen, result, retval, iternext))
static PyObject *
__Pyx__Coroutine_MethodReturnFromResult(PyObject* gen, __Pyx_PySendResult result, PyObject *retval, int iternext) {
    CYTHON_MAYBE_UNUSED_VAR(gen);
    if (likely(result == PYGEN_RETURN)) {
        int is_async = 0;
        #ifdef __Pyx_AsyncGen_USED
        is_async = __Pyx_AsyncGen_CheckExact(gen);
        #endif
        __Pyx_ReturnWithStopIteration(retval, is_async, iternext);
        Py_XDECREF(retval);
    }
    return NULL;
}
#if CYTHON_COMPILING_IN_CPYTHON
static CYTHON_INLINE
PyObject *__Pyx_PyGen_Send(PyGenObject *gen, PyObject *arg) {
#if PY_VERSION_HEX <= 0x030A00A1
    return _PyGen_Send(gen, arg);
#else
    PyObject *result;
    if (PyIter_Send((PyObject*)gen, arg ? arg : Py_None, &result) == PYGEN_RETURN) {
        if (PyAsyncGen_CheckExact(gen)) {
            assert(result == Py_None);
            PyErr_SetNone(PyExc_StopAsyncIteration);
        }
        else if (result == Py_None) {
            PyErr_SetNone(PyExc_StopIteration);
        }
        else {
#if PY_VERSION_HEX < 0x030d00A1
            _PyGen_SetStopIterationValue(result);
#else
            if (!PyTuple_Check(result) && !PyExceptionInstance_Check(result)) {
                PyErr_SetObject(PyExc_StopIteration, result);
            } else {
                PyObject *exc = __Pyx_PyObject_CallOneArg(PyExc_StopIteration, result);
                if (likely(exc != NULL)) {
                    PyErr_SetObject(PyExc_StopIteration, exc);
                    Py_DECREF(exc);
                }
            }
#endif
        }
        Py_DECREF(result);
        result = NULL;
    }
    return result;
#endif
}
#endif
static CYTHON_INLINE __Pyx_PySendResult
__Pyx_Coroutine_FinishDelegation(__pyx_CoroutineObject *gen, PyObject** retval) {
    __Pyx_PySendResult result;
    PyObject *val = NULL;
    assert(__Pyx_Coroutine_get_is_running(gen));
    __Pyx_Coroutine_Undelegate(gen);
    __Pyx_PyGen__FetchStopIterationValue(__Pyx_PyThreadState_Current, &val);
    result = __Pyx_Coroutine_SendEx(gen, val, retval, 0);
    Py_XDECREF(val);
    return result;
}
#if CYTHON_USE_AM_SEND
static __Pyx_PySendResult
__Pyx_Coroutine_SendToDelegate(__pyx_CoroutineObject *gen, __Pyx_pyiter_sendfunc gen_am_send, PyObject *value, PyObject **retval) {
    PyObject *ret = NULL;
    __Pyx_PySendResult delegate_result, result;
    assert(__Pyx_Coroutine_get_is_running(gen));
    delegate_result = gen_am_send(gen->yieldfrom, value, &ret);
    if (delegate_result == PYGEN_NEXT) {
        assert (ret != NULL);
        *retval = ret;
        return PYGEN_NEXT;
    }
    assert (delegate_result != PYGEN_ERROR || ret == NULL);
    __Pyx_Coroutine_Undelegate(gen);
    result = __Pyx_Coroutine_SendEx(gen, ret, retval, 0);
    Py_XDECREF(ret);
    return result;
}
#endif
static PyObject *__Pyx_Coroutine_Send(PyObject *self, PyObject *value) {
    PyObject *retval = NULL;
    __Pyx_PySendResult result = __Pyx_Coroutine_AmSend(self, value, &retval);
    return __Pyx_Coroutine_MethodReturnFromResult(self, result, retval, 0);
}
static __Pyx_PySendResult
__Pyx_Coroutine_AmSend(PyObject *self, PyObject *value, PyObject **retval) {
    __Pyx_PySendResult result;
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject*) self;
    if (unlikely(__Pyx_Coroutine_test_and_set_is_running(gen))) {
        *retval = __Pyx_Coroutine_AlreadyRunningError(gen);
        return PYGEN_ERROR;
    }
    #if CYTHON_USE_AM_SEND
    if (gen->yieldfrom_am_send) {
        result = __Pyx_Coroutine_SendToDelegate(gen, gen->yieldfrom_am_send, value, retval);
    } else
    #endif
    if (gen->yieldfrom) {
        PyObject *yf = gen->yieldfrom;
        PyObject *ret;
      #if !CYTHON_USE_AM_SEND
        #ifdef __Pyx_Generator_USED
        if (__Pyx_Generator_CheckExact(yf)) {
            ret = __Pyx_Coroutine_Send(yf, value);
        } else
        #endif
        #ifdef __Pyx_Coroutine_USED
        if (__Pyx_Coroutine_Check(yf)) {
            ret = __Pyx_Coroutine_Send(yf, value);
        } else
        #endif
        #ifdef __Pyx_AsyncGen_USED
        if (__pyx_PyAsyncGenASend_CheckExact(yf)) {
            ret = __Pyx_async_gen_asend_send(yf, value);
        } else
        #endif
        #if CYTHON_COMPILING_IN_CPYTHON
        if (PyGen_CheckExact(yf)) {
            ret = __Pyx_PyGen_Send((PyGenObject*)yf, value == Py_None ? NULL : value);
        } else
        if (PyCoro_CheckExact(yf)) {
            ret = __Pyx_PyGen_Send((PyGenObject*)yf, value == Py_None ? NULL : value);
        } else
        #endif
      #endif
        {
            #if !CYTHON_COMPILING_IN_LIMITED_API || __PYX_LIMITED_VERSION_HEX >= 0x03080000
            if (value == Py_None && PyIter_Check(yf))
                ret = __Pyx_PyIter_Next_Plain(yf);
            else
            #endif
                ret = __Pyx_PyObject_CallMethod1(yf, __pyx_mstate_global->__pyx_n_u_send, value);
        }
        if (likely(ret)) {
            __Pyx_Coroutine_unset_is_running(gen);
            *retval = ret;
            return PYGEN_NEXT;
        }
        result = __Pyx_Coroutine_FinishDelegation(gen, retval);
    } else {
        result = __Pyx_Coroutine_SendEx(gen, value, retval, 0);
    }
    __Pyx_Coroutine_unset_is_running(gen);
    return result;
}
static int __Pyx_Coroutine_CloseIter(__pyx_CoroutineObject *gen, PyObject *yf) {
    __Pyx_PySendResult result;
    PyObject *retval = NULL;
    CYTHON_UNUSED_VAR(gen);
    assert(__Pyx_Coroutine_get_is_running(gen));
    #ifdef __Pyx_Generator_USED
    if (__Pyx_Generator_CheckExact(yf)) {
        result = __Pyx_Coroutine_Close(yf, &retval);
    } else
    #endif
    #ifdef __Pyx_Coroutine_USED
    if (__Pyx_Coroutine_Check(yf)) {
        result = __Pyx_Coroutine_Close(yf, &retval);
    } else
    if (__Pyx_CoroutineAwait_CheckExact(yf)) {
        result = __Pyx_CoroutineAwait_Close((__pyx_CoroutineAwaitObject*)yf);
    } else
    #endif
    #ifdef __Pyx_AsyncGen_USED
    if (__pyx_PyAsyncGenASend_CheckExact(yf)) {
        retval = __Pyx_async_gen_asend_close(yf, NULL);
        result = PYGEN_RETURN;
    } else
    if (__pyx_PyAsyncGenAThrow_CheckExact(yf)) {
        retval = __Pyx_async_gen_athrow_close(yf, NULL);
        result = PYGEN_RETURN;
    } else
    #endif
    {
        PyObject *meth;
        result = PYGEN_RETURN;
        meth = __Pyx_PyObject_GetAttrStrNoError(yf, __pyx_mstate_global->__pyx_n_u_close);
        if (unlikely(!meth)) {
            if (unlikely(PyErr_Occurred())) {
                PyErr_WriteUnraisable(yf);
            }
        } else {
            retval = __Pyx_PyObject_CallNoArg(meth);
            Py_DECREF(meth);
            if (unlikely(!retval)) {
                result = PYGEN_ERROR;
            }
        }
    }
    Py_XDECREF(retval);
    return result == PYGEN_ERROR ? -1 : 0;
}
static PyObject *__Pyx_Generator_Next(PyObject *self) {
    __Pyx_PySendResult result;
    PyObject *retval = NULL;
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject*) self;
    if (unlikely(__Pyx_Coroutine_test_and_set_is_running(gen))) {
        return __Pyx_Coroutine_AlreadyRunningError(gen);
    }
    #if CYTHON_USE_AM_SEND
    if (gen->yieldfrom_am_send) {
        result = __Pyx_Coroutine_SendToDelegate(gen, gen->yieldfrom_am_send, Py_None, &retval);
    } else
    #endif
    if (gen->yieldfrom) {
        PyObject *yf = gen->yieldfrom;
        PyObject *ret;
        #ifdef __Pyx_Generator_USED
        if (__Pyx_Generator_CheckExact(yf)) {
            ret = __Pyx_Generator_Next(yf);
        } else
        #endif
        #ifdef __Pyx_Coroutine_USED
        if (__Pyx_Coroutine_CheckExact(yf)) {
            ret = __Pyx_Coroutine_Send(yf, Py_None);
        } else
        #endif
        #if CYTHON_COMPILING_IN_CPYTHON && (PY_VERSION_HEX < 0x030A00A3 || !CYTHON_USE_AM_SEND)
        if (PyGen_CheckExact(yf)) {
            ret = __Pyx_PyGen_Send((PyGenObject*)yf, NULL);
        } else
        #endif
            ret = __Pyx_PyIter_Next_Plain(yf);
        if (likely(ret)) {
            __Pyx_Coroutine_unset_is_running(gen);
            return ret;
        }
        result = __Pyx_Coroutine_FinishDelegation(gen, &retval);
    } else {
        result = __Pyx_Coroutine_SendEx(gen, Py_None, &retval, 0);
    }
    __Pyx_Coroutine_unset_is_running(gen);
    return __Pyx_Coroutine_MethodReturnFromResult(self, result, retval, 1);
}
static PyObject *__Pyx_Coroutine_Close_Method(PyObject *self, PyObject *arg) {
    PyObject *retval = NULL;
    __Pyx_PySendResult result;
    CYTHON_UNUSED_VAR(arg);
    result = __Pyx_Coroutine_Close(self, &retval);
    if (unlikely(result == PYGEN_ERROR))
        return NULL;
    Py_XDECREF(retval);
    Py_RETURN_NONE;
}
static __Pyx_PySendResult
__Pyx_Coroutine_Close(PyObject *self, PyObject **retval) {
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject *) self;
    __Pyx_PySendResult result;
    PyObject *yf;
    int err = 0;
    if (unlikely(__Pyx_Coroutine_test_and_set_is_running(gen))) {
        *retval = __Pyx_Coroutine_AlreadyRunningError(gen);
        return PYGEN_ERROR;
    }
    yf = gen->yieldfrom;
    if (yf) {
        Py_INCREF(yf);
        err = __Pyx_Coroutine_CloseIter(gen, yf);
        __Pyx_Coroutine_Undelegate(gen);
        Py_DECREF(yf);
    }
    if (err == 0)
        PyErr_SetNone(PyExc_GeneratorExit);
    result = __Pyx_Coroutine_SendEx(gen, NULL, retval, 1);
    if (result == PYGEN_ERROR) {
        __Pyx_PyThreadState_declare
        __Pyx_PyThreadState_assign
        __Pyx_Coroutine_unset_is_running(gen);
        if (!__Pyx_PyErr_Occurred()) {
            return PYGEN_RETURN;
        } else if (likely(__Pyx_PyErr_ExceptionMatches2(PyExc_GeneratorExit, PyExc_StopIteration))) {
            __Pyx_PyErr_Clear();
            return PYGEN_RETURN;
        }
        return PYGEN_ERROR;
    } else if (likely(result == PYGEN_RETURN && *retval == Py_None)) {
        __Pyx_Coroutine_unset_is_running(gen);
        return PYGEN_RETURN;
    } else {
        const char *msg;
        Py_DECREF(*retval);
        *retval = NULL;
        if ((0)) {
        #ifdef __Pyx_Coroutine_USED
        } else if (__Pyx_Coroutine_Check(self)) {
            msg = "coroutine ignored GeneratorExit";
        #endif
        #ifdef __Pyx_AsyncGen_USED
        } else if (__Pyx_AsyncGen_CheckExact(self)) {
            msg = "async generator ignored GeneratorExit";
        #endif
        } else {
            msg = "generator ignored GeneratorExit";
        }
        PyErr_SetString(PyExc_RuntimeError, msg);
        __Pyx_Coroutine_unset_is_running(gen);
        return PYGEN_ERROR;
    }
}
static PyObject *__Pyx__Coroutine_Throw(PyObject *self, PyObject *typ, PyObject *val, PyObject *tb,
                                        PyObject *args, int close_on_genexit) {
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject *) self;
    PyObject *yf;
    if (unlikely(__Pyx_Coroutine_test_and_set_is_running(gen)))
        return __Pyx_Coroutine_AlreadyRunningError(gen);
    yf = gen->yieldfrom;
    if (yf) {
        __Pyx_PySendResult result;
        PyObject *ret;
        Py_INCREF(yf);
        if (__Pyx_PyErr_GivenExceptionMatches(typ, PyExc_GeneratorExit) && close_on_genexit) {
            int err = __Pyx_Coroutine_CloseIter(gen, yf);
            Py_DECREF(yf);
            __Pyx_Coroutine_Undelegate(gen);
            if (err < 0)
                goto propagate_exception;
            goto throw_here;
        }
        if (0
        #ifdef __Pyx_Generator_USED
            || __Pyx_Generator_CheckExact(yf)
        #endif
        #ifdef __Pyx_Coroutine_USED
            || __Pyx_Coroutine_Check(yf)
        #endif
            ) {
            ret = __Pyx__Coroutine_Throw(yf, typ, val, tb, args, close_on_genexit);
        #ifdef __Pyx_Coroutine_USED
        } else if (__Pyx_CoroutineAwait_CheckExact(yf)) {
            ret = __Pyx__Coroutine_Throw(((__pyx_CoroutineAwaitObject*)yf)->coroutine, typ, val, tb, args, close_on_genexit);
        #endif
        } else {
            PyObject *meth = __Pyx_PyObject_GetAttrStrNoError(yf, __pyx_mstate_global->__pyx_n_u_throw);
            if (unlikely(!meth)) {
                Py_DECREF(yf);
                if (unlikely(PyErr_Occurred())) {
                    __Pyx_Coroutine_unset_is_running(gen);
                    return NULL;
                }
                __Pyx_Coroutine_Undelegate(gen);
                goto throw_here;
            }
            if (likely(args)) {
                ret = __Pyx_PyObject_Call(meth, args, NULL);
            } else {
                PyObject *cargs[4] = {NULL, typ, val, tb};
                ret = __Pyx_PyObject_FastCall(meth, cargs+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET);
            }
            Py_DECREF(meth);
        }
        Py_DECREF(yf);
        if (ret) {
            __Pyx_Coroutine_unset_is_running(gen);
            return ret;
        }
        result = __Pyx_Coroutine_FinishDelegation(gen, &ret);
        __Pyx_Coroutine_unset_is_running(gen);
        return __Pyx_Coroutine_MethodReturnFromResult(self, result, ret, 0);
    }
throw_here:
    __Pyx_Raise(typ, val, tb, NULL);
propagate_exception:
    {
        PyObject *retval = NULL;
        __Pyx_PySendResult result = __Pyx_Coroutine_SendEx(gen, NULL, &retval, 0);
        __Pyx_Coroutine_unset_is_running(gen);
        return __Pyx_Coroutine_MethodReturnFromResult(self, result, retval, 0);
    }
}
static PyObject *__Pyx_Coroutine_Throw(PyObject *self, PyObject *args) {
    PyObject *typ;
    PyObject *val = NULL;
    PyObject *tb = NULL;
    if (unlikely(!PyArg_UnpackTuple(args, "throw", 1, 3, &typ, &val, &tb)))
        return NULL;
    return __Pyx__Coroutine_Throw(self, typ, val, tb, args, 1);
}
static CYTHON_INLINE int __Pyx_Coroutine_traverse_excstate(__Pyx_ExcInfoStruct *exc_state, visitproc visit, void *arg) {
#if PY_VERSION_HEX >= 0x030B00a4
    Py_VISIT(exc_state->exc_value);
#else
    Py_VISIT(exc_state->exc_type);
    Py_VISIT(exc_state->exc_value);
    Py_VISIT(exc_state->exc_traceback);
#endif
    return 0;
}
static int __Pyx_Coroutine_traverse(__pyx_CoroutineObject *gen, visitproc visit, void *arg) {
    {
        int e = __Pyx_call_type_traverse((PyObject*)gen, 1, visit, arg);
        if (e) return e;
    }
    Py_VISIT(gen->closure);
    Py_VISIT(gen->classobj);
    Py_VISIT(gen->yieldfrom);
    return __Pyx_Coroutine_traverse_excstate(&gen->gi_exc_state, visit, arg);
}
static int __Pyx_Coroutine_clear(PyObject *self) {
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject *) self;
    Py_CLEAR(gen->closure);
    Py_CLEAR(gen->classobj);
    __Pyx_Coroutine_Undelegate(gen);
    __Pyx_Coroutine_ExceptionClear(&gen->gi_exc_state);
#ifdef __Pyx_AsyncGen_USED
    if (__Pyx_AsyncGen_CheckExact(self)) {
        Py_CLEAR(((__pyx_PyAsyncGenObject*)gen)->ag_finalizer);
    }
#endif
    Py_CLEAR(gen->gi_code);
    Py_CLEAR(gen->gi_frame);
    Py_CLEAR(gen->gi_name);
    Py_CLEAR(gen->gi_qualname);
    Py_CLEAR(gen->gi_modulename);
    return 0;
}
static void __Pyx_Coroutine_dealloc(PyObject *self) {
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject *) self;
    PyObject_GC_UnTrack(gen);
    #if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    if (gen->gi_weakreflist != NULL)
    #endif
        PyObject_ClearWeakRefs(self);
    if (gen->resume_label >= 0) {
        PyObject_GC_Track(self);
#if CYTHON_USE_TP_FINALIZE
        if (unlikely(PyObject_CallFinalizerFromDealloc(self)))
#else
        {
            destructor del = __Pyx_PyObject_GetSlot(gen, tp_del, destructor);
            if (del) del(self);
        }
        if (unlikely(Py_REFCNT(self) > 0))
#endif
        {
            return;
        }
        PyObject_GC_UnTrack(self);
    }
#ifdef __Pyx_AsyncGen_USED
    if (__Pyx_AsyncGen_CheckExact(self)) {
        /* We have to handle this case for asynchronous generators
           right here, because this code has to be between UNTRACK
           and GC_Del. */
        Py_CLEAR(((__pyx_PyAsyncGenObject*)self)->ag_finalizer);
    }
#endif
    __Pyx_Coroutine_clear(self);
    __Pyx_PyHeapTypeObject_GC_Del(gen);
}
#if CYTHON_USE_TP_FINALIZE
static void __Pyx_Coroutine_del(PyObject *self) {
    PyObject *error_type, *error_value, *error_traceback;
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject *) self;
    __Pyx_PyThreadState_declare
    if (gen->resume_label < 0) {
        return;
    }
    __Pyx_PyThreadState_assign
    __Pyx_ErrFetch(&error_type, &error_value, &error_traceback);
#ifdef __Pyx_AsyncGen_USED
    if (__Pyx_AsyncGen_CheckExact(self)) {
        __pyx_PyAsyncGenObject *agen = (__pyx_PyAsyncGenObject*)self;
        PyObject *finalizer = agen->ag_finalizer;
        if (finalizer && !agen->ag_closed) {
            PyObject *res = __Pyx_PyObject_CallOneArg(finalizer, self);
            if (unlikely(!res)) {
                PyErr_WriteUnraisable(self);
            } else {
                Py_DECREF(res);
            }
            __Pyx_ErrRestore(error_type, error_value, error_traceback);
            return;
        }
    }
#endif
    if (unlikely(gen->resume_label == 0 && !error_value)) {
#ifdef __Pyx_Coroutine_USED
#ifdef __Pyx_Generator_USED
    if (!__Pyx_Generator_CheckExact(self))
#endif
        {
        PyObject_GC_UnTrack(self);
        if (unlikely(PyErr_WarnFormat(PyExc_RuntimeWarning, 1, "coroutine '%.50S' was never awaited", gen->gi_qualname) < 0))
            PyErr_WriteUnraisable(self);
        PyObject_GC_Track(self);
        }
#endif
    } else {
        PyObject *retval = NULL;
        __Pyx_PySendResult result = __Pyx_Coroutine_Close(self, &retval);
        if (result == PYGEN_ERROR) {
            PyErr_WriteUnraisable(self);
        } else {
            Py_XDECREF(retval);
        }
    }
    __Pyx_ErrRestore(error_type, error_value, error_traceback);
}
#endif
static PyObject *
__Pyx_Coroutine_get_name(__pyx_CoroutineObject *self, void *context)
{
    PyObject *name = self->gi_name;
    CYTHON_UNUSED_VAR(context);
    if (unlikely(!name)) name = Py_None;
    Py_INCREF(name);
    return name;
}
static int
__Pyx_Coroutine_set_name(__pyx_CoroutineObject *self, PyObject *value, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (unlikely(value == NULL || !PyUnicode_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__name__ must be set to a string object");
        return -1;
    }
    Py_INCREF(value);
    __Pyx_Py_XDECREF_SET(self->gi_name, value);
    return 0;
}
static PyObject *
__Pyx_Coroutine_get_qualname(__pyx_CoroutineObject *self, void *context)
{
    PyObject *name = self->gi_qualname;
    CYTHON_UNUSED_VAR(context);
    if (unlikely(!name)) name = Py_None;
    Py_INCREF(name);
    return name;
}
static int
__Pyx_Coroutine_set_qualname(__pyx_CoroutineObject *self, PyObject *value, void *context)
{
    CYTHON_UNUSED_VAR(context);
    if (unlikely(value == NULL || !PyUnicode_Check(value))) {
        PyErr_SetString(PyExc_TypeError,
                        "__qualname__ must be set to a string object");
        return -1;
    }
    Py_INCREF(value);
    __Pyx_Py_XDECREF_SET(self->gi_qualname, value);
    return 0;
}
static PyObject *
__Pyx__Coroutine_get_frame(__pyx_CoroutineObject *self)
{
#if !CYTHON_COMPILING_IN_LIMITED_API
    PyObject *frame;
    #if PY_VERSION_HEX >= 0x030d0000
    Py_BEGIN_CRITICAL_SECTION(self);
    #endif
    frame = self->gi_frame;
    if (!frame) {
        if (unlikely(!self->gi_code)) {
            Py_RETURN_NONE;
        }
        PyObject *globals = PyDict_New();
        if (unlikely(!globals)) return NULL;
        frame = (PyObject *) PyFrame_New(
            PyThreadState_Get(),            /*PyThreadState *tstate,*/
            (PyCodeObject*) self->gi_code,  /*PyCodeObject *code,*/
            globals,                        /*PyObject *globals,*/
            0                               /*PyObject *locals*/
        );
        Py_DECREF(globals);
        if (unlikely(!frame))
            return NULL;
        if (unlikely(self->gi_frame)) {
            Py_DECREF(frame);
            frame = self->gi_frame;
        } else {
            self->gi_frame = frame;
        }
    }
    Py_INCREF(frame);
    #if PY_VERSION_HEX >= 0x030d0000
    Py_END_CRITICAL_SECTION();
    #endif
    return frame;
#else
    CYTHON_UNUSED_VAR(self);
    Py_RETURN_NONE;
#endif
}
static PyObject *
__Pyx_Coroutine_get_frame(__pyx_CoroutineObject *self, void *context) {
    CYTHON_UNUSED_VAR(context);
    PyObject *frame = self->gi_frame;
    if (frame)
        return __Pyx_NewRef(frame);
    return __Pyx__Coroutine_get_frame(self);
}
static __pyx_CoroutineObject *__Pyx__Coroutine_New(
            PyTypeObject* type, __pyx_coroutine_body_t body, PyObject *code, PyObject *closure,
            PyObject *name, PyObject *qualname, PyObject *module_name) {
    __pyx_CoroutineObject *gen = PyObject_GC_New(__pyx_CoroutineObject, type);
    if (unlikely(!gen))
        return NULL;
    return __Pyx__Coroutine_NewInit(gen, body, code, closure, name, qualname, module_name);
}
static __pyx_CoroutineObject *__Pyx__Coroutine_NewInit(
            __pyx_CoroutineObject *gen, __pyx_coroutine_body_t body, PyObject *code, PyObject *closure,
            PyObject *name, PyObject *qualname, PyObject *module_name) {
    gen->body = body;
    gen->closure = closure;
    Py_XINCREF(closure);
    gen->is_running = 0;
    gen->resume_label = 0;
    gen->classobj = NULL;
    gen->yieldfrom = NULL;
    gen->yieldfrom_am_send = NULL;
    #if PY_VERSION_HEX >= 0x030B00a4 && !CYTHON_COMPILING_IN_LIMITED_API
    gen->gi_exc_state.exc_value = NULL;
    #else
    gen->gi_exc_state.exc_type = NULL;
    gen->gi_exc_state.exc_value = NULL;
    gen->gi_exc_state.exc_traceback = NULL;
    #endif
#if CYTHON_USE_EXC_INFO_STACK
    gen->gi_exc_state.previous_item = NULL;
#endif
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    gen->gi_weakreflist = NULL;
#endif
    Py_XINCREF(qualname);
    gen->gi_qualname = qualname;
    Py_XINCREF(name);
    gen->gi_name = name;
    Py_XINCREF(module_name);
    gen->gi_modulename = module_name;
    Py_XINCREF(code);
    gen->gi_code = code;
    gen->gi_frame = NULL;
    PyObject_GC_Track(gen);
    return gen;
}
static char __Pyx_Coroutine_test_and_set_is_running(__pyx_CoroutineObject *gen) {
    char result;
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_BEGIN_CRITICAL_SECTION(gen);
    #endif
    result = gen->is_running;
    gen->is_running = 1;
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_END_CRITICAL_SECTION();
    #endif
    return result;
}
static void __Pyx_Coroutine_unset_is_running(__pyx_CoroutineObject *gen) {
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_BEGIN_CRITICAL_SECTION(gen);
    #endif
    assert(gen->is_running);
    gen->is_running = 0;
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_END_CRITICAL_SECTION();
    #endif
}
static char __Pyx_Coroutine_get_is_running(__pyx_CoroutineObject *gen) {
    char result;
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_BEGIN_CRITICAL_SECTION(gen);
    #endif
    result = gen->is_running;
    #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_END_CRITICAL_SECTION();
    #endif
    return result;
}
static PyObject *__Pyx_Coroutine_get_is_running_getter(PyObject *gen, void *closure) {
    CYTHON_UNUSED_VAR(closure);
    char result = __Pyx_Coroutine_get_is_running((__pyx_CoroutineObject*)gen);
    if (result) Py_RETURN_TRUE;
    else Py_RETURN_FALSE;
}
#if __PYX_HAS_PY_AM_SEND == 2
static void __Pyx_SetBackportTypeAmSend(PyTypeObject *type, __Pyx_PyAsyncMethodsStruct *static_amsend_methods, __Pyx_pyiter_sendfunc am_send) {
    Py_ssize_t ptr_offset = (char*)(type->tp_as_async) - (char*)type;
    if (ptr_offset < 0 || ptr_offset > type->tp_basicsize) {
        return;
    }
    memcpy((void*)static_amsend_methods, (void*)(type->tp_as_async), sizeof(*type->tp_as_async));
    static_amsend_methods->am_send = am_send;
    type->tp_as_async = __Pyx_SlotTpAsAsync(static_amsend_methods);
}
#endif
static PyObject *__Pyx_Coroutine_fail_reduce_ex(PyObject *self, PyObject *arg) {
    CYTHON_UNUSED_VAR(arg);
    __Pyx_TypeName self_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE((PyObject*)self));
    PyErr_Format(PyExc_TypeError, "cannot pickle '" __Pyx_FMT_TYPENAME "' object",
                         self_type_name);
    __Pyx_DECREF_TypeName(self_type_name);
    return NULL;
}

/* Generator */
static PyMethodDef __pyx_Generator_methods[] = {
    {"send", (PyCFunction) __Pyx_Coroutine_Send, METH_O,
     PyDoc_STR("send(arg) -> send 'arg' into generator,\nreturn next yielded value or raise StopIteration.")},
    {"throw", (PyCFunction) __Pyx_Coroutine_Throw, METH_VARARGS,
     PyDoc_STR("throw(typ[,val[,tb]]) -> raise exception in generator,\nreturn next yielded value or raise StopIteration.")},
    {"close", (PyCFunction) __Pyx_Coroutine_Close_Method, METH_NOARGS,
     PyDoc_STR("close() -> raise GeneratorExit inside generator.")},
    {"__reduce_ex__", (PyCFunction) __Pyx_Coroutine_fail_reduce_ex, METH_O, 0},
    {"__reduce__", (PyCFunction) __Pyx_Coroutine_fail_reduce_ex, METH_NOARGS, 0},
    {0, 0, 0, 0}
};
static PyMemberDef __pyx_Generator_memberlist[] = {
    {"gi_yieldfrom", T_OBJECT, offsetof(__pyx_CoroutineObject, yieldfrom), READONLY,
     PyDoc_STR("object being iterated by 'yield from', or None")},
    {"gi_code", T_OBJECT, offsetof(__pyx_CoroutineObject, gi_code), READONLY, NULL},
    {"__module__", T_OBJECT, offsetof(__pyx_CoroutineObject, gi_modulename), 0, 0},
#if PY_VERSION_HEX < 0x030C0000 || CYTHON_COMPILING_IN_LIMITED_API
    {"__weaklistoffset__", T_PYSSIZET, offsetof(__pyx_CoroutineObject, gi_weakreflist), READONLY, 0},
#endif
    {0, 0, 0, 0, 0}
};
static PyGetSetDef __pyx_Generator_getsets[] = {
    {"__name__", (getter)__Pyx_Coroutine_get_name, (setter)__Pyx_Coroutine_set_name,
     PyDoc_STR("name of the generator"), 0},
    {"__qualname__", (getter)__Pyx_Coroutine_get_qualname, (setter)__Pyx_Coroutine_set_qualname,
     PyDoc_STR("qualified name of the generator"), 0},
    {"gi_frame", (getter)__Pyx_Coroutine_get_frame, NULL,
     PyDoc_STR("Frame of the generator"), 0},
    {"gi_running", __Pyx_Coroutine_get_is_running_getter, NULL, NULL, NULL},
    {0, 0, 0, 0, 0}
};
static PyType_Slot __pyx_GeneratorType_slots[] = {
    {Py_tp_dealloc, (void *)__Pyx_Coroutine_dealloc},
    {Py_tp_traverse, (void *)__Pyx_Coroutine_traverse},
    {Py_tp_iter, (void *)PyObject_SelfIter},
    {Py_tp_iternext, (void *)__Pyx_Generator_Next},
    {Py_tp_methods, (void *)__pyx_Generator_methods},
    {Py_tp_members, (void *)__pyx_Generator_memberlist},
    {Py_tp_getset, (void *)__pyx_Generator_getsets},
    {Py_tp_getattro, (void *) PyObject_GenericGetAttr},
#if CYTHON_USE_TP_FINALIZE
    {Py_tp_finalize, (void *)__Pyx_Coroutine_del},
#endif
#if __PYX_HAS_PY_AM_SEND == 1
    {Py_am_send, (void *)__Pyx_Coroutine_AmSend},
#endif
    {0, 0},
};
static PyType_Spec __pyx_GeneratorType_spec = {
    __PYX_TYPE_MODULE_PREFIX "generator",
    sizeof(__pyx_CoroutineObject),
    0,
#if PY_VERSION_HEX >= 0x030C0000 && !CYTHON_COMPILING_IN_LIMITED_API
    Py_TPFLAGS_MANAGED_WEAKREF |
#endif
    Py_TPFLAGS_IMMUTABLETYPE | Py_TPFLAGS_DISALLOW_INSTANTIATION |
    Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | __Pyx_TPFLAGS_HAVE_AM_SEND,
    __pyx_GeneratorType_slots
};
#if __PYX_HAS_PY_AM_SEND == 2
static __Pyx_PyAsyncMethodsStruct __pyx_Generator_as_async;
#endif
static int __pyx_Generator_init(PyObject *module) {
    __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module);
    mstate->__pyx_GeneratorType = __Pyx_FetchCommonTypeFromSpec(
        mstate->__pyx_CommonTypesMetaclassType, module, &__pyx_GeneratorType_spec, NULL);
    if (unlikely(!mstate->__pyx_GeneratorType)) {
        return -1;
    }
#if __PYX_HAS_PY_AM_SEND == 2
    __Pyx_SetBackportTypeAmSend(mstate->__pyx_GeneratorType, &__pyx_Generator_as_async, &__Pyx_Coroutine_AmSend);
#endif
    return 0;
}
static PyObject *__Pyx_Generator_GetInlinedResult(PyObject *self) {
    __pyx_CoroutineObject *gen = (__pyx_CoroutineObject*) self;
    PyObject *retval = NULL;
    if (unlikely(__Pyx_Coroutine_test_and_set_is_running(gen))) {
        return __Pyx_Coroutine_AlreadyRunningError(gen);
    }
    __Pyx_PySendResult result = __Pyx_Coroutine_SendEx(gen, Py_None, &retval, 0);
    __Pyx_Coroutine_unset_is_running(gen);
    (void) result;
    assert (result == PYGEN_RETURN || result == PYGEN_ERROR);
    assert ((result == PYGEN_RETURN && retval != NULL) || (result == PYGEN_ERROR && retval == NULL));
    return retval;
}

/* CheckBinaryVersion */
static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer) {
    const unsigned long MAJOR_MINOR = 0xFFFF0000UL;
    if ((rt_version & MAJOR_MINOR) == (ct_version & MAJOR_MINOR))
        return 0;
    if (likely(allow_newer && (rt_version & MAJOR_MINOR) > (ct_version & MAJOR_MINOR)))
        return 1;
    {
        char message[200];
        PyOS_snprintf(message, sizeof(message),
                      "compile time Python version %d.%d "
                      "of module '%.100s' "
                      "%s "
                      "runtime version %d.%d",
                       (int) (ct_version >> 24), (int) ((ct_version >> 16) & 0xFF),
                       __Pyx_MODULE_NAME,
                       (allow_newer) ? "was newer than" : "does not match",
                       (int) (rt_version >> 24), (int) ((rt_version >> 16) & 0xFF)
       );
        return PyErr_WarnEx(NULL, message, 1);
    }
}

/* NewCodeObj */
#if CYTHON_COMPILING_IN_LIMITED_API
    static PyObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f,
                                       PyObject *code, PyObject *c, PyObject* n, PyObject *v,
                                       PyObject *fv, PyObject *cell, PyObject* fn,
                                       PyObject *name, int fline, PyObject *lnos) {
        PyObject *exception_table = NULL;
        PyObject *types_module=NULL, *code_type=NULL, *result=NULL;
        #if __PYX_LIMITED_VERSION_HEX < 0x030b0000
        PyObject *version_info;
        PyObject *py_minor_version = NULL;
        #endif
        long minor_version = 0;
        PyObject *type, *value, *traceback;
        PyErr_Fetch(&type, &value, &traceback);
        #if __PYX_LIMITED_VERSION_HEX >= 0x030b0000
        minor_version = 11;
        #else
        if (!(version_info = PySys_GetObject("version_info"))) goto end;
        if (!(py_minor_version = PySequence_GetItem(version_info, 1))) goto end;
        minor_version = PyLong_AsLong(py_minor_version);
        Py_DECREF(py_minor_version);
        if (minor_version == -1 && PyErr_Occurred()) goto end;
        #endif
        if (!(types_module = PyImport_ImportModule("types"))) goto end;
        if (!(code_type = PyObject_GetAttrString(types_module, "CodeType"))) goto end;
        if (minor_version <= 7) {
            (void)p;
            result = PyObject_CallFunction(code_type, "iiiiiOOOOOOiOOO", a, k, l, s, f, code,
                          c, n, v, fn, name, fline, lnos, fv, cell);
        } else if (minor_version <= 10) {
            result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOiOOO", a,p, k, l, s, f, code,
                          c, n, v, fn, name, fline, lnos, fv, cell);
        } else {
            if (!(exception_table = PyBytes_FromStringAndSize(NULL, 0))) goto end;
            result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOOiOOOO", a,p, k, l, s, f, code,
                          c, n, v, fn, name, name, fline, lnos, exception_table, fv, cell);
        }
    end:
        Py_XDECREF(code_type);
        Py_XDECREF(exception_table);
        Py_XDECREF(types_module);
        if (type) {
            PyErr_Restore(type, value, traceback);
        }
        return result;
    }
#elif PY_VERSION_HEX >= 0x030B0000
  static PyCodeObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f,
                                         PyObject *code, PyObject *c, PyObject* n, PyObject *v,
                                         PyObject *fv, PyObject *cell, PyObject* fn,
                                         PyObject *name, int fline, PyObject *lnos) {
    PyCodeObject *result;
    result =
      #if PY_VERSION_HEX >= 0x030C0000
        PyUnstable_Code_NewWithPosOnlyArgs
      #else
        PyCode_NewWithPosOnlyArgs
      #endif
        (a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, name, fline, lnos, __pyx_mstate_global->__pyx_empty_bytes);
    #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030c00A1
    if (likely(result))
        result->_co_firsttraceable = 0;
    #endif
    return result;
  }
#elif !CYTHON_COMPILING_IN_PYPY
  #define __Pyx__PyCode_New(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\
          PyCode_NewWithPosOnlyArgs(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
#else
  #define __Pyx__PyCode_New(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\
          PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
#endif
static PyObject* __Pyx_PyCode_New(
        const __Pyx_PyCode_New_function_description descr,
        PyObject * const *varnames,
        PyObject *filename,
        PyObject *funcname,
        PyObject *line_table,
        PyObject *tuple_dedup_map
) {
    PyObject *code_obj = NULL, *varnames_tuple_dedup = NULL, *code_bytes = NULL;
    Py_ssize_t var_count = (Py_ssize_t) descr.nlocals;
    PyObject *varnames_tuple = PyTuple_New(var_count);
    if (unlikely(!varnames_tuple)) return NULL;
    for (Py_ssize_t i=0; i < var_count; i++) {
        Py_INCREF(varnames[i]);
        if (__Pyx_PyTuple_SET_ITEM(varnames_tuple, i, varnames[i]) != (0)) goto done;
    }
    #if CYTHON_COMPILING_IN_LIMITED_API
    varnames_tuple_dedup = PyDict_GetItem(tuple_dedup_map, varnames_tuple);
    if (!varnames_tuple_dedup) {
        if (unlikely(PyDict_SetItem(tuple_dedup_map, varnames_tuple, varnames_tuple) < 0)) goto done;
        varnames_tuple_dedup = varnames_tuple;
    }
    #else
    varnames_tuple_dedup = PyDict_SetDefault(tuple_dedup_map, varnames_tuple, varnames_tuple);
    if (unlikely(!varnames_tuple_dedup)) goto done;
    #endif
    #if CYTHON_AVOID_BORROWED_REFS
    Py_INCREF(varnames_tuple_dedup);
    #endif
    if (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table != NULL && !CYTHON_COMPILING_IN_GRAAL) {
        Py_ssize_t line_table_length = __Pyx_PyBytes_GET_SIZE(line_table);
        #if !CYTHON_ASSUME_SAFE_SIZE
        if (unlikely(line_table_length == -1)) goto done;
        #endif
        Py_ssize_t code_len = (line_table_length * 2 + 4) & ~3LL;
        code_bytes = PyBytes_FromStringAndSize(NULL, code_len);
        if (unlikely(!code_bytes)) goto done;
        char* c_code_bytes = PyBytes_AsString(code_bytes);
        if (unlikely(!c_code_bytes)) goto done;
        memset(c_code_bytes, 0, (size_t) code_len);
    }
    code_obj = (PyObject*) __Pyx__PyCode_New(
        (int) descr.argcount,
        (int) descr.num_posonly_args,
        (int) descr.num_kwonly_args,
        (int) descr.nlocals,
        0,
        (int) descr.flags,
        code_bytes ? code_bytes : __pyx_mstate_global->__pyx_empty_bytes,
        __pyx_mstate_global->__pyx_empty_tuple,
        __pyx_mstate_global->__pyx_empty_tuple,
        varnames_tuple_dedup,
        __pyx_mstate_global->__pyx_empty_tuple,
        __pyx_mstate_global->__pyx_empty_tuple,
        filename,
        funcname,
        (int) descr.first_line,
        (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table) ? line_table : __pyx_mstate_global->__pyx_empty_bytes
    );
done:
    Py_XDECREF(code_bytes);
    #if CYTHON_AVOID_BORROWED_REFS
    Py_XDECREF(varnames_tuple_dedup);
    #endif
    Py_DECREF(varnames_tuple);
    return code_obj;
}

/* DecompressString */
static PyObject *__Pyx_DecompressString(const char *s, Py_ssize_t length, int algo) {
    PyObject *module = NULL, *decompress, *compressed_bytes, *decompressed;
    const char* module_name = algo == 3 ? "compression.zstd" : algo == 2 ? "bz2" : "zlib";
    PyObject *methodname = PyUnicode_FromString("decompress");
    if (unlikely(!methodname)) return NULL;
    #if __PYX_LIMITED_VERSION_HEX >= 0x030e0000
    if (algo == 3) {
        PyObject *fromlist = Py_BuildValue("[O]", methodname);
        if (unlikely(!fromlist)) goto bad;
        module = PyImport_ImportModuleLevel("compression.zstd", NULL, NULL, fromlist, 0);
        Py_DECREF(fromlist);
    } else
    #endif
        module = PyImport_ImportModule(module_name);
    if (unlikely(!module)) goto import_failed;
    decompress = PyObject_GetAttr(module, methodname);
    if (unlikely(!decompress)) goto import_failed;
    {
        #ifdef __cplusplus
            char *memview_bytes = const_cast<char*>(s);
        #else
            #if defined(__clang__)
              #pragma clang diagnostic push
              #pragma clang diagnostic ignored "-Wcast-qual"
            #elif !defined(__INTEL_COMPILER) && defined(__GNUC__)
              #pragma GCC diagnostic push
              #pragma GCC diagnostic ignored "-Wcast-qual"
            #endif
            char *memview_bytes = (char*) s;
            #if defined(__clang__)
              #pragma clang diagnostic pop
            #elif !defined(__INTEL_COMPILER) && defined(__GNUC__)
              #pragma GCC diagnostic pop
            #endif
        #endif
        #if CYTHON_COMPILING_IN_LIMITED_API && !defined(PyBUF_READ)
        int memview_flags = 0x100;
        #else
        int memview_flags = PyBUF_READ;
        #endif
        compressed_bytes = PyMemoryView_FromMemory(memview_bytes, length, memview_flags);
    }
    if (unlikely(!compressed_bytes)) {
        Py_DECREF(decompress);
        goto bad;
    }
    decompressed = PyObject_CallFunctionObjArgs(decompress, compressed_bytes, NULL);
    Py_DECREF(compressed_bytes);
    Py_DECREF(decompress);
    Py_DECREF(module);
    Py_DECREF(methodname);
    return decompressed;
import_failed:
    PyErr_Format(PyExc_ImportError,
        "Failed to import '%.20s.decompress' - cannot initialise module strings. "
        "String compression was configured with the C macro 'CYTHON_COMPRESS_STRINGS=%d'.",
        module_name, algo);
bad:
    Py_XDECREF(module);
    Py_DECREF(methodname);
    return NULL;
}

#include <string.h>
static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s) {
    size_t len = strlen(s);
    if (unlikely(len > (size_t) PY_SSIZE_T_MAX)) {
        PyErr_SetString(PyExc_OverflowError, "byte string is too long");
        return -1;
    }
    return (Py_ssize_t) len;
}
static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) {
    Py_ssize_t len = __Pyx_ssize_strlen(c_str);
    if (unlikely(len < 0)) return NULL;
    return __Pyx_PyUnicode_FromStringAndSize(c_str, len);
}
static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char* c_str) {
    Py_ssize_t len = __Pyx_ssize_strlen(c_str);
    if (unlikely(len < 0)) return NULL;
    return PyByteArray_FromStringAndSize(c_str, len);
}
static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject* o) {
    Py_ssize_t ignore;
    return __Pyx_PyObject_AsStringAndSize(o, &ignore);
}
#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8
static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) {
    if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL;
#if CYTHON_COMPILING_IN_LIMITED_API
    {
        const char* result;
        Py_ssize_t unicode_length;
        CYTHON_MAYBE_UNUSED_VAR(unicode_length); // only for __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
        #if __PYX_LIMITED_VERSION_HEX < 0x030A0000
        if (unlikely(PyArg_Parse(o, "s#", &result, length) < 0)) return NULL;
        #else
        result = PyUnicode_AsUTF8AndSize(o, length);
        #endif
        #if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
        unicode_length = PyUnicode_GetLength(o);
        if (unlikely(unicode_length < 0)) return NULL;
        if (unlikely(unicode_length != *length)) {
            PyUnicode_AsASCIIString(o);
            return NULL;
        }
        #endif
        return result;
    }
#else
#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII
    if (likely(PyUnicode_IS_ASCII(o))) {
        *length = PyUnicode_GET_LENGTH(o);
        return PyUnicode_AsUTF8(o);
    } else {
        PyUnicode_AsASCIIString(o);
        return NULL;
    }
#else
    return PyUnicode_AsUTF8AndSize(o, length);
#endif
#endif
}
#endif
static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject* o, Py_ssize_t *length) {
#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_UTF8
    if (PyUnicode_Check(o)) {
        return __Pyx_PyUnicode_AsStringAndSize(o, length);
    } else
#endif
    if (PyByteArray_Check(o)) {
#if (CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) || (CYTHON_COMPILING_IN_PYPY && (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE)))
        *length = PyByteArray_GET_SIZE(o);
        return PyByteArray_AS_STRING(o);
#else
        *length = PyByteArray_Size(o);
        if (*length == -1) return NULL;
        return PyByteArray_AsString(o);
#endif
    } else
    {
        char* result;
        int r = PyBytes_AsStringAndSize(o, &result, length);
        if (unlikely(r < 0)) {
            return NULL;
        } else {
            return result;
        }
    }
}
static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) {
   int is_true = x == Py_True;
   if (is_true | (x == Py_False) | (x == Py_None)) return is_true;
   else return PyObject_IsTrue(x);
}
static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject* x) {
    int retval;
    if (unlikely(!x)) return -1;
    retval = __Pyx_PyObject_IsTrue(x);
    Py_DECREF(x);
    return retval;
}
static PyObject* __Pyx_PyNumber_LongWrongResultType(PyObject* result) {
    __Pyx_TypeName result_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(result));
    if (PyLong_Check(result)) {
        if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1,
                "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ").  "
                "The ability to return an instance of a strict subclass of int is deprecated, "
                "and may be removed in a future version of Python.",
                result_type_name)) {
            __Pyx_DECREF_TypeName(result_type_name);
            Py_DECREF(result);
            return NULL;
        }
        __Pyx_DECREF_TypeName(result_type_name);
        return result;
    }
    PyErr_Format(PyExc_TypeError,
                 "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ")",
                 result_type_name);
    __Pyx_DECREF_TypeName(result_type_name);
    Py_DECREF(result);
    return NULL;
}
static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x) {
#if CYTHON_USE_TYPE_SLOTS
  PyNumberMethods *m;
#endif
  PyObject *res = NULL;
  if (likely(PyLong_Check(x)))
      return __Pyx_NewRef(x);
#if CYTHON_USE_TYPE_SLOTS
  m = Py_TYPE(x)->tp_as_number;
  if (likely(m && m->nb_int)) {
      res = m->nb_int(x);
  }
#else
  if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) {
      res = PyNumber_Long(x);
  }
#endif
  if (likely(res)) {
      if (unlikely(!PyLong_CheckExact(res))) {
          return __Pyx_PyNumber_LongWrongResultType(res);
      }
  }
  else if (!PyErr_Occurred()) {
      PyErr_SetString(PyExc_TypeError,
                      "an integer is required");
  }
  return res;
}
static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) {
  Py_ssize_t ival;
  PyObject *x;
  if (likely(PyLong_CheckExact(b))) {
    #if CYTHON_USE_PYLONG_INTERNALS
    if (likely(__Pyx_PyLong_IsCompact(b))) {
        return __Pyx_PyLong_CompactValue(b);
    } else {
      const digit* digits = __Pyx_PyLong_Digits(b);
      const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(b);
      switch (size) {
         case 2:
           if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) {
             return (Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
         case -2:
           if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) {
             return -(Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
         case 3:
           if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) {
             return (Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
         case -3:
           if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) {
             return -(Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
         case 4:
           if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) {
             return (Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
         case -4:
           if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) {
             return -(Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0]));
           }
           break;
      }
    }
    #endif
    return PyLong_AsSsize_t(b);
  }
  x = PyNumber_Index(b);
  if (!x) return -1;
  ival = PyLong_AsSsize_t(x);
  Py_DECREF(x);
  return ival;
}
static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject* o) {
  if (sizeof(Py_hash_t) == sizeof(Py_ssize_t)) {
    return (Py_hash_t) __Pyx_PyIndex_AsSsize_t(o);
  } else {
    Py_ssize_t ival;
    PyObject *x;
    x = PyNumber_Index(o);
    if (!x) return -1;
    ival = PyLong_AsLong(x);
    Py_DECREF(x);
    return ival;
  }
}
static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b) {
    CYTHON_UNUSED_VAR(b);
    return __Pyx_NewRef(Py_None);
}
static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) {
  return __Pyx_NewRef(b ? Py_True: Py_False);
}
static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t ival) {
    return PyLong_FromSize_t(ival);
}


/* MultiPhaseInitModuleState */
#if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE
#ifndef CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
#if (CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX >= 0x030C0000)
  #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 1
#else
  #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 0
#endif
#endif
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE && !CYTHON_ATOMICS
#error "Module state with PEP489 requires atomics. Currently that's one of\
 C11, C++11, gcc atomic intrinsics or MSVC atomic intrinsics"
#endif
#if !CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
#define __Pyx_ModuleStateLookup_Lock()
#define __Pyx_ModuleStateLookup_Unlock()
#elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000
static PyMutex __Pyx_ModuleStateLookup_mutex = {0};
#define __Pyx_ModuleStateLookup_Lock() PyMutex_Lock(&__Pyx_ModuleStateLookup_mutex)
#define __Pyx_ModuleStateLookup_Unlock() PyMutex_Unlock(&__Pyx_ModuleStateLookup_mutex)
#elif defined(__cplusplus) && __cplusplus >= 201103L
#include <mutex>
static std::mutex __Pyx_ModuleStateLookup_mutex;
#define __Pyx_ModuleStateLookup_Lock() __Pyx_ModuleStateLookup_mutex.lock()
#define __Pyx_ModuleStateLookup_Unlock() __Pyx_ModuleStateLookup_mutex.unlock()
#elif defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201112L) && !defined(__STDC_NO_THREADS__)
#include <threads.h>
static mtx_t __Pyx_ModuleStateLookup_mutex;
static once_flag __Pyx_ModuleStateLookup_mutex_once_flag = ONCE_FLAG_INIT;
static void __Pyx_ModuleStateLookup_initialize_mutex(void) {
    mtx_init(&__Pyx_ModuleStateLookup_mutex, mtx_plain);
}
#define __Pyx_ModuleStateLookup_Lock()\
  call_once(&__Pyx_ModuleStateLookup_mutex_once_flag, __Pyx_ModuleStateLookup_initialize_mutex);\
  mtx_lock(&__Pyx_ModuleStateLookup_mutex)
#define __Pyx_ModuleStateLookup_Unlock() mtx_unlock(&__Pyx_ModuleStateLookup_mutex)
#elif defined(HAVE_PTHREAD_H)
#include <pthread.h>
static pthread_mutex_t __Pyx_ModuleStateLookup_mutex = PTHREAD_MUTEX_INITIALIZER;
#define __Pyx_ModuleStateLookup_Lock() pthread_mutex_lock(&__Pyx_ModuleStateLookup_mutex)
#define __Pyx_ModuleStateLookup_Unlock() pthread_mutex_unlock(&__Pyx_ModuleStateLookup_mutex)
#elif defined(_WIN32)
#include <Windows.h>  // synchapi.h on its own doesn't work
static SRWLOCK __Pyx_ModuleStateLookup_mutex = SRWLOCK_INIT;
#define __Pyx_ModuleStateLookup_Lock() AcquireSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex)
#define __Pyx_ModuleStateLookup_Unlock() ReleaseSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex)
#else
#error "No suitable lock available for CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE.\
 Requires C standard >= C11, or C++ standard >= C++11,\
 or pthreads, or the Windows 32 API, or Python >= 3.13."
#endif
typedef struct {
    int64_t id;
    PyObject *module;
} __Pyx_InterpreterIdAndModule;
typedef struct {
    char interpreter_id_as_index;
    Py_ssize_t count;
    Py_ssize_t allocated;
    __Pyx_InterpreterIdAndModule table[1];
} __Pyx_ModuleStateLookupData;
#define __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE 32
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
static __pyx_atomic_int_type __Pyx_ModuleStateLookup_read_counter = 0;
#endif
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
static __pyx_atomic_ptr_type __Pyx_ModuleStateLookup_data = 0;
#else
static __Pyx_ModuleStateLookupData* __Pyx_ModuleStateLookup_data = NULL;
#endif
static __Pyx_InterpreterIdAndModule* __Pyx_State_FindModuleStateLookupTableLowerBound(
        __Pyx_InterpreterIdAndModule* table,
        Py_ssize_t count,
        int64_t interpreterId) {
    __Pyx_InterpreterIdAndModule* begin = table;
    __Pyx_InterpreterIdAndModule* end = begin + count;
    if (begin->id == interpreterId) {
        return begin;
    }
    while ((end - begin) > __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) {
        __Pyx_InterpreterIdAndModule* halfway = begin + (end - begin)/2;
        if (halfway->id == interpreterId) {
            return halfway;
        }
        if (halfway->id < interpreterId) {
            begin = halfway;
        } else {
            end = halfway;
        }
    }
    for (; begin < end; ++begin) {
        if (begin->id >= interpreterId) return begin;
    }
    return begin;
}
static PyObject *__Pyx_State_FindModule(CYTHON_UNUSED void* dummy) {
    int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get());
    if (interpreter_id == -1) return NULL;
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
    __Pyx_ModuleStateLookupData* data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data);
    {
        __pyx_atomic_incr_acq_rel(&__Pyx_ModuleStateLookup_read_counter);
        if (likely(data)) {
            __Pyx_ModuleStateLookupData* new_data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_acquire(&__Pyx_ModuleStateLookup_data);
            if (likely(data == new_data)) {
                goto read_finished;
            }
        }
        __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter);
        __Pyx_ModuleStateLookup_Lock();
        __pyx_atomic_incr_relaxed(&__Pyx_ModuleStateLookup_read_counter);
        data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data);
        __Pyx_ModuleStateLookup_Unlock();
    }
  read_finished:;
#else
    __Pyx_ModuleStateLookupData* data = __Pyx_ModuleStateLookup_data;
#endif
    __Pyx_InterpreterIdAndModule* found = NULL;
    if (unlikely(!data)) goto end;
    if (data->interpreter_id_as_index) {
        if (interpreter_id < data->count) {
            found = data->table+interpreter_id;
        }
    } else {
        found = __Pyx_State_FindModuleStateLookupTableLowerBound(
            data->table, data->count, interpreter_id);
    }
  end:
    {
        PyObject *result=NULL;
        if (found && found->id == interpreter_id) {
            result = found->module;
        }
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
        __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter);
#endif
        return result;
    }
}
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
static void __Pyx_ModuleStateLookup_wait_until_no_readers(void) {
    while (__pyx_atomic_load(&__Pyx_ModuleStateLookup_read_counter) != 0);
}
#else
#define __Pyx_ModuleStateLookup_wait_until_no_readers()
#endif
static int __Pyx_State_AddModuleInterpIdAsIndex(__Pyx_ModuleStateLookupData **old_data, PyObject* module, int64_t interpreter_id) {
    Py_ssize_t to_allocate = (*old_data)->allocated;
    while (to_allocate <= interpreter_id) {
        if (to_allocate == 0) to_allocate = 1;
        else to_allocate *= 2;
    }
    __Pyx_ModuleStateLookupData *new_data = *old_data;
    if (to_allocate != (*old_data)->allocated) {
         new_data = (__Pyx_ModuleStateLookupData *)realloc(
            *old_data,
            sizeof(__Pyx_ModuleStateLookupData)+(to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule));
        if (!new_data) {
            PyErr_NoMemory();
            return -1;
        }
        for (Py_ssize_t i = new_data->allocated; i < to_allocate; ++i) {
            new_data->table[i].id = i;
            new_data->table[i].module = NULL;
        }
        new_data->allocated = to_allocate;
    }
    new_data->table[interpreter_id].module = module;
    if (new_data->count < interpreter_id+1) {
        new_data->count = interpreter_id+1;
    }
    *old_data = new_data;
    return 0;
}
static void __Pyx_State_ConvertFromInterpIdAsIndex(__Pyx_ModuleStateLookupData *data) {
    __Pyx_InterpreterIdAndModule *read = data->table;
    __Pyx_InterpreterIdAndModule *write = data->table;
    __Pyx_InterpreterIdAndModule *end = read + data->count;
    for (; read<end; ++read) {
        if (read->module) {
            write->id = read->id;
            write->module = read->module;
            ++write;
        }
    }
    data->count = write - data->table;
    for (; write<end; ++write) {
        write->id = 0;
        write->module = NULL;
    }
    data->interpreter_id_as_index = 0;
}
static int __Pyx_State_AddModule(PyObject* module, CYTHON_UNUSED void* dummy) {
    int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get());
    if (interpreter_id == -1) return -1;
    int result = 0;
    __Pyx_ModuleStateLookup_Lock();
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
    __Pyx_ModuleStateLookupData *old_data = (__Pyx_ModuleStateLookupData *)
            __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0);
#else
    __Pyx_ModuleStateLookupData *old_data = __Pyx_ModuleStateLookup_data;
#endif
    __Pyx_ModuleStateLookupData *new_data = old_data;
    if (!new_data) {
        new_data = (__Pyx_ModuleStateLookupData *)calloc(1, sizeof(__Pyx_ModuleStateLookupData));
        if (!new_data) {
            result = -1;
            PyErr_NoMemory();
            goto end;
        }
        new_data->allocated = 1;
        new_data->interpreter_id_as_index = 1;
    }
    __Pyx_ModuleStateLookup_wait_until_no_readers();
    if (new_data->interpreter_id_as_index) {
        if (interpreter_id < __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) {
            result = __Pyx_State_AddModuleInterpIdAsIndex(&new_data, module, interpreter_id);
            goto end;
        }
        __Pyx_State_ConvertFromInterpIdAsIndex(new_data);
    }
    {
        Py_ssize_t insert_at = 0;
        {
            __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound(
                new_data->table, new_data->count, interpreter_id);
            assert(lower_bound);
            insert_at = lower_bound - new_data->table;
            if (unlikely(insert_at < new_data->count && lower_bound->id == interpreter_id)) {
                lower_bound->module = module;
                goto end;  // already in table, nothing more to do
            }
        }
        if (new_data->count+1 >= new_data->allocated) {
            Py_ssize_t to_allocate = (new_data->count+1)*2;
            new_data =
                (__Pyx_ModuleStateLookupData*)realloc(
                    new_data,
                    sizeof(__Pyx_ModuleStateLookupData) +
                    (to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule));
            if (!new_data) {
                result = -1;
                new_data = old_data;
                PyErr_NoMemory();
                goto end;
            }
            new_data->allocated = to_allocate;
        }
        ++new_data->count;
        int64_t last_id = interpreter_id;
        PyObject *last_module = module;
        for (Py_ssize_t i=insert_at; i<new_data->count; ++i) {
            int64_t current_id = new_data->table[i].id;
            new_data->table[i].id = last_id;
            last_id = current_id;
            PyObject *current_module = new_data->table[i].module;
            new_data->table[i].module = last_module;
            last_module = current_module;
        }
    }
  end:
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
    __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, new_data);
#else
    __Pyx_ModuleStateLookup_data = new_data;
#endif
    __Pyx_ModuleStateLookup_Unlock();
    return result;
}
static int __Pyx_State_RemoveModule(CYTHON_UNUSED void* dummy) {
    int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get());
    if (interpreter_id == -1) return -1;
    __Pyx_ModuleStateLookup_Lock();
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
    __Pyx_ModuleStateLookupData *data = (__Pyx_ModuleStateLookupData *)
            __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0);
#else
    __Pyx_ModuleStateLookupData *data = __Pyx_ModuleStateLookup_data;
#endif
    if (data->interpreter_id_as_index) {
        if (interpreter_id < data->count) {
            data->table[interpreter_id].module = NULL;
        }
        goto done;
    }
    {
        __Pyx_ModuleStateLookup_wait_until_no_readers();
        __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound(
            data->table, data->count, interpreter_id);
        if (!lower_bound) goto done;
        if (lower_bound->id != interpreter_id) goto done;
        __Pyx_InterpreterIdAndModule *end = data->table+data->count;
        for (;lower_bound<end-1; ++lower_bound) {
            lower_bound->id = (lower_bound+1)->id;
            lower_bound->module = (lower_bound+1)->module;
        }
    }
    --data->count;
    if (data->count == 0) {
        free(data);
        data = NULL;
    }
  done:
#if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE
    __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, data);
#else
    __Pyx_ModuleStateLookup_data = data;
#endif
    __Pyx_ModuleStateLookup_Unlock();
    return 0;
}
#endif

/* #### Code section: utility_code_pragmas_end ### */
#ifdef _MSC_VER
#pragma warning( pop )
#endif



/* #### Code section: end ### */
#endif /* Py_PYTHON_H */
