davidvgilmore commited on
Commit
78e5430
·
verified ·
1 Parent(s): 60f06d0

Upload hy3dgen/texgen/utils/uv_warp_utils.py with huggingface_hub

Browse files
hy3dgen/texgen/utils/uv_warp_utils.py ADDED
@@ -0,0 +1,42 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Open Source Model Licensed under the Apache License Version 2.0
2
+ # and Other Licenses of the Third-Party Components therein:
3
+ # The below Model in this distribution may have been modified by THL A29 Limited
4
+ # ("Tencent Modifications"). All Tencent Modifications are Copyright (C) 2024 THL A29 Limited.
5
+
6
+ # Copyright (C) 2024 THL A29 Limited, a Tencent company. All rights reserved.
7
+ # The below software and/or models in this distribution may have been
8
+ # modified by THL A29 Limited ("Tencent Modifications").
9
+ # All Tencent Modifications are Copyright (C) THL A29 Limited.
10
+
11
+ # Hunyuan 3D is licensed under the TENCENT HUNYUAN NON-COMMERCIAL LICENSE AGREEMENT
12
+ # except for the third-party components listed below.
13
+ # Hunyuan 3D does not impose any additional limitations beyond what is outlined
14
+ # in the repsective licenses of these third-party components.
15
+ # Users must comply with all terms and conditions of original licenses of these third-party
16
+ # components and must ensure that the usage of the third party components adheres to
17
+ # all relevant laws and regulations.
18
+
19
+ # For avoidance of doubts, Hunyuan 3D means the large language models and
20
+ # their software and algorithms, including trained model weights, parameters (including
21
+ # optimizer states), machine-learning model code, inference-enabling code, training-enabling code,
22
+ # fine-tuning enabling code and other elements of the foregoing made publicly available
23
+ # by Tencent in accordance with TENCENT HUNYUAN COMMUNITY LICENSE AGREEMENT.
24
+
25
+ import trimesh
26
+ import xatlas
27
+
28
+
29
+ def mesh_uv_wrap(mesh):
30
+ if isinstance(mesh, trimesh.Scene):
31
+ mesh = mesh.dump(concatenate=True)
32
+
33
+ if len(mesh.faces) > 50000:
34
+ raise ValueError("The mesh has more than 50,000 faces, which is not supported.")
35
+
36
+ vmapping, indices, uvs = xatlas.parametrize(mesh.vertices, mesh.faces)
37
+
38
+ mesh.vertices = mesh.vertices[vmapping]
39
+ mesh.faces = indices
40
+ mesh.visual.uv = uvs
41
+
42
+ return mesh