DataLine / ecg_visualization.py
Suraj Prasai
aded initial
458c8e2
# Import necessary libraries
import dash
from dash import html, dcc
from dash.dependencies import Input, Output
import pandas as pd
import plotly.graph_objects as go
from plotly.subplots import make_subplots
# Load the dataset
file_path = 'dataset/JS00001_filtered.csv' # Update this path as necessary
ecg_data = pd.read_csv(file_path)
# Define leads
leads = ['I', 'II', 'III', 'aVR', 'aVL', 'aVF', 'V1', 'V2', 'V3', 'V4', 'V5', 'V6']
# Initialize the Dash app
app = dash.Dash(__name__)
app.layout = html.Div(children=[
html.H1(children='ECG Data Dashboard', style={'textAlign': 'center', 'color': '#007BFF'}),
html.Div([
html.Label('Select ECG Lead for Analysis:'),
dcc.Dropdown(
id='lead-dropdown',
options=[{'label': 'All Leads', 'value': 'ALL'}] + [{'label': lead, 'value': lead} for lead in leads],
value='ALL' # Default value to show all leads
)
], style={'width': '30%', 'margin': '0 auto', 'padding': '20px'}),
dcc.Graph(id='ecg-data-visualization'),
], style={'padding': '20px', 'maxWidth': '1200px', 'margin': '0 auto'})
# Define callback to update the figure based on the selected lead
@app.callback(
Output('ecg-data-visualization', 'figure'),
[Input('lead-dropdown', 'value')]
)
def update_figure(selected_lead):
# Initialize the figure with subplots
fig = make_subplots(rows=4, cols=1,
subplot_titles=("ECG Signal Over Time", "Histogram of Signal Amplitudes",
"Scatter Plot: Lead I vs Lead II", "Rolling Average"),
vertical_spacing=0.1,
specs=[[{"type": "scatter"}], [{"type": "histogram"}], [{"type": "scatter"}], [{"type": "scatter"}]])
# Conditionally display either all leads or just the selected lead
if selected_lead == 'ALL':
# Show all leads
for lead in leads:
fig.add_trace(go.Scatter(x=ecg_data['time'], y=ecg_data[lead], mode='lines', name=f'Lead {lead}'), row=1, col=1)
fig.add_trace(go.Histogram(x=ecg_data[lead], name=f'Lead {lead}', opacity=0.75), row=2, col=1)
else:
# Show only the selected lead
ecg_data['RollingAvg'] = ecg_data[selected_lead].rolling(window=100).mean()
fig.add_trace(go.Scatter(x=ecg_data['time'], y=ecg_data[selected_lead], mode='lines', name=f'Lead {selected_lead}'), row=1, col=1)
fig.add_trace(go.Histogram(x=ecg_data[selected_lead], name=f'Lead {selected_lead}', opacity=0.75), row=2, col=1)
fig.add_trace(go.Scatter(x=ecg_data['time'], y=ecg_data['RollingAvg'], mode='lines', name=f'Rolling Average: Lead {selected_lead}'), row=4, col=1)
# Common settings for all cases
fig.update_traces(opacity=0.75, bingroup=1, row=2, col=1)
fig.update_layout(barmode='overlay')
fig.add_trace(go.Scatter(x=ecg_data['I'], y=ecg_data['II'], mode='markers', name='Lead I vs Lead II'), row=3, col=1)
# Update the figure layout
fig.update_layout(height=1600, title_text="Comprehensive ECG Data Analysis", showlegend=True)
return fig
# Run the app
if __name__ == '__main__':
app.run_server(debug=True)