import gradio as gr from markup import highlight, get_text from template import get_templates templates = get_templates() def change(inp, components=[]): """Based on an `inp`, render and highlight the appropriate code sample. Args: inp (`str`): The input button from the interface. Returns: `tuple`: A tuple of the initial code, the highlighted code, and the title for the section. """ code, explanation, docs = get_text(inp) if inp == "Basic": return (templates["initial"], highlight(code), "## Accelerate Code (Base Integration)", explanation, docs) elif inp == "Calculating Metrics": return (templates["initial_with_metrics"], highlight(code), f"## Accelerate Code ({inp})", explanation, docs) else: return (templates["accelerate"], highlight(code), f"## Accelerate Code ({inp})", explanation, docs) initial_md = gr.Markdown("## Initial Code") initial_code = gr.Markdown(templates["initial"]) with gr.Blocks() as demo: inp = gr.Radio( ["Basic", "Calculating Metrics", "Checkpointing", "Experiment Tracking", "Gradient Accumulation"], label="Select a feature you would like to integrate" ) with gr.Row(): with gr.Column(): initial_md.render() initial_code.render() with gr.Column(): feature = gr.Markdown("## Accelerate Code") out = gr.Markdown() with gr.Row(): with gr.Column(): gr.Markdown("## Explanation") explanation = gr.Markdown() with gr.Column(): gr.Markdown("## Documentation Links") docs = gr.Markdown() inp.change( fn=change, inputs=inp, outputs=[initial_code, out, feature, explanation, docs] ) demo.launch()