|
|
import streamlit as st |
|
|
import pandas as pd |
|
|
import matplotlib.pyplot as plt |
|
|
import random |
|
|
|
|
|
|
|
|
sample_player_names = ["Alice", "Bob", "Charlie", "Diana", "Ethan", "Fiona", "George", "Hannah", "Ivan", "Julia", "Aisha", "Carlos", "Mei", "Raj", "Lerato", "Dmitry", "Isabella", "Yuto", "Chloe", "Tariq"] |
|
|
|
|
|
|
|
|
|
|
|
def generate_fibonacci_sequence(max_value): |
|
|
sequence = [0, 1] |
|
|
while sequence[-1] + sequence[-2] <= max_value: |
|
|
sequence.append(sequence[-1] + sequence[-2]) |
|
|
return sequence |
|
|
|
|
|
def plot_graph(data, title): |
|
|
fig, ax = plt.subplots() |
|
|
|
|
|
|
|
|
for _, row in data.iterrows(): |
|
|
ax.scatter(x=row['User Value'], y=row['Complexity'], alpha=0.5, label=row['Player']) |
|
|
|
|
|
|
|
|
ax.set_xlim(0, 55) |
|
|
ax.set_ylim(0, 55) |
|
|
|
|
|
|
|
|
ax.axhline(y=27.5, color='gray', linestyle='--') |
|
|
ax.axvline(x=27.5, color='gray', linestyle='--') |
|
|
|
|
|
|
|
|
ax.set_xlabel("User Value") |
|
|
ax.set_ylabel("Complexity") |
|
|
ax.set_title(title) |
|
|
|
|
|
|
|
|
ax.legend() |
|
|
ax.grid(True) |
|
|
|
|
|
return fig |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def display_pitch_and_review(pitcher, player_names, max_fibonacci_value, fibonacci_numbers): |
|
|
with st.container(): |
|
|
|
|
|
project_key = f'project_{pitcher}' |
|
|
if project_key not in st.session_state: |
|
|
st.session_state[project_key] = '' |
|
|
project_name = st.text_input(f"Project Name by {pitcher}", st.session_state[project_key]) |
|
|
|
|
|
|
|
|
for reviewer in player_names: |
|
|
if reviewer != pitcher: |
|
|
st.write(f"{reviewer}'s Review") |
|
|
|
|
|
|
|
|
complexity_key = f'complexity_{pitcher}_{reviewer}' |
|
|
user_value_key = f'user_value_{pitcher}_{reviewer}' |
|
|
funding_key = f'funding_{pitcher}_{reviewer}' |
|
|
|
|
|
|
|
|
if complexity_key not in st.session_state: |
|
|
st.session_state[complexity_key] = random.choice(fibonacci_numbers) |
|
|
if user_value_key not in st.session_state: |
|
|
st.session_state[user_value_key] = random.choice(fibonacci_numbers) |
|
|
if funding_key not in st.session_state: |
|
|
st.session_state[funding_key] = random.choice(fibonacci_numbers) |
|
|
|
|
|
|
|
|
complexity = st.slider(f"Complexity for {project_name}", 0, max_fibonacci_value, st.session_state[complexity_key], key=complexity_key) |
|
|
user_value = st.slider(f"User Value for {project_name}", 0, max_fibonacci_value, st.session_state[user_value_key], key=user_value_key) |
|
|
funding_points = st.slider(f"Funding Points for {project_name}", 0, max_fibonacci_value, st.session_state[funding_key], key=funding_key) |
|
|
|
|
|
|
|
|
new_row = { |
|
|
"Player": reviewer, |
|
|
"Project": project_name, |
|
|
"Complexity": complexity, |
|
|
"User Value": user_value, |
|
|
"Funding Points": funding_points |
|
|
} |
|
|
st.session_state['game_data'] = pd.concat([st.session_state['game_data'], pd.DataFrame([new_row])], ignore_index=True) |
|
|
|
|
|
|
|
|
def update_game_data(pitcher, project_name, player_names, max_fibonacci_value): |
|
|
for reviewer in player_names: |
|
|
if reviewer != pitcher: |
|
|
complexity_key = f'complexity_{pitcher}_{reviewer}' |
|
|
user_value_key = f'user_value_{pitcher}_{reviewer}' |
|
|
funding_key = f'funding_{pitcher}_{reviewer}' |
|
|
|
|
|
new_row = { |
|
|
"Player": reviewer, |
|
|
"Project": project_name, |
|
|
"Complexity": st.session_state[complexity_key], |
|
|
"User Value": st.session_state[user_value_key], |
|
|
"Funding Points": st.session_state[funding_key] |
|
|
} |
|
|
st.session_state['game_data'] = pd.concat([st.session_state['game_data'], pd.DataFrame([new_row])], ignore_index=True) |
|
|
|
|
|
|
|
|
|
|
|
st.title("The Big Idea: Pitch Practice Game") |
|
|
|
|
|
|
|
|
number_of_players = st.sidebar.number_input("Enter number of players", 2, 10, 4) |
|
|
|
|
|
|
|
|
if 'player_names' not in st.session_state or st.sidebar.button("Initialize/Change Player Names"): |
|
|
st.session_state['player_names'] = [st.sidebar.text_input(f"Name of player {i+1}", value=random.choice(sample_player_names), key=f'player_{i}') for i in range(number_of_players)] |
|
|
else: |
|
|
|
|
|
for i in range(number_of_players): |
|
|
st.session_state['player_names'][i] = st.sidebar.text_input(f"Name of player {i+1}", value=st.session_state['player_names'][i], key=f'player_{i}') |
|
|
|
|
|
|
|
|
player_names = st.session_state['player_names'] |
|
|
|
|
|
|
|
|
if 'game_data' not in st.session_state: |
|
|
st.session_state['game_data'] = pd.DataFrame(columns=["Player", "Project", "Complexity", "User Value", "Funding Points"]) |
|
|
|
|
|
|
|
|
fibonacci_numbers = generate_fibonacci_sequence(55) |
|
|
max_fibonacci_value = max(fibonacci_numbers) |
|
|
|
|
|
|
|
|
if 'selected_pitcher' in st.session_state and st.session_state['selected_pitcher']: |
|
|
display_pitch_and_review(st.session_state['selected_pitcher'], player_names, max_fibonacci_value, fibonacci_numbers) |
|
|
if st.button("Save Reviews"): |
|
|
update_game_data(st.session_state['selected_pitcher'], st.session_state[f'project_{st.session_state["selected_pitcher"]}'], player_names, max_fibonacci_value) |
|
|
st.session_state['selected_pitcher'] = None |
|
|
|
|
|
|
|
|
for i, pitcher in enumerate(player_names): |
|
|
if st.sidebar.button(f"{pitcher}'s Pitch", key=f'pitch_{pitcher}_{i}'): |
|
|
st.session_state['selected_pitcher'] = pitcher |
|
|
|
|
|
|
|
|
|
|
|
if st.sidebar.button("Show Results"): |
|
|
st.write(st.session_state['game_data']) |
|
|
fig = plot_graph(st.session_state['game_data'], "Project Complexity vs User Value") |
|
|
st.pyplot(fig) |
|
|
|
|
|
if st.sidebar.button("Restart Game"): |
|
|
st.session_state['game_data'] = pd.DataFrame(columns=["Player", "Project", "Complexity", "User Value", "Funding Points"]) |
|
|
|
|
|
for key in list(st.session_state.keys()): |
|
|
del st.session_state[key] |
|
|
|
|
|
|
|
|
if not all(player_names): |
|
|
st.sidebar.warning("Please enter names for all players.") |