# This file was automatically generated by SWIG (http://www.swig.org).
# Version 4.0.2
#
# 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 as _swig_python_version_info
if _swig_python_version_info < (2, 7, 0):
    raise RuntimeError("Python 2.7 or later required")

# Import the low-level C/C++ module
if __package__ or "." in __name__:
    from . import _fsg_internal
else:
    import _fsg_internal

try:
    import builtins as __builtin__
except ImportError:
    import __builtin__

def _swig_repr(self):
    try:
        strthis = "proxy of " + self.this.__repr__()
    except __builtin__.Exception:
        strthis = ""
    return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)


def _swig_setattr_nondynamic_instance_variable(set):
    def set_instance_attr(self, name, value):
        if name == "thisown":
            self.this.own(value)
        elif name == "this":
            set(self, name, value)
        elif hasattr(self, name) and isinstance(getattr(type(self), name), property):
            set(self, name, value)
        else:
            raise AttributeError("You cannot add instance attributes to %s" % self)
    return set_instance_attr


def _swig_setattr_nondynamic_class_variable(set):
    def set_class_attr(cls, name, value):
        if hasattr(cls, name) and not isinstance(getattr(cls, name), property):
            set(cls, name, value)
        else:
            raise AttributeError("You cannot add class attributes to %s" % cls)
    return set_class_attr


def _swig_add_metaclass(metaclass):
    """Class decorator for adding a metaclass to a SWIG wrapped class - a slimmed down version of six.add_metaclass"""
    def wrapper(cls):
        return metaclass(cls.__name__, cls.__bases__, cls.__dict__.copy())
    return wrapper


class _SwigNonDynamicMeta(type):
    """Meta class to enforce nondynamic attributes (no new attributes) for a class"""
    __setattr__ = _swig_setattr_nondynamic_class_variable(type.__setattr__)


import weakref

class SwigPyIterator(object):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")

    def __init__(self, *args, **kwargs):
        raise AttributeError("No constructor defined - class is abstract")
    __repr__ = _swig_repr
    __swig_destroy__ = _fsg_internal.delete_SwigPyIterator

    def value(self):
        return _fsg_internal.SwigPyIterator_value(self)

    def incr(self, n=1):
        return _fsg_internal.SwigPyIterator_incr(self, n)

    def decr(self, n=1):
        return _fsg_internal.SwigPyIterator_decr(self, n)

    def distance(self, x):
        return _fsg_internal.SwigPyIterator_distance(self, x)

    def equal(self, x):
        return _fsg_internal.SwigPyIterator_equal(self, x)

    def copy(self):
        return _fsg_internal.SwigPyIterator_copy(self)

    def next(self):
        return _fsg_internal.SwigPyIterator_next(self)

    def __next__(self):
        return _fsg_internal.SwigPyIterator___next__(self)

    def previous(self):
        return _fsg_internal.SwigPyIterator_previous(self)

    def advance(self, n):
        return _fsg_internal.SwigPyIterator_advance(self, n)

    def __eq__(self, x):
        return _fsg_internal.SwigPyIterator___eq__(self, x)

    def __ne__(self, x):
        return _fsg_internal.SwigPyIterator___ne__(self, x)

    def __iadd__(self, n):
        return _fsg_internal.SwigPyIterator___iadd__(self, n)

    def __isub__(self, n):
        return _fsg_internal.SwigPyIterator___isub__(self, n)

    def __add__(self, n):
        return _fsg_internal.SwigPyIterator___add__(self, n)

    def __sub__(self, *args):
        return _fsg_internal.SwigPyIterator___sub__(self, *args)
    def __iter__(self):
        return self

# Register SwigPyIterator in _fsg_internal:
_fsg_internal.SwigPyIterator_swigregister(SwigPyIterator)

