import trimesh

import polyscope as ps
import igl

path = './libigl-tutorial-data/hand.mesh'

import numpy as np

#mesh = trimesh.load_mesh(path)


v, t, f_ = igl.read_mesh(path)
pts_b,f,_ = igl.random_points_on_mesh(1000,v,f_)
print(pts_b.shape,f.shape)

pts = np.array(np.sum(np.stack([v[f_[f][:,0]],v[f_[f][:,1]],v[f_[f][:,2]]],axis=-1) * pts_b[:,None,:],axis=-1))
print(f_[f][:,0])

# ps.init()
# ps_mesh = ps.register_point_cloud("My pg", pts)
# ps_mesh = ps.register_surface_mesh("My Mesh ori", v, f_)
# ps.show()




# lucy.ply
# R = np.array([[1,0,0],[0,0,1],[0,1,0]])
# v = mesh.vertices
# print(v.shape)
# #v, t, f = igl.read_mesh(path)
# v = (R@v.transpose()).transpose()
# #v = mesh.vertices
# v_mean = np.mean(v,axis=0)
# v = v-v_mean
# v_max = np.abs(np.max(v,axis=0))
# v_min = np.abs(np.min(v,axis=0))
# v_ = np.maximum(v_max,v_min)
# v = v/np.max(v_)
# # print(v[21253],v[16025])
# v_max = np.max(v,axis=0)
# v_min = np.min(v,axis=0)
# print(v_max,v_min)

# ps.init()
# ps_mesh = ps.register_point_cloud("My pg", v)
# ps.show()


#### spot_quadrangulated

# v = np.array(mesh.vertices)
# f = np.array(mesh.faces)
# print(f.shape)

# # a,f_k = igl.extract_manifold_patches(f)
# # print(a,f)
# # f = f[f_k==8]

# v_0 = v[0,:]
# v_1 = v[2009,:]
# v_2 = v[2008,:]
# ps.init()
# ps_mesh = ps.register_point_cloud("My Mesh_interp2", np.stack([v_0,v_1,v_2],axis=0))
# ps_mesh = ps.register_surface_mesh("My Mesh ori", v, f)
# ps.show()
# a = igl.exact_geodesic(v, f, np.array([2009]), np.arange(v.shape[0]))
# print(a[2008])


######### hand

# v, t, f = igl.read_mesh(path)

# f_k = f.reshape(-1)
# a = np.zeros((v.shape[0]))
# a[f_k] = 1

# v = v[a>0]
# v_mean = np.mean(v,axis=0)
# v = (v-v_mean)*4 + v_mean
# ps.init()

# v_0 = v[1674,:]
# v_1 = v[4171,:]

# ps_mesh = ps.register_point_cloud("My Mesh_interp2", np.stack([v_0,v_1],axis=0))
# ps_mesh = ps.register_surface_mesh("My Mesh ori", v, f)
# ps.show()



# print(np.arange(v.shape[0]))
# a = igl.exact_geodesic(v, f,np.array([1674]).reshape(-1,1), np.arange(v.shape[0]).reshape(-1,1))
# print(a)
# print(a.shape)


