diff --git a/.gitignore b/.gitignore
index fdaa75feb6fbffb716f6f0f874b635e79c42ac71..c3b54ab8559fc61fe2007a69e2a03f0d47434f52 100644
--- a/.gitignore
+++ b/.gitignore
@@ -35,3 +35,4 @@ hpvm/llvm-*.src.tar.xz
 hpvm/llvm-*.src/
 hpvm/projects/hpvm-rt/hpvm-rt.ll
 hpvm/test/**/build/
+Makefile.config
diff --git a/hpvm/test/hpvm-cava/.gitignore b/hpvm/test/hpvm-cava/.gitignore
index f08b880bf9b4b8171e9fb878bea3a6d266a1f9c0..ce3de54715a221ee11890e27dd743ed2ed9853d5 100644
--- a/hpvm/test/hpvm-cava/.gitignore
+++ b/hpvm/test/hpvm-cava/.gitignore
@@ -4,3 +4,5 @@ Makefile.config
 
 example-face/*.bin
 example-face/*.png
+scripts/cmodule.py
+scripts/gamut_map_wrap.cc
diff --git a/hpvm/test/hpvm-cava/Makefile.config b/hpvm/test/hpvm-cava/Makefile.config
deleted file mode 100644
index 1bdb62dec493fc63e581ae8204ea736c45ed5f7d..0000000000000000000000000000000000000000
--- a/hpvm/test/hpvm-cava/Makefile.config
+++ /dev/null
@@ -1,25 +0,0 @@
-CUDA_PATH=/software/cuda-9.1
-CUDA_LIB_PATH=$(CUDA_PATH)/lib64
-OPENCL_PATH=/software/cuda-9.1
-OPENCL_LIB_PATH=$(OPENCL_PATH)/lib64
-
-LLVM_SRC_ROOT=/home/aejjeh/work_dir/hpvm-reorg-9-temp/hpvm/llvm/
-
-LLVM_BUILD_DIR =$(LLVM_SRC_ROOT)/../build
-CC = $(LLVM_BUILD_DIR)/bin/clang
-PLATFORM_CFLAGS = -I$(LLVM_SRC_ROOT)/include -I$(OPENCL_PATH)/include/CL/ -I../include -I$(LLVM_BUILD_DIR)/include
-OCLBE = $(LLVM_BUILD_DIR)/bin/llvm-cbe
-
-CXX = $(LLVM_BUILD_DIR)/bin/clang++
-PLATFORM_CXXFLAGS = -I$(LLVM_SRC_ROOT)/include -I$(OPENCL_PATH)/include/CL/ -I../include -I$(LLVM_BUILD_DIR)/include
-
-LINKER = $(LLVM_BUILD_DIR)/bin/clang++
-PLATFORM_LDFLAGS = -lm -lpthread -lrt -lOpenCL -L$(OPENCL_LIB_PATH)
-
-LLVM_LIB_PATH = $(LLVM_BUILD_DIR)/lib
-LLVM_BIN_PATH = $(LLVM_BUILD_DIR)/bin
-
-OPT = $(LLVM_BIN_PATH)/opt
-LLVM_LINK = $(LLVM_BIN_PATH)/llvm-link
-LLVM_AS = $(LLVM_BIN_PATH)/llvm-as
-LIT = $(LLVM_BIN_PATH)/llvm-lit
\ No newline at end of file
diff --git a/hpvm/test/hpvm-cava/scripts/cmodule.py b/hpvm/test/hpvm-cava/scripts/cmodule.py
deleted file mode 100644
index 41b5d84e2e6b00e9ef569bb7f15fd07d41dc54a5..0000000000000000000000000000000000000000
--- a/hpvm/test/hpvm-cava/scripts/cmodule.py
+++ /dev/null
@@ -1,99 +0,0 @@
-# This file was automatically generated by SWIG (http://www.swig.org).
-# Version 3.0.8
-#
-# Do not make changes to this file unless you know what you are doing--modify
-# the SWIG interface file instead.
-
-
-
-
-
-from sys import version_info
-if version_info >= (2, 6, 0):
-    def swig_import_helper():
-        from os.path import dirname
-        import imp
-        fp = None
-        try:
-            fp, pathname, description = imp.find_module('_cmodule', [dirname(__file__)])
-        except ImportError:
-            import _cmodule
-            return _cmodule
-        if fp is not None:
-            try:
-                _mod = imp.load_module('_cmodule', fp, pathname, description)
-            finally:
-                fp.close()
-            return _mod
-    _cmodule = swig_import_helper()
-    del swig_import_helper
-else:
-    import _cmodule
-del version_info
-try:
-    _swig_property = property
-except NameError:
-    pass  # Python < 2.2 doesn't have 'property'.
-
-
-def _swig_setattr_nondynamic(self, class_type, name, value, static=1):
-    if (name == "thisown"):
-        return self.this.own(value)
-    if (name == "this"):
-        if type(value).__name__ == 'SwigPyObject':
-            self.__dict__[name] = value
-            return
-    method = class_type.__swig_setmethods__.get(name, None)
-    if method:
-        return method(self, value)
-    if (not static):
-        if _newclass:
-            object.__setattr__(self, name, value)
-        else:
-            self.__dict__[name] = value
-    else:
-        raise AttributeError("You cannot add attributes to %s" % self)
-
-
-def _swig_setattr(self, class_type, name, value):
-    return _swig_setattr_nondynamic(self, class_type, name, value, 0)
-
-
-def _swig_getattr_nondynamic(self, class_type, name, static=1):
-    if (name == "thisown"):
-        return self.this.own()
-    method = class_type.__swig_getmethods__.get(name, None)
-    if method:
-        return method(self)
-    if (not static):
-        return object.__getattr__(self, name)
-    else:
-        raise AttributeError(name)
-
-def _swig_getattr(self, class_type, name):
-    return _swig_getattr_nondynamic(self, class_type, name, 0)
-
-
-def _swig_repr(self):
-    try:
-        strthis = "proxy of " + self.this.__repr__()
-    except Exception:
-        strthis = ""
-    return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)
-
-try:
-    _object = object
-    _newclass = 1
-except AttributeError:
-    class _object:
-        pass
-    _newclass = 0
-
-
-
-def gamut_map(*args):
-    return _cmodule.gamut_map(*args)
-gamut_map = _cmodule.gamut_map
-# This file is compatible with both classic and new-style classes.
-
-
diff --git a/hpvm/test/hpvm-cava/scripts/gamut_map_wrap.cc b/hpvm/test/hpvm-cava/scripts/gamut_map_wrap.cc
deleted file mode 100644
index a9efa8ff6e7e312cc46cae3442597d4faca16130..0000000000000000000000000000000000000000
--- a/hpvm/test/hpvm-cava/scripts/gamut_map_wrap.cc
+++ /dev/null
@@ -1,4844 +0,0 @@
-/* ----------------------------------------------------------------------------
- * This file was automatically generated by SWIG (http://www.swig.org).
- * Version 3.0.8
- *
- * This file is not intended to be easily readable and contains a number of
- * coding conventions designed to improve portability and efficiency. Do not
- * make changes to this file unless you know what you are doing--modify the SWIG
- * interface file instead.
- * -----------------------------------------------------------------------------
- */
-
-#ifndef SWIGPYTHON
-#define SWIGPYTHON
-#endif
-
-#define SWIG_PYTHON_DIRECTOR_NO_VTABLE
-
-/* -----------------------------------------------------------------------------
- *  This section contains generic SWIG labels for method/variable
- *  declarations/attributes, and other compiler dependent labels.
- * -----------------------------------------------------------------------------
- */
-
-/* template workaround for compilers that cannot correctly implement the C++
- * standard */
-#ifndef SWIGTEMPLATEDISAMBIGUATOR
-#if defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x560)
-#define SWIGTEMPLATEDISAMBIGUATOR template
-#elif defined(__HP_aCC)
-/* Needed even with `aCC -AA' when `aCC -V' reports HP ANSI C++ B3910B A.03.55
- */
-/* If we find a maximum version that requires this, the test would be __HP_aCC
- * <= 35500 for A.03.55 */
-#define SWIGTEMPLATEDISAMBIGUATOR template
-#else
-#define SWIGTEMPLATEDISAMBIGUATOR
-#endif
-#endif
-
-/* inline attribute */
-#ifndef SWIGINLINE
-#if defined(__cplusplus) || (defined(__GNUC__) && !defined(__STRICT_ANSI__))
-#define SWIGINLINE inline
-#else
-#define SWIGINLINE
-#endif
-#endif
-
-/* attribute recognised by some compilers to avoid 'unused' warnings */
-#ifndef SWIGUNUSED
-#if defined(__GNUC__)
-#if !(defined(__cplusplus)) ||                                                 \
-    (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
-#define SWIGUNUSED __attribute__((__unused__))
-#else
-#define SWIGUNUSED
-#endif
-#elif defined(__ICC)
-#define SWIGUNUSED __attribute__((__unused__))
-#else
-#define SWIGUNUSED
-#endif
-#endif
-
-#ifndef SWIG_MSC_UNSUPPRESS_4505
-#if defined(_MSC_VER)
-#pragma warning(                                                               \
-    disable : 4505) /* unreferenced local function has been removed */
-#endif
-#endif
-
-#ifndef SWIGUNUSEDPARM
-#ifdef __cplusplus
-#define SWIGUNUSEDPARM(p)
-#else
-#define SWIGUNUSEDPARM(p) p SWIGUNUSED
-#endif
-#endif
-
-/* internal SWIG method */
-#ifndef SWIGINTERN
-#define SWIGINTERN static SWIGUNUSED
-#endif
-
-/* internal inline SWIG method */
-#ifndef SWIGINTERNINLINE
-#define SWIGINTERNINLINE SWIGINTERN SWIGINLINE
-#endif
-
-/* exporting methods */
-#if (__GNUC__ >= 4) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)
-#ifndef GCC_HASCLASSVISIBILITY
-#define GCC_HASCLASSVISIBILITY
-#endif
-#endif
-
-#ifndef SWIGEXPORT
-#if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
-#if defined(STATIC_LINKED)
-#define SWIGEXPORT
-#else
-#define SWIGEXPORT __declspec(dllexport)
-#endif
-#else
-#if defined(__GNUC__) && defined(GCC_HASCLASSVISIBILITY)
-#define SWIGEXPORT __attribute__((visibility("default")))
-#else
-#define SWIGEXPORT
-#endif
-#endif
-#endif
-
-/* calling conventions for Windows */
-#ifndef SWIGSTDCALL
-#if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
-#define SWIGSTDCALL __stdcall
-#else
-#define SWIGSTDCALL
-#endif
-#endif
-
-/* Deal with Microsoft's attempt at deprecating C standard runtime functions */
-#if !defined(SWIG_NO_CRT_SECURE_NO_DEPRECATE) && defined(_MSC_VER) &&          \
-    !defined(_CRT_SECURE_NO_DEPRECATE)
-#define _CRT_SECURE_NO_DEPRECATE
-#endif
-
-/* Deal with Microsoft's attempt at deprecating methods in the standard C++
- * library */
-#if !defined(SWIG_NO_SCL_SECURE_NO_DEPRECATE) && defined(_MSC_VER) &&          \
-    !defined(_SCL_SECURE_NO_DEPRECATE)
-#define _SCL_SECURE_NO_DEPRECATE
-#endif
-
-/* Deal with Apple's deprecated 'AssertMacros.h' from Carbon-framework */
-#if defined(__APPLE__) &&                                                      \
-    !defined(__ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES)
-#define __ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES 0
-#endif
-
-/* Intel's compiler complains if a variable which was never initialised is
- * cast to void, which is a common idiom which we use to indicate that we
- * are aware a variable isn't used.  So we just silence that warning.
- * See: https://github.com/swig/swig/issues/192 for more discussion.
- */
-#ifdef __INTEL_COMPILER
-#pragma warning disable 592
-#endif
-
-#if defined(_DEBUG) && defined(SWIG_PYTHON_INTERPRETER_NO_DEBUG)
-/* Use debug wrappers with the Python release dll */
-#undef _DEBUG
-#include <Python.h>
-#define _DEBUG
-#else
-#include <Python.h>
-#endif
-
-/* -----------------------------------------------------------------------------
- * swigrun.swg
- *
- * This file contains generic C API SWIG runtime support for pointer
- * type checking.
- * -----------------------------------------------------------------------------
- */
-
-/* This should only be incremented when either the layout of swig_type_info
-   changes, or for whatever reason, the runtime changes incompatibly */
-#define SWIG_RUNTIME_VERSION "4"
-
-/* define SWIG_TYPE_TABLE_NAME as "SWIG_TYPE_TABLE" */
-#ifdef SWIG_TYPE_TABLE
-#define SWIG_QUOTE_STRING(x) #x
-#define SWIG_EXPAND_AND_QUOTE_STRING(x) SWIG_QUOTE_STRING(x)
-#define SWIG_TYPE_TABLE_NAME SWIG_EXPAND_AND_QUOTE_STRING(SWIG_TYPE_TABLE)
-#else
-#define SWIG_TYPE_TABLE_NAME
-#endif
-
-/*
-  You can use the SWIGRUNTIME and SWIGRUNTIMEINLINE macros for
-  creating a static or dynamic library from the SWIG runtime code.
-  In 99.9% of the cases, SWIG just needs to declare them as 'static'.
-
-  But only do this if strictly necessary, ie, if you have problems
-  with your compiler or suchlike.
-*/
-
-#ifndef SWIGRUNTIME
-#define SWIGRUNTIME SWIGINTERN
-#endif
-
-#ifndef SWIGRUNTIMEINLINE
-#define SWIGRUNTIMEINLINE SWIGRUNTIME SWIGINLINE
-#endif
-
-/*  Generic buffer size */
-#ifndef SWIG_BUFFER_SIZE
-#define SWIG_BUFFER_SIZE 1024
-#endif
-
-/* Flags for pointer conversions */
-#define SWIG_POINTER_DISOWN 0x1
-#define SWIG_CAST_NEW_MEMORY 0x2
-
-/* Flags for new pointer objects */
-#define SWIG_POINTER_OWN 0x1
-
-/*
-   Flags/methods for returning states.
-
-   The SWIG conversion methods, as ConvertPtr, return an integer
-   that tells if the conversion was successful or not. And if not,
-   an error code can be returned (see swigerrors.swg for the codes).
-
-   Use the following macros/flags to set or process the returning
-   states.
-
-   In old versions of SWIG, code such as the following was usually written:
-
-     if (SWIG_ConvertPtr(obj,vptr,ty.flags) != -1) {
-       // success code
-     } else {
-       //fail code
-     }
-
-   Now you can be more explicit:
-
-    int res = SWIG_ConvertPtr(obj,vptr,ty.flags);
-    if (SWIG_IsOK(res)) {
-      // success code
-    } else {
-      // fail code
-    }
-
-   which is the same really, but now you can also do
-
-    Type *ptr;
-    int res = SWIG_ConvertPtr(obj,(void **)(&ptr),ty.flags);
-    if (SWIG_IsOK(res)) {
-      // success code
-      if (SWIG_IsNewObj(res) {
-        ...
-        delete *ptr;
-      } else {
-        ...
-      }
-    } else {
-      // fail code
-    }
-
-   I.e., now SWIG_ConvertPtr can return new objects and you can
-   identify the case and take care of the deallocation. Of course that
-   also requires SWIG_ConvertPtr to return new result values, such as
-
-      int SWIG_ConvertPtr(obj, ptr,...) {
-        if (<obj is ok>) {
-          if (<need new object>) {
-            *ptr = <ptr to new allocated object>;
-            return SWIG_NEWOBJ;
-          } else {
-            *ptr = <ptr to old object>;
-            return SWIG_OLDOBJ;
-          }
-        } else {
-          return SWIG_BADOBJ;
-        }
-      }
-
-   Of course, returning the plain '0(success)/-1(fail)' still works, but you can
-   be more explicit by returning SWIG_BADOBJ, SWIG_ERROR or any of the SWIG
-   errors code.
-
-   Finally, if the SWIG_CASTRANK_MODE is enabled, the result code
-   allows to return the 'cast rank', for example, if you have this
-
-       int food(double)
-       int fooi(int);
-
-   and you call
-
-      food(1)   // cast rank '1'  (1 -> 1.0)
-      fooi(1)   // cast rank '0'
-
-   just use the SWIG_AddCast()/SWIG_CheckState()
-*/
-
-#define SWIG_OK (0)
-#define SWIG_ERROR (-1)
-#define SWIG_IsOK(r) (r >= 0)
-#define SWIG_ArgError(r) ((r != SWIG_ERROR) ? r : SWIG_TypeError)
-
-/* The CastRankLimit says how many bits are used for the cast rank */
-#define SWIG_CASTRANKLIMIT (1 << 8)
-/* The NewMask denotes the object was created (using new/malloc) */
-#define SWIG_NEWOBJMASK (SWIG_CASTRANKLIMIT << 1)
-/* The TmpMask is for in/out typemaps that use temporal objects */
-#define SWIG_TMPOBJMASK (SWIG_NEWOBJMASK << 1)
-/* Simple returning values */
-#define SWIG_BADOBJ (SWIG_ERROR)
-#define SWIG_OLDOBJ (SWIG_OK)
-#define SWIG_NEWOBJ (SWIG_OK | SWIG_NEWOBJMASK)
-#define SWIG_TMPOBJ (SWIG_OK | SWIG_TMPOBJMASK)
-/* Check, add and del mask methods */
-#define SWIG_AddNewMask(r) (SWIG_IsOK(r) ? (r | SWIG_NEWOBJMASK) : r)
-#define SWIG_DelNewMask(r) (SWIG_IsOK(r) ? (r & ~SWIG_NEWOBJMASK) : r)
-#define SWIG_IsNewObj(r) (SWIG_IsOK(r) && (r & SWIG_NEWOBJMASK))
-#define SWIG_AddTmpMask(r) (SWIG_IsOK(r) ? (r | SWIG_TMPOBJMASK) : r)
-#define SWIG_DelTmpMask(r) (SWIG_IsOK(r) ? (r & ~SWIG_TMPOBJMASK) : r)
-#define SWIG_IsTmpObj(r) (SWIG_IsOK(r) && (r & SWIG_TMPOBJMASK))
-
-/* Cast-Rank Mode */
-#if defined(SWIG_CASTRANK_MODE)
-#ifndef SWIG_TypeRank
-#define SWIG_TypeRank unsigned long
-#endif
-#ifndef SWIG_MAXCASTRANK /* Default cast allowed */
-#define SWIG_MAXCASTRANK (2)
-#endif
-#define SWIG_CASTRANKMASK ((SWIG_CASTRANKLIMIT)-1)
-#define SWIG_CastRank(r) (r & SWIG_CASTRANKMASK)
-SWIGINTERNINLINE int SWIG_AddCast(int r) {
-  return SWIG_IsOK(r)
-             ? ((SWIG_CastRank(r) < SWIG_MAXCASTRANK) ? (r + 1) : SWIG_ERROR)
-             : r;
-}
-SWIGINTERNINLINE int SWIG_CheckState(int r) {
-  return SWIG_IsOK(r) ? SWIG_CastRank(r) + 1 : 0;
-}
-#else /* no cast-rank mode */
-#define SWIG_AddCast(r) (r)
-#define SWIG_CheckState(r) (SWIG_IsOK(r) ? 1 : 0)
-#endif
-
-#include <string.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-typedef void *(*swig_converter_func)(void *, int *);
-typedef struct swig_type_info *(*swig_dycast_func)(void **);
-
-/* Structure to store information on one type */
-typedef struct swig_type_info {
-  const char *name;       /* mangled name of this type */
-  const char *str;        /* human readable name of this type */
-  swig_dycast_func dcast; /* dynamic cast function down a hierarchy */
-  struct swig_cast_info
-      *cast;        /* linked list of types that can cast into this type */
-  void *clientdata; /* language specific type data */
-  int owndata;      /* flag if the structure owns the clientdata */
-} swig_type_info;
-
-/* Structure to store a type and conversion function used for casting */
-typedef struct swig_cast_info {
-  swig_type_info *type; /* pointer to type that is equivalent to this type */
-  swig_converter_func converter; /* function to cast the void pointers */
-  struct swig_cast_info *next;   /* pointer to next cast in linked list */
-  struct swig_cast_info *prev;   /* pointer to the previous cast */
-} swig_cast_info;
-
-/* Structure used to store module information
- * Each module generates one structure like this, and the runtime collects
- * all of these structures and stores them in a circularly linked list.*/
-typedef struct swig_module_info {
-  swig_type_info **types; /* Array of pointers to swig_type_info structures that
-                             are in this module */
-  size_t size;            /* Number of types in this module */
-  struct swig_module_info
-      *next; /* Pointer to next element in circularly linked list */
-  swig_type_info *
-      *type_initial; /* Array of initially generated type structures */
-  swig_cast_info *
-      *cast_initial; /* Array of initially generated casting structures */
-  void *clientdata;  /* Language specific module data */
-} swig_module_info;
-
-/*
-  Compare two type names skipping the space characters, therefore
-  "char*" == "char *" and "Class<int>" == "Class<int >", etc.
-
-  Return 0 when the two name types are equivalent, as in
-  strncmp, but skipping ' '.
-*/
-SWIGRUNTIME int SWIG_TypeNameComp(const char *f1, const char *l1,
-                                  const char *f2, const char *l2) {
-  for (; (f1 != l1) && (f2 != l2); ++f1, ++f2) {
-    while ((*f1 == ' ') && (f1 != l1))
-      ++f1;
-    while ((*f2 == ' ') && (f2 != l2))
-      ++f2;
-    if (*f1 != *f2)
-      return (*f1 > *f2) ? 1 : -1;
-  }
-  return (int)((l1 - f1) - (l2 - f2));
-}
-
-/*
-  Check type equivalence in a name list like <name1>|<name2>|...
-  Return 0 if equal, -1 if nb < tb, 1 if nb > tb
-*/
-SWIGRUNTIME int SWIG_TypeCmp(const char *nb, const char *tb) {
-  int equiv = 1;
-  const char *te = tb + strlen(tb);
-  const char *ne = nb;
-  while (equiv != 0 && *ne) {
-    for (nb = ne; *ne; ++ne) {
-      if (*ne == '|')
-        break;
-    }
-    equiv = SWIG_TypeNameComp(nb, ne, tb, te);
-    if (*ne)
-      ++ne;
-  }
-  return equiv;
-}
-
-/*
-  Check type equivalence in a name list like <name1>|<name2>|...
-  Return 0 if not equal, 1 if equal
-*/
-SWIGRUNTIME int SWIG_TypeEquiv(const char *nb, const char *tb) {
-  return SWIG_TypeCmp(nb, tb) == 0 ? 1 : 0;
-}
-
-/*
-  Check the typename
-*/
-SWIGRUNTIME swig_cast_info *SWIG_TypeCheck(const char *c, swig_type_info *ty) {
-  if (ty) {
-    swig_cast_info *iter = ty->cast;
-    while (iter) {
-      if (strcmp(iter->type->name, c) == 0) {
-        if (iter == ty->cast)
-          return iter;
-        /* Move iter to the top of the linked list */
-        iter->prev->next = iter->next;
-        if (iter->next)
-          iter->next->prev = iter->prev;
-        iter->next = ty->cast;
-        iter->prev = 0;
-        if (ty->cast)
-          ty->cast->prev = iter;
-        ty->cast = iter;
-        return iter;
-      }
-      iter = iter->next;
-    }
-  }
-  return 0;
-}
-
-/*
-  Identical to SWIG_TypeCheck, except strcmp is replaced with a pointer
-  comparison
-*/
-SWIGRUNTIME swig_cast_info *SWIG_TypeCheckStruct(swig_type_info *from,
-                                                 swig_type_info *ty) {
-  if (ty) {
-    swig_cast_info *iter = ty->cast;
-    while (iter) {
-      if (iter->type == from) {
-        if (iter == ty->cast)
-          return iter;
-        /* Move iter to the top of the linked list */
-        iter->prev->next = iter->next;
-        if (iter->next)
-          iter->next->prev = iter->prev;
-        iter->next = ty->cast;
-        iter->prev = 0;
-        if (ty->cast)
-          ty->cast->prev = iter;
-        ty->cast = iter;
-        return iter;
-      }
-      iter = iter->next;
-    }
-  }
-  return 0;
-}
-
-/*
-  Cast a pointer up an inheritance hierarchy
-*/
-SWIGRUNTIMEINLINE void *SWIG_TypeCast(swig_cast_info *ty, void *ptr,
-                                      int *newmemory) {
-  return ((!ty) || (!ty->converter)) ? ptr : (*ty->converter)(ptr, newmemory);
-}
-
-/*
-   Dynamic pointer casting. Down an inheritance hierarchy
-*/
-SWIGRUNTIME swig_type_info *SWIG_TypeDynamicCast(swig_type_info *ty,
-                                                 void **ptr) {
-  swig_type_info *lastty = ty;
-  if (!ty || !ty->dcast)
-    return ty;
-  while (ty && (ty->dcast)) {
-    ty = (*ty->dcast)(ptr);
-    if (ty)
-      lastty = ty;
-  }
-  return lastty;
-}
-
-/*
-  Return the name associated with this type
-*/
-SWIGRUNTIMEINLINE const char *SWIG_TypeName(const swig_type_info *ty) {
-  return ty->name;
-}
-
-/*
-  Return the pretty name associated with this type,
-  that is an unmangled type name in a form presentable to the user.
-*/
-SWIGRUNTIME const char *SWIG_TypePrettyName(const swig_type_info *type) {
-  /* The "str" field contains the equivalent pretty names of the
-     type, separated by vertical-bar characters.  We choose
-     to print the last name, as it is often (?) the most
-     specific. */
-  if (!type)
-    return NULL;
-  if (type->str != NULL) {
-    const char *last_name = type->str;
-    const char *s;
-    for (s = type->str; *s; s++)
-      if (*s == '|')
-        last_name = s + 1;
-    return last_name;
-  } else
-    return type->name;
-}
-
-/*
-   Set the clientdata field for a type
-*/
-SWIGRUNTIME void SWIG_TypeClientData(swig_type_info *ti, void *clientdata) {
-  swig_cast_info *cast = ti->cast;
-  /* if (ti->clientdata == clientdata) return; */
-  ti->clientdata = clientdata;
-
-  while (cast) {
-    if (!cast->converter) {
-      swig_type_info *tc = cast->type;
-      if (!tc->clientdata) {
-        SWIG_TypeClientData(tc, clientdata);
-      }
-    }
-    cast = cast->next;
-  }
-}
-SWIGRUNTIME void SWIG_TypeNewClientData(swig_type_info *ti, void *clientdata) {
-  SWIG_TypeClientData(ti, clientdata);
-  ti->owndata = 1;
-}
-
-/*
-  Search for a swig_type_info structure only by mangled name
-  Search is a O(log #types)
-
-  We start searching at module start, and finish searching when start == end.
-  Note: if start == end at the beginning of the function, we go all the way
-  around the circular list.
-*/
-SWIGRUNTIME swig_type_info *SWIG_MangledTypeQueryModule(swig_module_info *start,
-                                                        swig_module_info *end,
-                                                        const char *name) {
-  swig_module_info *iter = start;
-  do {
-    if (iter->size) {
-      size_t l = 0;
-      size_t r = iter->size - 1;
-      do {
-        /* since l+r >= 0, we can (>> 1) instead (/ 2) */
-        size_t i = (l + r) >> 1;
-        const char *iname = iter->types[i]->name;
-        if (iname) {
-          int compare = strcmp(name, iname);
-          if (compare == 0) {
-            return iter->types[i];
-          } else if (compare < 0) {
-            if (i) {
-              r = i - 1;
-            } else {
-              break;
-            }
-          } else if (compare > 0) {
-            l = i + 1;
-          }
-        } else {
-          break; /* should never happen */
-        }
-      } while (l <= r);
-    }
-    iter = iter->next;
-  } while (iter != end);
-  return 0;
-}
-
-/*
-  Search for a swig_type_info structure for either a mangled name or a human
-  readable name. It first searches the mangled names of the types, which is a
-  O(log #types) If a type is not found it then searches the human readable
-  names, which is O(#types).
-
-  We start searching at module start, and finish searching when start == end.
-  Note: if start == end at the beginning of the function, we go all the way
-  around the circular list.
-*/
-SWIGRUNTIME swig_type_info *SWIG_TypeQueryModule(swig_module_info *start,
-                                                 swig_module_info *end,
-                                                 const char *name) {
-  /* STEP 1: Search the name field using binary search */
-  swig_type_info *ret = SWIG_MangledTypeQueryModule(start, end, name);
-  if (ret) {
-    return ret;
-  } else {
-    /* STEP 2: If the type hasn't been found, do a complete search
-       of the str field (the human readable name) */
-    swig_module_info *iter = start;
-    do {
-      size_t i = 0;
-      for (; i < iter->size; ++i) {
-        if (iter->types[i]->str && (SWIG_TypeEquiv(iter->types[i]->str, name)))
-          return iter->types[i];
-      }
-      iter = iter->next;
-    } while (iter != end);
-  }
-
-  /* neither found a match */
-  return 0;
-}
-
-/*
-   Pack binary data into a string
-*/
-SWIGRUNTIME char *SWIG_PackData(char *c, void *ptr, size_t sz) {
-  static const char hex[17] = "0123456789abcdef";
-  const unsigned char *u = (unsigned char *)ptr;
-  const unsigned char *eu = u + sz;
-  for (; u != eu; ++u) {
-    unsigned char uu = *u;
-    *(c++) = hex[(uu & 0xf0) >> 4];
-    *(c++) = hex[uu & 0xf];
-  }
-  return c;
-}
-
-/*
-   Unpack binary data from a string
-*/
-SWIGRUNTIME const char *SWIG_UnpackData(const char *c, void *ptr, size_t sz) {
-  unsigned char *u = (unsigned char *)ptr;
-  const unsigned char *eu = u + sz;
-  for (; u != eu; ++u) {
-    char d = *(c++);
-    unsigned char uu;
-    if ((d >= '0') && (d <= '9'))
-      uu = ((d - '0') << 4);
-    else if ((d >= 'a') && (d <= 'f'))
-      uu = ((d - ('a' - 10)) << 4);
-    else
-      return (char *)0;
-    d = *(c++);
-    if ((d >= '0') && (d <= '9'))
-      uu |= (d - '0');
-    else if ((d >= 'a') && (d <= 'f'))
-      uu |= (d - ('a' - 10));
-    else
-      return (char *)0;
-    *u = uu;
-  }
-  return c;
-}
-
-/*
-   Pack 'void *' into a string buffer.
-*/
-SWIGRUNTIME char *SWIG_PackVoidPtr(char *buff, void *ptr, const char *name,
-                                   size_t bsz) {
-  char *r = buff;
-  if ((2 * sizeof(void *) + 2) > bsz)
-    return 0;
-  *(r++) = '_';
-  r = SWIG_PackData(r, &ptr, sizeof(void *));
-  if (strlen(name) + 1 > (bsz - (r - buff)))
-    return 0;
-  strcpy(r, name);
-  return buff;
-}
-
-SWIGRUNTIME const char *SWIG_UnpackVoidPtr(const char *c, void **ptr,
-                                           const char *name) {
-  if (*c != '_') {
-    if (strcmp(c, "NULL") == 0) {
-      *ptr = (void *)0;
-      return name;
-    } else {
-      return 0;
-    }
-  }
-  return SWIG_UnpackData(++c, ptr, sizeof(void *));
-}
-
-SWIGRUNTIME char *SWIG_PackDataName(char *buff, void *ptr, size_t sz,
-                                    const char *name, size_t bsz) {
-  char *r = buff;
-  size_t lname = (name ? strlen(name) : 0);
-  if ((2 * sz + 2 + lname) > bsz)
-    return 0;
-  *(r++) = '_';
-  r = SWIG_PackData(r, ptr, sz);
-  if (lname) {
-    strncpy(r, name, lname + 1);
-  } else {
-    *r = 0;
-  }
-  return buff;
-}
-
-SWIGRUNTIME const char *SWIG_UnpackDataName(const char *c, void *ptr, size_t sz,
-                                            const char *name) {
-  if (*c != '_') {
-    if (strcmp(c, "NULL") == 0) {
-      memset(ptr, 0, sz);
-      return name;
-    } else {
-      return 0;
-    }
-  }
-  return SWIG_UnpackData(++c, ptr, sz);
-}
-
-#ifdef __cplusplus
-}
-#endif
-
-/*  Errors in SWIG */
-#define SWIG_UnknownError -1
-#define SWIG_IOError -2
-#define SWIG_RuntimeError -3
-#define SWIG_IndexError -4
-#define SWIG_TypeError -5
-#define SWIG_DivisionByZero -6
-#define SWIG_OverflowError -7
-#define SWIG_SyntaxError -8
-#define SWIG_ValueError -9
-#define SWIG_SystemError -10
-#define SWIG_AttributeError -11
-#define SWIG_MemoryError -12
-#define SWIG_NullReferenceError -13
-
-/* Compatibility macros for Python 3 */
-#if PY_VERSION_HEX >= 0x03000000
-
-#define PyClass_Check(obj) PyObject_IsInstance(obj, (PyObject *)&PyType_Type)
-#define PyInt_Check(x) PyLong_Check(x)
-#define PyInt_AsLong(x) PyLong_AsLong(x)
-#define PyInt_FromLong(x) PyLong_FromLong(x)
-#define PyInt_FromSize_t(x) PyLong_FromSize_t(x)
-#define PyString_Check(name) PyBytes_Check(name)
-#define PyString_FromString(x) PyUnicode_FromString(x)
-#define PyString_Format(fmt, args) PyUnicode_Format(fmt, args)
-#define PyString_AsString(str) PyBytes_AsString(str)
-#define PyString_Size(str) PyBytes_Size(str)
-#define PyString_InternFromString(key) PyUnicode_InternFromString(key)
-#define Py_TPFLAGS_HAVE_CLASS Py_TPFLAGS_BASETYPE
-#define PyString_AS_STRING(x) PyUnicode_AS_STRING(x)
-#define _PyLong_FromSsize_t(x) PyLong_FromSsize_t(x)
-
-#endif
-
-#ifndef Py_TYPE
-#define Py_TYPE(op) ((op)->ob_type)
-#endif
-
-/* SWIG APIs for compatibility of both Python 2 & 3 */
-
-#if PY_VERSION_HEX >= 0x03000000
-#define SWIG_Python_str_FromFormat PyUnicode_FromFormat
-#else
-#define SWIG_Python_str_FromFormat PyString_FromFormat
-#endif
-
-/* Warning: This function will allocate a new string in Python 3,
- * so please call SWIG_Python_str_DelForPy3(x) to free the space.
- */
-SWIGINTERN char *SWIG_Python_str_AsChar(PyObject *str) {
-#if PY_VERSION_HEX >= 0x03000000
-  char *cstr;
-  char *newstr;
-  Py_ssize_t len;
-  str = PyUnicode_AsUTF8String(str);
-  PyBytes_AsStringAndSize(str, &cstr, &len);
-  newstr = (char *)malloc(len + 1);
-  memcpy(newstr, cstr, len + 1);
-  Py_XDECREF(str);
-  return newstr;
-#else
-  return PyString_AsString(str);
-#endif
-}
-
-#if PY_VERSION_HEX >= 0x03000000
-#define SWIG_Python_str_DelForPy3(x) free((void *)(x))
-#else
-#define SWIG_Python_str_DelForPy3(x)
-#endif
-
-SWIGINTERN PyObject *SWIG_Python_str_FromChar(const char *c) {
-#if PY_VERSION_HEX >= 0x03000000
-  return PyUnicode_FromString(c);
-#else
-  return PyString_FromString(c);
-#endif
-}
-
-/* Add PyOS_snprintf for old Pythons */
-#if PY_VERSION_HEX < 0x02020000
-#if defined(_MSC_VER) || defined(__BORLANDC__) || defined(_WATCOM)
-#define PyOS_snprintf _snprintf
-#else
-#define PyOS_snprintf snprintf
-#endif
-#endif
-
-/* A crude PyString_FromFormat implementation for old Pythons */
-#if PY_VERSION_HEX < 0x02020000
-
-#ifndef SWIG_PYBUFFER_SIZE
-#define SWIG_PYBUFFER_SIZE 1024
-#endif
-
-static PyObject *PyString_FromFormat(const char *fmt, ...) {
-  va_list ap;
-  char buf[SWIG_PYBUFFER_SIZE * 2];
-  int res;
-  va_start(ap, fmt);
-  res = vsnprintf(buf, sizeof(buf), fmt, ap);
-  va_end(ap);
-  return (res < 0 || res >= (int)sizeof(buf)) ? 0 : PyString_FromString(buf);
-}
-#endif
-
-/* Add PyObject_Del for old Pythons */
-#if PY_VERSION_HEX < 0x01060000
-#define PyObject_Del(op) PyMem_DEL((op))
-#endif
-#ifndef PyObject_DEL
-#define PyObject_DEL PyObject_Del
-#endif
-
-/* A crude PyExc_StopIteration exception for old Pythons */
-#if PY_VERSION_HEX < 0x02020000
-#ifndef PyExc_StopIteration
-#define PyExc_StopIteration PyExc_RuntimeError
-#endif
-#ifndef PyObject_GenericGetAttr
-#define PyObject_GenericGetAttr 0
-#endif
-#endif
-
-/* Py_NotImplemented is defined in 2.1 and up. */
-#if PY_VERSION_HEX < 0x02010000
-#ifndef Py_NotImplemented
-#define Py_NotImplemented PyExc_RuntimeError
-#endif
-#endif
-
-/* A crude PyString_AsStringAndSize implementation for old Pythons */
-#if PY_VERSION_HEX < 0x02010000
-#ifndef PyString_AsStringAndSize
-#define PyString_AsStringAndSize(obj, s, len)                                  \
-  {                                                                            \
-    *s = PyString_AsString(obj);                                               \
-    *len = *s ? strlen(*s) : 0;                                                \
-  }
-#endif
-#endif
-
-/* PySequence_Size for old Pythons */
-#if PY_VERSION_HEX < 0x02000000
-#ifndef PySequence_Size
-#define PySequence_Size PySequence_Length
-#endif
-#endif
-
-/* PyBool_FromLong for old Pythons */
-#if PY_VERSION_HEX < 0x02030000
-static PyObject *PyBool_FromLong(long ok) {
-  PyObject *result = ok ? Py_True : Py_False;
-  Py_INCREF(result);
-  return result;
-}
-#endif
-
-/* Py_ssize_t for old Pythons */
-/* This code is as recommended by: */
-/* http://www.python.org/dev/peps/pep-0353/#conversion-guidelines */
-#if PY_VERSION_HEX < 0x02050000 && !defined(PY_SSIZE_T_MIN)
-typedef int Py_ssize_t;
-#define PY_SSIZE_T_MAX INT_MAX
-#define PY_SSIZE_T_MIN INT_MIN
-typedef inquiry lenfunc;
-typedef intargfunc ssizeargfunc;
-typedef intintargfunc ssizessizeargfunc;
-typedef intobjargproc ssizeobjargproc;
-typedef intintobjargproc ssizessizeobjargproc;
-typedef getreadbufferproc readbufferproc;
-typedef getwritebufferproc writebufferproc;
-typedef getsegcountproc segcountproc;
-typedef getcharbufferproc charbufferproc;
-static long PyNumber_AsSsize_t(PyObject *x, void *SWIGUNUSEDPARM(exc)) {
-  long result = 0;
-  PyObject *i = PyNumber_Int(x);
-  if (i) {
-    result = PyInt_AsLong(i);
-    Py_DECREF(i);
-  }
-  return result;
-}
-#endif
-
-#if PY_VERSION_HEX < 0x02050000
-#define PyInt_FromSize_t(x) PyInt_FromLong((long)x)
-#endif
-
-#if PY_VERSION_HEX < 0x02040000
-#define Py_VISIT(op)                                                           \
-  do {                                                                         \
-    if (op) {                                                                  \
-      int vret = visit((op), arg);                                             \
-      if (vret)                                                                \
-        return vret;                                                           \
-    }                                                                          \
-  } while (0)
-#endif
-
-#if PY_VERSION_HEX < 0x02030000
-typedef struct {
-  PyTypeObject type;
-  PyNumberMethods as_number;
-  PyMappingMethods as_mapping;
-  PySequenceMethods as_sequence;
-  PyBufferProcs as_buffer;
-  PyObject *name, *slots;
-} PyHeapTypeObject;
-#endif
-
-#if PY_VERSION_HEX < 0x02030000
-typedef destructor freefunc;
-#endif
-
-#if ((PY_MAJOR_VERSION == 2 && PY_MINOR_VERSION > 6) ||                        \
-     (PY_MAJOR_VERSION == 3 && PY_MINOR_VERSION > 0) ||                        \
-     (PY_MAJOR_VERSION > 3))
-#define SWIGPY_USE_CAPSULE
-#define SWIGPY_CAPSULE_NAME                                                    \
-  ((char *)"swig_runtime_data" SWIG_RUNTIME_VERSION                            \
-           ".type_pointer_capsule" SWIG_TYPE_TABLE_NAME)
-#endif
-
-#if PY_VERSION_HEX < 0x03020000
-#define PyDescr_TYPE(x) (((PyDescrObject *)(x))->d_type)
-#define PyDescr_NAME(x) (((PyDescrObject *)(x))->d_name)
-#endif
-
-/* -----------------------------------------------------------------------------
- * error manipulation
- * -----------------------------------------------------------------------------
- */
-
-SWIGRUNTIME PyObject *SWIG_Python_ErrorType(int code) {
-  PyObject *type = 0;
-  switch (code) {
-  case SWIG_MemoryError:
-    type = PyExc_MemoryError;
-    break;
-  case SWIG_IOError:
-    type = PyExc_IOError;
-    break;
-  case SWIG_RuntimeError:
-    type = PyExc_RuntimeError;
-    break;
-  case SWIG_IndexError:
-    type = PyExc_IndexError;
-    break;
-  case SWIG_TypeError:
-    type = PyExc_TypeError;
-    break;
-  case SWIG_DivisionByZero:
-    type = PyExc_ZeroDivisionError;
-    break;
-  case SWIG_OverflowError:
-    type = PyExc_OverflowError;
-    break;
-  case SWIG_SyntaxError:
-    type = PyExc_SyntaxError;
-    break;
-  case SWIG_ValueError:
-    type = PyExc_ValueError;
-    break;
-  case SWIG_SystemError:
-    type = PyExc_SystemError;
-    break;
-  case SWIG_AttributeError:
-    type = PyExc_AttributeError;
-    break;
-  default:
-    type = PyExc_RuntimeError;
-  }
-  return type;
-}
-
-SWIGRUNTIME void SWIG_Python_AddErrorMsg(const char *mesg) {
-  PyObject *type = 0;
-  PyObject *value = 0;
-  PyObject *traceback = 0;
-
-  if (PyErr_Occurred())
-    PyErr_Fetch(&type, &value, &traceback);
-  if (value) {
-    char *tmp;
-    PyObject *old_str = PyObject_Str(value);
-    PyErr_Clear();
-    Py_XINCREF(type);
-
-    PyErr_Format(type, "%s %s", tmp = SWIG_Python_str_AsChar(old_str), mesg);
-    SWIG_Python_str_DelForPy3(tmp);
-    Py_DECREF(old_str);
-    Py_DECREF(value);
-  } else {
-    PyErr_SetString(PyExc_RuntimeError, mesg);
-  }
-}
-
-#if defined(SWIG_PYTHON_NO_THREADS)
-#if defined(SWIG_PYTHON_THREADS)
-#undef SWIG_PYTHON_THREADS
-#endif
-#endif
-#if defined(SWIG_PYTHON_THREADS) /* Threading support is enabled */
-#if !defined(SWIG_PYTHON_USE_GIL) && !defined(SWIG_PYTHON_NO_USE_GIL)
-#if (PY_VERSION_HEX >=                                                         \
-     0x02030000) /* For 2.3 or later, use the PyGILState calls */
-#define SWIG_PYTHON_USE_GIL
-#endif
-#endif
-#if defined(SWIG_PYTHON_USE_GIL) /* Use PyGILState threads calls */
-#ifndef SWIG_PYTHON_INITIALIZE_THREADS
-#define SWIG_PYTHON_INITIALIZE_THREADS PyEval_InitThreads()
-#endif
-#ifdef __cplusplus /* C++ code */
-class SWIG_Python_Thread_Block {
-  bool status;
-  PyGILState_STATE state;
-
-public:
-  void end() {
-    if (status) {
-      PyGILState_Release(state);
-      status = false;
-    }
-  }
-  SWIG_Python_Thread_Block() : status(true), state(PyGILState_Ensure()) {}
-  ~SWIG_Python_Thread_Block() { end(); }
-};
-class SWIG_Python_Thread_Allow {
-  bool status;
-  PyThreadState *save;
-
-public:
-  void end() {
-    if (status) {
-      PyEval_RestoreThread(save);
-      status = false;
-    }
-  }
-  SWIG_Python_Thread_Allow() : status(true), save(PyEval_SaveThread()) {}
-  ~SWIG_Python_Thread_Allow() { end(); }
-};
-#define SWIG_PYTHON_THREAD_BEGIN_BLOCK                                         \
-  SWIG_Python_Thread_Block _swig_thread_block
-#define SWIG_PYTHON_THREAD_END_BLOCK _swig_thread_block.end()
-#define SWIG_PYTHON_THREAD_BEGIN_ALLOW                                         \
-  SWIG_Python_Thread_Allow _swig_thread_allow
-#define SWIG_PYTHON_THREAD_END_ALLOW _swig_thread_allow.end()
-#else /* C code */
-#define SWIG_PYTHON_THREAD_BEGIN_BLOCK                                         \
-  PyGILState_STATE _swig_thread_block = PyGILState_Ensure()
-#define SWIG_PYTHON_THREAD_END_BLOCK PyGILState_Release(_swig_thread_block)
-#define SWIG_PYTHON_THREAD_BEGIN_ALLOW                                         \
-  PyThreadState *_swig_thread_allow = PyEval_SaveThread()
-#define SWIG_PYTHON_THREAD_END_ALLOW PyEval_RestoreThread(_swig_thread_allow)
-#endif
-#else /* Old thread way, not implemented, user must provide it */
-#if !defined(SWIG_PYTHON_INITIALIZE_THREADS)
-#define SWIG_PYTHON_INITIALIZE_THREADS
-#endif
-#if !defined(SWIG_PYTHON_THREAD_BEGIN_BLOCK)
-#define SWIG_PYTHON_THREAD_BEGIN_BLOCK
-#endif
-#if !defined(SWIG_PYTHON_THREAD_END_BLOCK)
-#define SWIG_PYTHON_THREAD_END_BLOCK
-#endif
-#if !defined(SWIG_PYTHON_THREAD_BEGIN_ALLOW)
-#define SWIG_PYTHON_THREAD_BEGIN_ALLOW
-#endif
-#if !defined(SWIG_PYTHON_THREAD_END_ALLOW)
-#define SWIG_PYTHON_THREAD_END_ALLOW
-#endif
-#endif
-#else /* No thread support */
-#define SWIG_PYTHON_INITIALIZE_THREADS
-#define SWIG_PYTHON_THREAD_BEGIN_BLOCK
-#define SWIG_PYTHON_THREAD_END_BLOCK
-#define SWIG_PYTHON_THREAD_BEGIN_ALLOW
-#define SWIG_PYTHON_THREAD_END_ALLOW
-#endif
-
-/* -----------------------------------------------------------------------------
- * Python API portion that goes into the runtime
- * -----------------------------------------------------------------------------
- */
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/* -----------------------------------------------------------------------------
- * Constant declarations
- * -----------------------------------------------------------------------------
- */
-
-/* Constant Types */
-#define SWIG_PY_POINTER 4
-#define SWIG_PY_BINARY 5
-
-/* Constant information structure */
-typedef struct swig_const_info {
-  int type;
-  char *name;
-  long lvalue;
-  double dvalue;
-  void *pvalue;
-  swig_type_info **ptype;
-} swig_const_info;
-
-/* -----------------------------------------------------------------------------
- * Wrapper of PyInstanceMethod_New() used in Python 3
- * It is exported to the generated module, used for -fastproxy
- * -----------------------------------------------------------------------------
- */
-#if PY_VERSION_HEX >= 0x03000000
-SWIGRUNTIME PyObject *SWIG_PyInstanceMethod_New(PyObject *SWIGUNUSEDPARM(self),
-                                                PyObject *func) {
-  return PyInstanceMethod_New(func);
-}
-#else
-SWIGRUNTIME PyObject *
-SWIG_PyInstanceMethod_New(PyObject *SWIGUNUSEDPARM(self),
-                          PyObject *SWIGUNUSEDPARM(func)) {
-  return NULL;
-}
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-/* -----------------------------------------------------------------------------
- * pyrun.swg
- *
- * This file contains the runtime support for Python modules
- * and includes code for managing global variables and pointer
- * type checking.
- *
- * -----------------------------------------------------------------------------
- */
-
-/* Common SWIG API */
-
-/* for raw pointers */
-#define SWIG_Python_ConvertPtr(obj, pptr, type, flags)                         \
-  SWIG_Python_ConvertPtrAndOwn(obj, pptr, type, flags, 0)
-#define SWIG_ConvertPtr(obj, pptr, type, flags)                                \
-  SWIG_Python_ConvertPtr(obj, pptr, type, flags)
-#define SWIG_ConvertPtrAndOwn(obj, pptr, type, flags, own)                     \
-  SWIG_Python_ConvertPtrAndOwn(obj, pptr, type, flags, own)
-
-#ifdef SWIGPYTHON_BUILTIN
-#define SWIG_NewPointerObj(ptr, type, flags)                                   \
-  SWIG_Python_NewPointerObj(self, ptr, type, flags)
-#else
-#define SWIG_NewPointerObj(ptr, type, flags)                                   \
-  SWIG_Python_NewPointerObj(NULL, ptr, type, flags)
-#endif
-
-#define SWIG_InternalNewPointerObj(ptr, type, flags)                           \
-  SWIG_Python_NewPointerObj(NULL, ptr, type, flags)
-
-#define SWIG_CheckImplicit(ty) SWIG_Python_CheckImplicit(ty)
-#define SWIG_AcquirePtr(ptr, src) SWIG_Python_AcquirePtr(ptr, src)
-#define swig_owntype int
-
-/* for raw packed data */
-#define SWIG_ConvertPacked(obj, ptr, sz, ty)                                   \
-  SWIG_Python_ConvertPacked(obj, ptr, sz, ty)
-#define SWIG_NewPackedObj(ptr, sz, type) SWIG_Python_NewPackedObj(ptr, sz, type)
-
-/* for class or struct pointers */
-#define SWIG_ConvertInstance(obj, pptr, type, flags)                           \
-  SWIG_ConvertPtr(obj, pptr, type, flags)
-#define SWIG_NewInstanceObj(ptr, type, flags)                                  \
-  SWIG_NewPointerObj(ptr, type, flags)
-
-/* for C or C++ function pointers */
-#define SWIG_ConvertFunctionPtr(obj, pptr, type)                               \
-  SWIG_Python_ConvertFunctionPtr(obj, pptr, type)
-#define SWIG_NewFunctionPtrObj(ptr, type)                                      \
-  SWIG_Python_NewPointerObj(NULL, ptr, type, 0)
-
-/* for C++ member pointers, ie, member methods */
-#define SWIG_ConvertMember(obj, ptr, sz, ty)                                   \
-  SWIG_Python_ConvertPacked(obj, ptr, sz, ty)
-#define SWIG_NewMemberObj(ptr, sz, type) SWIG_Python_NewPackedObj(ptr, sz, type)
-
-/* Runtime API */
-
-#define SWIG_GetModule(clientdata) SWIG_Python_GetModule(clientdata)
-#define SWIG_SetModule(clientdata, pointer) SWIG_Python_SetModule(pointer)
-#define SWIG_NewClientData(obj) SwigPyClientData_New(obj)
-
-#define SWIG_SetErrorObj SWIG_Python_SetErrorObj
-#define SWIG_SetErrorMsg SWIG_Python_SetErrorMsg
-#define SWIG_ErrorType(code) SWIG_Python_ErrorType(code)
-#define SWIG_Error(code, msg) SWIG_Python_SetErrorMsg(SWIG_ErrorType(code), msg)
-#define SWIG_fail goto fail
-
-/* Runtime API implementation */
-
-/* Error manipulation */
-
-SWIGINTERN void SWIG_Python_SetErrorObj(PyObject *errtype, PyObject *obj) {
-  SWIG_PYTHON_THREAD_BEGIN_BLOCK;
-  PyErr_SetObject(errtype, obj);
-  Py_DECREF(obj);
-  SWIG_PYTHON_THREAD_END_BLOCK;
-}
-
-SWIGINTERN void SWIG_Python_SetErrorMsg(PyObject *errtype, const char *msg) {
-  SWIG_PYTHON_THREAD_BEGIN_BLOCK;
-  PyErr_SetString(errtype, msg);
-  SWIG_PYTHON_THREAD_END_BLOCK;
-}
-
-#define SWIG_Python_Raise(obj, type, desc)                                     \
-  SWIG_Python_SetErrorObj(SWIG_Python_ExceptionType(desc), obj)
-
-/* Set a constant value */
-
-#if defined(SWIGPYTHON_BUILTIN)
-
-SWIGINTERN void SwigPyBuiltin_AddPublicSymbol(PyObject *seq, const char *key) {
-  PyObject *s = PyString_InternFromString(key);
-  PyList_Append(seq, s);
-  Py_DECREF(s);
-}
-
-SWIGINTERN void SWIG_Python_SetConstant(PyObject *d, PyObject *public_interface,
-                                        const char *name, PyObject *obj) {
-#if PY_VERSION_HEX < 0x02030000
-  PyDict_SetItemString(d, (char *)name, obj);
-#else
-  PyDict_SetItemString(d, name, obj);
-#endif
-  Py_DECREF(obj);
-  if (public_interface)
-    SwigPyBuiltin_AddPublicSymbol(public_interface, name);
-}
-
-#else
-
-SWIGINTERN void SWIG_Python_SetConstant(PyObject *d, const char *name,
-                                        PyObject *obj) {
-#if PY_VERSION_HEX < 0x02030000
-  PyDict_SetItemString(d, (char *)name, obj);
-#else
-  PyDict_SetItemString(d, name, obj);
-#endif
-  Py_DECREF(obj);
-}
-
-#endif
-
-/* Append a value to the result obj */
-
-SWIGINTERN PyObject *SWIG_Python_AppendOutput(PyObject *result, PyObject *obj) {
-#if !defined(SWIG_PYTHON_OUTPUT_TUPLE)
-  if (!result) {
-    result = obj;
-  } else if (result == Py_None) {
-    Py_DECREF(result);
-    result = obj;
-  } else {
-    if (!PyList_Check(result)) {
-      PyObject *o2 = result;
-      result = PyList_New(1);
-      PyList_SetItem(result, 0, o2);
-    }
-    PyList_Append(result, obj);
-    Py_DECREF(obj);
-  }
-  return result;
-#else
-  PyObject *o2;
-  PyObject *o3;
-  if (!result) {
-    result = obj;
-  } else if (result == Py_None) {
-    Py_DECREF(result);
-    result = obj;
-  } else {
-    if (!PyTuple_Check(result)) {
-      o2 = result;
-      result = PyTuple_New(1);
-      PyTuple_SET_ITEM(result, 0, o2);
-    }
-    o3 = PyTuple_New(1);
-    PyTuple_SET_ITEM(o3, 0, obj);
-    o2 = result;
-    result = PySequence_Concat(o2, o3);
-    Py_DECREF(o2);
-    Py_DECREF(o3);
-  }
-  return result;
-#endif
-}
-
-/* Unpack the argument tuple */
-
-SWIGINTERN Py_ssize_t SWIG_Python_UnpackTuple(PyObject *args, const char *name,
-                                              Py_ssize_t min, Py_ssize_t max,
-                                              PyObject **objs) {
-  if (!args) {
-    if (!min && !max) {
-      return 1;
-    } else {
-      PyErr_Format(PyExc_TypeError, "%s expected %s%d arguments, got none",
-                   name, (min == max ? "" : "at least "), (int)min);
-      return 0;
-    }
-  }
-  if (!PyTuple_Check(args)) {
-    if (min <= 1 && max >= 1) {
-      Py_ssize_t i;
-      objs[0] = args;
-      for (i = 1; i < max; ++i) {
-        objs[i] = 0;
-      }
-      return 2;
-    }
-    PyErr_SetString(PyExc_SystemError,
-                    "UnpackTuple() argument list is not a tuple");
-    return 0;
-  } else {
-    Py_ssize_t l = PyTuple_GET_SIZE(args);
-    if (l < min) {
-      PyErr_Format(PyExc_TypeError, "%s expected %s%d arguments, got %d", name,
-                   (min == max ? "" : "at least "), (int)min, (int)l);
-      return 0;
-    } else if (l > max) {
-      PyErr_Format(PyExc_TypeError, "%s expected %s%d arguments, got %d", name,
-                   (min == max ? "" : "at most "), (int)max, (int)l);
-      return 0;
-    } else {
-      Py_ssize_t i;
-      for (i = 0; i < l; ++i) {
-        objs[i] = PyTuple_GET_ITEM(args, i);
-      }
-      for (; l < max; ++l) {
-        objs[l] = 0;
-      }
-      return i + 1;
-    }
-  }
-}
-
-/* A functor is a function object with one single object argument */
-#if PY_VERSION_HEX >= 0x02020000
-#define SWIG_Python_CallFunctor(functor, obj)                                  \
-  PyObject_CallFunctionObjArgs(functor, obj, NULL);
-#else
-#define SWIG_Python_CallFunctor(functor, obj)                                  \
-  PyObject_CallFunction(functor, "O", obj);
-#endif
-
-/*
-  Helper for static pointer initialization for both C and C++ code, for example
-  static PyObject *SWIG_STATIC_POINTER(MyVar) = NewSomething(...);
-*/
-#ifdef __cplusplus
-#define SWIG_STATIC_POINTER(var) var
-#else
-#define SWIG_STATIC_POINTER(var)                                               \
-  var = 0;                                                                     \
-  if (!var)                                                                    \
-  var
-#endif
-
-/* -----------------------------------------------------------------------------
- * Pointer declarations
- * -----------------------------------------------------------------------------
- */
-
-/* Flags for new pointer objects */
-#define SWIG_POINTER_NOSHADOW (SWIG_POINTER_OWN << 1)
-#define SWIG_POINTER_NEW (SWIG_POINTER_NOSHADOW | SWIG_POINTER_OWN)
-
-#define SWIG_POINTER_IMPLICIT_CONV (SWIG_POINTER_DISOWN << 1)
-
-#define SWIG_BUILTIN_TP_INIT (SWIG_POINTER_OWN << 2)
-#define SWIG_BUILTIN_INIT (SWIG_BUILTIN_TP_INIT | SWIG_POINTER_OWN)
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*  How to access Py_None */
-#if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__)
-#ifndef SWIG_PYTHON_NO_BUILD_NONE
-#ifndef SWIG_PYTHON_BUILD_NONE
-#define SWIG_PYTHON_BUILD_NONE
-#endif
-#endif
-#endif
-
-#ifdef SWIG_PYTHON_BUILD_NONE
-#ifdef Py_None
-#undef Py_None
-#define Py_None SWIG_Py_None()
-#endif
-SWIGRUNTIMEINLINE PyObject *_SWIG_Py_None(void) {
-  PyObject *none = Py_BuildValue((char *)"");
-  Py_DECREF(none);
-  return none;
-}
-SWIGRUNTIME PyObject *SWIG_Py_None(void) {
-  static PyObject *SWIG_STATIC_POINTER(none) = _SWIG_Py_None();
-  return none;
-}
-#endif
-
-/* The python void return value */
-
-SWIGRUNTIMEINLINE PyObject *SWIG_Py_Void(void) {
-  PyObject *none = Py_None;
-  Py_INCREF(none);
-  return none;
-}
-
-/* SwigPyClientData */
-
-typedef struct {
-  PyObject *klass;
-  PyObject *newraw;
-  PyObject *newargs;
-  PyObject *destroy;
-  int delargs;
-  int implicitconv;
-  PyTypeObject *pytype;
-} SwigPyClientData;
-
-SWIGRUNTIMEINLINE int SWIG_Python_CheckImplicit(swig_type_info *ty) {
-  SwigPyClientData *data = (SwigPyClientData *)ty->clientdata;
-  return data ? data->implicitconv : 0;
-}
-
-SWIGRUNTIMEINLINE PyObject *SWIG_Python_ExceptionType(swig_type_info *desc) {
-  SwigPyClientData *data = desc ? (SwigPyClientData *)desc->clientdata : 0;
-  PyObject *klass = data ? data->klass : 0;
-  return (klass ? klass : PyExc_RuntimeError);
-}
-
-SWIGRUNTIME SwigPyClientData *SwigPyClientData_New(PyObject *obj) {
-  if (!obj) {
-    return 0;
-  } else {
-    SwigPyClientData *data =
-        (SwigPyClientData *)malloc(sizeof(SwigPyClientData));
-    /* the klass element */
-    data->klass = obj;
-    Py_INCREF(data->klass);
-    /* the newraw method and newargs arguments used to create a new raw instance
-     */
-    if (PyClass_Check(obj)) {
-      data->newraw = 0;
-      data->newargs = obj;
-      Py_INCREF(obj);
-    } else {
-#if (PY_VERSION_HEX < 0x02020000)
-      data->newraw = 0;
-#else
-      data->newraw = PyObject_GetAttrString(data->klass, (char *)"__new__");
-#endif
-      if (data->newraw) {
-        Py_INCREF(data->newraw);
-        data->newargs = PyTuple_New(1);
-        PyTuple_SetItem(data->newargs, 0, obj);
-      } else {
-        data->newargs = obj;
-      }
-      Py_INCREF(data->newargs);
-    }
-    /* the destroy method, aka as the C++ delete method */
-    data->destroy =
-        PyObject_GetAttrString(data->klass, (char *)"__swig_destroy__");
-    if (PyErr_Occurred()) {
-      PyErr_Clear();
-      data->destroy = 0;
-    }
-    if (data->destroy) {
-      int flags;
-      Py_INCREF(data->destroy);
-      flags = PyCFunction_GET_FLAGS(data->destroy);
-#ifdef METH_O
-      data->delargs = !(flags & (METH_O));
-#else
-      data->delargs = 0;
-#endif
-    } else {
-      data->delargs = 0;
-    }
-    data->implicitconv = 0;
-    data->pytype = 0;
-    return data;
-  }
-}
-
-SWIGRUNTIME void SwigPyClientData_Del(SwigPyClientData *data) {
-  Py_XDECREF(data->newraw);
-  Py_XDECREF(data->newargs);
-  Py_XDECREF(data->destroy);
-}
-
-/* =============== SwigPyObject =====================*/
-
-typedef struct {
-  PyObject_HEAD void *ptr;
-  swig_type_info *ty;
-  int own;
-  PyObject *next;
-#ifdef SWIGPYTHON_BUILTIN
-  PyObject *dict;
-#endif
-} SwigPyObject;
-
-#ifdef SWIGPYTHON_BUILTIN
-
-SWIGRUNTIME PyObject *
-SwigPyObject_get___dict__(PyObject *v, PyObject *SWIGUNUSEDPARM(args)) {
-  SwigPyObject *sobj = (SwigPyObject *)v;
-
-  if (!sobj->dict)
-    sobj->dict = PyDict_New();
-
-  Py_INCREF(sobj->dict);
-  return sobj->dict;
-}
-
-#endif
-
-SWIGRUNTIME PyObject *SwigPyObject_long(SwigPyObject *v) {
-  return PyLong_FromVoidPtr(v->ptr);
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_format(const char *fmt, SwigPyObject *v) {
-  PyObject *res = NULL;
-  PyObject *args = PyTuple_New(1);
-  if (args) {
-    if (PyTuple_SetItem(args, 0, SwigPyObject_long(v)) == 0) {
-      PyObject *ofmt = SWIG_Python_str_FromChar(fmt);
-      if (ofmt) {
-#if PY_VERSION_HEX >= 0x03000000
-        res = PyUnicode_Format(ofmt, args);
-#else
-        res = PyString_Format(ofmt, args);
-#endif
-        Py_DECREF(ofmt);
-      }
-      Py_DECREF(args);
-    }
-  }
-  return res;
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_oct(SwigPyObject *v) {
-  return SwigPyObject_format("%o", v);
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_hex(SwigPyObject *v) {
-  return SwigPyObject_format("%x", v);
-}
-
-SWIGRUNTIME PyObject *
-#ifdef METH_NOARGS
-SwigPyObject_repr(SwigPyObject *v)
-#else
-SwigPyObject_repr(SwigPyObject *v, PyObject *args)
-#endif
-{
-  const char *name = SWIG_TypePrettyName(v->ty);
-  PyObject *repr = SWIG_Python_str_FromFormat(
-      "<Swig Object of type '%s' at %p>", (name ? name : "unknown"), (void *)v);
-  if (v->next) {
-#ifdef METH_NOARGS
-    PyObject *nrep = SwigPyObject_repr((SwigPyObject *)v->next);
-#else
-    PyObject *nrep = SwigPyObject_repr((SwigPyObject *)v->next, args);
-#endif
-#if PY_VERSION_HEX >= 0x03000000
-    PyObject *joined = PyUnicode_Concat(repr, nrep);
-    Py_DecRef(repr);
-    Py_DecRef(nrep);
-    repr = joined;
-#else
-    PyString_ConcatAndDel(&repr, nrep);
-#endif
-  }
-  return repr;
-}
-
-SWIGRUNTIME int SwigPyObject_compare(SwigPyObject *v, SwigPyObject *w) {
-  void *i = v->ptr;
-  void *j = w->ptr;
-  return (i < j) ? -1 : ((i > j) ? 1 : 0);
-}
-
-/* Added for Python 3.x, would it also be useful for Python 2.x? */
-SWIGRUNTIME PyObject *SwigPyObject_richcompare(SwigPyObject *v, SwigPyObject *w,
-                                               int op) {
-  PyObject *res;
-  if (op != Py_EQ && op != Py_NE) {
-    Py_INCREF(Py_NotImplemented);
-    return Py_NotImplemented;
-  }
-  res = PyBool_FromLong((SwigPyObject_compare(v, w) == 0) == (op == Py_EQ) ? 1
-                                                                           : 0);
-  return res;
-}
-
-SWIGRUNTIME PyTypeObject *SwigPyObject_TypeOnce(void);
-
-#ifdef SWIGPYTHON_BUILTIN
-static swig_type_info *SwigPyObject_stype = 0;
-SWIGRUNTIME PyTypeObject *SwigPyObject_type(void) {
-  SwigPyClientData *cd;
-  assert(SwigPyObject_stype);
-  cd = (SwigPyClientData *)SwigPyObject_stype->clientdata;
-  assert(cd);
-  assert(cd->pytype);
-  return cd->pytype;
-}
-#else
-SWIGRUNTIME PyTypeObject *SwigPyObject_type(void) {
-  static PyTypeObject *SWIG_STATIC_POINTER(type) = SwigPyObject_TypeOnce();
-  return type;
-}
-#endif
-
-SWIGRUNTIMEINLINE int SwigPyObject_Check(PyObject *op) {
-#ifdef SWIGPYTHON_BUILTIN
-  PyTypeObject *target_tp = SwigPyObject_type();
-  if (PyType_IsSubtype(op->ob_type, target_tp))
-    return 1;
-  return (strcmp(op->ob_type->tp_name, "SwigPyObject") == 0);
-#else
-  return (Py_TYPE(op) == SwigPyObject_type()) ||
-         (strcmp(Py_TYPE(op)->tp_name, "SwigPyObject") == 0);
-#endif
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_New(void *ptr, swig_type_info *ty, int own);
-
-SWIGRUNTIME void SwigPyObject_dealloc(PyObject *v) {
-  SwigPyObject *sobj = (SwigPyObject *)v;
-  PyObject *next = sobj->next;
-  if (sobj->own == SWIG_POINTER_OWN) {
-    swig_type_info *ty = sobj->ty;
-    SwigPyClientData *data = ty ? (SwigPyClientData *)ty->clientdata : 0;
-    PyObject *destroy = data ? data->destroy : 0;
-    if (destroy) {
-      /* destroy is always a VARARGS method */
-      PyObject *res;
-
-      /* PyObject_CallFunction() has the potential to silently drop
-         the active active exception.  In cases of unnamed temporary
-         variable or where we just finished iterating over a generator
-         StopIteration will be active right now, and this needs to
-         remain true upon return from SwigPyObject_dealloc.  So save
-         and restore. */
-
-      PyObject *val = NULL, *type = NULL, *tb = NULL;
-      PyErr_Fetch(&val, &type, &tb);
-
-      if (data->delargs) {
-        /* we need to create a temporary object to carry the destroy operation
-         */
-        PyObject *tmp = SwigPyObject_New(sobj->ptr, ty, 0);
-        res = SWIG_Python_CallFunctor(destroy, tmp);
-        Py_DECREF(tmp);
-      } else {
-        PyCFunction meth = PyCFunction_GET_FUNCTION(destroy);
-        PyObject *mself = PyCFunction_GET_SELF(destroy);
-        res = ((*meth)(mself, v));
-      }
-      if (!res)
-        PyErr_WriteUnraisable(destroy);
-
-      PyErr_Restore(val, type, tb);
-
-      Py_XDECREF(res);
-    }
-#if !defined(SWIG_PYTHON_SILENT_MEMLEAK)
-    else {
-      const char *name = SWIG_TypePrettyName(ty);
-      printf("swig/python detected a memory leak of type '%s', no destructor "
-             "found.\n",
-             (name ? name : "unknown"));
-    }
-#endif
-  }
-  Py_XDECREF(next);
-  PyObject_DEL(v);
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_append(PyObject *v, PyObject *next) {
-  SwigPyObject *sobj = (SwigPyObject *)v;
-#ifndef METH_O
-  PyObject *tmp = 0;
-  if (!PyArg_ParseTuple(next, (char *)"O:append", &tmp))
-    return NULL;
-  next = tmp;
-#endif
-  if (!SwigPyObject_Check(next)) {
-    PyErr_SetString(PyExc_TypeError, "Attempt to append a non SwigPyObject");
-    return NULL;
-  }
-  sobj->next = next;
-  Py_INCREF(next);
-  return SWIG_Py_Void();
-}
-
-SWIGRUNTIME PyObject *
-#ifdef METH_NOARGS
-SwigPyObject_next(PyObject *v)
-#else
-SwigPyObject_next(PyObject *v, PyObject *SWIGUNUSEDPARM(args))
-#endif
-{
-  SwigPyObject *sobj = (SwigPyObject *)v;
-  if (sobj->next) {
-    Py_INCREF(sobj->next);
-    return sobj->next;
-  } else {
-    return SWIG_Py_Void();
-  }
-}
-
-SWIGINTERN PyObject *
-#ifdef METH_NOARGS
-SwigPyObject_disown(PyObject *v)
-#else
-SwigPyObject_disown(PyObject *v, PyObject *SWIGUNUSEDPARM(args))
-#endif
-{
-  SwigPyObject *sobj = (SwigPyObject *)v;
-  sobj->own = 0;
-  return SWIG_Py_Void();
-}
-
-SWIGINTERN PyObject *
-#ifdef METH_NOARGS
-SwigPyObject_acquire(PyObject *v)
-#else
-SwigPyObject_acquire(PyObject *v, PyObject *SWIGUNUSEDPARM(args))
-#endif
-{
-  SwigPyObject *sobj = (SwigPyObject *)v;
-  sobj->own = SWIG_POINTER_OWN;
-  return SWIG_Py_Void();
-}
-
-SWIGINTERN PyObject *SwigPyObject_own(PyObject *v, PyObject *args) {
-  PyObject *val = 0;
-#if (PY_VERSION_HEX < 0x02020000)
-  if (!PyArg_ParseTuple(args, (char *)"|O:own", &val))
-#elif (PY_VERSION_HEX < 0x02050000)
-  if (!PyArg_UnpackTuple(args, (char *)"own", 0, 1, &val))
-#else
-  if (!PyArg_UnpackTuple(args, "own", 0, 1, &val))
-#endif
-  {
-    return NULL;
-  } else {
-    SwigPyObject *sobj = (SwigPyObject *)v;
-    PyObject *obj = PyBool_FromLong(sobj->own);
-    if (val) {
-#ifdef METH_NOARGS
-      if (PyObject_IsTrue(val)) {
-        SwigPyObject_acquire(v);
-      } else {
-        SwigPyObject_disown(v);
-      }
-#else
-      if (PyObject_IsTrue(val)) {
-        SwigPyObject_acquire(v, args);
-      } else {
-        SwigPyObject_disown(v, args);
-      }
-#endif
-    }
-    return obj;
-  }
-}
-
-#ifdef METH_O
-static PyMethodDef swigobject_methods[] = {
-    {(char *)"disown", (PyCFunction)SwigPyObject_disown, METH_NOARGS,
-     (char *)"releases ownership of the pointer"},
-    {(char *)"acquire", (PyCFunction)SwigPyObject_acquire, METH_NOARGS,
-     (char *)"acquires ownership of the pointer"},
-    {(char *)"own", (PyCFunction)SwigPyObject_own, METH_VARARGS,
-     (char *)"returns/sets ownership of the pointer"},
-    {(char *)"append", (PyCFunction)SwigPyObject_append, METH_O,
-     (char *)"appends another 'this' object"},
-    {(char *)"next", (PyCFunction)SwigPyObject_next, METH_NOARGS,
-     (char *)"returns the next 'this' object"},
-    {(char *)"__repr__", (PyCFunction)SwigPyObject_repr, METH_NOARGS,
-     (char *)"returns object representation"},
-    {0, 0, 0, 0}};
-#else
-static PyMethodDef swigobject_methods[] = {
-    {(char *)"disown", (PyCFunction)SwigPyObject_disown, METH_VARARGS,
-     (char *)"releases ownership of the pointer"},
-    {(char *)"acquire", (PyCFunction)SwigPyObject_acquire, METH_VARARGS,
-     (char *)"acquires ownership of the pointer"},
-    {(char *)"own", (PyCFunction)SwigPyObject_own, METH_VARARGS,
-     (char *)"returns/sets ownership of the pointer"},
-    {(char *)"append", (PyCFunction)SwigPyObject_append, METH_VARARGS,
-     (char *)"appends another 'this' object"},
-    {(char *)"next", (PyCFunction)SwigPyObject_next, METH_VARARGS,
-     (char *)"returns the next 'this' object"},
-    {(char *)"__repr__", (PyCFunction)SwigPyObject_repr, METH_VARARGS,
-     (char *)"returns object representation"},
-    {0, 0, 0, 0}};
-#endif
-
-#if PY_VERSION_HEX < 0x02020000
-SWIGINTERN PyObject *SwigPyObject_getattr(SwigPyObject *sobj, char *name) {
-  return Py_FindMethod(swigobject_methods, (PyObject *)sobj, name);
-}
-#endif
-
-SWIGRUNTIME PyTypeObject *SwigPyObject_TypeOnce(void) {
-  static char swigobject_doc[] = "Swig object carries a C/C++ instance pointer";
-
-  static PyNumberMethods SwigPyObject_as_number = {
-    (binaryfunc)0, /*nb_add*/
-    (binaryfunc)0, /*nb_subtract*/
-    (binaryfunc)0, /*nb_multiply*/
-                   /* nb_divide removed in Python 3 */
-#if PY_VERSION_HEX < 0x03000000
-    (binaryfunc)0, /*nb_divide*/
-#endif
-    (binaryfunc)0,  /*nb_remainder*/
-    (binaryfunc)0,  /*nb_divmod*/
-    (ternaryfunc)0, /*nb_power*/
-    (unaryfunc)0,   /*nb_negative*/
-    (unaryfunc)0,   /*nb_positive*/
-    (unaryfunc)0,   /*nb_absolute*/
-    (inquiry)0,     /*nb_nonzero*/
-    0,              /*nb_invert*/
-    0,              /*nb_lshift*/
-    0,              /*nb_rshift*/
-    0,              /*nb_and*/
-    0,              /*nb_xor*/
-    0,              /*nb_or*/
-#if PY_VERSION_HEX < 0x03000000
-    0, /*nb_coerce*/
-#endif
-    (unaryfunc)SwigPyObject_long, /*nb_int*/
-#if PY_VERSION_HEX < 0x03000000
-    (unaryfunc)SwigPyObject_long, /*nb_long*/
-#else
-    0, /*nb_reserved*/
-#endif
-    (unaryfunc)0, /*nb_float*/
-#if PY_VERSION_HEX < 0x03000000
-    (unaryfunc)SwigPyObject_oct, /*nb_oct*/
-    (unaryfunc)SwigPyObject_hex, /*nb_hex*/
-#endif
-#if PY_VERSION_HEX >= 0x03050000 /* 3.5 */
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0 /* nb_inplace_add -> nb_inplace_matrix_multiply */
-#elif PY_VERSION_HEX >= 0x03000000 /* 3.0 */
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0 /* nb_inplace_add -> nb_index, nb_inplace_divide removed */
-#elif PY_VERSION_HEX >= 0x02050000 /* 2.5.0 */
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0 /* nb_inplace_add -> nb_index */
-#elif PY_VERSION_HEX >= 0x02020000 /* 2.2.0 */
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0 /* nb_inplace_add -> nb_inplace_true_divide */
-#elif PY_VERSION_HEX >= 0x02000000 /* 2.0.0 */
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0,
-    0 /* nb_inplace_add -> nb_inplace_or */
-#endif
-  };
-
-  static PyTypeObject swigpyobject_type;
-  static int type_init = 0;
-  if (!type_init) {
-    const PyTypeObject tmp = {
-    /* PyObject header changed in Python 3 */
-#if PY_VERSION_HEX >= 0x03000000
-      PyVarObject_HEAD_INIT(NULL, 0)
-#else
-      PyObject_HEAD_INIT(NULL) 0,    /* ob_size */
-#endif
-          (char *) "SwigPyObject",      /* tp_name */
-      sizeof(SwigPyObject),             /* tp_basicsize */
-      0,                                /* tp_itemsize */
-      (destructor)SwigPyObject_dealloc, /* tp_dealloc */
-      0,                                /* tp_print */
-#if PY_VERSION_HEX < 0x02020000
-      (getattrfunc)SwigPyObject_getattr, /* tp_getattr */
-#else
-      (getattrfunc)0,                /* tp_getattr */
-#endif
-      (setattrfunc)0, /* tp_setattr */
-#if PY_VERSION_HEX >= 0x03000000
-      0, /* tp_reserved in 3.0.1, tp_compare in 3.0.0 but not used */
-#else
-      (cmpfunc)SwigPyObject_compare, /* tp_compare */
-#endif
-      (reprfunc)SwigPyObject_repr,           /* tp_repr */
-      &SwigPyObject_as_number,               /* tp_as_number */
-      0,                                     /* tp_as_sequence */
-      0,                                     /* tp_as_mapping */
-      (hashfunc)0,                           /* tp_hash */
-      (ternaryfunc)0,                        /* tp_call */
-      0,                                     /* tp_str */
-      PyObject_GenericGetAttr,               /* tp_getattro */
-      0,                                     /* tp_setattro */
-      0,                                     /* tp_as_buffer */
-      Py_TPFLAGS_DEFAULT,                    /* tp_flags */
-      swigobject_doc,                        /* tp_doc */
-      0,                                     /* tp_traverse */
-      0,                                     /* tp_clear */
-      (richcmpfunc)SwigPyObject_richcompare, /* tp_richcompare */
-      0,                                     /* tp_weaklistoffset */
-#if PY_VERSION_HEX >= 0x02020000
-      0,                  /* tp_iter */
-      0,                  /* tp_iternext */
-      swigobject_methods, /* tp_methods */
-      0,                  /* tp_members */
-      0,                  /* tp_getset */
-      0,                  /* tp_base */
-      0,                  /* tp_dict */
-      0,                  /* tp_descr_get */
-      0,                  /* tp_descr_set */
-      0,                  /* tp_dictoffset */
-      0,                  /* tp_init */
-      0,                  /* tp_alloc */
-      0,                  /* tp_new */
-      0,                  /* tp_free */
-      0,                  /* tp_is_gc */
-      0,                  /* tp_bases */
-      0,                  /* tp_mro */
-      0,                  /* tp_cache */
-      0,                  /* tp_subclasses */
-      0,                  /* tp_weaklist */
-#endif
-#if PY_VERSION_HEX >= 0x02030000
-      0, /* tp_del */
-#endif
-#if PY_VERSION_HEX >= 0x02060000
-      0, /* tp_version_tag */
-#endif
-#if PY_VERSION_HEX >= 0x03040000
-      0, /* tp_finalize */
-#endif
-#ifdef COUNT_ALLOCS
-      0, /* tp_allocs */
-      0, /* tp_frees */
-      0, /* tp_maxalloc */
-#if PY_VERSION_HEX >= 0x02050000
-      0, /* tp_prev */
-#endif
-      0 /* tp_next */
-#endif
-    };
-    swigpyobject_type = tmp;
-    type_init = 1;
-#if PY_VERSION_HEX < 0x02020000
-    swigpyobject_type.ob_type = &PyType_Type;
-#else
-    if (PyType_Ready(&swigpyobject_type) < 0)
-      return NULL;
-#endif
-  }
-  return &swigpyobject_type;
-}
-
-SWIGRUNTIME PyObject *SwigPyObject_New(void *ptr, swig_type_info *ty, int own) {
-  SwigPyObject *sobj = PyObject_NEW(SwigPyObject, SwigPyObject_type());
-  if (sobj) {
-    sobj->ptr = ptr;
-    sobj->ty = ty;
-    sobj->own = own;
-    sobj->next = 0;
-  }
-  return (PyObject *)sobj;
-}
-
-/* -----------------------------------------------------------------------------
- * Implements a simple Swig Packed type, and use it instead of string
- * -----------------------------------------------------------------------------
- */
-
-typedef struct {
-  PyObject_HEAD void *pack;
-  swig_type_info *ty;
-  size_t size;
-} SwigPyPacked;
-
-SWIGRUNTIME int SwigPyPacked_print(SwigPyPacked *v, FILE *fp,
-                                   int SWIGUNUSEDPARM(flags)) {
-  char result[SWIG_BUFFER_SIZE];
-  fputs("<Swig Packed ", fp);
-  if (SWIG_PackDataName(result, v->pack, v->size, 0, sizeof(result))) {
-    fputs("at ", fp);
-    fputs(result, fp);
-  }
-  fputs(v->ty->name, fp);
-  fputs(">", fp);
-  return 0;
-}
-
-SWIGRUNTIME PyObject *SwigPyPacked_repr(SwigPyPacked *v) {
-  char result[SWIG_BUFFER_SIZE];
-  if (SWIG_PackDataName(result, v->pack, v->size, 0, sizeof(result))) {
-    return SWIG_Python_str_FromFormat("<Swig Packed at %s%s>", result,
-                                      v->ty->name);
-  } else {
-    return SWIG_Python_str_FromFormat("<Swig Packed %s>", v->ty->name);
-  }
-}
-
-SWIGRUNTIME PyObject *SwigPyPacked_str(SwigPyPacked *v) {
-  char result[SWIG_BUFFER_SIZE];
-  if (SWIG_PackDataName(result, v->pack, v->size, 0, sizeof(result))) {
-    return SWIG_Python_str_FromFormat("%s%s", result, v->ty->name);
-  } else {
-    return SWIG_Python_str_FromChar(v->ty->name);
-  }
-}
-
-SWIGRUNTIME int SwigPyPacked_compare(SwigPyPacked *v, SwigPyPacked *w) {
-  size_t i = v->size;
-  size_t j = w->size;
-  int s = (i < j) ? -1 : ((i > j) ? 1 : 0);
-  return s ? s : strncmp((char *)v->pack, (char *)w->pack, 2 * v->size);
-}
-
-SWIGRUNTIME PyTypeObject *SwigPyPacked_TypeOnce(void);
-
-SWIGRUNTIME PyTypeObject *SwigPyPacked_type(void) {
-  static PyTypeObject *SWIG_STATIC_POINTER(type) = SwigPyPacked_TypeOnce();
-  return type;
-}
-
-SWIGRUNTIMEINLINE int SwigPyPacked_Check(PyObject *op) {
-  return ((op)->ob_type == SwigPyPacked_TypeOnce()) ||
-         (strcmp((op)->ob_type->tp_name, "SwigPyPacked") == 0);
-}
-
-SWIGRUNTIME void SwigPyPacked_dealloc(PyObject *v) {
-  if (SwigPyPacked_Check(v)) {
-    SwigPyPacked *sobj = (SwigPyPacked *)v;
-    free(sobj->pack);
-  }
-  PyObject_DEL(v);
-}
-
-SWIGRUNTIME PyTypeObject *SwigPyPacked_TypeOnce(void) {
-  static char swigpacked_doc[] = "Swig object carries a C/C++ instance pointer";
-  static PyTypeObject swigpypacked_type;
-  static int type_init = 0;
-  if (!type_init) {
-    const PyTypeObject tmp = {
-    /* PyObject header changed in Python 3 */
-#if PY_VERSION_HEX >= 0x03000000
-      PyVarObject_HEAD_INIT(NULL, 0)
-#else
-      PyObject_HEAD_INIT(NULL) 0,    /* ob_size */
-#endif
-          (char *) "SwigPyPacked",      /* tp_name */
-      sizeof(SwigPyPacked),             /* tp_basicsize */
-      0,                                /* tp_itemsize */
-      (destructor)SwigPyPacked_dealloc, /* tp_dealloc */
-      (printfunc)SwigPyPacked_print,    /* tp_print */
-      (getattrfunc)0,                   /* tp_getattr */
-      (setattrfunc)0,                   /* tp_setattr */
-#if PY_VERSION_HEX >= 0x03000000
-      0, /* tp_reserved in 3.0.1 */
-#else
-      (cmpfunc)SwigPyPacked_compare, /* tp_compare */
-#endif
-      (reprfunc)SwigPyPacked_repr, /* tp_repr */
-      0,                           /* tp_as_number */
-      0,                           /* tp_as_sequence */
-      0,                           /* tp_as_mapping */
-      (hashfunc)0,                 /* tp_hash */
-      (ternaryfunc)0,              /* tp_call */
-      (reprfunc)SwigPyPacked_str,  /* tp_str */
-      PyObject_GenericGetAttr,     /* tp_getattro */
-      0,                           /* tp_setattro */
-      0,                           /* tp_as_buffer */
-      Py_TPFLAGS_DEFAULT,          /* tp_flags */
-      swigpacked_doc,              /* tp_doc */
-      0,                           /* tp_traverse */
-      0,                           /* tp_clear */
-      0,                           /* tp_richcompare */
-      0,                           /* tp_weaklistoffset */
-#if PY_VERSION_HEX >= 0x02020000
-      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 */
-      0, /* tp_dictoffset */
-      0, /* tp_init */
-      0, /* tp_alloc */
-      0, /* tp_new */
-      0, /* tp_free */
-      0, /* tp_is_gc */
-      0, /* tp_bases */
-      0, /* tp_mro */
-      0, /* tp_cache */
-      0, /* tp_subclasses */
-      0, /* tp_weaklist */
-#endif
-#if PY_VERSION_HEX >= 0x02030000
-      0, /* tp_del */
-#endif
-#if PY_VERSION_HEX >= 0x02060000
-      0, /* tp_version_tag */
-#endif
-#if PY_VERSION_HEX >= 0x03040000
-      0, /* tp_finalize */
-#endif
-#ifdef COUNT_ALLOCS
-      0, /* tp_allocs */
-      0, /* tp_frees */
-      0, /* tp_maxalloc */
-#if PY_VERSION_HEX >= 0x02050000
-      0, /* tp_prev */
-#endif
-      0 /* tp_next */
-#endif
-    };
-    swigpypacked_type = tmp;
-    type_init = 1;
-#if PY_VERSION_HEX < 0x02020000
-    swigpypacked_type.ob_type = &PyType_Type;
-#else
-    if (PyType_Ready(&swigpypacked_type) < 0)
-      return NULL;
-#endif
-  }
-  return &swigpypacked_type;
-}
-
-SWIGRUNTIME PyObject *SwigPyPacked_New(void *ptr, size_t size,
-                                       swig_type_info *ty) {
-  SwigPyPacked *sobj = PyObject_NEW(SwigPyPacked, SwigPyPacked_type());
-  if (sobj) {
-    void *pack = malloc(size);
-    if (pack) {
-      memcpy(pack, ptr, size);
-      sobj->pack = pack;
-      sobj->ty = ty;
-      sobj->size = size;
-    } else {
-      PyObject_DEL((PyObject *)sobj);
-      sobj = 0;
-    }
-  }
-  return (PyObject *)sobj;
-}
-
-SWIGRUNTIME swig_type_info *SwigPyPacked_UnpackData(PyObject *obj, void *ptr,
-                                                    size_t size) {
-  if (SwigPyPacked_Check(obj)) {
-    SwigPyPacked *sobj = (SwigPyPacked *)obj;
-    if (sobj->size != size)
-      return 0;
-    memcpy(ptr, sobj->pack, size);
-    return sobj->ty;
-  } else {
-    return 0;
-  }
-}
-
-/* -----------------------------------------------------------------------------
- * pointers/data manipulation
- * -----------------------------------------------------------------------------
- */
-
-SWIGRUNTIMEINLINE PyObject *_SWIG_This(void) {
-  return SWIG_Python_str_FromChar("this");
-}
-
-static PyObject *swig_this = NULL;
-
-SWIGRUNTIME PyObject *SWIG_This(void) {
-  if (swig_this == NULL)
-    swig_this = _SWIG_This();
-  return swig_this;
-}
-
-/* #define SWIG_PYTHON_SLOW_GETSET_THIS */
-
-/* TODO: I don't know how to implement the fast getset in Python 3 right now */
-#if PY_VERSION_HEX >= 0x03000000
-#define SWIG_PYTHON_SLOW_GETSET_THIS
-#endif
-
-SWIGRUNTIME SwigPyObject *SWIG_Python_GetSwigThis(PyObject *pyobj) {
-  PyObject *obj;
-
-  if (SwigPyObject_Check(pyobj))
-    return (SwigPyObject *)pyobj;
-
-#ifdef SWIGPYTHON_BUILTIN
-  (void)obj;
-#ifdef PyWeakref_CheckProxy
-  if (PyWeakref_CheckProxy(pyobj)) {
-    pyobj = PyWeakref_GET_OBJECT(pyobj);
-    if (pyobj && SwigPyObject_Check(pyobj))
-      return (SwigPyObject *)pyobj;
-  }
-#endif
-  return NULL;
-#else
-
-  obj = 0;
-
-#if (!defined(SWIG_PYTHON_SLOW_GETSET_THIS) && (PY_VERSION_HEX >= 0x02030000))
-  if (PyInstance_Check(pyobj)) {
-    obj = _PyInstance_Lookup(pyobj, SWIG_This());
-  } else {
-    PyObject **dictptr = _PyObject_GetDictPtr(pyobj);
-    if (dictptr != NULL) {
-      PyObject *dict = *dictptr;
-      obj = dict ? PyDict_GetItem(dict, SWIG_This()) : 0;
-    } else {
-#ifdef PyWeakref_CheckProxy
-      if (PyWeakref_CheckProxy(pyobj)) {
-        PyObject *wobj = PyWeakref_GET_OBJECT(pyobj);
-        return wobj ? SWIG_Python_GetSwigThis(wobj) : 0;
-      }
-#endif
-      obj = PyObject_GetAttr(pyobj, SWIG_This());
-      if (obj) {
-        Py_DECREF(obj);
-      } else {
-        if (PyErr_Occurred())
-          PyErr_Clear();
-        return 0;
-      }
-    }
-  }
-#else
-  obj = PyObject_GetAttr(pyobj, SWIG_This());
-  if (obj) {
-    Py_DECREF(obj);
-  } else {
-    if (PyErr_Occurred())
-      PyErr_Clear();
-    return 0;
-  }
-#endif
-  if (obj && !SwigPyObject_Check(obj)) {
-    /* a PyObject is called 'this', try to get the 'real this'
-       SwigPyObject from it */
-    return SWIG_Python_GetSwigThis(obj);
-  }
-  return (SwigPyObject *)obj;
-#endif
-}
-
-/* Acquire a pointer value */
-
-SWIGRUNTIME int SWIG_Python_AcquirePtr(PyObject *obj, int own) {
-  if (own == SWIG_POINTER_OWN) {
-    SwigPyObject *sobj = SWIG_Python_GetSwigThis(obj);
-    if (sobj) {
-      int oldown = sobj->own;
-      sobj->own = own;
-      return oldown;
-    }
-  }
-  return 0;
-}
-
-/* Convert a pointer value */
-
-SWIGRUNTIME int SWIG_Python_ConvertPtrAndOwn(PyObject *obj, void **ptr,
-                                             swig_type_info *ty, int flags,
-                                             int *own) {
-  int res;
-  SwigPyObject *sobj;
-  int implicit_conv = (flags & SWIG_POINTER_IMPLICIT_CONV) != 0;
-
-  if (!obj)
-    return SWIG_ERROR;
-  if (obj == Py_None && !implicit_conv) {
-    if (ptr)
-      *ptr = 0;
-    return SWIG_OK;
-  }
-
-  res = SWIG_ERROR;
-
-  sobj = SWIG_Python_GetSwigThis(obj);
-  if (own)
-    *own = 0;
-  while (sobj) {
-    void *vptr = sobj->ptr;
-    if (ty) {
-      swig_type_info *to = sobj->ty;
-      if (to == ty) {
-        /* no type cast needed */
-        if (ptr)
-          *ptr = vptr;
-        break;
-      } else {
-        swig_cast_info *tc = SWIG_TypeCheck(to->name, ty);
-        if (!tc) {
-          sobj = (SwigPyObject *)sobj->next;
-        } else {
-          if (ptr) {
-            int newmemory = 0;
-            *ptr = SWIG_TypeCast(tc, vptr, &newmemory);
-            if (newmemory == SWIG_CAST_NEW_MEMORY) {
-              assert(own); /* badly formed typemap which will lead to a memory
-                              leak - it must set and use own to delete *ptr */
-              if (own)
-                *own = *own | SWIG_CAST_NEW_MEMORY;
-            }
-          }
-          break;
-        }
-      }
-    } else {
-      if (ptr)
-        *ptr = vptr;
-      break;
-    }
-  }
-  if (sobj) {
-    if (own)
-      *own = *own | sobj->own;
-    if (flags & SWIG_POINTER_DISOWN) {
-      sobj->own = 0;
-    }
-    res = SWIG_OK;
-  } else {
-    if (implicit_conv) {
-      SwigPyClientData *data = ty ? (SwigPyClientData *)ty->clientdata : 0;
-      if (data && !data->implicitconv) {
-        PyObject *klass = data->klass;
-        if (klass) {
-          PyObject *impconv;
-          data->implicitconv =
-              1; /* avoid recursion and call 'explicit' constructors*/
-          impconv = SWIG_Python_CallFunctor(klass, obj);
-          data->implicitconv = 0;
-          if (PyErr_Occurred()) {
-            PyErr_Clear();
-            impconv = 0;
-          }
-          if (impconv) {
-            SwigPyObject *iobj = SWIG_Python_GetSwigThis(impconv);
-            if (iobj) {
-              void *vptr;
-              res = SWIG_Python_ConvertPtrAndOwn((PyObject *)iobj, &vptr, ty, 0,
-                                                 0);
-              if (SWIG_IsOK(res)) {
-                if (ptr) {
-                  *ptr = vptr;
-                  /* transfer the ownership to 'ptr' */
-                  iobj->own = 0;
-                  res = SWIG_AddCast(res);
-                  res = SWIG_AddNewMask(res);
-                } else {
-                  res = SWIG_AddCast(res);
-                }
-              }
-            }
-            Py_DECREF(impconv);
-          }
-        }
-      }
-    }
-    if (!SWIG_IsOK(res) && obj == Py_None) {
-      if (ptr)
-        *ptr = 0;
-      if (PyErr_Occurred())
-        PyErr_Clear();
-      res = SWIG_OK;
-    }
-  }
-  return res;
-}
-
-/* Convert a function ptr value */
-
-SWIGRUNTIME int SWIG_Python_ConvertFunctionPtr(PyObject *obj, void **ptr,
-                                               swig_type_info *ty) {
-  if (!PyCFunction_Check(obj)) {
-    return SWIG_ConvertPtr(obj, ptr, ty, 0);
-  } else {
-    void *vptr = 0;
-
-    /* here we get the method pointer for callbacks */
-    const char *doc = (((PyCFunctionObject *)obj)->m_ml->ml_doc);
-    const char *desc = doc ? strstr(doc, "swig_ptr: ") : 0;
-    if (desc)
-      desc = ty ? SWIG_UnpackVoidPtr(desc + 10, &vptr, ty->name) : 0;
-    if (!desc)
-      return SWIG_ERROR;
-    if (ty) {
-      swig_cast_info *tc = SWIG_TypeCheck(desc, ty);
-      if (tc) {
-        int newmemory = 0;
-        *ptr = SWIG_TypeCast(tc, vptr, &newmemory);
-        assert(!newmemory); /* newmemory handling not yet implemented */
-      } else {
-        return SWIG_ERROR;
-      }
-    } else {
-      *ptr = vptr;
-    }
-    return SWIG_OK;
-  }
-}
-
-/* Convert a packed value value */
-
-SWIGRUNTIME int SWIG_Python_ConvertPacked(PyObject *obj, void *ptr, size_t sz,
-                                          swig_type_info *ty) {
-  swig_type_info *to = SwigPyPacked_UnpackData(obj, ptr, sz);
-  if (!to)
-    return SWIG_ERROR;
-  if (ty) {
-    if (to != ty) {
-      /* check type cast? */
-      swig_cast_info *tc = SWIG_TypeCheck(to->name, ty);
-      if (!tc)
-        return SWIG_ERROR;
-    }
-  }
-  return SWIG_OK;
-}
-
-/* -----------------------------------------------------------------------------
- * Create a new pointer object
- * -----------------------------------------------------------------------------
- */
-
-/*
-  Create a new instance object, without calling __init__, and set the
-  'this' attribute.
-*/
-
-SWIGRUNTIME PyObject *SWIG_Python_NewShadowInstance(SwigPyClientData *data,
-                                                    PyObject *swig_this) {
-#if (PY_VERSION_HEX >= 0x02020000)
-  PyObject *inst = 0;
-  PyObject *newraw = data->newraw;
-  if (newraw) {
-    inst = PyObject_Call(newraw, data->newargs, NULL);
-    if (inst) {
-#if !defined(SWIG_PYTHON_SLOW_GETSET_THIS)
-      PyObject **dictptr = _PyObject_GetDictPtr(inst);
-      if (dictptr != NULL) {
-        PyObject *dict = *dictptr;
-        if (dict == NULL) {
-          dict = PyDict_New();
-          *dictptr = dict;
-          PyDict_SetItem(dict, SWIG_This(), swig_this);
-        }
-      }
-#else
-      PyObject *key = SWIG_This();
-      PyObject_SetAttr(inst, key, swig_this);
-#endif
-    }
-  } else {
-#if PY_VERSION_HEX >= 0x03000000
-    inst = ((PyTypeObject *)data->newargs)
-               ->tp_new((PyTypeObject *)data->newargs, Py_None, Py_None);
-    if (inst) {
-      PyObject_SetAttr(inst, SWIG_This(), swig_this);
-      Py_TYPE(inst)->tp_flags &= ~Py_TPFLAGS_VALID_VERSION_TAG;
-    }
-#else
-    PyObject *dict = PyDict_New();
-    if (dict) {
-      PyDict_SetItem(dict, SWIG_This(), swig_this);
-      inst = PyInstance_NewRaw(data->newargs, dict);
-      Py_DECREF(dict);
-    }
-#endif
-  }
-  return inst;
-#else
-#if (PY_VERSION_HEX >= 0x02010000)
-  PyObject *inst = 0;
-  PyObject *dict = PyDict_New();
-  if (dict) {
-    PyDict_SetItem(dict, SWIG_This(), swig_this);
-    inst = PyInstance_NewRaw(data->newargs, dict);
-    Py_DECREF(dict);
-  }
-  return (PyObject *)inst;
-#else
-  PyInstanceObject *inst = PyObject_NEW(PyInstanceObject, &PyInstance_Type);
-  if (inst == NULL) {
-    return NULL;
-  }
-  inst->in_class = (PyClassObject *)data->newargs;
-  Py_INCREF(inst->in_class);
-  inst->in_dict = PyDict_New();
-  if (inst->in_dict == NULL) {
-    Py_DECREF(inst);
-    return NULL;
-  }
-#ifdef Py_TPFLAGS_HAVE_WEAKREFS
-  inst->in_weakreflist = NULL;
-#endif
-#ifdef Py_TPFLAGS_GC
-  PyObject_GC_Init(inst);
-#endif
-  PyDict_SetItem(inst->in_dict, SWIG_This(), swig_this);
-  return (PyObject *)inst;
-#endif
-#endif
-}
-
-SWIGRUNTIME void SWIG_Python_SetSwigThis(PyObject *inst, PyObject *swig_this) {
-  PyObject *dict;
-#if (PY_VERSION_HEX >= 0x02020000) && !defined(SWIG_PYTHON_SLOW_GETSET_THIS)
-  PyObject **dictptr = _PyObject_GetDictPtr(inst);
-  if (dictptr != NULL) {
-    dict = *dictptr;
-    if (dict == NULL) {
-      dict = PyDict_New();
-      *dictptr = dict;
-    }
-    PyDict_SetItem(dict, SWIG_This(), swig_this);
-    return;
-  }
-#endif
-  dict = PyObject_GetAttrString(inst, (char *)"__dict__");
-  PyDict_SetItem(dict, SWIG_This(), swig_this);
-  Py_DECREF(dict);
-}
-
-SWIGINTERN PyObject *SWIG_Python_InitShadowInstance(PyObject *args) {
-  PyObject *obj[2];
-  if (!SWIG_Python_UnpackTuple(args, "swiginit", 2, 2, obj)) {
-    return NULL;
-  } else {
-    SwigPyObject *sthis = SWIG_Python_GetSwigThis(obj[0]);
-    if (sthis) {
-      SwigPyObject_append((PyObject *)sthis, obj[1]);
-    } else {
-      SWIG_Python_SetSwigThis(obj[0], obj[1]);
-    }
-    return SWIG_Py_Void();
-  }
-}
-
-/* Create a new pointer object */
-
-SWIGRUNTIME PyObject *SWIG_Python_NewPointerObj(PyObject *self, void *ptr,
-                                                swig_type_info *type,
-                                                int flags) {
-  SwigPyClientData *clientdata;
-  PyObject *robj;
-  int own;
-
-  if (!ptr)
-    return SWIG_Py_Void();
-
-  clientdata = type ? (SwigPyClientData *)(type->clientdata) : 0;
-  own = (flags & SWIG_POINTER_OWN) ? SWIG_POINTER_OWN : 0;
-  if (clientdata && clientdata->pytype) {
-    SwigPyObject *newobj;
-    if (flags & SWIG_BUILTIN_TP_INIT) {
-      newobj = (SwigPyObject *)self;
-      if (newobj->ptr) {
-        PyObject *next_self =
-            clientdata->pytype->tp_alloc(clientdata->pytype, 0);
-        while (newobj->next)
-          newobj = (SwigPyObject *)newobj->next;
-        newobj->next = next_self;
-        newobj = (SwigPyObject *)next_self;
-#ifdef SWIGPYTHON_BUILTIN
-        newobj->dict = 0;
-#endif
-      }
-    } else {
-      newobj = PyObject_New(SwigPyObject, clientdata->pytype);
-#ifdef SWIGPYTHON_BUILTIN
-      newobj->dict = 0;
-#endif
-    }
-    if (newobj) {
-      newobj->ptr = ptr;
-      newobj->ty = type;
-      newobj->own = own;
-      newobj->next = 0;
-      return (PyObject *)newobj;
-    }
-    return SWIG_Py_Void();
-  }
-
-  assert(!(flags & SWIG_BUILTIN_TP_INIT));
-
-  robj = SwigPyObject_New(ptr, type, own);
-  if (robj && clientdata && !(flags & SWIG_POINTER_NOSHADOW)) {
-    PyObject *inst = SWIG_Python_NewShadowInstance(clientdata, robj);
-    Py_DECREF(robj);
-    robj = inst;
-  }
-  return robj;
-}
-
-/* Create a new packed object */
-
-SWIGRUNTIMEINLINE PyObject *SWIG_Python_NewPackedObj(void *ptr, size_t sz,
-                                                     swig_type_info *type) {
-  return ptr ? SwigPyPacked_New((void *)ptr, sz, type) : SWIG_Py_Void();
-}
-
-/* -----------------------------------------------------------------------------*
- *  Get type list
- * -----------------------------------------------------------------------------*/
-
-#ifdef SWIG_LINK_RUNTIME
-void *SWIG_ReturnGlobalTypeList(void *);
-#endif
-
-SWIGRUNTIME swig_module_info *
-SWIG_Python_GetModule(void *SWIGUNUSEDPARM(clientdata)) {
-  static void *type_pointer = (void *)0;
-  /* first check if module already created */
-  if (!type_pointer) {
-#ifdef SWIG_LINK_RUNTIME
-    type_pointer = SWIG_ReturnGlobalTypeList((void *)0);
-#else
-#ifdef SWIGPY_USE_CAPSULE
-    type_pointer = PyCapsule_Import(SWIGPY_CAPSULE_NAME, 0);
-#else
-    type_pointer =
-        PyCObject_Import((char *)"swig_runtime_data" SWIG_RUNTIME_VERSION,
-                         (char *)"type_pointer" SWIG_TYPE_TABLE_NAME);
-#endif
-    if (PyErr_Occurred()) {
-      PyErr_Clear();
-      type_pointer = (void *)0;
-    }
-#endif
-  }
-  return (swig_module_info *)type_pointer;
-}
-
-#if PY_MAJOR_VERSION < 2
-/* PyModule_AddObject function was introduced in Python 2.0.  The following
-   function is copied out of Python/modsupport.c in python version 2.3.4 */
-SWIGINTERN int PyModule_AddObject(PyObject *m, char *name, PyObject *o) {
-  PyObject *dict;
-  if (!PyModule_Check(m)) {
-    PyErr_SetString(PyExc_TypeError,
-                    "PyModule_AddObject() needs module as first arg");
-    return SWIG_ERROR;
-  }
-  if (!o) {
-    PyErr_SetString(PyExc_TypeError,
-                    "PyModule_AddObject() needs non-NULL value");
-    return SWIG_ERROR;
-  }
-
-  dict = PyModule_GetDict(m);
-  if (dict == NULL) {
-    /* Internal error -- modules must have a dict! */
-    PyErr_Format(PyExc_SystemError, "module '%s' has no __dict__",
-                 PyModule_GetName(m));
-    return SWIG_ERROR;
-  }
-  if (PyDict_SetItemString(dict, name, o))
-    return SWIG_ERROR;
-  Py_DECREF(o);
-  return SWIG_OK;
-}
-#endif
-
-SWIGRUNTIME void
-#ifdef SWIGPY_USE_CAPSULE
-SWIG_Python_DestroyModule(PyObject *obj)
-#else
-SWIG_Python_DestroyModule(void *vptr)
-#endif
-{
-#ifdef SWIGPY_USE_CAPSULE
-  swig_module_info *swig_module =
-      (swig_module_info *)PyCapsule_GetPointer(obj, SWIGPY_CAPSULE_NAME);
-#else
-  swig_module_info *swig_module = (swig_module_info *)vptr;
-#endif
-  swig_type_info **types = swig_module->types;
-  size_t i;
-  for (i = 0; i < swig_module->size; ++i) {
-    swig_type_info *ty = types[i];
-    if (ty->owndata) {
-      SwigPyClientData *data = (SwigPyClientData *)ty->clientdata;
-      if (data)
-        SwigPyClientData_Del(data);
-    }
-  }
-  Py_DECREF(SWIG_This());
-  swig_this = NULL;
-}
-
-SWIGRUNTIME void SWIG_Python_SetModule(swig_module_info *swig_module) {
-#if PY_VERSION_HEX >= 0x03000000
-  /* Add a dummy module object into sys.modules */
-  PyObject *module =
-      PyImport_AddModule((char *)"swig_runtime_data" SWIG_RUNTIME_VERSION);
-#else
-  static PyMethodDef swig_empty_runtime_method_table[] = {
-      {NULL, NULL, 0, NULL}}; /* Sentinel */
-  PyObject *module =
-      Py_InitModule((char *)"swig_runtime_data" SWIG_RUNTIME_VERSION,
-                    swig_empty_runtime_method_table);
-#endif
-#ifdef SWIGPY_USE_CAPSULE
-  PyObject *pointer = PyCapsule_New((void *)swig_module, SWIGPY_CAPSULE_NAME,
-                                    SWIG_Python_DestroyModule);
-  if (pointer && module) {
-    PyModule_AddObject(
-        module, (char *)"type_pointer_capsule" SWIG_TYPE_TABLE_NAME, pointer);
-  } else {
-    Py_XDECREF(pointer);
-  }
-#else
-  PyObject *pointer =
-      PyCObject_FromVoidPtr((void *)swig_module, SWIG_Python_DestroyModule);
-  if (pointer && module) {
-    PyModule_AddObject(module, (char *)"type_pointer" SWIG_TYPE_TABLE_NAME,
-                       pointer);
-  } else {
-    Py_XDECREF(pointer);
-  }
-#endif
-}
-
-/* The python cached type query */
-SWIGRUNTIME PyObject *SWIG_Python_TypeCache(void) {
-  static PyObject *SWIG_STATIC_POINTER(cache) = PyDict_New();
-  return cache;
-}
-
-SWIGRUNTIME swig_type_info *SWIG_Python_TypeQuery(const char *type) {
-  PyObject *cache = SWIG_Python_TypeCache();
-  PyObject *key = SWIG_Python_str_FromChar(type);
-  PyObject *obj = PyDict_GetItem(cache, key);
-  swig_type_info *descriptor;
-  if (obj) {
-#ifdef SWIGPY_USE_CAPSULE
-    descriptor = (swig_type_info *)PyCapsule_GetPointer(obj, NULL);
-#else
-    descriptor = (swig_type_info *)PyCObject_AsVoidPtr(obj);
-#endif
-  } else {
-    swig_module_info *swig_module = SWIG_GetModule(0);
-    descriptor = SWIG_TypeQueryModule(swig_module, swig_module, type);
-    if (descriptor) {
-#ifdef SWIGPY_USE_CAPSULE
-      obj = PyCapsule_New((void *)descriptor, NULL, NULL);
-#else
-      obj = PyCObject_FromVoidPtr(descriptor, NULL);
-#endif
-      PyDict_SetItem(cache, key, obj);
-      Py_DECREF(obj);
-    }
-  }
-  Py_DECREF(key);
-  return descriptor;
-}
-
-/*
-   For backward compatibility only
-*/
-#define SWIG_POINTER_EXCEPTION 0
-#define SWIG_arg_fail(arg) SWIG_Python_ArgFail(arg)
-#define SWIG_MustGetPtr(p, type, argnum, flags)                                \
-  SWIG_Python_MustGetPtr(p, type, argnum, flags)
-
-SWIGRUNTIME int SWIG_Python_AddErrMesg(const char *mesg, int infront) {
-  if (PyErr_Occurred()) {
-    PyObject *type = 0;
-    PyObject *value = 0;
-    PyObject *traceback = 0;
-    PyErr_Fetch(&type, &value, &traceback);
-    if (value) {
-      char *tmp;
-      PyObject *old_str = PyObject_Str(value);
-      Py_XINCREF(type);
-      PyErr_Clear();
-      if (infront) {
-        PyErr_Format(type, "%s %s", mesg,
-                     tmp = SWIG_Python_str_AsChar(old_str));
-      } else {
-        PyErr_Format(type, "%s %s", tmp = SWIG_Python_str_AsChar(old_str),
-                     mesg);
-      }
-      SWIG_Python_str_DelForPy3(tmp);
-      Py_DECREF(old_str);
-    }
-    return 1;
-  } else {
-    return 0;
-  }
-}
-
-SWIGRUNTIME int SWIG_Python_ArgFail(int argnum) {
-  if (PyErr_Occurred()) {
-    /* add information about failing argument */
-    char mesg[256];
-    PyOS_snprintf(mesg, sizeof(mesg), "argument number %d:", argnum);
-    return SWIG_Python_AddErrMesg(mesg, 1);
-  } else {
-    return 0;
-  }
-}
-
-SWIGRUNTIMEINLINE const char *SwigPyObject_GetDesc(PyObject *self) {
-  SwigPyObject *v = (SwigPyObject *)self;
-  swig_type_info *ty = v ? v->ty : 0;
-  return ty ? ty->str : "";
-}
-
-SWIGRUNTIME void SWIG_Python_TypeError(const char *type, PyObject *obj) {
-  if (type) {
-#if defined(SWIG_COBJECT_TYPES)
-    if (obj && SwigPyObject_Check(obj)) {
-      const char *otype = (const char *)SwigPyObject_GetDesc(obj);
-      if (otype) {
-        PyErr_Format(PyExc_TypeError,
-                     "a '%s' is expected, 'SwigPyObject(%s)' is received", type,
-                     otype);
-        return;
-      }
-    } else
-#endif
-    {
-      const char *otype = (obj ? obj->ob_type->tp_name : 0);
-      if (otype) {
-        PyObject *str = PyObject_Str(obj);
-        const char *cstr = str ? SWIG_Python_str_AsChar(str) : 0;
-        if (cstr) {
-          PyErr_Format(PyExc_TypeError,
-                       "a '%s' is expected, '%s(%s)' is received", type, otype,
-                       cstr);
-          SWIG_Python_str_DelForPy3(cstr);
-        } else {
-          PyErr_Format(PyExc_TypeError, "a '%s' is expected, '%s' is received",
-                       type, otype);
-        }
-        Py_XDECREF(str);
-        return;
-      }
-    }
-    PyErr_Format(PyExc_TypeError, "a '%s' is expected", type);
-  } else {
-    PyErr_Format(PyExc_TypeError, "unexpected type is received");
-  }
-}
-
-/* Convert a pointer value, signal an exception on a type mismatch */
-SWIGRUNTIME void *SWIG_Python_MustGetPtr(PyObject *obj, swig_type_info *ty,
-                                         int SWIGUNUSEDPARM(argnum),
-                                         int flags) {
-  void *result;
-  if (SWIG_Python_ConvertPtr(obj, &result, ty, flags) == -1) {
-    PyErr_Clear();
-#if SWIG_POINTER_EXCEPTION
-    if (flags) {
-      SWIG_Python_TypeError(SWIG_TypePrettyName(ty), obj);
-      SWIG_Python_ArgFail(argnum);
-    }
-#endif
-  }
-  return result;
-}
-
-#ifdef SWIGPYTHON_BUILTIN
-SWIGRUNTIME int SWIG_Python_NonDynamicSetAttr(PyObject *obj, PyObject *name,
-                                              PyObject *value) {
-  PyTypeObject *tp = obj->ob_type;
-  PyObject *descr;
-  PyObject *encoded_name;
-  descrsetfunc f;
-  int res = -1;
-
-#ifdef Py_USING_UNICODE
-  if (PyString_Check(name)) {
-    name = PyUnicode_Decode(PyString_AsString(name), PyString_Size(name), NULL,
-                            NULL);
-    if (!name)
-      return -1;
-  } else if (!PyUnicode_Check(name))
-#else
-  if (!PyString_Check(name))
-#endif
-  {
-    PyErr_Format(PyExc_TypeError, "attribute name must be string, not '%.200s'",
-                 name->ob_type->tp_name);
-    return -1;
-  } else {
-    Py_INCREF(name);
-  }
-
-  if (!tp->tp_dict) {
-    if (PyType_Ready(tp) < 0)
-      goto done;
-  }
-
-  descr = _PyType_Lookup(tp, name);
-  f = NULL;
-  if (descr != NULL)
-    f = descr->ob_type->tp_descr_set;
-  if (!f) {
-    if (PyString_Check(name)) {
-      encoded_name = name;
-      Py_INCREF(name);
-    } else {
-      encoded_name = PyUnicode_AsUTF8String(name);
-    }
-    PyErr_Format(PyExc_AttributeError,
-                 "'%.100s' object has no attribute '%.200s'", tp->tp_name,
-                 PyString_AsString(encoded_name));
-    Py_DECREF(encoded_name);
-  } else {
-    res = f(descr, obj, value);
-  }
-
-done:
-  Py_DECREF(name);
-  return res;
-}
-#endif
-
-#ifdef __cplusplus
-}
-#endif
-
-#define SWIG_exception_fail(code, msg)                                         \
-  do {                                                                         \
-    SWIG_Error(code, msg);                                                     \
-    SWIG_fail;                                                                 \
-  } while (0)
-
-#define SWIG_contract_assert(expr, msg)                                        \
-  if (!(expr)) {                                                               \
-    SWIG_Error(SWIG_RuntimeError, msg);                                        \
-    SWIG_fail;                                                                 \
-  } else
-
-/* -------- TYPES TABLE (BEGIN) -------- */
-
-#define SWIGTYPE_p_char swig_types[0]
-#define SWIGTYPE_p_float swig_types[1]
-static swig_type_info *swig_types[3];
-static swig_module_info swig_module = {swig_types, 2, 0, 0, 0, 0};
-#define SWIG_TypeQuery(name)                                                   \
-  SWIG_TypeQueryModule(&swig_module, &swig_module, name)
-#define SWIG_MangledTypeQuery(name)                                            \
-  SWIG_MangledTypeQueryModule(&swig_module, &swig_module, name)
-
-/* -------- TYPES TABLE (END) -------- */
-
-#if (PY_VERSION_HEX <= 0x02000000)
-#if !defined(SWIG_PYTHON_CLASSIC)
-#error "This python version requires swig to be run with the '-classic' option"
-#endif
-#endif
-
-/*-----------------------------------------------
-              @(target):= _cmodule.so
-  ------------------------------------------------*/
-#if PY_VERSION_HEX >= 0x03000000
-#define SWIG_init PyInit__cmodule
-
-#else
-#define SWIG_init init_cmodule
-
-#endif
-#define SWIG_name "_cmodule"
-
-#define SWIGVERSION 0x030008
-#define SWIG_VERSION SWIGVERSION
-
-#define SWIG_as_voidptr(a) (void *)((const void *)(a))
-#define SWIG_as_voidptrptr(a) ((void)SWIG_as_voidptr(*a), (void **)(a))
-
-#define SWIG_FILE_WITH_INIT
-#include "gamut_map.h"
-
-#ifndef SWIG_FILE_WITH_INIT
-#define NO_IMPORT_ARRAY
-#endif
-#include "stdio.h"
-#define NPY_NO_DEPRECATED_API NPY_1_7_API_VERSION
-#include <numpy/arrayobject.h>
-
-void gamut_map_full(float *input, int in_dim1, int in_dim2, int in_dim3,
-                    float *result, int out_dim1, int out_dim2, int out_dim3,
-                    float *ctrl_pts, int cp_dim1, int cp_dim2, float *weights,
-                    int weight_dim1, int weight_dim2, float *coefs,
-                    int coef_dim1, int coef_dim2) {
-  gamut_map(input, in_dim1, in_dim2, in_dim3, result, ctrl_pts, weights, coefs,
-            cp_dim1);
-}
-
-#if NPY_API_VERSION < 0x00000007
-#define NPY_ARRAY_DEFAULT NPY_DEFAULT
-#define NPY_ARRAY_FARRAY NPY_FARRAY
-#define NPY_FORTRANORDER NPY_FORTRAN
-#endif
-
-/* Macros to extract array attributes.
- */
-#if NPY_API_VERSION < 0x00000007
-#define is_array(a) ((a) && PyArray_Check((PyArrayObject *)a))
-#define array_type(a) (int)(PyArray_TYPE((PyArrayObject *)a))
-#define array_numdims(a) (((PyArrayObject *)a)->nd)
-#define array_dimensions(a) (((PyArrayObject *)a)->dimensions)
-#define array_size(a, i) (((PyArrayObject *)a)->dimensions[i])
-#define array_strides(a) (((PyArrayObject *)a)->strides)
-#define array_stride(a, i) (((PyArrayObject *)a)->strides[i])
-#define array_data(a) (((PyArrayObject *)a)->data)
-#define array_descr(a) (((PyArrayObject *)a)->descr)
-#define array_flags(a) (((PyArrayObject *)a)->flags)
-#define array_clearflags(a, f) (((PyArrayObject *)a)->flags) &= ~f
-#define array_enableflags(a, f) (((PyArrayObject *)a)->flags) = f
-#define array_is_fortran(a) (PyArray_ISFORTRAN((PyArrayObject *)a))
-#else
-#define is_array(a) ((a) && PyArray_Check(a))
-#define array_type(a) PyArray_TYPE((PyArrayObject *)a)
-#define array_numdims(a) PyArray_NDIM((PyArrayObject *)a)
-#define array_dimensions(a) PyArray_DIMS((PyArrayObject *)a)
-#define array_strides(a) PyArray_STRIDES((PyArrayObject *)a)
-#define array_stride(a, i) PyArray_STRIDE((PyArrayObject *)a, i)
-#define array_size(a, i) PyArray_DIM((PyArrayObject *)a, i)
-#define array_data(a) PyArray_DATA((PyArrayObject *)a)
-#define array_descr(a) PyArray_DESCR((PyArrayObject *)a)
-#define array_flags(a) PyArray_FLAGS((PyArrayObject *)a)
-#define array_enableflags(a, f) PyArray_ENABLEFLAGS((PyArrayObject *)a, f)
-#define array_clearflags(a, f) PyArray_CLEARFLAGS((PyArrayObject *)a, f)
-#define array_is_fortran(a) (PyArray_IS_F_CONTIGUOUS((PyArrayObject *)a))
-#endif
-#define array_is_contiguous(a) (PyArray_ISCONTIGUOUS((PyArrayObject *)a))
-#define array_is_native(a) (PyArray_ISNOTSWAPPED((PyArrayObject *)a))
-
-/* Given a PyObject, return a string describing its type.
- */
-const char *pytype_string(PyObject *py_obj) {
-  if (py_obj == NULL)
-    return "C NULL value";
-  if (py_obj == Py_None)
-    return "Python None";
-  if (PyCallable_Check(py_obj))
-    return "callable";
-  if (PyString_Check(py_obj))
-    return "string";
-  if (PyInt_Check(py_obj))
-    return "int";
-  if (PyFloat_Check(py_obj))
-    return "float";
-  if (PyDict_Check(py_obj))
-    return "dict";
-  if (PyList_Check(py_obj))
-    return "list";
-  if (PyTuple_Check(py_obj))
-    return "tuple";
-#if PY_MAJOR_VERSION < 3
-  if (PyFile_Check(py_obj))
-    return "file";
-  if (PyModule_Check(py_obj))
-    return "module";
-  if (PyInstance_Check(py_obj))
-    return "instance";
-#endif
-
-  return "unknown type";
-}
-
-/* Given a NumPy typecode, return a string describing the type.
- */
-const char *typecode_string(int typecode) {
-  static const char *type_names[25] = {"bool",
-                                       "byte",
-                                       "unsigned byte",
-                                       "short",
-                                       "unsigned short",
-                                       "int",
-                                       "unsigned int",
-                                       "long",
-                                       "unsigned long",
-                                       "long long",
-                                       "unsigned long long",
-                                       "float",
-                                       "double",
-                                       "long double",
-                                       "complex float",
-                                       "complex double",
-                                       "complex long double",
-                                       "object",
-                                       "string",
-                                       "unicode",
-                                       "void",
-                                       "ntypes",
-                                       "notype",
-                                       "char",
-                                       "unknown"};
-  return typecode < 24 ? type_names[typecode] : type_names[24];
-}
-
-/* Make sure input has correct numpy type.  This now just calls
-   PyArray_EquivTypenums().
- */
-int type_match(int actual_type, int desired_type) {
-  return PyArray_EquivTypenums(actual_type, desired_type);
-}
-
-#ifdef SWIGPY_USE_CAPSULE
-void free_cap(PyObject *cap) {
-  void *array = (void *)PyCapsule_GetPointer(cap, SWIGPY_CAPSULE_NAME);
-  if (array != NULL)
-    free(array);
-}
-#endif
-
-/* Given a PyObject pointer, cast it to a PyArrayObject pointer if
- * legal.  If not, set the python error string appropriately and
- * return NULL.
- */
-PyArrayObject *obj_to_array_no_conversion(PyObject *input, int typecode) {
-  PyArrayObject *ary = NULL;
-  if (is_array(input) && (typecode == NPY_NOTYPE ||
-                          PyArray_EquivTypenums(array_type(input), typecode))) {
-    ary = (PyArrayObject *)input;
-  } else if
-    is_array(input) {
-      const char *desired_type = typecode_string(typecode);
-      const char *actual_type = typecode_string(array_type(input));
-      PyErr_Format(PyExc_TypeError,
-                   "Array of type '%s' required.  Array of type '%s' given",
-                   desired_type, actual_type);
-      ary = NULL;
-    }
-  else {
-    const char *desired_type = typecode_string(typecode);
-    const char *actual_type = pytype_string(input);
-    PyErr_Format(PyExc_TypeError,
-                 "Array of type '%s' required.  A '%s' was given", desired_type,
-                 actual_type);
-    ary = NULL;
-  }
-  return ary;
-}
-
-/* Convert the given PyObject to a NumPy array with the given
- * typecode.  On success, return a valid PyArrayObject* with the
- * correct type.  On failure, the python error string will be set and
- * the routine returns NULL.
- */
-PyArrayObject *obj_to_array_allow_conversion(PyObject *input, int typecode,
-                                             int *is_new_object) {
-  PyArrayObject *ary = NULL;
-  PyObject *py_obj;
-  if (is_array(input) && (typecode == NPY_NOTYPE ||
-                          PyArray_EquivTypenums(array_type(input), typecode))) {
-    ary = (PyArrayObject *)input;
-    *is_new_object = 0;
-  } else {
-    py_obj = PyArray_FROMANY(input, typecode, 0, 0, NPY_ARRAY_DEFAULT);
-    /* If NULL, PyArray_FromObject will have set python error value.*/
-    ary = (PyArrayObject *)py_obj;
-    *is_new_object = 1;
-  }
-  return ary;
-}
-
-/* Given a PyArrayObject, check to see if it is contiguous.  If so,
- * return the input pointer and flag it as not a new object.  If it is
- * not contiguous, create a new PyArrayObject using the original data,
- * flag it as a new object and return the pointer.
- */
-PyArrayObject *make_contiguous(PyArrayObject *ary, int *is_new_object,
-                               int min_dims, int max_dims) {
-  PyArrayObject *result;
-  if (array_is_contiguous(ary)) {
-    result = ary;
-    *is_new_object = 0;
-  } else {
-    result = (PyArrayObject *)PyArray_ContiguousFromObject(
-        (PyObject *)ary, array_type(ary), min_dims, max_dims);
-    *is_new_object = 1;
-  }
-  return result;
-}
-
-/* Given a PyArrayObject, check to see if it is Fortran-contiguous.
- * If so, return the input pointer, but do not flag it as not a new
- * object.  If it is not Fortran-contiguous, create a new
- * PyArrayObject using the original data, flag it as a new object
- * and return the pointer.
- */
-PyArrayObject *make_fortran(PyArrayObject *ary, int *is_new_object) {
-  PyArrayObject *result;
-  if (array_is_fortran(ary)) {
-    result = ary;
-    *is_new_object = 0;
-  } else {
-    Py_INCREF(array_descr(ary));
-    result = (PyArrayObject *)PyArray_FromArray(ary, array_descr(ary),
-#if NPY_API_VERSION < 0x00000007
-                                                NPY_FORTRANORDER);
-#else
-                                                NPY_ARRAY_F_CONTIGUOUS);
-#endif
-    *is_new_object = 1;
-  }
-  return result;
-}
-
-/* Convert a given PyObject to a contiguous PyArrayObject of the
- * specified type.  If the input object is not a contiguous
- * PyArrayObject, a new one will be created and the new object flag
- * will be set.
- */
-PyArrayObject *obj_to_array_contiguous_allow_conversion(PyObject *input,
-                                                        int typecode,
-                                                        int *is_new_object) {
-  int is_new1 = 0;
-  int is_new2 = 0;
-  PyArrayObject *ary2;
-  PyArrayObject *ary1 =
-      obj_to_array_allow_conversion(input, typecode, &is_new1);
-  if (ary1) {
-    ary2 = make_contiguous(ary1, &is_new2, 0, 0);
-    if (is_new1 && is_new2) {
-      Py_DECREF(ary1);
-    }
-    ary1 = ary2;
-  }
-  *is_new_object = is_new1 || is_new2;
-  return ary1;
-}
-
-/* Convert a given PyObject to a Fortran-ordered PyArrayObject of the
- * specified type.  If the input object is not a Fortran-ordered
- * PyArrayObject, a new one will be created and the new object flag
- * will be set.
- */
-PyArrayObject *obj_to_array_fortran_allow_conversion(PyObject *input,
-                                                     int typecode,
-                                                     int *is_new_object) {
-  int is_new1 = 0;
-  int is_new2 = 0;
-  PyArrayObject *ary2;
-  PyArrayObject *ary1 =
-      obj_to_array_allow_conversion(input, typecode, &is_new1);
-  if (ary1) {
-    ary2 = make_fortran(ary1, &is_new2);
-    if (is_new1 && is_new2) {
-      Py_DECREF(ary1);
-    }
-    ary1 = ary2;
-  }
-  *is_new_object = is_new1 || is_new2;
-  return ary1;
-}
-
-/* Test whether a python object is contiguous.  If array is
- * contiguous, return 1.  Otherwise, set the python error string and
- * return 0.
- */
-int require_contiguous(PyArrayObject *ary) {
-  int contiguous = 1;
-  if (!array_is_contiguous(ary)) {
-    PyErr_SetString(
-        PyExc_TypeError,
-        "Array must be contiguous.  A non-contiguous array was given");
-    contiguous = 0;
-  }
-  return contiguous;
-}
-
-/* Test whether a python object is (C_ or F_) contiguous.  If array is
- * contiguous, return 1.  Otherwise, set the python error string and
- * return 0.
- */
-int require_c_or_f_contiguous(PyArrayObject *ary) {
-  int contiguous = 1;
-  if (!(array_is_contiguous(ary) || array_is_fortran(ary))) {
-    PyErr_SetString(PyExc_TypeError, "Array must be contiguous (C_ or F_).  A "
-                                     "non-contiguous array was given");
-    contiguous = 0;
-  }
-  return contiguous;
-}
-
-/* Require that a numpy array is not byte-swapped.  If the array is
- * not byte-swapped, return 1.  Otherwise, set the python error string
- * and return 0.
- */
-int require_native(PyArrayObject *ary) {
-  int native = 1;
-  if (!array_is_native(ary)) {
-    PyErr_SetString(PyExc_TypeError, "Array must have native byteorder.  "
-                                     "A byte-swapped array was given");
-    native = 0;
-  }
-  return native;
-}
-
-/* Require the given PyArrayObject to have a specified number of
- * dimensions.  If the array has the specified number of dimensions,
- * return 1.  Otherwise, set the python error string and return 0.
- */
-int require_dimensions(PyArrayObject *ary, int exact_dimensions) {
-  int success = 1;
-  if (array_numdims(ary) != exact_dimensions) {
-    PyErr_Format(
-        PyExc_TypeError,
-        "Array must have %d dimensions.  Given array has %d dimensions",
-        exact_dimensions, array_numdims(ary));
-    success = 0;
-  }
-  return success;
-}
-
-/* Require the given PyArrayObject to have one of a list of specified
- * number of dimensions.  If the array has one of the specified number
- * of dimensions, return 1.  Otherwise, set the python error string
- * and return 0.
- */
-int require_dimensions_n(PyArrayObject *ary, int *exact_dimensions, int n) {
-  int success = 0;
-  int i;
-  char dims_str[255] = "";
-  char s[255];
-  for (i = 0; i < n && !success; i++) {
-    if (array_numdims(ary) == exact_dimensions[i]) {
-      success = 1;
-    }
-  }
-  if (!success) {
-    for (i = 0; i < n - 1; i++) {
-      sprintf(s, "%d, ", exact_dimensions[i]);
-      strcat(dims_str, s);
-    }
-    sprintf(s, " or %d", exact_dimensions[n - 1]);
-    strcat(dims_str, s);
-    PyErr_Format(
-        PyExc_TypeError,
-        "Array must have %s dimensions.  Given array has %d dimensions",
-        dims_str, array_numdims(ary));
-  }
-  return success;
-}
-
-/* Require the given PyArrayObject to have a specified shape.  If the
- * array has the specified shape, return 1.  Otherwise, set the python
- * error string and return 0.
- */
-int require_size(PyArrayObject *ary, npy_intp *size, int n) {
-  int i;
-  int success = 1;
-  size_t len;
-  char desired_dims[255] = "[";
-  char s[255];
-  char actual_dims[255] = "[";
-  for (i = 0; i < n; i++) {
-    if (size[i] != -1 && size[i] != array_size(ary, i)) {
-      success = 0;
-    }
-  }
-  if (!success) {
-    for (i = 0; i < n; i++) {
-      if (size[i] == -1) {
-        sprintf(s, "*,");
-      } else {
-        sprintf(s, "%ld,", (long int)size[i]);
-      }
-      strcat(desired_dims, s);
-    }
-    len = strlen(desired_dims);
-    desired_dims[len - 1] = ']';
-    for (i = 0; i < n; i++) {
-      sprintf(s, "%ld,", (long int)array_size(ary, i));
-      strcat(actual_dims, s);
-    }
-    len = strlen(actual_dims);
-    actual_dims[len - 1] = ']';
-    PyErr_Format(PyExc_TypeError,
-                 "Array must have shape of %s.  Given array has shape of %s",
-                 desired_dims, actual_dims);
-  }
-  return success;
-}
-
-/* Require the given PyArrayObject to to be Fortran ordered.  If the
- * the PyArrayObject is already Fortran ordered, do nothing.  Else,
- * set the Fortran ordering flag and recompute the strides.
- */
-int require_fortran(PyArrayObject *ary) {
-  int success = 1;
-  int nd = array_numdims(ary);
-  int i;
-  npy_intp *strides = array_strides(ary);
-  if (array_is_fortran(ary))
-    return success;
-  int n_non_one = 0;
-  /* Set the Fortran ordered flag */
-  const npy_intp *dims = array_dimensions(ary);
-  for (i = 0; i < nd; ++i)
-    n_non_one += (dims[i] != 1) ? 1 : 0;
-  if (n_non_one > 1)
-    array_clearflags(ary, NPY_ARRAY_CARRAY);
-  array_enableflags(ary, NPY_ARRAY_FARRAY);
-  /* Recompute the strides */
-  strides[0] = strides[nd - 1];
-  for (i = 1; i < nd; ++i)
-    strides[i] = strides[i - 1] * array_size(ary, i - 1);
-  return success;
-}
-
-#include <limits.h>
-#if !defined(SWIG_NO_LLONG_MAX)
-#if !defined(LLONG_MAX) && defined(__GNUC__) && defined(__LONG_LONG_MAX__)
-#define LLONG_MAX __LONG_LONG_MAX__
-#define LLONG_MIN (-LLONG_MAX - 1LL)
-#define ULLONG_MAX (LLONG_MAX * 2ULL + 1ULL)
-#endif
-#endif
-
-SWIGINTERN int SWIG_AsVal_double(PyObject *obj, double *val) {
-  int res = SWIG_TypeError;
-  if (PyFloat_Check(obj)) {
-    if (val)
-      *val = PyFloat_AsDouble(obj);
-    return SWIG_OK;
-#if PY_VERSION_HEX < 0x03000000
-  } else if (PyInt_Check(obj)) {
-    if (val)
-      *val = PyInt_AsLong(obj);
-    return SWIG_OK;
-#endif
-  } else if (PyLong_Check(obj)) {
-    double v = PyLong_AsDouble(obj);
-    if (!PyErr_Occurred()) {
-      if (val)
-        *val = v;
-      return SWIG_OK;
-    } else {
-      PyErr_Clear();
-    }
-  }
-#ifdef SWIG_PYTHON_CAST_MODE
-  {
-    int dispatch = 0;
-    double d = PyFloat_AsDouble(obj);
-    if (!PyErr_Occurred()) {
-      if (val)
-        *val = d;
-      return SWIG_AddCast(SWIG_OK);
-    } else {
-      PyErr_Clear();
-    }
-    if (!dispatch) {
-      long v = PyLong_AsLong(obj);
-      if (!PyErr_Occurred()) {
-        if (val)
-          *val = v;
-        return SWIG_AddCast(SWIG_AddCast(SWIG_OK));
-      } else {
-        PyErr_Clear();
-      }
-    }
-  }
-#endif
-  return res;
-}
-
-#include <float.h>
-
-#include <math.h>
-
-SWIGINTERNINLINE int SWIG_CanCastAsInteger(double *d, double min, double max) {
-  double x = *d;
-  if ((min <= x && x <= max)) {
-    double fx = floor(x);
-    double cx = ceil(x);
-    double rd = ((x - fx) < 0.5) ? fx : cx; /* simple rint */
-    if ((errno == EDOM) || (errno == ERANGE)) {
-      errno = 0;
-    } else {
-      double summ, reps, diff;
-      if (rd < x) {
-        diff = x - rd;
-      } else if (rd > x) {
-        diff = rd - x;
-      } else {
-        return 1;
-      }
-      summ = rd + x;
-      reps = diff / summ;
-      if (reps < 8 * DBL_EPSILON) {
-        *d = rd;
-        return 1;
-      }
-    }
-  }
-  return 0;
-}
-
-SWIGINTERN int SWIG_AsVal_long(PyObject *obj, long *val) {
-#if PY_VERSION_HEX < 0x03000000
-  if (PyInt_Check(obj)) {
-    if (val)
-      *val = PyInt_AsLong(obj);
-    return SWIG_OK;
-  } else
-#endif
-      if (PyLong_Check(obj)) {
-    long v = PyLong_AsLong(obj);
-    if (!PyErr_Occurred()) {
-      if (val)
-        *val = v;
-      return SWIG_OK;
-    } else {
-      PyErr_Clear();
-      return SWIG_OverflowError;
-    }
-  }
-#ifdef SWIG_PYTHON_CAST_MODE
-  {
-    int dispatch = 0;
-    long v = PyInt_AsLong(obj);
-    if (!PyErr_Occurred()) {
-      if (val)
-        *val = v;
-      return SWIG_AddCast(SWIG_OK);
-    } else {
-      PyErr_Clear();
-    }
-    if (!dispatch) {
-      double d;
-      int res = SWIG_AddCast(SWIG_AsVal_double(obj, &d));
-      if (SWIG_IsOK(res) && SWIG_CanCastAsInteger(&d, LONG_MIN, LONG_MAX)) {
-        if (val)
-          *val = (long)(d);
-        return res;
-      }
-    }
-  }
-#endif
-  return SWIG_TypeError;
-}
-
-SWIGINTERN int SWIG_AsVal_int(PyObject *obj, int *val) {
-  long v;
-  int res = SWIG_AsVal_long(obj, &v);
-  if (SWIG_IsOK(res)) {
-    if ((v < INT_MIN || v > INT_MAX)) {
-      return SWIG_OverflowError;
-    } else {
-      if (val)
-        *val = (int)(v);
-    }
-  }
-  return res;
-}
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-SWIGINTERN PyObject *_wrap_gamut_map__SWIG_0(PyObject *SWIGUNUSEDPARM(self),
-                                             PyObject *args) {
-  PyObject *resultobj = 0;
-  float *arg1 = (float *)0;
-  int arg2;
-  int arg3;
-  int arg4;
-  float *arg5 = (float *)0;
-  int arg6;
-  int arg7;
-  int arg8;
-  float *arg9 = (float *)0;
-  int arg10;
-  int arg11;
-  float *arg12 = (float *)0;
-  int arg13;
-  int arg14;
-  float *arg15 = (float *)0;
-  int arg16;
-  int arg17;
-  PyArrayObject *array1 = NULL;
-  int is_new_object1 = 0;
-  PyArrayObject *array5 = NULL;
-  PyArrayObject *array9 = NULL;
-  int is_new_object9 = 0;
-  PyArrayObject *array12 = NULL;
-  int is_new_object12 = 0;
-  PyArrayObject *array15 = NULL;
-  int is_new_object15 = 0;
-  PyObject *obj0 = 0;
-  PyObject *obj1 = 0;
-  PyObject *obj2 = 0;
-  PyObject *obj3 = 0;
-  PyObject *obj4 = 0;
-
-  if (!PyArg_ParseTuple(args, (char *)"OOOOO:gamut_map", &obj0, &obj1, &obj2,
-                        &obj3, &obj4))
-    SWIG_fail;
-  {
-    npy_intp size[3] = {-1, -1, -1};
-    array1 = obj_to_array_contiguous_allow_conversion(obj0, NPY_FLOAT,
-                                                      &is_new_object1);
-    if (!array1 || !require_dimensions(array1, 3) ||
-        !require_size(array1, size, 3))
-      SWIG_fail;
-    arg1 = (float *)array_data(array1);
-    arg2 = (int)array_size(array1, 0);
-    arg3 = (int)array_size(array1, 1);
-    arg4 = (int)array_size(array1, 2);
-  }
-  {
-    array5 = obj_to_array_no_conversion(obj1, NPY_FLOAT);
-    if (!array5 || !require_dimensions(array5, 3) ||
-        !require_contiguous(array5) || !require_native(array5))
-      SWIG_fail;
-    arg5 = (float *)array_data(array5);
-    arg6 = (int)array_size(array5, 0);
-    arg7 = (int)array_size(array5, 1);
-    arg8 = (int)array_size(array5, 2);
-  }
-  {
-    npy_intp size[2] = {-1, -1};
-    array9 = obj_to_array_contiguous_allow_conversion(obj2, NPY_FLOAT,
-                                                      &is_new_object9);
-    if (!array9 || !require_dimensions(array9, 2) ||
-        !require_size(array9, size, 2))
-      SWIG_fail;
-    arg9 = (float *)array_data(array9);
-    arg10 = (int)array_size(array9, 0);
-    arg11 = (int)array_size(array9, 1);
-  }
-  {
-    npy_intp size[2] = {-1, -1};
-    array12 = obj_to_array_contiguous_allow_conversion(obj3, NPY_FLOAT,
-                                                       &is_new_object12);
-    if (!array12 || !require_dimensions(array12, 2) ||
-        !require_size(array12, size, 2))
-      SWIG_fail;
-    arg12 = (float *)array_data(array12);
-    arg13 = (int)array_size(array12, 0);
-    arg14 = (int)array_size(array12, 1);
-  }
-  {
-    npy_intp size[2] = {-1, -1};
-    array15 = obj_to_array_contiguous_allow_conversion(obj4, NPY_FLOAT,
-                                                       &is_new_object15);
-    if (!array15 || !require_dimensions(array15, 2) ||
-        !require_size(array15, size, 2))
-      SWIG_fail;
-    arg15 = (float *)array_data(array15);
-    arg16 = (int)array_size(array15, 0);
-    arg17 = (int)array_size(array15, 1);
-  }
-  {
-    gamut_map_full(arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9, arg10,
-                   arg11, arg12, arg13, arg14, arg15, arg16, arg17);
-    if (PyErr_Occurred())
-      SWIG_fail;
-  }
-  resultobj = SWIG_Py_Void();
-  {
-    if (is_new_object1 && array1) {
-      Py_DECREF(array1);
-    }
-  }
-  {
-    if (is_new_object9 && array9) {
-      Py_DECREF(array9);
-    }
-  }
-  {
-    if (is_new_object12 && array12) {
-      Py_DECREF(array12);
-    }
-  }
-  {
-    if (is_new_object15 && array15) {
-      Py_DECREF(array15);
-    }
-  }
-  return resultobj;
-fail : {
-  if (is_new_object1 && array1) {
-    Py_DECREF(array1);
-  }
-}
-  {
-    if (is_new_object9 && array9) {
-      Py_DECREF(array9);
-    }
-  }
-  {
-    if (is_new_object12 && array12) {
-      Py_DECREF(array12);
-    }
-  }
-  {
-    if (is_new_object15 && array15) {
-      Py_DECREF(array15);
-    }
-  }
-  return NULL;
-}
-
-SWIGINTERN PyObject *_wrap_gamut_map__SWIG_1(PyObject *SWIGUNUSEDPARM(self),
-                                             PyObject *args) {
-  PyObject *resultobj = 0;
-  float *arg1 = (float *)0;
-  int arg2;
-  int arg3;
-  int arg4;
-  float *arg5 = (float *)0;
-  float *arg6 = (float *)0;
-  float *arg7 = (float *)0;
-  float *arg8 = (float *)0;
-  int arg9;
-  void *argp1 = 0;
-  int res1 = 0;
-  int val2;
-  int ecode2 = 0;
-  int val3;
-  int ecode3 = 0;
-  int val4;
-  int ecode4 = 0;
-  void *argp5 = 0;
-  int res5 = 0;
-  void *argp6 = 0;
-  int res6 = 0;
-  void *argp7 = 0;
-  int res7 = 0;
-  void *argp8 = 0;
-  int res8 = 0;
-  int val9;
-  int ecode9 = 0;
-  PyObject *obj0 = 0;
-  PyObject *obj1 = 0;
-  PyObject *obj2 = 0;
-  PyObject *obj3 = 0;
-  PyObject *obj4 = 0;
-  PyObject *obj5 = 0;
-  PyObject *obj6 = 0;
-  PyObject *obj7 = 0;
-  PyObject *obj8 = 0;
-
-  if (!PyArg_ParseTuple(args, (char *)"OOOOOOOOO:gamut_map", &obj0, &obj1,
-                        &obj2, &obj3, &obj4, &obj5, &obj6, &obj7, &obj8))
-    SWIG_fail;
-  res1 = SWIG_ConvertPtr(obj0, &argp1, SWIGTYPE_p_float, 0 | 0);
-  if (!SWIG_IsOK(res1)) {
-    SWIG_exception_fail(SWIG_ArgError(res1), "in method '"
-                                             "gamut_map"
-                                             "', argument "
-                                             "1"
-                                             " of type '"
-                                             "float *"
-                                             "'");
-  }
-  arg1 = (float *)(argp1);
-  ecode2 = SWIG_AsVal_int(obj1, &val2);
-  if (!SWIG_IsOK(ecode2)) {
-    SWIG_exception_fail(SWIG_ArgError(ecode2), "in method '"
-                                               "gamut_map"
-                                               "', argument "
-                                               "2"
-                                               " of type '"
-                                               "int"
-                                               "'");
-  }
-  arg2 = (int)(val2);
-  ecode3 = SWIG_AsVal_int(obj2, &val3);
-  if (!SWIG_IsOK(ecode3)) {
-    SWIG_exception_fail(SWIG_ArgError(ecode3), "in method '"
-                                               "gamut_map"
-                                               "', argument "
-                                               "3"
-                                               " of type '"
-                                               "int"
-                                               "'");
-  }
-  arg3 = (int)(val3);
-  ecode4 = SWIG_AsVal_int(obj3, &val4);
-  if (!SWIG_IsOK(ecode4)) {
-    SWIG_exception_fail(SWIG_ArgError(ecode4), "in method '"
-                                               "gamut_map"
-                                               "', argument "
-                                               "4"
-                                               " of type '"
-                                               "int"
-                                               "'");
-  }
-  arg4 = (int)(val4);
-  res5 = SWIG_ConvertPtr(obj4, &argp5, SWIGTYPE_p_float, 0 | 0);
-  if (!SWIG_IsOK(res5)) {
-    SWIG_exception_fail(SWIG_ArgError(res5), "in method '"
-                                             "gamut_map"
-                                             "', argument "
-                                             "5"
-                                             " of type '"
-                                             "float *"
-                                             "'");
-  }
-  arg5 = (float *)(argp5);
-  res6 = SWIG_ConvertPtr(obj5, &argp6, SWIGTYPE_p_float, 0 | 0);
-  if (!SWIG_IsOK(res6)) {
-    SWIG_exception_fail(SWIG_ArgError(res6), "in method '"
-                                             "gamut_map"
-                                             "', argument "
-                                             "6"
-                                             " of type '"
-                                             "float *"
-                                             "'");
-  }
-  arg6 = (float *)(argp6);
-  res7 = SWIG_ConvertPtr(obj6, &argp7, SWIGTYPE_p_float, 0 | 0);
-  if (!SWIG_IsOK(res7)) {
-    SWIG_exception_fail(SWIG_ArgError(res7), "in method '"
-                                             "gamut_map"
-                                             "', argument "
-                                             "7"
-                                             " of type '"
-                                             "float *"
-                                             "'");
-  }
-  arg7 = (float *)(argp7);
-  res8 = SWIG_ConvertPtr(obj7, &argp8, SWIGTYPE_p_float, 0 | 0);
-  if (!SWIG_IsOK(res8)) {
-    SWIG_exception_fail(SWIG_ArgError(res8), "in method '"
-                                             "gamut_map"
-                                             "', argument "
-                                             "8"
-                                             " of type '"
-                                             "float *"
-                                             "'");
-  }
-  arg8 = (float *)(argp8);
-  ecode9 = SWIG_AsVal_int(obj8, &val9);
-  if (!SWIG_IsOK(ecode9)) {
-    SWIG_exception_fail(SWIG_ArgError(ecode9), "in method '"
-                                               "gamut_map"
-                                               "', argument "
-                                               "9"
-                                               " of type '"
-                                               "int"
-                                               "'");
-  }
-  arg9 = (int)(val9);
-  gamut_map(arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8, arg9);
-  resultobj = SWIG_Py_Void();
-  return resultobj;
-fail:
-  return NULL;
-}
-
-SWIGINTERN PyObject *_wrap_gamut_map(PyObject *self, PyObject *args) {
-  Py_ssize_t argc;
-  PyObject *argv[10] = {0};
-  Py_ssize_t ii;
-
-  if (!PyTuple_Check(args))
-    SWIG_fail;
-  argc = args ? PyObject_Length(args) : 0;
-  for (ii = 0; (ii < 9) && (ii < argc); ii++) {
-    argv[ii] = PyTuple_GET_ITEM(args, ii);
-  }
-  if (argc == 5) {
-    int _v;
-    { _v = is_array(argv[0]) || PySequence_Check(argv[0]); }
-    if (_v) {
-      {
-        _v = is_array(argv[1]) &&
-             PyArray_EquivTypenums(array_type(argv[1]), NPY_FLOAT);
-      }
-      if (_v) {
-        {
-          _v = is_array(argv[2]) || PySequence_Check(argv[2]);
-        }
-        if (_v) {
-          {
-            _v = is_array(argv[3]) || PySequence_Check(argv[3]);
-          }
-          if (_v) {
-            {
-              _v = is_array(argv[4]) || PySequence_Check(argv[4]);
-            }
-            if (_v) {
-              if (argc <= 5) {
-                return _wrap_gamut_map__SWIG_0(self, args);
-              }
-              if (argc <= 6) {
-                return _wrap_gamut_map__SWIG_0(self, args);
-              }
-              return _wrap_gamut_map__SWIG_0(self, args);
-            }
-          }
-        }
-      }
-    }
-  }
-  if (argc == 9) {
-    int _v;
-    void *vptr = 0;
-    int res = SWIG_ConvertPtr(argv[0], &vptr, SWIGTYPE_p_float, 0);
-    _v = SWIG_CheckState(res);
-    if (_v) {
-      {
-        int res = SWIG_AsVal_int(argv[1], NULL);
-        _v = SWIG_CheckState(res);
-      }
-      if (_v) {
-        {
-          int res = SWIG_AsVal_int(argv[2], NULL);
-          _v = SWIG_CheckState(res);
-        }
-        if (_v) {
-          {
-            int res = SWIG_AsVal_int(argv[3], NULL);
-            _v = SWIG_CheckState(res);
-          }
-          if (_v) {
-            void *vptr = 0;
-            int res = SWIG_ConvertPtr(argv[4], &vptr, SWIGTYPE_p_float, 0);
-            _v = SWIG_CheckState(res);
-            if (_v) {
-              void *vptr = 0;
-              int res = SWIG_ConvertPtr(argv[5], &vptr, SWIGTYPE_p_float, 0);
-              _v = SWIG_CheckState(res);
-              if (_v) {
-                void *vptr = 0;
-                int res = SWIG_ConvertPtr(argv[6], &vptr, SWIGTYPE_p_float, 0);
-                _v = SWIG_CheckState(res);
-                if (_v) {
-                  void *vptr = 0;
-                  int res =
-                      SWIG_ConvertPtr(argv[7], &vptr, SWIGTYPE_p_float, 0);
-                  _v = SWIG_CheckState(res);
-                  if (_v) {
-                    {
-                      int res = SWIG_AsVal_int(argv[8], NULL);
-                      _v = SWIG_CheckState(res);
-                    }
-                    if (_v) {
-                      return _wrap_gamut_map__SWIG_1(self, args);
-                    }
-                  }
-                }
-              }
-            }
-          }
-        }
-      }
-    }
-  }
-
-fail:
-  SWIG_SetErrorMsg(
-      PyExc_NotImplementedError,
-      "Wrong number or type of arguments for overloaded function 'gamut_map'.\n"
-      "  Possible C/C++ prototypes are:\n"
-      "    gamut_map_full(float *,int,int,int,float *,int,int,int,float "
-      "*,int,int,float *,int,int,float *,int,int)\n"
-      "    gamut_map(float *,int,int,int,float *,float *,float *,float "
-      "*,int)\n");
-  return 0;
-}
-
-static PyMethodDef SwigMethods[] = {
-    {(char *)"SWIG_PyInstanceMethod_New",
-     (PyCFunction)SWIG_PyInstanceMethod_New, METH_O, NULL},
-    {(char *)"gamut_map", _wrap_gamut_map, METH_VARARGS, NULL},
-    {NULL, NULL, 0, NULL}};
-
-/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (BEGIN) -------- */
-
-static swig_type_info _swigt__p_char = {"_p_char", "char *",  0,
-                                        0,         (void *)0, 0};
-static swig_type_info _swigt__p_float = {"_p_float", "float *", 0,
-                                         0,          (void *)0, 0};
-
-static swig_type_info *swig_type_initial[] = {
-    &_swigt__p_char,
-    &_swigt__p_float,
-};
-
-static swig_cast_info _swigc__p_char[] = {{&_swigt__p_char, 0, 0, 0},
-                                          {0, 0, 0, 0}};
-static swig_cast_info _swigc__p_float[] = {{&_swigt__p_float, 0, 0, 0},
-                                           {0, 0, 0, 0}};
-
-static swig_cast_info *swig_cast_initial[] = {
-    _swigc__p_char,
-    _swigc__p_float,
-};
-
-/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (END) -------- */
-
-static swig_const_info swig_const_table[] = {{0, 0, 0, 0.0, 0, 0}};
-
-#ifdef __cplusplus
-}
-#endif
-/* -----------------------------------------------------------------------------
- * Type initialization:
- * This problem is tough by the requirement that no dynamic
- * memory is used. Also, since swig_type_info structures store pointers to
- * swig_cast_info structures and swig_cast_info structures store pointers back
- * to swig_type_info structures, we need some lookup code at initialization.
- * The idea is that swig generates all the structures that are needed.
- * The runtime then collects these partially filled structures.
- * The SWIG_InitializeModule function takes these initial arrays out of
- * swig_module, and does all the lookup, filling in the swig_module.types
- * array with the correct data and linking the correct swig_cast_info
- * structures together.
- *
- * The generated swig_type_info structures are assigned statically to an initial
- * array. We just loop through that array, and handle each type individually.
- * First we lookup if this type has been already loaded, and if so, use the
- * loaded structure instead of the generated one. Then we have to fill in the
- * cast linked list. The cast data is initially stored in something like a
- * two-dimensional array. Each row corresponds to a type (there are the same
- * number of rows as there are in the swig_type_initial array). Each entry in
- * a column is one of the swig_cast_info structures for that type.
- * The cast_initial array is actually an array of arrays, because each row has
- * a variable number of columns. So to actually build the cast linked list,
- * we find the array of casts associated with the type, and loop through it
- * adding the casts to the list. The one last trick we need to do is making
- * sure the type pointer in the swig_cast_info struct is correct.
- *
- * First off, we lookup the cast->type name to see if it is already loaded.
- * There are three cases to handle:
- *  1) If the cast->type has already been loaded AND the type we are adding
- *     casting info to has not been loaded (it is in this module), THEN we
- *     replace the cast->type pointer with the type pointer that has already
- *     been loaded.
- *  2) If BOTH types (the one we are adding casting info to, and the
- *     cast->type) are loaded, THEN the cast info has already been loaded by
- *     the previous module so we just ignore it.
- *  3) Finally, if cast->type has not already been loaded, then we add that
- *     swig_cast_info to the linked list (because the cast->type) pointer will
- *     be correct.
- * -----------------------------------------------------------------------------
- */
-
-#ifdef __cplusplus
-extern "C" {
-#if 0
-} /* c-mode */
-#endif
-#endif
-
-#if 0
-#define SWIGRUNTIME_DEBUG
-#endif
-
-SWIGRUNTIME void SWIG_InitializeModule(void *clientdata) {
-  size_t i;
-  swig_module_info *module_head, *iter;
-  int init;
-
-  /* check to see if the circular list has been setup, if not, set it up */
-  if (swig_module.next == 0) {
-    /* Initialize the swig_module */
-    swig_module.type_initial = swig_type_initial;
-    swig_module.cast_initial = swig_cast_initial;
-    swig_module.next = &swig_module;
-    init = 1;
-  } else {
-    init = 0;
-  }
-
-  /* Try and load any already created modules */
-  module_head = SWIG_GetModule(clientdata);
-  if (!module_head) {
-    /* This is the first module loaded for this interpreter */
-    /* so set the swig module into the interpreter */
-    SWIG_SetModule(clientdata, &swig_module);
-  } else {
-    /* the interpreter has loaded a SWIG module, but has it loaded this one? */
-    iter = module_head;
-    do {
-      if (iter == &swig_module) {
-        /* Our module is already in the list, so there's nothing more to do. */
-        return;
-      }
-      iter = iter->next;
-    } while (iter != module_head);
-
-    /* otherwise we must add our module into the list */
-    swig_module.next = module_head->next;
-    module_head->next = &swig_module;
-  }
-
-  /* When multiple interpreters are used, a module could have already been
-     initialized in a different interpreter, but not yet have a pointer in this
-     interpreter. In this case, we do not want to continue adding types...
-     everything should be set up already */
-  if (init == 0)
-    return;
-
-    /* Now work on filling in swig_module.types */
-#ifdef SWIGRUNTIME_DEBUG
-  printf("SWIG_InitializeModule: size %d\n", swig_module.size);
-#endif
-  for (i = 0; i < swig_module.size; ++i) {
-    swig_type_info *type = 0;
-    swig_type_info *ret;
-    swig_cast_info *cast;
-
-#ifdef SWIGRUNTIME_DEBUG
-    printf("SWIG_InitializeModule: type %d %s\n", i,
-           swig_module.type_initial[i]->name);
-#endif
-
-    /* if there is another module already loaded */
-    if (swig_module.next != &swig_module) {
-      type = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module,
-                                         swig_module.type_initial[i]->name);
-    }
-    if (type) {
-      /* Overwrite clientdata field */
-#ifdef SWIGRUNTIME_DEBUG
-      printf("SWIG_InitializeModule: found type %s\n", type->name);
-#endif
-      if (swig_module.type_initial[i]->clientdata) {
-        type->clientdata = swig_module.type_initial[i]->clientdata;
-#ifdef SWIGRUNTIME_DEBUG
-        printf("SWIG_InitializeModule: found and overwrite type %s \n",
-               type->name);
-#endif
-      }
-    } else {
-      type = swig_module.type_initial[i];
-    }
-
-    /* Insert casting types */
-    cast = swig_module.cast_initial[i];
-    while (cast->type) {
-      /* Don't need to add information already in the list */
-      ret = 0;
-#ifdef SWIGRUNTIME_DEBUG
-      printf("SWIG_InitializeModule: look cast %s\n", cast->type->name);
-#endif
-      if (swig_module.next != &swig_module) {
-        ret = SWIG_MangledTypeQueryModule(swig_module.next, &swig_module,
-                                          cast->type->name);
-#ifdef SWIGRUNTIME_DEBUG
-        if (ret)
-          printf("SWIG_InitializeModule: found cast %s\n", ret->name);
-#endif
-      }
-      if (ret) {
-        if (type == swig_module.type_initial[i]) {
-#ifdef SWIGRUNTIME_DEBUG
-          printf("SWIG_InitializeModule: skip old type %s\n", ret->name);
-#endif
-          cast->type = ret;
-          ret = 0;
-        } else {
-          /* Check for casting already in the list */
-          swig_cast_info *ocast = SWIG_TypeCheck(ret->name, type);
-#ifdef SWIGRUNTIME_DEBUG
-          if (ocast)
-            printf("SWIG_InitializeModule: skip old cast %s\n", ret->name);
-#endif
-          if (!ocast)
-            ret = 0;
-        }
-      }
-
-      if (!ret) {
-#ifdef SWIGRUNTIME_DEBUG
-        printf("SWIG_InitializeModule: adding cast %s\n", cast->type->name);
-#endif
-        if (type->cast) {
-          type->cast->prev = cast;
-          cast->next = type->cast;
-        }
-        type->cast = cast;
-      }
-      cast++;
-    }
-    /* Set entry in modules->types array equal to the type */
-    swig_module.types[i] = type;
-  }
-  swig_module.types[i] = 0;
-
-#ifdef SWIGRUNTIME_DEBUG
-  printf("**** SWIG_InitializeModule: Cast List ******\n");
-  for (i = 0; i < swig_module.size; ++i) {
-    int j = 0;
-    swig_cast_info *cast = swig_module.cast_initial[i];
-    printf("SWIG_InitializeModule: type %d %s\n", i,
-           swig_module.type_initial[i]->name);
-    while (cast->type) {
-      printf("SWIG_InitializeModule: cast type %s\n", cast->type->name);
-      cast++;
-      ++j;
-    }
-    printf("---- Total casts: %d\n", j);
-  }
-  printf("**** SWIG_InitializeModule: Cast List ******\n");
-#endif
-}
-
-/* This function will propagate the clientdata field of type to
- * any new swig_type_info structures that have been added into the list
- * of equivalent types.  It is like calling
- * SWIG_TypeClientData(type, clientdata) a second time.
- */
-SWIGRUNTIME void SWIG_PropagateClientData(void) {
-  size_t i;
-  swig_cast_info *equiv;
-  static int init_run = 0;
-
-  if (init_run)
-    return;
-  init_run = 1;
-
-  for (i = 0; i < swig_module.size; i++) {
-    if (swig_module.types[i]->clientdata) {
-      equiv = swig_module.types[i]->cast;
-      while (equiv) {
-        if (!equiv->converter) {
-          if (equiv->type && !equiv->type->clientdata)
-            SWIG_TypeClientData(equiv->type, swig_module.types[i]->clientdata);
-        }
-        equiv = equiv->next;
-      }
-    }
-  }
-}
-
-#ifdef __cplusplus
-#if 0
-{
-  /* c-mode */
-#endif
-}
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/* Python-specific SWIG API */
-#define SWIG_newvarlink() SWIG_Python_newvarlink()
-#define SWIG_addvarlink(p, name, get_attr, set_attr)                           \
-  SWIG_Python_addvarlink(p, name, get_attr, set_attr)
-#define SWIG_InstallConstants(d, constants)                                    \
-  SWIG_Python_InstallConstants(d, constants)
-
-/* -----------------------------------------------------------------------------
- * global variable support code.
- * -----------------------------------------------------------------------------
- */
-
-typedef struct swig_globalvar {
-  char *name;                  /* Name of global variable */
-  PyObject *(*get_attr)(void); /* Return the current value */
-  int (*set_attr)(PyObject *); /* Set the value */
-  struct swig_globalvar *next;
-} swig_globalvar;
-
-typedef struct swig_varlinkobject {
-  PyObject_HEAD swig_globalvar *vars;
-} swig_varlinkobject;
-
-SWIGINTERN PyObject *swig_varlink_repr(swig_varlinkobject *SWIGUNUSEDPARM(v)) {
-#if PY_VERSION_HEX >= 0x03000000
-  return PyUnicode_InternFromString("<Swig global variables>");
-#else
-  return PyString_FromString("<Swig global variables>");
-#endif
-}
-
-SWIGINTERN PyObject *swig_varlink_str(swig_varlinkobject *v) {
-#if PY_VERSION_HEX >= 0x03000000
-  PyObject *str = PyUnicode_InternFromString("(");
-  PyObject *tail;
-  PyObject *joined;
-  swig_globalvar *var;
-  for (var = v->vars; var; var = var->next) {
-    tail = PyUnicode_FromString(var->name);
-    joined = PyUnicode_Concat(str, tail);
-    Py_DecRef(str);
-    Py_DecRef(tail);
-    str = joined;
-    if (var->next) {
-      tail = PyUnicode_InternFromString(", ");
-      joined = PyUnicode_Concat(str, tail);
-      Py_DecRef(str);
-      Py_DecRef(tail);
-      str = joined;
-    }
-  }
-  tail = PyUnicode_InternFromString(")");
-  joined = PyUnicode_Concat(str, tail);
-  Py_DecRef(str);
-  Py_DecRef(tail);
-  str = joined;
-#else
-  PyObject *str = PyString_FromString("(");
-  swig_globalvar *var;
-  for (var = v->vars; var; var = var->next) {
-    PyString_ConcatAndDel(&str, PyString_FromString(var->name));
-    if (var->next)
-      PyString_ConcatAndDel(&str, PyString_FromString(", "));
-  }
-  PyString_ConcatAndDel(&str, PyString_FromString(")"));
-#endif
-  return str;
-}
-
-SWIGINTERN int swig_varlink_print(swig_varlinkobject *v, FILE *fp,
-                                  int SWIGUNUSEDPARM(flags)) {
-  char *tmp;
-  PyObject *str = swig_varlink_str(v);
-  fprintf(fp, "Swig global variables ");
-  fprintf(fp, "%s\n", tmp = SWIG_Python_str_AsChar(str));
-  SWIG_Python_str_DelForPy3(tmp);
-  Py_DECREF(str);
-  return 0;
-}
-
-SWIGINTERN void swig_varlink_dealloc(swig_varlinkobject *v) {
-  swig_globalvar *var = v->vars;
-  while (var) {
-    swig_globalvar *n = var->next;
-    free(var->name);
-    free(var);
-    var = n;
-  }
-}
-
-SWIGINTERN PyObject *swig_varlink_getattr(swig_varlinkobject *v, char *n) {
-  PyObject *res = NULL;
-  swig_globalvar *var = v->vars;
-  while (var) {
-    if (strcmp(var->name, n) == 0) {
-      res = (*var->get_attr)();
-      break;
-    }
-    var = var->next;
-  }
-  if (res == NULL && !PyErr_Occurred()) {
-    PyErr_Format(PyExc_AttributeError, "Unknown C global variable '%s'", n);
-  }
-  return res;
-}
-
-SWIGINTERN int swig_varlink_setattr(swig_varlinkobject *v, char *n,
-                                    PyObject *p) {
-  int res = 1;
-  swig_globalvar *var = v->vars;
-  while (var) {
-    if (strcmp(var->name, n) == 0) {
-      res = (*var->set_attr)(p);
-      break;
-    }
-    var = var->next;
-  }
-  if (res == 1 && !PyErr_Occurred()) {
-    PyErr_Format(PyExc_AttributeError, "Unknown C global variable '%s'", n);
-  }
-  return res;
-}
-
-SWIGINTERN PyTypeObject *swig_varlink_type(void) {
-  static char varlink__doc__[] = "Swig var link object";
-  static PyTypeObject varlink_type;
-  static int type_init = 0;
-  if (!type_init) {
-    const PyTypeObject tmp = {
-    /* PyObject header changed in Python 3 */
-#if PY_VERSION_HEX >= 0x03000000
-      PyVarObject_HEAD_INIT(NULL, 0)
-#else
-      PyObject_HEAD_INIT(NULL) 0, /* ob_size */
-#endif
-          (char *) "swigvarlink",        /* tp_name */
-      sizeof(swig_varlinkobject),        /* tp_basicsize */
-      0,                                 /* tp_itemsize */
-      (destructor)swig_varlink_dealloc,  /* tp_dealloc */
-      (printfunc)swig_varlink_print,     /* tp_print */
-      (getattrfunc)swig_varlink_getattr, /* tp_getattr */
-      (setattrfunc)swig_varlink_setattr, /* tp_setattr */
-      0,                                 /* tp_compare */
-      (reprfunc)swig_varlink_repr,       /* tp_repr */
-      0,                                 /* tp_as_number */
-      0,                                 /* tp_as_sequence */
-      0,                                 /* tp_as_mapping */
-      0,                                 /* tp_hash */
-      0,                                 /* tp_call */
-      (reprfunc)swig_varlink_str,        /* tp_str */
-      0,                                 /* tp_getattro */
-      0,                                 /* tp_setattro */
-      0,                                 /* tp_as_buffer */
-      0,                                 /* tp_flags */
-      varlink__doc__,                    /* tp_doc */
-      0,                                 /* tp_traverse */
-      0,                                 /* tp_clear */
-      0,                                 /* tp_richcompare */
-      0,                                 /* tp_weaklistoffset */
-#if PY_VERSION_HEX >= 0x02020000
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0,
-      0, /* tp_iter -> tp_weaklist */
-#endif
-#if PY_VERSION_HEX >= 0x02030000
-      0, /* tp_del */
-#endif
-#if PY_VERSION_HEX >= 0x02060000
-      0, /* tp_version_tag */
-#endif
-#if PY_VERSION_HEX >= 0x03040000
-      0, /* tp_finalize */
-#endif
-#ifdef COUNT_ALLOCS
-      0, /* tp_allocs */
-      0, /* tp_frees */
-      0, /* tp_maxalloc */
-#if PY_VERSION_HEX >= 0x02050000
-      0, /* tp_prev */
-#endif
-      0 /* tp_next */
-#endif
-    };
-    varlink_type = tmp;
-    type_init = 1;
-#if PY_VERSION_HEX < 0x02020000
-    varlink_type.ob_type = &PyType_Type;
-#else
-    if (PyType_Ready(&varlink_type) < 0)
-      return NULL;
-#endif
-  }
-  return &varlink_type;
-}
-
-/* Create a variable linking object for use later */
-SWIGINTERN PyObject *SWIG_Python_newvarlink(void) {
-  swig_varlinkobject *result =
-      PyObject_NEW(swig_varlinkobject, swig_varlink_type());
-  if (result) {
-    result->vars = 0;
-  }
-  return ((PyObject *)result);
-}
-
-SWIGINTERN void SWIG_Python_addvarlink(PyObject *p, char *name,
-                                       PyObject *(*get_attr)(void),
-                                       int (*set_attr)(PyObject *p)) {
-  swig_varlinkobject *v = (swig_varlinkobject *)p;
-  swig_globalvar *gv = (swig_globalvar *)malloc(sizeof(swig_globalvar));
-  if (gv) {
-    size_t size = strlen(name) + 1;
-    gv->name = (char *)malloc(size);
-    if (gv->name) {
-      strncpy(gv->name, name, size);
-      gv->get_attr = get_attr;
-      gv->set_attr = set_attr;
-      gv->next = v->vars;
-    }
-  }
-  v->vars = gv;
-}
-
-SWIGINTERN PyObject *SWIG_globals(void) {
-  static PyObject *_SWIG_globals = 0;
-  if (!_SWIG_globals)
-    _SWIG_globals = SWIG_newvarlink();
-  return _SWIG_globals;
-}
-
-/* -----------------------------------------------------------------------------
- * constants/methods manipulation
- * -----------------------------------------------------------------------------
- */
-
-/* Install Constants */
-SWIGINTERN void SWIG_Python_InstallConstants(PyObject *d,
-                                             swig_const_info constants[]) {
-  PyObject *obj = 0;
-  size_t i;
-  for (i = 0; constants[i].type; ++i) {
-    switch (constants[i].type) {
-    case SWIG_PY_POINTER:
-      obj = SWIG_InternalNewPointerObj(constants[i].pvalue,
-                                       *(constants[i]).ptype, 0);
-      break;
-    case SWIG_PY_BINARY:
-      obj = SWIG_NewPackedObj(constants[i].pvalue, constants[i].lvalue,
-                              *(constants[i].ptype));
-      break;
-    default:
-      obj = 0;
-      break;
-    }
-    if (obj) {
-      PyDict_SetItemString(d, constants[i].name, obj);
-      Py_DECREF(obj);
-    }
-  }
-}
-
-/* -----------------------------------------------------------------------------*/
-/* Fix SwigMethods to carry the callback ptrs when needed */
-/* -----------------------------------------------------------------------------*/
-
-SWIGINTERN void SWIG_Python_FixMethods(PyMethodDef *methods,
-                                       swig_const_info *const_table,
-                                       swig_type_info **types,
-                                       swig_type_info **types_initial) {
-  size_t i;
-  for (i = 0; methods[i].ml_name; ++i) {
-    const char *c = methods[i].ml_doc;
-    if (!c)
-      continue;
-    c = strstr(c, "swig_ptr: ");
-    if (c) {
-      int j;
-      swig_const_info *ci = 0;
-      const char *name = c + 10;
-      for (j = 0; const_table[j].type; ++j) {
-        if (strncmp(const_table[j].name, name, strlen(const_table[j].name)) ==
-            0) {
-          ci = &(const_table[j]);
-          break;
-        }
-      }
-      if (ci) {
-        void *ptr = (ci->type == SWIG_PY_POINTER) ? ci->pvalue : 0;
-        if (ptr) {
-          size_t shift = (ci->ptype) - types;
-          swig_type_info *ty = types_initial[shift];
-          size_t ldoc = (c - methods[i].ml_doc);
-          size_t lptr = strlen(ty->name) + 2 * sizeof(void *) + 2;
-          char *ndoc = (char *)malloc(ldoc + lptr + 10);
-          if (ndoc) {
-            char *buff = ndoc;
-            strncpy(buff, methods[i].ml_doc, ldoc);
-            buff += ldoc;
-            strncpy(buff, "swig_ptr: ", 10);
-            buff += 10;
-            SWIG_PackVoidPtr(buff, ptr, ty->name, lptr);
-            methods[i].ml_doc = ndoc;
-          }
-        }
-      }
-    }
-  }
-}
-
-#ifdef __cplusplus
-}
-#endif
-
-/* -----------------------------------------------------------------------------*
- *  Partial Init method
- * -----------------------------------------------------------------------------*/
-
-#ifdef __cplusplus
-extern "C"
-#endif
-
-    SWIGEXPORT
-#if PY_VERSION_HEX >= 0x03000000
-        PyObject *
-#else
-void
-#endif
-        SWIG_init(void) {
-  PyObject *m, *d, *md;
-#if PY_VERSION_HEX >= 0x03000000
-  static struct PyModuleDef SWIG_module = {
-#if PY_VERSION_HEX >= 0x03020000
-    PyModuleDef_HEAD_INIT,
-#else
-    {
-        PyObject_HEAD_INIT(NULL) NULL, /* m_init */
-        0,                             /* m_index */
-        NULL,                          /* m_copy */
-    },
-#endif
-    (char *)SWIG_name,
-    NULL,
-    -1,
-    SwigMethods,
-    NULL,
-    NULL,
-    NULL,
-    NULL
-  };
-#endif
-
-#if defined(SWIGPYTHON_BUILTIN)
-  static SwigPyClientData SwigPyObject_clientdata = {0, 0, 0, 0, 0, 0, 0};
-  static PyGetSetDef this_getset_def = {
-      (char *)"this", &SwigPyBuiltin_ThisClosure, NULL, NULL, NULL};
-  static SwigPyGetSet thisown_getset_closure = {(PyCFunction)SwigPyObject_own,
-                                                (PyCFunction)SwigPyObject_own};
-  static PyGetSetDef thisown_getset_def = {
-      (char *)"thisown", SwigPyBuiltin_GetterClosure,
-      SwigPyBuiltin_SetterClosure, NULL, &thisown_getset_closure};
-  PyObject *metatype_args;
-  PyTypeObject *builtin_pytype;
-  int builtin_base_count;
-  swig_type_info *builtin_basetype;
-  PyObject *tuple;
-  PyGetSetDescrObject *static_getset;
-  PyTypeObject *metatype;
-  SwigPyClientData *cd;
-  PyObject *public_interface, *public_symbol;
-  PyObject *this_descr;
-  PyObject *thisown_descr;
-  PyObject *self = 0;
-  int i;
-
-  (void)builtin_pytype;
-  (void)builtin_base_count;
-  (void)builtin_basetype;
-  (void)tuple;
-  (void)static_getset;
-  (void)self;
-
-  /* metatype is used to implement static member variables. */
-  metatype_args = Py_BuildValue("(s(O){})", "SwigPyObjectType", &PyType_Type);
-  assert(metatype_args);
-  metatype = (PyTypeObject *)PyType_Type.tp_call((PyObject *)&PyType_Type,
-                                                 metatype_args, NULL);
-  assert(metatype);
-  Py_DECREF(metatype_args);
-  metatype->tp_setattro = (setattrofunc)&SwigPyObjectType_setattro;
-  assert(PyType_Ready(metatype) >= 0);
-#endif
-
-  /* Fix SwigMethods to carry the callback ptrs when needed */
-  SWIG_Python_FixMethods(SwigMethods, swig_const_table, swig_types,
-                         swig_type_initial);
-
-#if PY_VERSION_HEX >= 0x03000000
-  m = PyModule_Create(&SWIG_module);
-#else
-  m = Py_InitModule((char *)SWIG_name, SwigMethods);
-#endif
-
-  md = d = PyModule_GetDict(m);
-  (void)md;
-
-  SWIG_InitializeModule(0);
-
-#ifdef SWIGPYTHON_BUILTIN
-  SwigPyObject_stype = SWIG_MangledTypeQuery("_p_SwigPyObject");
-  assert(SwigPyObject_stype);
-  cd = (SwigPyClientData *)SwigPyObject_stype->clientdata;
-  if (!cd) {
-    SwigPyObject_stype->clientdata = &SwigPyObject_clientdata;
-    SwigPyObject_clientdata.pytype = SwigPyObject_TypeOnce();
-  } else if (SwigPyObject_TypeOnce()->tp_basicsize !=
-             cd->pytype->tp_basicsize) {
-    PyErr_SetString(PyExc_RuntimeError, "Import error: attempted to load two "
-                                        "incompatible swig-generated modules.");
-#if PY_VERSION_HEX >= 0x03000000
-    return NULL;
-#else
-    return;
-#endif
-  }
-
-  /* All objects have a 'this' attribute */
-  this_descr = PyDescr_NewGetSet(SwigPyObject_type(), &this_getset_def);
-  (void)this_descr;
-
-  /* All objects have a 'thisown' attribute */
-  thisown_descr = PyDescr_NewGetSet(SwigPyObject_type(), &thisown_getset_def);
-  (void)thisown_descr;
-
-  public_interface = PyList_New(0);
-  public_symbol = 0;
-  (void)public_symbol;
-
-  PyDict_SetItemString(md, "__all__", public_interface);
-  Py_DECREF(public_interface);
-  for (i = 0; SwigMethods[i].ml_name != NULL; ++i)
-    SwigPyBuiltin_AddPublicSymbol(public_interface, SwigMethods[i].ml_name);
-  for (i = 0; swig_const_table[i].name != 0; ++i)
-    SwigPyBuiltin_AddPublicSymbol(public_interface, swig_const_table[i].name);
-#endif
-
-  SWIG_InstallConstants(d, swig_const_table);
-
-  import_array();
-
-#if PY_VERSION_HEX >= 0x03000000
-  return m;
-#else
-  return;
-#endif
-}
diff --git a/hpvm/test/pipeline/Makefile.config b/hpvm/test/pipeline/Makefile.config
deleted file mode 100644
index 1bdb62dec493fc63e581ae8204ea736c45ed5f7d..0000000000000000000000000000000000000000
--- a/hpvm/test/pipeline/Makefile.config
+++ /dev/null
@@ -1,25 +0,0 @@
-CUDA_PATH=/software/cuda-9.1
-CUDA_LIB_PATH=$(CUDA_PATH)/lib64
-OPENCL_PATH=/software/cuda-9.1
-OPENCL_LIB_PATH=$(OPENCL_PATH)/lib64
-
-LLVM_SRC_ROOT=/home/aejjeh/work_dir/hpvm-reorg-9-temp/hpvm/llvm/
-
-LLVM_BUILD_DIR =$(LLVM_SRC_ROOT)/../build
-CC = $(LLVM_BUILD_DIR)/bin/clang
-PLATFORM_CFLAGS = -I$(LLVM_SRC_ROOT)/include -I$(OPENCL_PATH)/include/CL/ -I../include -I$(LLVM_BUILD_DIR)/include
-OCLBE = $(LLVM_BUILD_DIR)/bin/llvm-cbe
-
-CXX = $(LLVM_BUILD_DIR)/bin/clang++
-PLATFORM_CXXFLAGS = -I$(LLVM_SRC_ROOT)/include -I$(OPENCL_PATH)/include/CL/ -I../include -I$(LLVM_BUILD_DIR)/include
-
-LINKER = $(LLVM_BUILD_DIR)/bin/clang++
-PLATFORM_LDFLAGS = -lm -lpthread -lrt -lOpenCL -L$(OPENCL_LIB_PATH)
-
-LLVM_LIB_PATH = $(LLVM_BUILD_DIR)/lib
-LLVM_BIN_PATH = $(LLVM_BUILD_DIR)/bin
-
-OPT = $(LLVM_BIN_PATH)/opt
-LLVM_LINK = $(LLVM_BIN_PATH)/llvm-link
-LLVM_AS = $(LLVM_BIN_PATH)/llvm-as
-LIT = $(LLVM_BIN_PATH)/llvm-lit
\ No newline at end of file