|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import os |
|
from . import * |
|
|
|
|
|
class BingoException(Exception): |
|
|
|
def __init__(self, value): |
|
self.value = value |
|
|
|
def __str__(self): |
|
if sys.version_info > (3, 0): |
|
return repr(self.value.decode('ascii')) |
|
else: |
|
return repr(self.value) |
|
|
|
|
|
class Bingo(object): |
|
def __init__(self, bingoId, indigo, lib): |
|
self._id = bingoId |
|
self._indigo = indigo |
|
self._lib = lib |
|
self._lib.bingoVersion.restype = c_char_p |
|
self._lib.bingoVersion.argtypes = None |
|
self._lib.bingoCreateDatabaseFile.restype = c_int |
|
self._lib.bingoCreateDatabaseFile.argtypes = [c_char_p, c_char_p, c_char_p] |
|
self._lib.bingoLoadDatabaseFile.restype = c_int |
|
self._lib.bingoLoadDatabaseFile.argtypes = [c_char_p, c_char_p] |
|
self._lib.bingoCloseDatabase.restype = c_int |
|
self._lib.bingoCloseDatabase.argtypes = [c_int] |
|
self._lib.bingoInsertRecordObj.restype = c_int |
|
self._lib.bingoInsertRecordObj.argtypes = [c_int, c_int] |
|
self._lib.bingoInsertRecordObjWithExtFP.restype = c_int |
|
self._lib.bingoInsertRecordObjWithExtFP.argtypes = [c_int, c_int, c_int] |
|
self._lib.bingoGetRecordObj.restype = c_int |
|
self._lib.bingoGetRecordObj.argtypes = [c_int, c_int] |
|
self._lib.bingoInsertRecordObjWithId.restype = c_int |
|
self._lib.bingoInsertRecordObjWithId.argtypes = [c_int, c_int, c_int] |
|
self._lib.bingoInsertRecordObjWithIdAndExtFP.restype = c_int |
|
self._lib.bingoInsertRecordObjWithIdAndExtFP.argtypes = [c_int, c_int, c_int, c_int] |
|
self._lib.bingoDeleteRecord.restype = c_int |
|
self._lib.bingoDeleteRecord.argtypes = [c_int, c_int] |
|
self._lib.bingoSearchSub.restype = c_int |
|
self._lib.bingoSearchSub.argtypes = [c_int, c_int, c_char_p] |
|
self._lib.bingoSearchExact.restype = c_int |
|
self._lib.bingoSearchExact.argtypes = [c_int, c_int, c_char_p] |
|
self._lib.bingoSearchMolFormula.restype = c_int |
|
self._lib.bingoSearchMolFormula.argtypes = [c_int, c_char_p, c_char_p] |
|
self._lib.bingoSearchSim.restype = c_int |
|
self._lib.bingoSearchSim.argtypes = [c_int, c_int, c_float, c_float, c_char_p] |
|
self._lib.bingoSearchSimWithExtFP.restype = c_int |
|
self._lib.bingoSearchSimWithExtFP.argtypes = [c_int, c_int, c_float, c_float, c_int, c_char_p] |
|
self._lib.bingoSearchSimTopN.restype = c_int |
|
self._lib.bingoSearchSimTopN.argtypes = [c_int, c_int, c_int, c_float, c_char_p] |
|
self._lib.bingoSearchSimTopNWithExtFP.restype = c_int |
|
self._lib.bingoSearchSimTopNWithExtFP.argtypes = [c_int, c_int, c_int, c_float, c_int, c_char_p] |
|
self._lib.bingoEnumerateId.restype = c_int |
|
self._lib.bingoEnumerateId.argtypes = [c_int] |
|
self._lib.bingoNext.restype = c_int |
|
self._lib.bingoNext.argtypes = [c_int] |
|
self._lib.bingoGetCurrentId.restype = c_int |
|
self._lib.bingoGetCurrentId.argtypes = [c_int] |
|
self._lib.bingoGetObject.restype = c_int |
|
self._lib.bingoGetObject.argtypes = [c_int] |
|
self._lib.bingoEndSearch.restype = c_int |
|
self._lib.bingoEndSearch.argtypes = [c_int] |
|
self._lib.bingoGetCurrentSimilarityValue.restype = c_float |
|
self._lib.bingoGetCurrentSimilarityValue.argtypes = [c_int] |
|
self._lib.bingoOptimize.restype = c_int |
|
self._lib.bingoOptimize.argtypes = [c_int] |
|
self._lib.bingoEstimateRemainingResultsCount.restype = c_int |
|
self._lib.bingoEstimateRemainingResultsCount.argtypes = [c_int] |
|
self._lib.bingoEstimateRemainingResultsCountError.restype = c_int |
|
self._lib.bingoEstimateRemainingResultsCountError.argtypes = [c_int] |
|
self._lib.bingoEstimateRemainingTime.restype = c_int |
|
self._lib.bingoEstimateRemainingTime.argtypes = [c_int, POINTER(c_float)] |
|
self._lib.bingoContainersCount.restype = c_int |
|
self._lib.bingoContainersCount.argtypes = [c_int] |
|
self._lib.bingoCellsCount.restype = c_int |
|
self._lib.bingoCellsCount.argtypes = [c_int] |
|
self._lib.bingoCurrentCell.restype = c_int |
|
self._lib.bingoCurrentCell.argtypes = [c_int] |
|
self._lib.bingoMinCell.restype = c_int |
|
self._lib.bingoMinCell.argtypes = [c_int] |
|
self._lib.bingoMaxCell.restype = c_int |
|
self._lib.bingoMaxCell.argtypes = [c_int] |
|
|
|
def __del__(self): |
|
self.close() |
|
|
|
def close(self): |
|
self._indigo._setSessionId() |
|
if self._id >= 0: |
|
Bingo._checkResult(self._indigo, self._lib.bingoCloseDatabase(self._id)) |
|
self._id = -1 |
|
|
|
@staticmethod |
|
def _checkResult(indigo, result): |
|
if result < 0: |
|
raise BingoException(indigo._lib.indigoGetLastError()) |
|
return result |
|
|
|
@staticmethod |
|
def _checkResultPtr (indigo, result): |
|
if result is None: |
|
raise BingoException(indigo._lib.indigoGetLastError()) |
|
return result |
|
|
|
@staticmethod |
|
def _checkResultString (indigo, result): |
|
res = Bingo._checkResultPtr(indigo, result) |
|
if sys.version_info >= (3, 0): |
|
return res.decode('ascii') |
|
else: |
|
return res.encode('ascii') |
|
|
|
@staticmethod |
|
def _getLib(indigo): |
|
if os.name == 'posix' and not platform.mac_ver()[0] and not platform.system().startswith("CYGWIN"): |
|
_lib = CDLL(indigo.dllpath + "/libbingo.so") |
|
elif os.name == 'nt' or platform.system().startswith("CYGWIN"): |
|
_lib = CDLL(indigo.dllpath + "/bingo.dll") |
|
elif platform.mac_ver()[0]: |
|
_lib = CDLL(indigo.dllpath + "/libbingo.dylib") |
|
else: |
|
raise BingoException("unsupported OS: " + os.name) |
|
return _lib |
|
|
|
@staticmethod |
|
def createDatabaseFile(indigo, path, databaseType, options=''): |
|
indigo._setSessionId() |
|
if not options: |
|
options = '' |
|
lib = Bingo._getLib(indigo) |
|
lib.bingoCreateDatabaseFile.restype = c_int |
|
lib.bingoCreateDatabaseFile.argtypes = [c_char_p, c_char_p, c_char_p] |
|
return Bingo(Bingo._checkResult(indigo, lib.bingoCreateDatabaseFile(path.encode('ascii'), databaseType.encode('ascii'), options.encode('ascii'))), indigo, lib) |
|
|
|
@staticmethod |
|
def loadDatabaseFile(indigo, path, options=''): |
|
indigo._setSessionId() |
|
if not options: |
|
options = '' |
|
lib = Bingo._getLib(indigo) |
|
lib.bingoLoadDatabaseFile.restype = c_int |
|
lib.bingoLoadDatabaseFile.argtypes = [c_char_p, c_char_p] |
|
return Bingo(Bingo._checkResult(indigo, lib.bingoLoadDatabaseFile(path.encode('ascii'), options.encode('ascii'))), indigo, lib) |
|
|
|
def version(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResultString(self._indigo, self._lib.bingoVersion()) |
|
|
|
def insert(self, indigoObject, index=None): |
|
self._indigo._setSessionId() |
|
if not index: |
|
return Bingo._checkResult(self._indigo, self._lib.bingoInsertRecordObj(self._id, indigoObject.id)) |
|
else: |
|
return Bingo._checkResult(self._indigo, |
|
self._lib.bingoInsertRecordObjWithId(self._id, indigoObject.id, index)) |
|
|
|
def insertWithExtFP(self, indigoObject, ext_fp, index=None): |
|
self._indigo._setSessionId() |
|
if not index: |
|
return Bingo._checkResult(self._indigo, self._lib.bingoInsertRecordObjWithExtFP(self._id, indigoObject.id, ext_fp.id)) |
|
else: |
|
return Bingo._checkResult(self._indigo, |
|
self._lib.bingoInsertRecordObjWithIdAndExtFP(self._id, indigoObject.id, index, ext_fp.id)) |
|
|
|
def delete(self, index): |
|
self._indigo._setSessionId() |
|
Bingo._checkResult(self._indigo, self._lib.bingoDeleteRecord(self._id, index)) |
|
|
|
def searchSub(self, query, options=''): |
|
self._indigo._setSessionId() |
|
if not options: |
|
options = '' |
|
return BingoObject(Bingo._checkResult(self._indigo, self._lib.bingoSearchSub(self._id, query.id, options.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def searchExact(self, query, options=''): |
|
self._indigo._setSessionId() |
|
if not options: |
|
options = '' |
|
return BingoObject(Bingo._checkResult(self._indigo, self._lib.bingoSearchExact(self._id, query.id, options.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def searchSim(self, query, minSim, maxSim, metric='tanimoto'): |
|
self._indigo._setSessionId() |
|
if not metric: |
|
metric = 'tanimoto' |
|
return BingoObject( |
|
Bingo._checkResult(self._indigo, self._lib.bingoSearchSim(self._id, query.id, minSim, maxSim, metric.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def searchSimWithExtFP(self, query, minSim, maxSim, ext_fp, metric='tanimoto'): |
|
self._indigo._setSessionId() |
|
if not metric: |
|
metric = 'tanimoto' |
|
return BingoObject( |
|
Bingo._checkResult(self._indigo, self._lib.bingoSearchSimWithExtFP(self._id, query.id, minSim, maxSim, ext_fp.id, metric.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def searchSimTopN(self, query, limit, minSim, metric='tanimoto'): |
|
self._indigo._setSessionId() |
|
if not metric: |
|
metric = 'tanimoto' |
|
return BingoObject( |
|
Bingo._checkResult(self._indigo, self._lib.bingoSearchSimTopN(self._id, query.id, limit, minSim, metric.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def searchSimTopNWithExtFP(self, query, limit, minSim, ext_fp, metric='tanimoto'): |
|
self._indigo._setSessionId() |
|
if not metric: |
|
metric = 'tanimoto' |
|
return BingoObject( |
|
Bingo._checkResult(self._indigo, self._lib.bingoSearchSimTopNWithExtFP(self._id, query.id, limit, minSim, ext_fp.id, metric.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def enumerateId(self): |
|
self._indigo._setSessionId() |
|
e = self._lib.bingoEnumerateId(self._id) |
|
result = Bingo._checkResult(self._indigo, e) |
|
return BingoObject(result, self._indigo, self) |
|
|
|
def searchMolFormula(self, query, options=''): |
|
self._indigo._setSessionId() |
|
if not options: |
|
options = '' |
|
return BingoObject(Bingo._checkResult(self._indigo, self._lib.bingoSearchMolFormula(self._id, query.encode('ascii'), options.encode('ascii'))), |
|
self._indigo, self) |
|
|
|
def optimize(self): |
|
self._indigo._setSessionId() |
|
Bingo._checkResult(self._indigo, self._lib.bingoOptimize(self._id)) |
|
|
|
def getRecordById (self, id): |
|
self._indigo._setSessionId() |
|
return IndigoObject(self._indigo, Bingo._checkResult(self._indigo, self._lib.bingoGetRecordObj(self._id, id))) |
|
|
|
class BingoObject(object): |
|
def __init__(self, objId, indigo, bingo): |
|
self._id = objId |
|
self._indigo = indigo |
|
self._bingo = bingo |
|
|
|
def __del__(self): |
|
self.close() |
|
|
|
def close(self): |
|
self._indigo._setSessionId() |
|
if self._id >= 0: |
|
Bingo._checkResult(self._indigo, self._bingo._lib.bingoEndSearch(self._id)) |
|
self._id = -1 |
|
|
|
def next(self): |
|
self._indigo._setSessionId() |
|
return (Bingo._checkResult(self._indigo, self._bingo._lib.bingoNext(self._id)) == 1) |
|
|
|
def getCurrentId(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoGetCurrentId(self._id)) |
|
|
|
def getIndigoObject(self): |
|
self._indigo._setSessionId() |
|
return IndigoObject(self._indigo, Bingo._checkResult(self._indigo, self._bingo._lib.bingoGetObject(self._id))) |
|
|
|
def getCurrentSimilarityValue(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoGetCurrentSimilarityValue(self._id)) |
|
|
|
def estimateRemainingResultsCount(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoEstimateRemainingResultsCount(self._id)) |
|
|
|
def estimateRemainingResultsCountError(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoEstimateRemainingResultsCountError(self._id)) |
|
|
|
def estimateRemainingTime(self): |
|
self._indigo._setSessionId() |
|
value = c_float() |
|
Bingo._checkResult(self._indigo, self._bingo._lib.bingoEstimateRemainingTime(self._id, pointer(value))) |
|
return value.value |
|
|
|
def containersCount(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoContainersCount(self._id)) |
|
|
|
def cellsCount(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoCellsCount(self._id)) |
|
|
|
def currentCell(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoCurrentCell(self._id)) |
|
|
|
def minCell(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoMinCell(self._id)) |
|
|
|
def maxCell(self): |
|
self._indigo._setSessionId() |
|
return Bingo._checkResult(self._indigo, self._bingo._lib.bingoMaxCell(self._id)) |
|
|
|
def __enter__(self): |
|
return self |
|
|
|
def __exit__(self, exc_type, exc_val, exc_tb): |
|
self.close() |
|
|
|
def __iter__(self): |
|
return self |
|
|
|
def __next__(self): |
|
next_item = self.next() |
|
if next_item: |
|
return self |
|
raise StopIteration |
|
|