File size: 1,894 Bytes
db541e4
f73076c
 
db541e4
c72f5fe
 
f73076c
 
 
 
 
 
 
 
 
 
 
c72f5fe
 
affd796
 
 
 
 
 
 
 
 
 
2f14da2
 
 
 
f73076c
 
 
 
2f14da2
 
 
affd796
 
 
 
 
 
 
 
f73076c
 
 
 
 
affd796
 
db541e4
affd796
 
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
import gradio as gr
from evodiff.pretrained import OA_DM_38M, D3PM_UNIFORM_38M
from evodiff.generate import generate_oaardm, generate_d3pm



def make_seq(seq_len, model_type):
    if model_type == "EvoDiff-Seq-OADM 38M":
        checkpoint = OA_DM_38M()
        model, collater, tokenizer, scheme = checkpoint
        tokeinzed_sample, generated_sequence = generate_oaardm(model, tokenizer, seq_len, batch_size=1, device='cpu')
    
    if model_type == "EvoDiff-D3PM-Uniform 38M":
        checkpoint = D3PM_UNIFORM_38M(return_all=True)
        model, collater, tokenizer, scheme, timestep, Q_bar, Q = checkpoint
        tokeinzed_sample, generated_sequence = generate_d3pm(model, tokenizer, Q, Q_bar, timestep, seq_len, batch_size=1, device='cpu')

    return generated_sequence

# iface = gr.Interface(
#     fn=make_seq,
#     inputs=gr.Slider(10, 100),
#     outputs="text"
#     )

# iface.launch()


with gr.Blocks() as edapp:
    with gr.Row():
        gr.Markdown(
            """
            # EvoDiff
            ## Generation of protein sequences and evolutionary alignments via discrete diffusion models

            Created By: Microsoft Research [Sarah Alamdari, Nitya Thakkar, Rianne van den Berg, Alex X. Lu, Nicolo Fusi, ProfileAva P. Amini, and Kevin K. Yang]
            
            Spaces App By: Colby T. Ford
            """
        )
    with gr.Row():
        gr.Markdown(
            """
            ## Unconditional sequence generation
            Generate a sequence with EvoDiff-Seq-OADM 38M
            """)
        gr.Interface(
            fn=make_seq,
            inputs=[
                gr.Slider(10, 100, label = "Sequence Length")
                gr.Dropdown(["EvoDiff-Seq-OADM 38M", "EvoDiff-D3PM-Uniform 38M"], type="value"),
                gr.()
                ],
            outputs="text"
            )

if __name__ == "__main__":
    edapp.launch()