From d5ddc0a56d9f52f27fb6edcc2fa1caf66fdb9eb0 Mon Sep 17 00:00:00 2001 From: Samo Penic <samo.penic@gmail.com> Date: Thu, 15 Aug 2019 06:05:39 +0000 Subject: [PATCH] Fixed argtypes in wrapper --- trisurf/wrapper.py | 60 +++++++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 39 insertions(+), 21 deletions(-) diff --git a/trisurf/wrapper.py b/trisurf/wrapper.py index 1f9fd2c..3bdda16 100644 --- a/trisurf/wrapper.py +++ b/trisurf/wrapper.py @@ -214,26 +214,26 @@ #function call wrappers def create_vesicle_from_tape(tape): """Using pointer for tape, it creates a vesicle, returning pointer to it.""" - ts.create_vesicle_from_tape.argtype=POINTER(ts_tape) + ts.create_vesicle_from_tape.argtypes=POINTER(ts_tape) ts.create_vesicle_from_tape.restype=POINTER(ts_vesicle) return ts.create_vesicle_from_tape(tape) def parsetape(filename='tape'): """Loads tape with filename (if not given it defaults to 'tape'). It returns a pointer to structure for tape""" ts.parsetape.restype=POINTER(ts_tape) - ts.parsetape.argtype=[c_char_p] + ts.parsetape.argtypes=[c_char_p] return ts.parsetape(filename.encode('ascii')) def parseDump(filename): """Loads a vtu file with 'filename' and creates a vesicle returning pointer to it""" - ts.parseDump.argtype=[c_char_p] + ts.parseDump.argtypes=[c_char_p] ts.parseDump.restype=POINTER(ts_vesicle) vesicle=ts.parseDump(filename.encode('ascii')) return vesicle def single_timestep(vesicle): """Makes a single timestep in simulations. Returns a tuple of vmsrt and bfrt (vertex move success rate and bond flip success rate)""" - ts.single_timestep.argtype=[POINTER(ts_vesicle),POINTER(c_double),POINTER(c_double)] + ts.single_timestep.argtypes=[POINTER(ts_vesicle),POINTER(c_double),POINTER(c_double)] vmsrt=c_double(0.0) bfsrt=c_double(0.0) ts.single_timestep(vesicle,byref(vmsrt),byref(bfsrt)) @@ -241,25 +241,25 @@ def write_vertex_xml_file(vesicle,timestep_no=0): """Writes a vesicle into file with filename 'timestep_XXXXXX.vtu', where XXXXXX is a leading zeroed number given with timestep_no parameter (defaults to 0 if not given""" - ts.write_vertex_xml_file.argtypes=[POINTER(ts_vesicle),c_int] + ts.write_vertex_xml_file.argtypess=[POINTER(ts_vesicle),c_int] ts.write_vertex_xml_file(vesicle,c_int(timestep_no)) def vesicle_free(vesicle): """Free memory of the whole vesicle""" - ts.vesicle_free.argtype=[POINTER(ts_vesicle)] + ts.vesicle_free.argtypes=[POINTER(ts_vesicle)] ts.vesicle_free(vesicle) def vesicle_volume(vesicle): - ts.vesicle_volume.argtype=[POINTER(ts_vesicle)] + ts.vesicle_volume.argtypes=[POINTER(ts_vesicle)] ts.vesicle_volume(vesicle) def vesicle_area(vesicle): - ts.vesicle_area.argtype=[POINTER(ts_vesicle)] + ts.vesicle_area.argtypes=[POINTER(ts_vesicle)] ts.vesicle_area(vesicle) def gyration_eigen(vesicle): - ts.gyration_eigen.argtype=[POINTER(ts_vesicle), POINTER(c_double), POINTER(c_double), POINTER(c_double)] + ts.gyration_eigen.argtypes=[POINTER(ts_vesicle), POINTER(c_double), POINTER(c_double), POINTER(c_double)] l1=c_double(0.0) l2=c_double(0.0) l3=c_double(0.0) @@ -267,7 +267,7 @@ return (l1.value, l2.value, l3.value) def vesicle_meancurvature(vesicle): - ts.vesicle_meancurvature.argtype=[POINTER(ts_vesicle)] + ts.vesicle_meancurvature.argtypes=[POINTER(ts_vesicle)] ts.vesicle_meancurvature.restype=c_double return ts.vesicle_meancurvature(vesicle) @@ -277,38 +277,56 @@ return ret def clusterize_vesicle(vesicle, cluster_list): - ts.clusterize_vesicle.argtype=[POINTER(ts_vesicle), POINTER(ts_cluster_list)] + ts.clusterize_vesicle.argtypes=[POINTER(ts_vesicle), POINTER(ts_cluster_list)] ts.clusterize_vesicle(vesicle, cluster_list) def cluster_list_free(cluster_list): """Free memory of cluster list""" - ts.cluster_list_free.argtype=[POINTER(ts_cluster_list)] + ts.cluster_list_free.argtypes=[POINTER(ts_cluster_list)] ts.cluster_list_free(cluster_list) def stretchenergy(vesicle, triangle): - ts.stretchenergy.argtype=[POINTER(ts_vesicle), POINTER(ts_triangle)] + ts.stretchenergy.argtypes=[POINTER(ts_vesicle), POINTER(ts_triangle)] ts.stretchenergy(vesicle,triangle) def get_absolute_ulm2(vesicle,l,m): - ts.get_absolute_ulm2.argtype=[POINTER(ts_vesicle), c_double, c_double] + ts.get_absolute_ulm2.argtypes=[POINTER(ts_vesicle), c_double, c_double] ts.get_absolute_ulm2.restype=c_double ret=ts.get_absolute_ulm2(vesicle,l,m) return ret def getR0(vesicle): - ts.getR0.argtype=[POINTER(ts_vesicle)] + ts.getR0.argtypes=[POINTER(ts_vesicle)] ts.getR0.restype=c_double r0=ts.getR0(vesicle) return r0 def preparationSh(vesicle,r0): - ts.preparationSh.argtype=[POINTER(ts_vesicle), c_double] - ts.preparationSh(vesicle,float(r0)) + ts.preparationSh.argtypes=[POINTER(ts_vesicle), c_double] + ts.preparationSh(vesicle,r0) def calculateUlmComplex(vesicle): - ts.calculateUlmComplex.argtype=[POINTER(ts_vesicle)] + ts.calculateUlmComplex.argtypes=[POINTER(ts_vesicle)] ts.calculateUlmComplex(vesicle) -def solve_for_ulm2(vesicle): - ts.solve_for_ulm2.argtype=[POINTER(ts_vesicle)] - ts.solve_for_ulm2(vesicle) + +def Ulm2Complex2String(vesicle): + ts.Ulm2Complex2String.argtypes=[POINTER(ts_vesicle)] + ts.Ulm2Complex2String.restype=c_char_p + string=ts.Ulm2Complex2String(vesicle) + return string + +def freeUlm2String(string): + ts.freeUlm2String.argtypes=[c_char_p] + ts.freeUlm2String(string) + + +#This function seems not to exist!!! +#def solve_for_ulm2(vesicle): +# ts.solve_for_ulm2.argtypes=[POINTER(ts_vesicle)] +# ts.solve_for_ulm2(vesicle) + +def mean_curvature_and_energy(vesicle): + ts.mean_curvature_and_energy.argtypes=[POINTER(ts_vesicle)] + ts.mean_curvature_and_energy(vesicle) + -- Gitblit v1.9.3