import gradio as gr import pandas as pd import numpy as np from data_proc import load_equity_data, load_yield_curve_data, load_credit_spread_data, load_fed_balance_sheet from data_proc import plot_treasury_curves, plot_credit_spreads, plot_fed_balance_sheet loser_frame, largest_frame = load_equity_data() yc_frame = load_yield_curve_data() spread_frame = load_credit_spread_data() fed_frame = load_fed_balance_sheet() with gr.Blocks() as crisis_dashboard: gr.Markdown("
Banking Crisis Dashboard
") with gr.Tab("Bank Performance"): with gr.Row(): with gr.Column(): gr.Markdown("##
Worst performing banks
") gr.DataFrame(loser_frame) with gr.Column(): gr.Markdown("##
Largest bank performance
") gr.DataFrame(largest_frame) gr.Markdown("###
*performance since 3/8/2023
") with gr.Row(): with gr.Column(): gr.Markdown("## Failed banks") gr.DataFrame(pd.DataFrame(list(zip(['FRC','SBNY','SIVB'], ['First Republic Bank','Signature Bank', 'SVB Financial Group'])), columns=['Ticker','Bank Name'])) with gr.Tab("Interest Rates"): with gr.Row(): with gr.Column(): # gr.Markdown("##
Treasury yield curve
") gr.Plot(plot_treasury_curves(yc_frame)) with gr.Column(): # gr.Markdown("##
Credit spreads
") gr.Plot(plot_credit_spreads(spread_frame)) gr.Markdown("###
Data Source: FRED
") with gr.Tab("Fed Balance Sheet"): with gr.Row(): with gr.Column(): gr.Plot(plot_fed_balance_sheet(fed_frame)) with gr.Column(): gr.Plot(plot_fed_balance_sheet(fed_frame, 'Liabilities')) gr.Markdown("###
*change since 3/8/2023") #with gr.Tab("Bank Balance Sheets"): crisis_dashboard.launch()