FLAME¶
FLAME is a head model with shape, expression, neck, jaw, and eye controls.
Setup¶
FLAME requires registration at https://flame.is.tue.mpg.de/.
# Download FLAME after configuring credentials for the upstream site.
body-models download flame
Manual paths can also be configured:
# Point body-models at an already downloaded neutral FLAME model.
body-models set flame /path/to/FLAME_NEUTRAL.pkl
API¶
body_models.parts.flame.numpy.FLAME
¶
FLAME(
model_path=None,
simplify=1.0,
rotation_type="axis_angle",
kernel="numpy",
)
Bases: BodyModel
FLAME head model with NumPy backend.
Initialize the FLAME model.
| PARAMETER | DESCRIPTION |
|---|---|
model_path
|
Path to model assets, or the default assets when omitted.
TYPE:
|
simplify
|
Mesh simplification factor to apply while loading.
TYPE:
|
rotation_type
|
Rotation representation expected by pose inputs.
TYPE:
|
kernel
|
Backend kernel used for forward evaluation.
TYPE:
|
| METHOD | DESCRIPTION |
|---|---|
forward_vertices |
Compute posed mesh vertices. |
forward_skeleton |
Compute posed joint transforms. |
prepare_identity |
Precompute shape/expression-dependent state for repeated forward passes. |
prepare_pose |
Precompute pose-dependent state for repeated forward passes. |
joint_index |
Resolve a standard joint to this model's native joint index. |
get_tpose |
Get parameters for the SMPL-style T-pose. |
get_apose |
Get parameters for the MHR-style A-pose. |
prepare_skinning |
Pack prepared model state into renderer-ready skinning inputs. |
| ATTRIBUTE | DESCRIPTION |
|---|---|
common_joints |
Common anatomical joints mapped to this model's native joint names.
TYPE:
|
Source code in src/body_models/parts/flame/numpy.py
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 | |
common_joints
property
¶
common_joints
Common anatomical joints mapped to this model's native joint names.
forward_vertices
¶
forward_vertices(
head_pose,
head_rotation=None,
global_rotation=None,
global_translation=None,
vertex_indices=None,
*,
shape=None,
expression=None,
identity=None,
)
Compute posed mesh vertices.
| PARAMETER | DESCRIPTION |
|---|---|
head_pose
|
Local head and facial joint rotations.
TYPE:
|
head_rotation
|
Root head rotation.
TYPE:
|
global_rotation
|
Global model rotation.
TYPE:
|
global_translation
|
Global model translation.
TYPE:
|
vertex_indices
|
Optional subset of vertices to return.
TYPE:
|
shape
|
Shape coefficients.
TYPE:
|
expression
|
Facial expression coefficients.
TYPE:
|
identity
|
Optional output from :meth:
TYPE:
|
| RETURNS | DESCRIPTION |
|---|---|
Float[ndarray, 'B V 3']
|
Posed vertex positions. |
Source code in src/body_models/parts/flame/numpy.py
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | |
forward_skeleton
¶
forward_skeleton(
head_pose,
head_rotation=None,
global_rotation=None,
global_translation=None,
joint_indices=None,
*,
shape=None,
expression=None,
identity=None,
)
Compute posed joint transforms.
| PARAMETER | DESCRIPTION |
|---|---|
head_pose
|
Local head and facial joint rotations.
TYPE:
|
head_rotation
|
Root head rotation.
TYPE:
|
global_rotation
|
Global model rotation.
TYPE:
|
global_translation
|
Global model translation.
TYPE:
|
joint_indices
|
Optional subset of joints to return.
TYPE:
|
shape
|
Shape coefficients.
TYPE:
|
expression
|
Facial expression coefficients.
TYPE:
|
identity
|
Optional output from :meth:
TYPE:
|
| RETURNS | DESCRIPTION |
|---|---|
Float[ndarray, 'B 5 4 4']
|
Joint transforms in the model hierarchy. |
Source code in src/body_models/parts/flame/numpy.py
146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 | |
prepare_identity
¶
prepare_identity(shape, expression, skip_vertices=False)
Precompute shape/expression-dependent state for repeated forward passes.
Source code in src/body_models/parts/flame/numpy.py
189 190 191 192 193 194 195 196 | |
prepare_pose
¶
prepare_pose(
head_pose, head_rotation=None, *, identity, skip_vertices=False
)
Precompute pose-dependent state for repeated forward passes.
Source code in src/body_models/parts/flame/numpy.py
198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 | |
joint_index
¶
joint_index(joint)
Resolve a standard joint to this model's native joint index.
Source code in src/body_models/base.py
77 78 79 80 81 82 83 84 85 | |
get_tpose
¶
get_tpose(batch_dims=(), **kwargs)
Get parameters for the SMPL-style T-pose.
Source code in src/body_models/base.py
134 135 136 137 138 139 140 | |
get_apose
¶
get_apose(batch_dims=(), **kwargs)
Get parameters for the MHR-style A-pose.
Source code in src/body_models/base.py
142 143 144 145 146 147 148 | |
prepare_skinning
¶
prepare_skinning(*, identity, pose)
Pack prepared model state into renderer-ready skinning inputs.
Source code in src/body_models/base.py
161 162 163 164 165 166 167 168 169 170 171 172 173 174 | |