| |
| 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 |
| |
| file_path = 'dataset/JS00001_filtered.csv' |
| ecg_data = pd.read_csv(file_path) |
|
|
| |
| leads = ['I', 'II', 'III', 'aVR', 'aVL', 'aVF', 'V1', 'V2', 'V3', 'V4', 'V5', 'V6'] |
|
|
| |
| 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' |
| ) |
| ], style={'width': '30%', 'margin': '0 auto', 'padding': '20px'}), |
| dcc.Graph(id='ecg-data-visualization'), |
| ], style={'padding': '20px', 'maxWidth': '1200px', 'margin': '0 auto'}) |
|
|
| |
| @app.callback( |
| Output('ecg-data-visualization', 'figure'), |
| [Input('lead-dropdown', 'value')] |
| ) |
| def update_figure(selected_lead): |
| |
| 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"}]]) |
|
|
| |
| if selected_lead == 'ALL': |
| |
| 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: |
| |
| 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) |
|
|
| |
| 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) |
|
|
| |
| fig.update_layout(height=1600, title_text="Comprehensive ECG Data Analysis", showlegend=True) |
| return fig |
|
|
| |
| if __name__ == '__main__': |
| app.run_server(debug=True) |