|
import streamlit as st |
|
import streamlit.components.v1 as components |
|
import pandas as pd |
|
from my_model.tabs.run_inference import InferenceRunner |
|
from my_model.tabs.results import run_demo |
|
from my_model.state_manager import StateManager |
|
|
|
class UIManager(): |
|
"""Manages the user interface for the Streamlit application.""" |
|
|
|
def __init__(self): |
|
"""Initializes the UIManager with predefined tabs.""" |
|
|
|
self.tabs = { |
|
"Home": self.display_home, |
|
"Dataset Analysis": self.display_dataset_analysis, |
|
"Results": self.display_results, |
|
"Run Inference": self.display_run_inference, |
|
"Dissertation Report": self.display_dissertation_report, |
|
"Code": self.display_code |
|
} |
|
|
|
state_manager = StateManager() |
|
state_manager.initialize_state() |
|
|
|
|
|
def add_tab(self, tab_name, display_function): |
|
"""Adds a new tab to the UI.""" |
|
self.tabs[tab_name] = display_function |
|
|
|
|
|
def display_sidebar(self): |
|
"""Displays the sidebar for navigation.""" |
|
|
|
st.sidebar.title("Navigation") |
|
selection = st.sidebar.radio("Go to", list(self.tabs.keys()), disabled=st.session_state['loading_in_progress']) |
|
st.sidebar.image("Files/mm.jpeg", use_column_width=True) |
|
st.sidebar.markdown("**[Mohammed H AlHaj](https://www.linkedin.com/in/m7mdal7aj)**") |
|
|
|
return selection |
|
|
|
|
|
def display_selected_page(self, selection): |
|
"""Displays the selected page based on user's choice.""" |
|
|
|
if selection in self.tabs: |
|
self.tabs[selection]() |
|
|
|
|
|
def display_home(self): |
|
"""Displays the Home page of the application.""" |
|
|
|
st.title('Multimodal Learning for Visual Question Answering using World Knowledge') |
|
st.text('') |
|
st.header('(Knowledge-Based Visual Question Answering)') |
|
with open("Files/Model Arch.html", 'r', encoding='utf-8') as f: |
|
model_arch_html = f.read() |
|
col1, col2 = st.columns([1,1]) |
|
with col1: |
|
|
|
|
|
st.header("Model Architecture") |
|
components.html(model_arch_html, height=1400) |
|
|
|
|
|
with col2: |
|
|
|
st.header("Abstract") |
|
st.write("""\n\nNavigating the frontier of the Visual Turing Test, this research delves into multimodal learning to bridge the gap between visual perception and linguistic interpretation, a foundational challenge in artificial intelligence. It scrutinizes the integration of visual cognition and external knowledge, emphasizing the pivotal role of the Transformer model in enhancing language processing and supporting complex multimodal tasks. |
|
This research explores the task of Knowledge-Based Visual Question Answering (KB-VQA), it examines the influence of Pre-Trained Large Language Models (PT-LLMs) and Pre-Trained Multimodal Models (PT-LMMs), which have transformed the machine learning landscape by utilizing expansive, pre-trained knowledge repositories to tackle complex tasks, thereby enhancing KB-VQA systems. |
|
\nAn examination of existing Knowledge-Based Visual Question Answering (KB-VQA) methodologies led to a refined approach that converts visual content into the linguistic domain, creating detailed captions and object enumerations. This process leverages the implicit knowledge and inferential capabilities of PT-LLMs. The research refines the fine-tuning of PT-LLMs by integrating specialized tokens, enhancing the models’ ability to interpret visual contexts. The research also reviews current image representation techniques and knowledge sources, advocating for the utilization of implicit knowledge in PT-LLMs, especially for tasks that do not require specialized expertise. |
|
\nRigorous ablation experiments conducted to assess the impact of various visual context elements on model performance, with a particular focus on the importance of image descriptions generated during the captioning phase. The study includes a comprehensive analysis of major KB-VQA datasets, specifically the OK-VQA corpus, and critically evaluates the metrics used, incorporating semantic evaluation with GPT-4 to align the assessment with practical application needs. |
|
\nThe evaluation results underscore the developed model’s competent and competitive performance. It achieves a VQA score of 63.57% under syntactic evaluation and excels with an Exact Match (EM) score of 68.36%. Further, semantic evaluations yield even more impressive outcomes, with VQA and EM scores of 71.09% and 72.55%, respectively. These results demonstrate that the model effectively applies reasoning over the visual context and successfully retrieves the necessary knowledge to answer visual questions.""") |
|
st.write("""\n\n\nThis is an interactive application built to demonstrate the project developed and allow for interaction with the KB-VQA model as part of the dissertation for Masters degree in Artificial Intelligence at the [University of Bath](https://www.bath.ac.uk/). |
|
\n\n\nDeveloped by: [Mohammed H AlHaj](https://www.linkedin.com/in/m7mdal7aj)""") |
|
|
|
st.header("Acknowledgement") |
|
st.write("""I am profoundly grateful for the support and guidance I have received throughout the course of my dissertation. I would like to extend my deepest appreciation to the following individuals: |
|
\nTo my supervisor, [Dr. Andreas Theophilou](https://researchportal.bath.ac.uk/en/persons/andreas-theophilou), whose expertise, and insightful guidance have been instrumental in the completion of this research. Your mentorship has not only profoundly shaped my work but also my future endeavours in the field of computer science. |
|
Special mention must be made of my mentors at the University of Bath— [Dr. Ben Ralph](https://researchportal.bath.ac.uk/en/persons/ben-ralph), [Dr. Hongping Cai](https://researchportal.bath.ac.uk/en/persons/hongping-cai), and [Dr. Nadejda Roubtsova](https://researchportal.bath.ac.uk/en/persons/nadejda-roubtsova). The wealth of knowledge and insights I have gained from you has been indispensable. Your unwavering dedication to academic excellence and steadfast support have been crucial in navigating my academic journey. |
|
\nMy colleagues deserve equal gratitude, for their camaraderie and collaborative spirit have not only made this journey feasible but also deeply enjoyable. The shared experiences and the challenges we have overcome together have been integral to my personal and professional growth. |
|
\nLastly, my heartfelt thanks are extended to my family, whose unyielding love and encouragement have been my steadfast anchor. Your belief in my abilities has consistently inspired me and bolstered my strength throughout this process. |
|
This dissertation is not merely a reflection of my individual efforts but stands as a testament to the collective support and wisdom of each individual mentioned above. I am honoured and privileged to be part of such a supportive and enriching academic community. |
|
""") |
|
|
|
def display_dataset_analysis(self): |
|
"""Displays the Dataset Analysis page.""" |
|
|
|
st.title("OK-VQA Dataset Analysis") |
|
st.write("This is a Place Holder until the contents are uploaded.") |
|
|
|
|
|
def display_results(self): |
|
"""Displays Evaluation Results page.""" |
|
|
|
st.title("Evaluation Results & Analyses") |
|
st.write("This page demonstrates the model evaluation results and analyses in an interactive way.") |
|
st.write("\n") |
|
|
|
run_demo() |
|
|
|
|
|
|
|
def display_run_inference(self): |
|
"""Displays the Run Inference page.""" |
|
|
|
st.title("Run Inference") |
|
st.write("Please note that this is not a general purpose model, it is specifically trained on [OK-VQA Dataset](https://okvqa.allenai.org/) and desgined to give short and direct answers to the given questions about the given image.") |
|
st.write("\n") |
|
inference_runner = InferenceRunner() |
|
inference_runner.run_inference() |
|
|
|
|
|
def display_dissertation_report(self): |
|
"""Displays the Dissertation Report page.""" |
|
|
|
st.title("Dissertation Report") |
|
st.write("Click the link below to view the PDF.") |
|
|
|
st.download_button( |
|
label="Download PDF", |
|
data=open("Files/Dissertation Report.pdf", "rb"), |
|
file_name="example.pdf", |
|
mime="application/octet-stream" |
|
) |
|
|
|
|
|
def display_code(self): |
|
"""Displays the Code page with a link to the project's code repository.""" |
|
|
|
st.title("Code") |
|
st.markdown("You can view the code for this project on HuggingFace Space files page.") |
|
st.markdown("[View Code](https://huggingface.co/spaces/m7mdal7aj/Mohammed_Alhaj_KB-VQA/tree/main)", unsafe_allow_html=True) |
|
|
|
|
|
def display_placeholder(self): |
|
"""Displays a placeholder for future content.""" |
|
|
|
st.title("Stay Tuned") |
|
st.write("This is a Place Holder until the contents are uploaded.") |
|
|