class vectori(object):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def iterator(self):
        return _fsg_internal.vectori_iterator(self)
    def __iter__(self):
        return self.iterator()

    def __nonzero__(self):
        return _fsg_internal.vectori___nonzero__(self)

    def __bool__(self):
        return _fsg_internal.vectori___bool__(self)

    def __len__(self):
        return _fsg_internal.vectori___len__(self)

    def __getslice__(self, i, j):
        return _fsg_internal.vectori___getslice__(self, i, j)

    def __setslice__(self, *args):
        return _fsg_internal.vectori___setslice__(self, *args)

    def __delslice__(self, i, j):
        return _fsg_internal.vectori___delslice__(self, i, j)

    def __delitem__(self, *args):
        return _fsg_internal.vectori___delitem__(self, *args)

    def __getitem__(self, *args):
        return _fsg_internal.vectori___getitem__(self, *args)

    def __setitem__(self, *args):
        return _fsg_internal.vectori___setitem__(self, *args)

    def pop(self):
        return _fsg_internal.vectori_pop(self)

    def append(self, x):
        return _fsg_internal.vectori_append(self, x)

    def empty(self):
        return _fsg_internal.vectori_empty(self)

    def size(self):
        return _fsg_internal.vectori_size(self)

    def swap(self, v):
        return _fsg_internal.vectori_swap(self, v)

    def begin(self):
        return _fsg_internal.vectori_begin(self)

    def end(self):
        return _fsg_internal.vectori_end(self)

    def rbegin(self):
        return _fsg_internal.vectori_rbegin(self)

    def rend(self):
        return _fsg_internal.vectori_rend(self)

    def clear(self):
        return _fsg_internal.vectori_clear(self)

    def get_allocator(self):
        return _fsg_internal.vectori_get_allocator(self)

    def pop_back(self):
        return _fsg_internal.vectori_pop_back(self)

    def erase(self, *args):
        return _fsg_internal.vectori_erase(self, *args)

    def __init__(self, *args):
        _fsg_internal.vectori_swiginit(self, _fsg_internal.new_vectori(*args))

    def push_back(self, x):
        return _fsg_internal.vectori_push_back(self, x)

    def front(self):
        return _fsg_internal.vectori_front(self)

    def back(self):
        return _fsg_internal.vectori_back(self)

    def assign(self, n, x):
        return _fsg_internal.vectori_assign(self, n, x)

    def resize(self, *args):
        return _fsg_internal.vectori_resize(self, *args)

    def insert(self, *args):
        return _fsg_internal.vectori_insert(self, *args)

    def reserve(self, n):
        return _fsg_internal.vectori_reserve(self, n)

    def capacity(self):
        return _fsg_internal.vectori_capacity(self)
    __swig_destroy__ = _fsg_internal.delete_vectori

# Register vectori in _fsg_internal:
_fsg_internal.vectori_swigregister(vectori)

class vectord(object):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def iterator(self):
        return _fsg_internal.vectord_iterator(self)
    def __iter__(self):
        return self.iterator()

    def __nonzero__(self):
        return _fsg_internal.vectord___nonzero__(self)

    def __bool__(self):
        return _fsg_internal.vectord___bool__(self)

    def __len__(self):
        return _fsg_internal.vectord___len__(self)

    def __getslice__(self, i, j):
        return _fsg_internal.vectord___getslice__(self, i, j)

    def __setslice__(self, *args):
        return _fsg_internal.vectord___setslice__(self, *args)

    def __delslice__(self, i, j):
        return _fsg_internal.vectord___delslice__(self, i, j)

    def __delitem__(self, *args):
        return _fsg_internal.vectord___delitem__(self, *args)

    def __getitem__(self, *args):
        return _fsg_internal.vectord___getitem__(self, *args)

    def __setitem__(self, *args):
        return _fsg_internal.vectord___setitem__(self, *args)

    def pop(self):
        return _fsg_internal.vectord_pop(self)

    def append(self, x):
        return _fsg_internal.vectord_append(self, x)

    def empty(self):
        return _fsg_internal.vectord_empty(self)

    def size(self):
        return _fsg_internal.vectord_size(self)

    def swap(self, v):
        return _fsg_internal.vectord_swap(self, v)

    def begin(self):
        return _fsg_internal.vectord_begin(self)

    def end(self):
        return _fsg_internal.vectord_end(self)

    def rbegin(self):
        return _fsg_internal.vectord_rbegin(self)

    def rend(self):
        return _fsg_internal.vectord_rend(self)

    def clear(self):
        return _fsg_internal.vectord_clear(self)

    def get_allocator(self):
        return _fsg_internal.vectord_get_allocator(self)

    def pop_back(self):
        return _fsg_internal.vectord_pop_back(self)

    def erase(self, *args):
        return _fsg_internal.vectord_erase(self, *args)

    def __init__(self, *args):
        _fsg_internal.vectord_swiginit(self, _fsg_internal.new_vectord(*args))

    def push_back(self, x):
        return _fsg_internal.vectord_push_back(self, x)

    def front(self):
        return _fsg_internal.vectord_front(self)

    def back(self):
        return _fsg_internal.vectord_back(self)

    def assign(self, n, x):
        return _fsg_internal.vectord_assign(self, n, x)

    def resize(self, *args):
        return _fsg_internal.vectord_resize(self, *args)

    def insert(self, *args):
        return _fsg_internal.vectord_insert(self, *args)

    def reserve(self, n):
        return _fsg_internal.vectord_reserve(self, n)

    def capacity(self):
        return _fsg_internal.vectord_capacity(self)
    __swig_destroy__ = _fsg_internal.delete_vectord

