ElenaRyumina's picture
Summary
c0f6432
raw
history blame
4.06 kB
"""
File: app.py
Author: Elena Ryumina and Dmitry Ryumin
Description: Description: Main application file for Facial_Expression_Recognition.
The file defines the Gradio interface, sets up the main blocks,
and includes event handlers for various components.
License: MIT License
"""
import gradio as gr
# Importing necessary components for the Gradio app
from app.description import DESCRIPTION_STATIC, DESCRIPTION_DYNAMIC
from app.authors import AUTHORS
from app.app_utils import preprocess_image_and_predict, preprocess_video_and_predict
def clear_static_info():
return (
gr.Image(value=None, type="pil"),
gr.Image(value=None, scale=1, elem_classes="dl2"),
gr.Label(value=None, num_top_classes=3, scale=1, elem_classes="dl3"),
)
def clear_dynamic_info():
return (
gr.Video(value=None),
gr.Video(value=None),
gr.Video(value=None),
gr.Plot(value=None),
)
with gr.Blocks(css="app.css") as demo:
with gr.Tab("Dynamic App"):
gr.Markdown(value=DESCRIPTION_DYNAMIC)
with gr.Row():
with gr.Column(scale=2):
input_video = gr.Video(elem_classes="video1")
with gr.Row():
clear_btn_dynamic = gr.Button(
value="Clear", interactive=True, scale=1
)
submit_dynamic = gr.Button(
value="Submit", interactive=True, scale=1, elem_classes="submit"
)
with gr.Column(scale=2, elem_classes="dl4"):
with gr.Row():
output_video = gr.Video(label="Original video", scale=2, elem_classes="video2")
output_face = gr.Video(label="Pre-processed video", scale=1, elem_classes="video3")
output_statistics = gr.Plot(label="Statistics of emotions", elem_classes="stat")
gr.Examples(
["videos/video1.mp4",
"videos/video2.mp4"],
[input_video],
)
with gr.Tab("Static App"):
gr.Markdown(value=DESCRIPTION_STATIC)
with gr.Row():
with gr.Column(scale=2, elem_classes="dl1"):
input_image = gr.Image(type="pil")
with gr.Row():
clear_btn = gr.Button(
value="Clear", interactive=True, scale=1, elem_classes="clear"
)
submit = gr.Button(
value="Submit", interactive=True, scale=1, elem_classes="submit"
)
with gr.Column(scale=1, elem_classes="dl4"):
output_image = gr.Image(scale=1, elem_classes="dl2")
output_label = gr.Label(num_top_classes=3, scale=1, elem_classes="dl3")
gr.Examples(
[
"images/fig7.jpg",
"images/fig1.jpg",
"images/fig2.jpg",
"images/fig3.jpg",
"images/fig4.jpg",
"images/fig5.jpg",
"images/fig6.jpg",
],
[input_image],
)
with gr.Tab("Authors"):
gr.Markdown(value=AUTHORS)
submit.click(
fn=preprocess_image_and_predict,
inputs=[input_image],
outputs=[output_image, output_label],
queue=True,
)
clear_btn.click(
fn=clear_static_info,
inputs=[],
outputs=[input_image, output_image, output_label],
queue=True,
)
submit_dynamic.click(
fn=preprocess_video_and_predict,
inputs=input_video,
outputs=[
output_video,
output_face,
output_statistics
],
queue=True,
)
clear_btn_dynamic.click(
fn=clear_dynamic_info,
inputs=[],
outputs=[
input_video,
output_video,
output_face,
output_statistics
],
queue=True,
)
if __name__ == "__main__":
demo.queue(api_open=False).launch(share=False)