import gradio as gr
import numpy as np
import plotly.graph_objects as go
from src.utils import select_board
TITLE = """
Pento-LLaVA 🤖🎯🎮
"""
pento_llava_app = gr.Blocks()
fig, targets, info = select_board('easy', 18, 0)
# Update the figure to include a boundary/frame
fig.update_layout(
xaxis=dict(showline=True, linecolor='black', linewidth=2, showgrid=True, zeroline=True),
yaxis=dict(showline=True, linecolor='black', linewidth=2, showgrid=True, zeroline=True),
margin=dict(l=0, r=0, t=0, b=0),
height=512,
width=512
)
target_strs = []
for t in targets:
target_strs.append(t['target_str'])
def gen_new_board(value):
value = int(value)
fig, _, _ = select_board('easy', 18, value)
# Update the figure to include a boundary/frame
fig.update_layout(
xaxis=dict(showline=True, linecolor='black', linewidth=2, showgrid=True, zeroline=True),
yaxis=dict(showline=True, linecolor='black', linewidth=2, showgrid=True, zeroline=True),
margin=dict(l=0, r=0, t=0, b=0),
height=512,
width=512
)
return fig
def gen_info(value):
value = int(value)
_, _, info = select_board('easy', 18, value)
return info
def gen_target_str(value):
value = int(value)
_, _, info = select_board('easy', 18, value)
target_info = info[0]
target_str = f"Target piece for this episode is {target_info['piece_colour']} {target_info['piece_shape']} located at {target_info['piece_region']}"
return target_str
with pento_llava_app:
gr.HTML(TITLE)
with gr.Row():
with gr.Column():
main_board = gr.Plot(fig)
with gr.Column():
with gr.Row():
select_board_items = gr.Dropdown(
choices=range(512),
interactive=True
)
with gr.Row():
display_string = gr.HTML(value=gen_target_str(0))
select_board_items.change(
fn=gen_new_board,
inputs=[select_board_items],
outputs=[main_board],
queue=True
)
select_board_items.change(
fn=gen_target_str,
inputs=[select_board_items],
outputs=[display_string],
queue=True
)
pento_llava_app.load()
pento_llava_app.queue()
pento_llava_app.launch()