Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
ComfyUI-MimicMotionWrapper
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
王骏浩
ComfyUI-MimicMotionWrapper
Commits
58bd4f5a
提交
58bd4f5a
authored
7月 08, 2024
作者:
kijai
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
include unet config
上级
9656f049
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
52 行增加
和
28 行删除
+52
-28
unet_config.json
configs/unet_config.json
+38
-0
nodes.py
nodes.py
+14
-28
没有找到文件。
configs/unet_config.json
0 → 100644
浏览文件 @
58bd4f5a
{
"_class_name"
:
"UNetSpatioTemporalConditionModel"
,
"_diffusers_version"
:
"0.24.0.dev0"
,
"_name_or_path"
:
"/home/suraj_huggingface_co/.cache/huggingface/hub/models--diffusers--svd-xt/snapshots/9703ded20c957c340781ee710b75660826deb487/unet"
,
"addition_time_embed_dim"
:
256
,
"block_out_channels"
:
[
320
,
640
,
1280
,
1280
],
"cross_attention_dim"
:
1024
,
"down_block_types"
:
[
"CrossAttnDownBlockSpatioTemporal"
,
"CrossAttnDownBlockSpatioTemporal"
,
"CrossAttnDownBlockSpatioTemporal"
,
"DownBlockSpatioTemporal"
],
"in_channels"
:
8
,
"layers_per_block"
:
2
,
"num_attention_heads"
:
[
5
,
10
,
20
,
20
],
"num_frames"
:
25
,
"out_channels"
:
4
,
"projection_class_embeddings_input_dim"
:
768
,
"sample_size"
:
96
,
"transformer_layers_per_block"
:
1
,
"up_block_types"
:
[
"UpBlockSpatioTemporal"
,
"CrossAttnUpBlockSpatioTemporal"
,
"CrossAttnUpBlockSpatioTemporal"
,
"CrossAttnUpBlockSpatioTemporal"
]
}
nodes.py
浏览文件 @
58bd4f5a
...
@@ -19,8 +19,13 @@ from .mimicmotion.modules.pose_net import PoseNet
...
@@ -19,8 +19,13 @@ from .mimicmotion.modules.pose_net import PoseNet
from
.lcm_scheduler
import
AnimateLCMSVDStochasticIterativeScheduler
from
.lcm_scheduler
import
AnimateLCMSVDStochasticIterativeScheduler
from
accelerate
import
init_empty_weights
from
contextlib
import
nullcontext
from
accelerate.utils
import
set_module_tensor_to_device
try
:
from
accelerate
import
init_empty_weights
from
accelerate.utils
import
set_module_tensor_to_device
is_accelerate_available
=
True
except
:
pass
def
loglinear_interp
(
t_steps
,
num_steps
):
def
loglinear_interp
(
t_steps
,
num_steps
):
...
@@ -36,28 +41,6 @@ def loglinear_interp(t_steps, num_steps):
...
@@ -36,28 +41,6 @@ def loglinear_interp(t_steps, num_steps):
interped_ys
=
np
.
exp
(
new_ys
)[::
-
1
]
.
copy
()
interped_ys
=
np
.
exp
(
new_ys
)[::
-
1
]
.
copy
()
return
interped_ys
return
interped_ys
class
MimicMotionModel
(
torch
.
nn
.
Module
):
def
__init__
(
self
,
base_model_path
,
lcm
=
False
):
"""construnct base model components and load pretrained svd model except pose-net
Args:
base_model_path (str): pretrained svd model path
"""
super
()
.
__init__
()
unet_subfolder
=
"unet_lcm"
if
lcm
else
"unet"
self
.
unet
=
UNetSpatioTemporalConditionModel
.
from_config
(
UNetSpatioTemporalConditionModel
.
load_config
(
base_model_path
,
subfolder
=
unet_subfolder
,
variant
=
"fp16"
))
self
.
vae
=
AutoencoderKLTemporalDecoder
.
from_pretrained
(
base_model_path
,
subfolder
=
"vae"
,
variant
=
"fp16"
)
self
.
image_encoder
=
CLIPVisionModelWithProjection
.
from_pretrained
(
base_model_path
,
subfolder
=
"image_encoder"
,
variant
=
"fp16"
)
self
.
noise_scheduler
=
EulerDiscreteScheduler
.
from_pretrained
(
base_model_path
,
subfolder
=
"scheduler"
)
self
.
feature_extractor
=
CLIPImageProcessor
.
from_pretrained
(
base_model_path
,
subfolder
=
"feature_extractor"
)
# pose_net
self
.
pose_net
=
PoseNet
(
noise_latent_channels
=
self
.
unet
.
config
.
block_out_channels
[
0
])
class
DownloadAndLoadMimicMotionModel
:
class
DownloadAndLoadMimicMotionModel
:
@classmethod
@classmethod
def
INPUT_TYPES
(
s
):
def
INPUT_TYPES
(
s
):
...
@@ -116,13 +99,16 @@ class DownloadAndLoadMimicMotionModel:
...
@@ -116,13 +99,16 @@ class DownloadAndLoadMimicMotionModel:
local_dir_use_symlinks
=
False
)
local_dir_use_symlinks
=
False
)
pbar
.
update
(
1
)
pbar
.
update
(
1
)
unet_config
=
UNetSpatioTemporalConditionModel
.
load_config
(
svd_path
,
subfolder
=
"unet"
,
variant
=
"fp16"
)
unet_config
=
UNetSpatioTemporalConditionModel
.
load_config
(
os
.
path
.
join
(
script_directory
,
"configs"
,
"unet_config.json"
)
)
print
(
"Loading UNET"
)
print
(
"Loading UNET"
)
with
(
init_empty_weights
()):
with
(
init_empty_weights
()
if
is_accelerate_available
else
nullcontext
()
):
self
.
unet
=
UNetSpatioTemporalConditionModel
.
from_config
(
unet_config
)
self
.
unet
=
UNetSpatioTemporalConditionModel
.
from_config
(
unet_config
)
sd
=
comfy
.
utils
.
load_torch_file
(
os
.
path
.
join
(
model_path
))
sd
=
comfy
.
utils
.
load_torch_file
(
os
.
path
.
join
(
model_path
))
for
key
in
sd
:
if
is_accelerate_available
:
set_module_tensor_to_device
(
self
.
unet
,
key
,
dtype
=
dtype
,
device
=
device
,
value
=
sd
[
key
])
for
key
in
sd
:
set_module_tensor_to_device
(
self
.
unet
,
key
,
dtype
=
dtype
,
device
=
device
,
value
=
sd
[
key
])
else
:
self
.
unet
.
load_state_dict
(
sd
,
strict
=
False
)
del
sd
del
sd
pbar
.
update
(
1
)
pbar
.
update
(
1
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论