Spaces:
Runtime error
Runtime error
File size: 2,482 Bytes
64b053f |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
import streamlit as st
import pandas as pd
import random
import plotly.graph_objects as go
import plotly.express as px
# Define the states and conditions of interest
states = ["Minnesota", "Florida", "California"]
top_n = 10
# Define the list dictionary of top 10 health conditions descending by cost, with emojis
health_conditions = [
{"condition": "๐ Heart disease", "emoji": "๐", "spending": 214.3},
{"condition": "๐ค Trauma-related disorders", "emoji": "๐", "spending": 198.6},
{"condition": "๐ฆ Cancer", "emoji": "๐๏ธ", "spending": 171.0},
{"condition": "๐ง Mental disorders", "emoji": "๐ง", "spending": 150.8},
{"condition": "๐ฆด Osteoarthritis and joint disorders", "emoji": "๐ฅ", "spending": 142.4},
{"condition": "๐ Diabetes", "emoji": "๐ฉธ", "spending": 107.4},
{"condition": "๐ซ Chronic obstructive pulmonary disease and asthma", "emoji": "๐ซ", "spending": 91.0},
{"condition": "๐ฉบ Hypertension", "emoji": "๐", "spending": 83.9},
{"condition": "๐ฌ Hyperlipidemia", "emoji": "๐ฌ", "spending": 83.9},
{"condition": "๐ฆด Back problems", "emoji": "๐ง", "spending": 67.0}
]
# Create a DataFrame from the list dictionary
df_top_conditions = pd.DataFrame(health_conditions)
# Calculate the total spending
total_spending = round(df_top_conditions["spending"].sum(), 1)
# Define the roll function
def roll():
# Generate a thousand 10-sided dice rolls for each health condition
rolls = [random.randint(1, 10) for _ in range(1000)]
# Calculate the frequency of each variant
frequencies = [rolls.count(i) for i in range(1, 11)]
return frequencies
# Define the sunburst chart
fig_sunburst = go.Figure(go.Sunburst(
labels=df_top_conditions["emoji"] + " " + df_top_conditions["condition"],
parents=[""] * top_n,
values=df_top_conditions["spending"],
maxdepth=2
))
# Customize the layout of the sunburst chart
fig_sunburst.update_layout(title=f"Top {top_n} Health Conditions in {', '.join(states)} by Spending (Total: ${total_spending}B)")
# Display the sunburst chart and variants per condition in the Streamlit app
st.plotly_chart(fig_sunburst)
for index, row in df_top_conditions.iterrows():
frequencies = roll()
fig_bar = px.bar(x=[f"Variant {i}" for i in range(1, 11)], y=frequencies[:10], labels={'x': 'Variant', 'y': 'Frequency'})
fig_bar.update_layout(title=f"Variants of {row['condition']} ({row['emoji']})")
st.plotly_chart(fig_bar)
|