qiny17 commited on
Commit
4dacbb9
0 Parent(s):

Duplicate from qiny17/ArtIstic-GENREator

Browse files
Files changed (4) hide show
  1. .gitattributes +34 -0
  2. README.md +14 -0
  3. app.py +91 -0
  4. requirements.txt +6 -0
.gitattributes ADDED
@@ -0,0 +1,34 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ *.7z filter=lfs diff=lfs merge=lfs -text
2
+ *.arrow filter=lfs diff=lfs merge=lfs -text
3
+ *.bin filter=lfs diff=lfs merge=lfs -text
4
+ *.bz2 filter=lfs diff=lfs merge=lfs -text
5
+ *.ckpt filter=lfs diff=lfs merge=lfs -text
6
+ *.ftz filter=lfs diff=lfs merge=lfs -text
7
+ *.gz filter=lfs diff=lfs merge=lfs -text
8
+ *.h5 filter=lfs diff=lfs merge=lfs -text
9
+ *.joblib filter=lfs diff=lfs merge=lfs -text
10
+ *.lfs.* filter=lfs diff=lfs merge=lfs -text
11
+ *.mlmodel filter=lfs diff=lfs merge=lfs -text
12
+ *.model filter=lfs diff=lfs merge=lfs -text
13
+ *.msgpack filter=lfs diff=lfs merge=lfs -text
14
+ *.npy filter=lfs diff=lfs merge=lfs -text
15
+ *.npz filter=lfs diff=lfs merge=lfs -text
16
+ *.onnx filter=lfs diff=lfs merge=lfs -text
17
+ *.ot filter=lfs diff=lfs merge=lfs -text
18
+ *.parquet filter=lfs diff=lfs merge=lfs -text
19
+ *.pb filter=lfs diff=lfs merge=lfs -text
20
+ *.pickle filter=lfs diff=lfs merge=lfs -text
21
+ *.pkl filter=lfs diff=lfs merge=lfs -text
22
+ *.pt filter=lfs diff=lfs merge=lfs -text
23
+ *.pth filter=lfs diff=lfs merge=lfs -text
24
+ *.rar filter=lfs diff=lfs merge=lfs -text
25
+ *.safetensors filter=lfs diff=lfs merge=lfs -text
26
+ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
27
+ *.tar.* filter=lfs diff=lfs merge=lfs -text
28
+ *.tflite filter=lfs diff=lfs merge=lfs -text
29
+ *.tgz filter=lfs diff=lfs merge=lfs -text
30
+ *.wasm filter=lfs diff=lfs merge=lfs -text
31
+ *.xz filter=lfs diff=lfs merge=lfs -text
32
+ *.zip filter=lfs diff=lfs merge=lfs -text
33
+ *.zst filter=lfs diff=lfs merge=lfs -text
34
+ *tfevents* filter=lfs diff=lfs merge=lfs -text
README.md ADDED
@@ -0,0 +1,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ title: ArtIstic GENREator
3
+ emoji: 📈
4
+ colorFrom: indigo
5
+ colorTo: green
6
+ sdk: gradio
7
+ sdk_version: 3.12.0
8
+ app_file: app.py
9
+ pinned: false
10
+ license: mit
11
+ duplicated_from: qiny17/ArtIstic-GENREator
12
+ ---
13
+
14
+ Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
app.py ADDED
@@ -0,0 +1,91 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import torch
2
+ import gradio as gr
3
+ from transformers import pipeline, T5ForConditionalGeneration, T5Tokenizer
4
+ from diffusers import StableDiffusionPipeline, EulerDiscreteScheduler
5
+
6
+ # generate lyrics
7
+ lyrics_generator = pipeline("text-generation", "ECE1786-AG/lyrics-generator")
8
+
9
+ # summarize lyrics
10
+ model = T5ForConditionalGeneration.from_pretrained("Michau/t5-base-en-generate-headline")
11
+ tokenizer = T5Tokenizer.from_pretrained("Michau/t5-base-en-generate-headline")
12
+
13
+ # generate single cover
14
+ scheduler = EulerDiscreteScheduler.from_pretrained("stabilityai/stable-diffusion-2", subfolder="scheduler")
15
+ pipe = StableDiffusionPipeline.from_pretrained("stabilityai/stable-diffusion-2", scheduler=scheduler, revision="fp16", torch_dtype=torch.float16)
16
+ device = "cuda" if torch.cuda.is_available() else "cpu"
17
+ pipe = pipe.to(device)
18
+
19
+ def generate_lyrics(genre, prompt):
20
+ complete_prompt = "<BOS> <{0}>\n{1}".format(genre, prompt)
21
+ lyrics = lyrics_generator(complete_prompt, max_length=1024)
22
+ lyrics = lyrics[0]['generated_text']
23
+ lyrics = lyrics.split('\n', 1)[1] # remove first line from the generated lyrics
24
+
25
+ return lyrics
26
+
27
+ def summarize_lyrics(lyrics):
28
+ text = "headline: " + lyrics
29
+ encoding = tokenizer.encode_plus(text, return_tensors = "pt")
30
+ input_ids = encoding["input_ids"]
31
+ attention_masks = encoding["attention_mask"]
32
+ beam_outputs = model.generate(
33
+ input_ids = input_ids,
34
+ attention_mask = attention_masks,
35
+ max_length = 100,
36
+ num_beams = 5,
37
+ early_stopping = True,
38
+ )
39
+ result = tokenizer.decode(beam_outputs[0])
40
+ result = result.replace('<pad>', '')
41
+ result = result.replace('</s>', '')
42
+
43
+ return result
44
+
45
+ def generate_cover(prompt, style, effect):
46
+ prompt = summarize_lyrics(prompt) # call function summarize_lyrics to summarize lyrics
47
+ prompt = prompt + ", " + effect + ", album cover, artistic, " + style
48
+ print(prompt)
49
+ image = pipe(prompt).images[0]
50
+ return image
51
+
52
+ demo = gr.Blocks()
53
+ with demo:
54
+ gr.HTML(
55
+ """
56
+ <div style="text-align: center; max-width: 700px; margin: 0 auto;">
57
+ <div style="display: inline-flex; align-items: center; gap: 0.8rem; font-size: 1.75rem;">
58
+ <h1 style="font-weight: 900; margin-bottom: 7px;">ArtIstic GENREator</h1>
59
+ </div>
60
+ <p style="margin-bottom: 10px; font-size: 94%">Generate Inspirational Lyrics and Single Cover</p>
61
+ </div>
62
+ """
63
+ )
64
+
65
+ with gr.Row():
66
+
67
+ # Left column (lyrics generation)
68
+ with gr.Column():
69
+ with gr.Accordion("Step 1. Generate Lyrics"):
70
+ gr.Markdown("Enter the starting text and select genre to generate lyrics")
71
+ with gr.Row():
72
+ input_start_text = gr.Textbox(placeholder='I am', label="Starting Text")
73
+ input_lyrics_type = gr.Radio(choices=['pop', 'rap', 'country', 'rock', 'r&b'], value='pop', label="Lyrics Genre")
74
+ button_gen_lyrics = gr.Button("Generate Lyrics", variant="primary")
75
+ output_generated_lyrics = gr.Textbox(label="Generated Lyrics", lines=8)
76
+
77
+ # Right column (single cover generation)
78
+ with gr.Column():
79
+ with gr.Accordion("Step 2. Generate Single Cover"):
80
+ gr.Markdown("Cover will be generated based on style, effect and generated lyrics")
81
+ with gr.Row():
82
+ input_cover_style = gr.Dropdown(choices=['painted', 'abstract', 'minimalist', 'illustrated', 'photographic', 'vintage'], value='painted', label="Track Cover Style")
83
+ input_cover_effect = gr.Radio(choices=['black and white', 'highly detailed', 'blurred'], value='highly detailed', label="Track Cover Effect")
84
+ button_gen_cover = gr.Button("Generate Cover", variant="primary")
85
+ output_generated_cover = gr.Image(label="Generated Cover")
86
+
87
+ # Bind functions to buttons
88
+ button_gen_lyrics.click(fn=generate_lyrics, inputs=[input_lyrics_type , input_start_text], outputs=output_generated_lyrics)
89
+ button_gen_cover.click(fn=generate_cover, inputs=[output_generated_lyrics, input_cover_style, input_cover_effect], outputs=output_generated_cover)
90
+
91
+ demo.launch(debug=True)
requirements.txt ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ transformers
2
+ torch
3
+ sentencepiece
4
+ diffusers[torch]
5
+ accelerate
6
+ scipy