Spaces:
Running
Running
import streamlit as st | |
import plotly.graph_objects as go | |
# Title | |
st.title("Interactive Equation Plotter") | |
# Sidebar sliders | |
st.sidebar.header("Controls") | |
w = st.sidebar.slider('W (slope)', min_value=-10.0, max_value=10.0, value=1.0, step=0.1) | |
b = st.sidebar.slider('B (intercept)', min_value=-100.0, max_value=100.0, value=0.0, step=1.0) | |
# Initial x position | |
x = st.slider('X position', min_value=-100.0, max_value=100.0, value=0.0, step=1.0) | |
# Calculate y based on the equation y = w * x + b | |
y = w * x + b | |
# Create the plot | |
fig = go.Figure() | |
# Plot for the y-axis (top line) | |
fig.add_shape(type="line", x0=-100, x1=100, y0=1, y1=1, | |
line=dict(color="blue", width=2, dash="dash")) | |
# Plot for the x-axis (bottom line) | |
fig.add_shape(type="line", x0=-100, x1=100, y0=-1, y1=-1, | |
line=dict(color="blue", width=2, dash="dash")) | |
# Plot the x point | |
fig.add_trace(go.Scatter(x=[x], y=[-1], mode='markers', marker=dict(color='red', size=10), name="X point")) | |
# Plot the y point | |
fig.add_trace(go.Scatter(x=[y], y=[1], mode='markers', marker=dict(color='red', size=10), name="Y point")) | |
# Update the layout | |
fig.update_layout( | |
title=f'y = {w} * x + {b}', | |
xaxis=dict(range=[-100, 100]), | |
yaxis=dict(range=[-2, 2], showticklabels=False), | |
showlegend=False, | |
height=400, | |
margin=dict(t=50, b=10) | |
) | |
# Display the plot in Streamlit | |
st.plotly_chart(fig) | |
# Add instruction to click and drag the point on x-axis | |
st.write("Drag the red dot on the x-axis to change the x position.") | |