-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathbody_parameters.py
82 lines (62 loc) · 2.56 KB
/
body_parameters.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
import torch
class OptimizationSMPL(torch.nn.Module):
"""
Class used to optimize SMPL parameters.
"""
def __init__(self, cfg: dict):
super(OptimizationSMPL, self).__init__()
# self.pose = torch.nn.Parameter(torch.zeros(1, 72).cuda())
# self.beta = torch.nn.Parameter((torch.zeros(1, 10).cuda()))
# self.trans = torch.nn.Parameter(torch.zeros(1, 3).cuda())
# self.scale = torch.nn.Parameter(torch.ones(1).cuda()*1)
pose = torch.zeros(1, 72).cuda()
beta = torch.zeros(1, 10).cuda()
trans = torch.zeros(1, 3).cuda()
scale = torch.ones(1).cuda()*1
if "init_params" in cfg:
init_params = cfg["init_params"]
if "pose" in init_params:
pose = cfg["init_params"]["pose"].cuda()
if "shape" in init_params:
beta = cfg["init_params"]["shape"].cuda()
if "trans" in init_params:
trans = cfg["init_params"]["trans"].cuda()
if "scale" in init_params:
scale = cfg["init_params"]["scale"].cuda()
if "refine_params" in cfg:
params_to_refine = cfg["refine_params"]
if "pose" in params_to_refine:
self.pose = torch.nn.Parameter(pose)
else:
self.pose = pose
if "shape" in params_to_refine:
self.beta = torch.nn.Parameter(beta)
else:
self.beta = beta
if "trans" in params_to_refine:
self.trans = torch.nn.Parameter(trans)
else:
self.trans = trans
if "scale" in params_to_refine:
self.scale = torch.nn.Parameter(scale)
else:
self.scale = scale
else:
self.pose = torch.nn.Parameter(pose)
self.beta = torch.nn.Parameter(beta)
self.trans = torch.nn.Parameter(trans)
self.scale = torch.nn.Parameter(scale)
def forward(self):
return self.pose, self.beta, self.trans, self.scale
class BodyParameters():
def __new__(cls, cfg):
possible_model_types = ["smpl"] #["smpl", "smplx"]
model_type = cfg["body_model"].lower()
if model_type == "smpl":
return OptimizationSMPL(cfg)
# elif model_type == "smplx":
# return OptimizationSMPLX()
else:
msg = f"Model type {model_type} not defined. \
Possible model types are: {possible_model_types}"
raise NotImplementedError(msg)