# Register vectord in _fsg_internal:
_fsg_internal.vectord_swigregister(vectord)

class KDESolver(object):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def query(self, data, query, bandwidth, debug):
        return _fsg_internal.KDESolver_query(self, data, query, bandwidth, debug)
    __swig_destroy__ = _fsg_internal.delete_KDESolver

    def __init__(self):
        if self.__class__ == KDESolver:
            _self = None
        else:
            _self = self
        _fsg_internal.KDESolver_swiginit(self, _fsg_internal.new_KDESolver(_self, ))
    def __disown__(self):
        self.this.disown()
        _fsg_internal.disown_KDESolver(self)
        return weakref.proxy(self)

# Register KDESolver in _fsg_internal:
_fsg_internal.KDESolver_swigregister(KDESolver)

class IFGT(KDESolver):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def __init__(self):
        _fsg_internal.IFGT_swiginit(self, _fsg_internal.new_IFGT())

    def query(self, data, query, bandwidth, debug):
        return _fsg_internal.IFGT_query(self, data, query, bandwidth, debug)
    __swig_destroy__ = _fsg_internal.delete_IFGT

# Register IFGT in _fsg_internal:
_fsg_internal.IFGT_swigregister(IFGT)

class LaplaceKDE(KDESolver):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def __init__(self):
        _fsg_internal.LaplaceKDE_swiginit(self, _fsg_internal.new_LaplaceKDE())

    def query(self, data, query, bandwidth, debug):
        return _fsg_internal.LaplaceKDE_query(self, data, query, bandwidth, debug)
    __swig_destroy__ = _fsg_internal.delete_LaplaceKDE

# Register LaplaceKDE in _fsg_internal:
_fsg_internal.LaplaceKDE_swigregister(LaplaceKDE)

class ExponentialKDE(KDESolver):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr

    def __init__(self):
        _fsg_internal.ExponentialKDE_swiginit(self, _fsg_internal.new_ExponentialKDE())

    def query(self, data, query, bandwidth, debug):
        return _fsg_internal.ExponentialKDE_query(self, data, query, bandwidth, debug)
    __swig_destroy__ = _fsg_internal.delete_ExponentialKDE

# Register ExponentialKDE in _fsg_internal:
_fsg_internal.ExponentialKDE_swigregister(ExponentialKDE)


def generateRandomPoints(numPoints, numDimensions):
    return _fsg_internal.generateRandomPoints(numPoints, numDimensions)

def readDataFromFile(filename):
    return _fsg_internal.readDataFromFile(filename)

def computeDegreesNaively(points, sigma):
    return _fsg_internal.computeDegreesNaively(points, sigma)

def adjacencyToLaplacian(adj_mat):
    return _fsg_internal.adjacencyToLaplacian(adj_mat)

def fast_similarity_graph(points, sigma, solver):
    return _fsg_internal.fast_similarity_graph(points, sigma, solver)

def fast_similarity_graph_debug(points, sigma, solver):
    return _fsg_internal.fast_similarity_graph_debug(points, sigma, solver)

def similarity_graph(points, sigma):
    return _fsg_internal.similarity_graph(points, sigma)

def spectral_cluster(points, k, sigma):
    return _fsg_internal.spectral_cluster(points, k, sigma)

def fast_spectral_cluster(points, k, sigma):
    return _fsg_internal.fast_spectral_cluster(points, k, sigma)

def sprsMatValues(matrix):
    return _fsg_internal.sprsMatValues(matrix)

def sprsMatInnerIndices(matrix):
    return _fsg_internal.sprsMatInnerIndices(matrix)

def sprsMatOuterStarts(matrix):
    return _fsg_internal.sprsMatOuterStarts(matrix)

def sprsMatToVec(*args):
    return _fsg_internal.sprsMatToVec(*args)

def sprsMatFromVectors(column_starts, row_indices, values):
    return _fsg_internal.sprsMatFromVectors(column_starts, row_indices, values)

def isSymmetric(matrix):
    return _fsg_internal.isSymmetric(matrix)

def safeGetline(_is, t):
    return _fsg_internal.safeGetline(_is, t)
class SprsMat(object):
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
    __repr__ = _swig_repr
    __swig_destroy__ = _fsg_internal.delete_SprsMat

    def __init__(self):
        _fsg_internal.SprsMat_swiginit(self, _fsg_internal.new_SprsMat())

# Register SprsMat in _fsg_internal:
_fsg_internal.SprsMat_swigregister(SprsMat)



