Cython wrapper trial 4 memory allocation
parent
20f60a18b0
commit
fe821367e3
File diff suppressed because it is too large
Load Diff
|
@ -2,13 +2,15 @@
|
||||||
|
|
||||||
import numpy as np
|
import numpy as np
|
||||||
from libc.stdlib cimport free, malloc
|
from libc.stdlib cimport free, malloc
|
||||||
|
from cpython.mem cimport PyMem_Malloc, PyMem_Free
|
||||||
|
|
||||||
# Declare C function and data
|
|
||||||
|
# Declare C function and data
|
||||||
cdef extern from "openGJK.h":
|
cdef extern from "openGJK.h":
|
||||||
struct bd:
|
struct bd:
|
||||||
int numpoints
|
int numpoints
|
||||||
double s[3]
|
double s[3]
|
||||||
double** coord
|
double ** coord
|
||||||
|
|
||||||
struct simplex:
|
struct simplex:
|
||||||
int nvrtx
|
int nvrtx
|
||||||
|
@ -31,22 +33,35 @@ def pygjk(bod1, bod2):
|
||||||
|
|
||||||
print("Break 1")#--------------------------------------------------
|
print("Break 1")#--------------------------------------------------
|
||||||
|
|
||||||
# Allocate memory for pointers
|
|
||||||
bd1.coord = <double**> malloc(sizeof(double)*bod1.ndim)
|
|
||||||
bd1.coord[0] = <double*> malloc(sizeof(double)*3)
|
|
||||||
bd2.coord = <double**> malloc(sizeof(double)*bod2.ndim)
|
|
||||||
bd2.coord[0] = <double*> malloc(sizeof(double)*3)
|
|
||||||
|
|
||||||
|
|
||||||
# Convert 1D array to 2D, if any
|
# Convert 1D array to 2D, if any
|
||||||
if bod1.ndim < 2:
|
if bod1.ndim < 2:
|
||||||
bod1 = np.append([bod1], [[1.,1.,1.]], axis = 0)
|
bod1 = np.append([bod1], [[1.,1.,1.]], axis = 0)
|
||||||
|
bd1.numpoints = np.size(bod1,0) - 1
|
||||||
|
else:
|
||||||
|
bd1.numpoints = np.size(bod1,0)
|
||||||
|
|
||||||
|
print(bd1.numpoints)
|
||||||
|
|
||||||
if bod2.ndim < 2:
|
if bod2.ndim < 2:
|
||||||
bod2 = np.append([bod2], [[1.,1.,1.]], axis = 0)
|
bod2 = np.append([bod2], [[1.,1.,1.]], axis = 0)
|
||||||
|
bd2.numpoints = np.size(bod2,0) - 1
|
||||||
|
else:
|
||||||
|
bd2.numpoints = np.size(bod2,0)
|
||||||
|
|
||||||
bd1.numpoints = np.size(bod1,0)
|
print(bd2.numpoints)
|
||||||
bd2.numpoints = np.size(bod2,0)
|
|
||||||
|
|
||||||
|
|
||||||
|
# Allocate memory for pointer (not working)
|
||||||
|
cdef bd *bdptr = <bd *> malloc(sizeof(bd))
|
||||||
|
|
||||||
|
if bd1.numpoints > bd2.numpoints:
|
||||||
|
bdptr.coord[0] = <double *> malloc(3 * sizeof(double))
|
||||||
|
bdptr.coord = <double **> malloc(bd1.numpoints * sizeof(bdptr.coord[0]))
|
||||||
|
|
||||||
|
else:
|
||||||
|
bdptr.coord[0] = <double *> malloc(3 * sizeof(double))
|
||||||
|
bdptr.coord = <double **> malloc(bd2.numpoints * sizeof(bdptr.coord[0]))
|
||||||
|
|
||||||
|
|
||||||
print("Break 2")#--------------------------------------------------
|
print("Break 2")#--------------------------------------------------
|
||||||
|
|
||||||
|
@ -55,6 +70,8 @@ def pygjk(bod1, bod2):
|
||||||
double [:,:] narr1 = bod1
|
double [:,:] narr1 = bod1
|
||||||
double [:,:] narr2 = bod2
|
double [:,:] narr2 = bod2
|
||||||
|
|
||||||
|
print(narr2[0,0]) # output a <double>, works fine
|
||||||
|
|
||||||
print("Break 3")#--------------------------------------------------
|
print("Break 3")#--------------------------------------------------
|
||||||
|
|
||||||
# Assign coordinate values (Segmentation Fault Here!!, )
|
# Assign coordinate values (Segmentation Fault Here!!, )
|
||||||
|
@ -76,8 +93,7 @@ def pygjk(bod1, bod2):
|
||||||
answer = gjk(bd1, bd2, &s)
|
answer = gjk(bd1, bd2, &s)
|
||||||
|
|
||||||
# Free the memory
|
# Free the memory
|
||||||
free(bd1.coord)
|
free(bdptr)
|
||||||
free(bd2.coord)
|
|
||||||
|
|
||||||
return answer
|
return answer
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue