Loading [MathJax]/extensions/tex2jax.js
IMP logo
IMP Reference Guide  develop.7e67b86265,2025/01/03
The Integrative Modeling Platform
kmeans/__init__.py
1 # This file was automatically generated by SWIG (https://www.swig.org).
2 # Version 4.3.0
3 #
4 # Do not make changes to this file unless you know what you are doing - modify
5 # the SWIG interface file instead.
6 
7 
8 # This wrapper is part of IMP,
9 # Copyright 2007-2025 IMP Inventors. All rights reserved.
10 
11 
12 
13 
14 from sys import version_info as _swig_python_version_info
15 import _IMP_kmeans
16 
17 try:
18  import builtins as __builtin__
19 except ImportError:
20  import __builtin__
21 
22 def _swig_repr(self):
23  try:
24  strthis = "proxy of " + self.this.__repr__()
25  except __builtin__.Exception:
26  strthis = ""
27  return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)
28 
29 
30 def _swig_setattr_nondynamic_instance_variable(set):
31  def set_instance_attr(self, name, value):
32  if name == "this":
33  set(self, name, value)
34  elif name == "thisown":
35  self.this.own(value)
36  elif hasattr(self, name) and isinstance(getattr(type(self), name), property):
37  set(self, name, value)
38  else:
39  raise AttributeError("You cannot add instance attributes to %s" % self)
40  return set_instance_attr
41 
42 
43 def _swig_setattr_nondynamic_class_variable(set):
44  def set_class_attr(cls, name, value):
45  if hasattr(cls, name) and not isinstance(getattr(cls, name), property):
46  set(cls, name, value)
47  else:
48  raise AttributeError("You cannot add class attributes to %s" % cls)
49  return set_class_attr
50 
51 
52 def _swig_add_metaclass(metaclass):
53  """Class decorator for adding a metaclass to a SWIG wrapped class - a slimmed down version of six.add_metaclass"""
54  def wrapper(cls):
55  return metaclass(cls.__name__, cls.__bases__, cls.__dict__.copy())
56  return wrapper
57 
58 
59 class _SwigNonDynamicMeta(type):
60  """Meta class to enforce nondynamic attributes (no new attributes) for a class"""
61  __setattr__ = _swig_setattr_nondynamic_class_variable(type.__setattr__)
62 
63 
64 import weakref
65 
66 class IMP_KMEANS_SwigPyIterator(object):
67  r"""Proxy of C++ swig::IMP_KMEANS_SwigPyIterator class."""
68 
69  thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
70 
71  def __init__(self, *args, **kwargs):
72  raise AttributeError("No constructor defined - class is abstract")
73  __repr__ = _swig_repr
74  __swig_destroy__ = _IMP_kmeans.delete_IMP_KMEANS_SwigPyIterator
75 
76  def value(self):
77  r"""value(IMP_KMEANS_SwigPyIterator self) -> PyObject *"""
78  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_value(self)
79 
80  def incr(self, n=1):
81  r"""incr(IMP_KMEANS_SwigPyIterator self, size_t n=1) -> IMP_KMEANS_SwigPyIterator"""
82  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_incr(self, n)
83 
84  def decr(self, n=1):
85  r"""decr(IMP_KMEANS_SwigPyIterator self, size_t n=1) -> IMP_KMEANS_SwigPyIterator"""
86  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_decr(self, n)
87 
88  def distance(self, x):
89  r"""distance(IMP_KMEANS_SwigPyIterator self, IMP_KMEANS_SwigPyIterator x) -> ptrdiff_t"""
90  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_distance(self, x)
91 
92  def equal(self, x):
93  r"""equal(IMP_KMEANS_SwigPyIterator self, IMP_KMEANS_SwigPyIterator x) -> bool"""
94  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_equal(self, x)
95 
96  def copy(self):
97  r"""copy(IMP_KMEANS_SwigPyIterator self) -> IMP_KMEANS_SwigPyIterator"""
98  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_copy(self)
99 
100  def next(self):
101  r"""next(IMP_KMEANS_SwigPyIterator self) -> PyObject *"""
102  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_next(self)
103 
104  def __next__(self):
105  r"""__next__(IMP_KMEANS_SwigPyIterator self) -> PyObject *"""
106  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___next__(self)
107 
108  def previous(self):
109  r"""previous(IMP_KMEANS_SwigPyIterator self) -> PyObject *"""
110  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_previous(self)
111 
112  def advance(self, n):
113  r"""advance(IMP_KMEANS_SwigPyIterator self, ptrdiff_t n) -> IMP_KMEANS_SwigPyIterator"""
114  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator_advance(self, n)
115 
116  def __eq__(self, x):
117  r"""__eq__(IMP_KMEANS_SwigPyIterator self, IMP_KMEANS_SwigPyIterator x) -> bool"""
118  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___eq__(self, x)
119 
120  def __ne__(self, x):
121  r"""__ne__(IMP_KMEANS_SwigPyIterator self, IMP_KMEANS_SwigPyIterator x) -> bool"""
122  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___ne__(self, x)
123 
124  def __iadd__(self, n):
125  r"""__iadd__(IMP_KMEANS_SwigPyIterator self, ptrdiff_t n) -> IMP_KMEANS_SwigPyIterator"""
126  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___iadd__(self, n)
127 
128  def __isub__(self, n):
129  r"""__isub__(IMP_KMEANS_SwigPyIterator self, ptrdiff_t n) -> IMP_KMEANS_SwigPyIterator"""
130  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___isub__(self, n)
131 
132  def __add__(self, n):
133  r"""__add__(IMP_KMEANS_SwigPyIterator self, ptrdiff_t n) -> IMP_KMEANS_SwigPyIterator"""
134  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___add__(self, n)
135 
136  def __sub__(self, *args):
137  r"""
138  __sub__(IMP_KMEANS_SwigPyIterator self, ptrdiff_t n) -> IMP_KMEANS_SwigPyIterator
139  __sub__(IMP_KMEANS_SwigPyIterator self, IMP_KMEANS_SwigPyIterator x) -> ptrdiff_t
140  """
141  return _IMP_kmeans.IMP_KMEANS_SwigPyIterator___sub__(self, *args)
142  def __iter__(self):
143  return self
144 
145 # Register IMP_KMEANS_SwigPyIterator in _IMP_kmeans:
146 _IMP_kmeans.IMP_KMEANS_SwigPyIterator_swigregister(IMP_KMEANS_SwigPyIterator)
147 
148 _value_types=[]
149 _object_types=[]
150 _raii_types=[]
151 _plural_types=[]
152 
153 IMP_DEBUG = _IMP_kmeans.IMP_DEBUG
154 
155 IMP_RELEASE = _IMP_kmeans.IMP_RELEASE
156 
157 IMP_SILENT = _IMP_kmeans.IMP_SILENT
158 
159 IMP_PROGRESS = _IMP_kmeans.IMP_PROGRESS
160 
161 IMP_TERSE = _IMP_kmeans.IMP_TERSE
162 
163 IMP_VERBOSE = _IMP_kmeans.IMP_VERBOSE
164 
165 IMP_MEMORY = _IMP_kmeans.IMP_MEMORY
166 
167 IMP_NONE = _IMP_kmeans.IMP_NONE
168 
169 IMP_USAGE = _IMP_kmeans.IMP_USAGE
170 
171 IMP_INTERNAL = _IMP_kmeans.IMP_INTERNAL
172 
173 IMP_KERNEL_HAS_LOG4CXX = _IMP_kmeans.IMP_KERNEL_HAS_LOG4CXX
174 
175 IMP_COMPILER_HAS_CEREAL_RAW_POINTER = _IMP_kmeans.IMP_COMPILER_HAS_CEREAL_RAW_POINTER
176 
177 IMP_COMPILER_HAS_DEBUG_VECTOR = _IMP_kmeans.IMP_COMPILER_HAS_DEBUG_VECTOR
178 
179 IMP_COMPILER_HAS_RANDOM_SHUFFLE = _IMP_kmeans.IMP_COMPILER_HAS_RANDOM_SHUFFLE
180 
181 IMP_COMPILER_HAS_THREE_WAY = _IMP_kmeans.IMP_COMPILER_HAS_THREE_WAY
182 
183 IMP_KERNEL_HAS_BOOST_RANDOM = _IMP_kmeans.IMP_KERNEL_HAS_BOOST_RANDOM
184 
185 IMP_KERNEL_HAS_NUMPY = _IMP_kmeans.IMP_KERNEL_HAS_NUMPY
186 
187 IMP_KERNEL_HAS_GPERFTOOLS = _IMP_kmeans.IMP_KERNEL_HAS_GPERFTOOLS
188 
189 IMP_KERNEL_HAS_TCMALLOC_HEAPCHECKER = _IMP_kmeans.IMP_KERNEL_HAS_TCMALLOC_HEAPCHECKER
190 
191 IMP_KERNEL_HAS_TCMALLOC_HEAPPROFILER = _IMP_kmeans.IMP_KERNEL_HAS_TCMALLOC_HEAPPROFILER
192 
193 IMPKERNEL_SHOW_WARNINGS = _IMP_kmeans.IMPKERNEL_SHOW_WARNINGS
194 
195 
196 import sys
197 class _DirectorObjects:
198  """@internal Simple class to keep references to director objects
199  to prevent premature deletion."""
200  def __init__(self):
201  self._objects = []
202  def register(self, obj):
203  """Take a reference to a director object; will only work for
204  refcounted C++ classes"""
205  if hasattr(obj, 'get_ref_count'):
206  self._objects.append(obj)
207  def cleanup(self):
208  """Only drop our reference and allow cleanup by Python if no other
209  Python references exist (we hold 3 references: one in self._objects,
210  one in x, and one in the argument list for getrefcount) *and* no
211  other C++ references exist (the Python object always holds one)"""
212  objs = [x for x in self._objects if sys.getrefcount(x) > 3 \
213  or x.get_ref_count() > 1]
214 # Do in two steps so the references are kept until the end of the
215 # function (deleting references may trigger a fresh call to this method)
216  self._objects = objs
217  def get_object_count(self):
218  """Get number of director objects (useful for testing only)"""
219  return len(self._objects)
220 _director_objects = _DirectorObjects()
221 
222 class _ostream(object):
223  r"""Proxy of C++ std::ostream class."""
224 
225  thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
226 
227  def __init__(self, *args, **kwargs):
228  raise AttributeError("No constructor defined")
229  __repr__ = _swig_repr
230 
231  def write(self, osa_buf):
232  r"""write(_ostream self, char const * osa_buf)"""
233  return _IMP_kmeans._ostream_write(self, osa_buf)
234 
235 # Register _ostream in _IMP_kmeans:
236 _IMP_kmeans._ostream_swigregister(_ostream)
237 IMP_C_OPEN_BINARY = _IMP_kmeans.IMP_C_OPEN_BINARY
238 
239 import IMP
240 IMP_KMEANS_HAS_BOOST_FILESYSTEM = _IMP_kmeans.IMP_KMEANS_HAS_BOOST_FILESYSTEM
241 
242 IMP_KMEANS_HAS_BOOST_PROGRAMOPTIONS = _IMP_kmeans.IMP_KMEANS_HAS_BOOST_PROGRAMOPTIONS
243 
244 IMP_KMEANS_HAS_BOOST_RANDOM = _IMP_kmeans.IMP_KMEANS_HAS_BOOST_RANDOM
245 
246 IMP_KMEANS_HAS_BOOST_SYSTEM = _IMP_kmeans.IMP_KMEANS_HAS_BOOST_SYSTEM
247 
248 IMP_KMEANS_HAS_NUMPY = _IMP_kmeans.IMP_KMEANS_HAS_NUMPY
249 
250 IMPKMEANS_SHOW_WARNINGS = _IMP_kmeans.IMPKMEANS_SHOW_WARNINGS
251 
252 
253 _object_types.append("KMeans")
254 
255 
256 def _object_cast_to_KMeans(o):
257  r"""_object_cast_to_KMeans(Object o) -> KMeans"""
258  return _IMP_kmeans._object_cast_to_KMeans(o)
259 KM_LLOYDS = _IMP_kmeans.KM_LLOYDS
260 
261 KM_LOCAL_SWAP = _IMP_kmeans.KM_LOCAL_SWAP
262 
263 KM_LOCAL_EZ_HYBRID = _IMP_kmeans.KM_LOCAL_EZ_HYBRID
264 
265 KM_HYBRID = _IMP_kmeans.KM_HYBRID
266 
267 class KMeans(IMP.Object):
268  r"""Proxy of C++ IMP::kmeans::KMeans class."""
269 
270  thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc="The membership flag")
271 
272  def __init__(self, *args):
273  r"""
274  __init__(KMeans self, std::string const & fname_data, int dim, unsigned int max_nPts) -> KMeans
275  __init__(KMeans self) -> KMeans
276  """
277  _IMP_kmeans.KMeans_swiginit(self, _IMP_kmeans.new_KMeans(*args))
278 
279  def get_version_info(self):
280  r"""get_version_info(KMeans self) -> VersionInfo"""
281  return _IMP_kmeans.KMeans_get_version_info(self)
282  __swig_destroy__ = _IMP_kmeans.delete_KMeans
283 
284  def execute(self, *args):
285  r"""execute(KMeans self, unsigned int k, IMP::kmeans::KM_ALG_TYPE alg_type=KM_LLOYDS, int stages=100)"""
286  return _IMP_kmeans.KMeans_execute(self, *args)
287 
288  def add_data_pt(self, p):
289  r"""add_data_pt(KMeans self, IMP::Floats const & p)"""
290  return _IMP_kmeans.KMeans_add_data_pt(self, p)
291 
292  def clear_data(self):
293  r"""clear_data(KMeans self)"""
294  return _IMP_kmeans.KMeans_clear_data(self)
295 
296  def get_data_point(self, i):
297  r"""get_data_point(KMeans self, unsigned int i) -> IMP::Floats const &"""
298  return _IMP_kmeans.KMeans_get_data_point(self, i)
299 
300  def get_number_of_data_points(self):
301  r"""get_number_of_data_points(KMeans self) -> unsigned int"""
302  return _IMP_kmeans.KMeans_get_number_of_data_points(self)
303 
304  def print_centers(self, *args):
305  r"""print_centers(KMeans self, IMP::LogLevel ll=PROGRESS)"""
306  return _IMP_kmeans.KMeans_print_centers(self, *args)
307 
308  def get_center(self, i):
309  r"""get_center(KMeans self, unsigned int i) -> IMP::Floats"""
310  return _IMP_kmeans.KMeans_get_center(self, i)
311 
312  def get_assignments(self):
313  r"""get_assignments(KMeans self) -> IMP::Ints"""
314  return _IMP_kmeans.KMeans_get_assignments(self)
315 
316  def get_squared_distance_to_centers(self):
317  r"""get_squared_distance_to_centers(KMeans self) -> IMP::Floats"""
318  return _IMP_kmeans.KMeans_get_squared_distance_to_centers(self)
319 
320  def get_number_of_centers(self):
321  r"""get_number_of_centers(KMeans self) -> unsigned int"""
322  return _IMP_kmeans.KMeans_get_number_of_centers(self)
323 
324  def __str__(self):
325  r"""__str__(KMeans self) -> std::string"""
326  return _IMP_kmeans.KMeans___str__(self)
327 
328  def __repr__(self):
329  r"""__repr__(KMeans self) -> std::string"""
330  return _IMP_kmeans.KMeans___repr__(self)
331 
332  @staticmethod
333  def get_from(o):
334  return _object_cast_to_KMeans(o)
335 
336 
337 # Register KMeans in _IMP_kmeans:
338 _IMP_kmeans.KMeans_swigregister(KMeans)
339 
340 def get_module_version():
341  r"""get_module_version() -> std::string const"""
342  return _IMP_kmeans.get_module_version()
343 
344 def get_example_path(fname):
345  r"""get_example_path(std::string fname) -> std::string"""
346  return _IMP_kmeans.get_example_path(fname)
347 
348 def get_data_path(fname):
349  r"""get_data_path(std::string fname) -> std::string"""
350  return _IMP_kmeans.get_data_path(fname)
351 
352 from . import _version_check
353 _version_check.check_version(get_module_version())
354 __version__ = get_module_version()
355 
356 
Common base class for heavy weight IMP objects.
Definition: Object.h:111
std::string get_module_version()
Return the version of this module, as a string.
virtual VersionInfo get_version_info() const
Get information about the module and version of the object.
Definition: Object.h:206
std::string get_example_path(std::string file_name)
Return the full path to one of this module's example files.
std::string get_data_path(std::string file_name)
Return the full path to one of this module's data files.