-
Notifications
You must be signed in to change notification settings - Fork 61
Expand file tree
/
Copy pathsample_hf.py
More file actions
59 lines (47 loc) · 1.68 KB
/
sample_hf.py
File metadata and controls
59 lines (47 loc) · 1.68 KB
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
import hydra
import torch
import torch.nn as nn
from omegaconf import DictConfig, OmegaConf
from dnadiffusion.utils.sample_util import create_sample
def sample(
data: dict,
model: nn.Module,
sample_batch_size: int,
number_of_samples: int,
guidance_scale: float,
):
device = "cuda" if torch.cuda.is_available() else "cpu"
model = model.to(device)
print(f"Model sent to {device}")
numeric_to_tag_dict = data[-1]
cell_num_list = data[-2]
print(f"Found cell types: {[numeric_to_tag_dict[i] for i in cell_num_list]}")
for cell_type in cell_num_list:
print(f"Generating {number_of_samples} samples for cell {numeric_to_tag_dict[cell_type]}")
create_sample(
model,
cell_type=cell_type,
sample_bs=sample_batch_size,
conditional_numeric_to_tag=numeric_to_tag_dict,
number_of_samples=number_of_samples,
cond_weight_to_metric=guidance_scale,
save_timesteps=False,
save_dataframe=True,
generate_attention_maps=False,
)
@hydra.main(config_path="configs", config_name="sample_hf", version_base="1.3")
def main(cfg: DictConfig) -> None:
print(OmegaConf.to_yaml(cfg))
pretrained_unet = hydra.utils.instantiate(cfg.model)
unet = pretrained_unet.model
diffusion = hydra.utils.instantiate(cfg.diffusion, model=unet)
data = hydra.utils.instantiate(cfg.data)
sample(
data=data,
model=diffusion,
sample_batch_size=cfg.sampling.sample_batch_size,
number_of_samples=cfg.sampling.number_of_samples,
guidance_scale=cfg.sampling.guidance_scale,
)
if __name__ == "__main__":
main()