import numpy as np
import torch
import time
import ctypes
#float64 is double 
#float32 is float
import numpy.ctypeslib as npct


def Gaussain_elimination(arr_3):
    arr_31 =  np.array(arr_3.flatten(), dtype=np.float64)
    arr_31 = (ctypes.c_double * len(arr_31))(*arr_31)
    arr_4 = np.zeros(arr_3.shape, dtype=np.float64).flatten()
    arr_4 = (ctypes.c_double * len(arr_4))(*arr_4)
    lib = ctypes.CDLL("/root/os/ge.dll")
    #print("elimination start"
    rk = lib.twodemiarr(arr_31, ctypes.c_int(len(arr_3)), ctypes.c_int(len(arr_3[0])), arr_4)
    #print("elimination end")
    return np.array(arr_4, dtype = np.float64).reshape(arr_3.shape), rk