Spaces:
Running
Running
import streamlit as st | |
import pandas as pd | |
import datetime | |
import matplotlib.pyplot as plt | |
import numpy as np | |
import io | |
# Data: zodiac signs with date ranges and personality traits | |
zodiac_traits = { | |
'Aries': {'dates': ((3,21), (4,19)), 'traits': ['Courageous', 'Determined', 'Confident', 'Enthusiastic']}, | |
'Taurus': {'dates': ((4,20), (5,20)), 'traits': ['Reliable', 'Patient', 'Practical', 'Devoted']}, | |
'Gemini': {'dates': ((5,21), (6,20)), 'traits': ['Gentle', 'Affectionate', 'Curious', 'Adaptable']}, | |
'Cancer': {'dates': ((6,21), (7,22)), 'traits': ['Tenacious', 'Highly Imaginative', 'Loyal', 'Emotional']}, | |
'Leo': {'dates': ((7,23), (8,22)), 'traits': ['Creative', 'Passionate', 'Generous', 'Warmhearted']}, | |
'Virgo': {'dates': ((8,23), (9,22)), 'traits': ['Loyal', 'Analytical', 'Kind', 'Hardworking']}, | |
'Libra': {'dates': ((9,23), (10,22)), 'traits': ['Cooperative', 'Diplomatic', 'Gracious', 'Fair-minded']}, | |
'Scorpio': {'dates': ((10,23), (11,21)), 'traits': ['Resourceful', 'Brave', 'Passionate', 'Stubborn']}, | |
'Sagittarius': {'dates': ((11,22), (12,21)), 'traits': ['Generous', 'Idealistic', 'Great Sense of Humor']}, | |
'Capricorn': {'dates': ((12,22), (1,19)), 'traits': ['Responsible', 'Disciplined', 'Self-control', 'Good Managers']}, | |
'Aquarius': {'dates': ((1,20), (2,18)), 'traits': ['Progressive', 'Original', 'Independent', 'Humanitarian']}, | |
'Pisces': {'dates': ((2,19), (3,20)), 'traits': ['Compassionate', 'Artistic', 'Intuitive', 'Gentle']}, | |
} | |
# Compatibility scores between signs (1-10) | |
compatibility = pd.DataFrame( | |
data=[ | |
[5,6,7,4,8,5,6,7,8,5,6,7], # Aries with Aries, Taurus, ... Pisces | |
[6,5,6,7,5,8,7,6,5,8,7,6], | |
[7,6,5,8,6,7,8,5,6,7,8,5], | |
[4,7,8,5,7,6,5,8,7,6,5,8], | |
[8,5,6,7,5,7,6,7,5,8,6,7], | |
[5,8,7,6,7,5,8,6,7,5,8,6], | |
[6,7,8,5,6,8,5,7,6,8,7,5], | |
[7,6,5,8,7,6,7,5,8,6,7,6], | |
[8,5,6,7,5,7,6,8,5,7,6,8], | |
[5,8,7,6,8,5,8,6,7,5,8,6], | |
[6,7,8,5,6,8,7,7,6,8,5,7], | |
[7,6,5,8,7,6,5,6,8,6,7,5] | |
], | |
index=list(zodiac_traits.keys()), | |
columns=list(zodiac_traits.keys()) | |
) | |
# Helper to determine zodiac sign from birthdate | |
def get_zodiac_sign(month: int, day: int) -> str: | |
for sign, info in zodiac_traits.items(): | |
start, end = info['dates'] | |
start_month, start_day = start | |
end_month, end_day = end | |
# handle year wrap for Capricorn | |
if start_month == 12: | |
if (month == start_month and day >= start_day) or (month == end_month and day <= end_day): | |
return sign | |
else: | |
if (month == start_month and day >= start_day) or (month == end_month and day <= end_day) or (start_month < month < end_month): | |
return sign | |
return None | |
# Function to create radar chart | |
def create_radar_chart(traits, values, sign): | |
num_vars = len(traits) | |
# Compute the angle for each trait (360 degrees divided by number of traits) | |
angles = np.linspace(0, 2 * np.pi, num_vars, endpoint=False).tolist() | |
# The plot needs to be circular, so we repeat the first value to close the loop | |
values += values[:1] | |
angles += angles[:1] | |
# Create the radar chart | |
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw=dict(polar=True)) | |
# Plot the data | |
ax.fill(angles, values, color='blue', alpha=0.25) | |
ax.plot(angles, values, color='blue', linewidth=2) # Outline of the chart | |
# Set the labels for each axis (the traits) | |
ax.set_yticklabels([]) # Remove the radial ticks | |
ax.set_xticks(angles[:-1]) # Set the ticks for each trait | |
ax.set_xticklabels(traits, color='black', fontsize=12) | |
# Add the title | |
ax.set_title(f'{sign} Personality Traits', size=14, color='black', fontweight='bold') | |
# Show the radar chart | |
return fig | |
# Streamlit UI | |
st.title('Zodiac Matcher') | |
# Horoscope Section | |
st.header('Get Your Horoscope and Personality Traits') | |
birthdate = st.date_input("Enter your birthdate:") | |
if birthdate: | |
dt = datetime.datetime.strptime(str(birthdate), '%Y-%m-%d') | |
sign = get_zodiac_sign(dt.month, dt.day) | |
traits = zodiac_traits[sign]['traits'] | |
st.subheader(f"Your zodiac sign is: {sign}") | |
st.write(f"Personality Traits: {', '.join(traits)}") | |
# Display Radar Chart for Zodiac Sign | |
trait_values = [9, 10, 8, 9] # Example trait values for the radar chart (can be adjusted) | |
fig = create_radar_chart(traits, trait_values, sign) | |
buf = io.BytesIO() | |
fig.savefig(buf, format='png') | |
buf.seek(0) | |
st.image(buf) | |
# Compatibility Section | |
st.header('Check Compatibility Between Two Zodiac Signs') | |
sign1 = st.selectbox('Select your sign:', list(zodiac_traits.keys())) | |
sign2 = st.selectbox('Select partner sign:', list(zodiac_traits.keys())) | |
if sign1 and sign2: | |
score = compatibility.at[sign1, sign2] | |
st.subheader(f"Compatibility Score between {sign1} and {sign2}: {score}") | |
# Plotting Compatibility Chart | |
fig, ax = plt.subplots() | |
ax.bar([sign1 + " & " + sign2], [score]) | |
ax.set_ylim(0, 10) | |
ax.set_ylabel('Score (1-10)') | |
ax.set_title(f'{sign1} & {sign2} Compatibility') | |
buf = io.BytesIO() | |
plt.savefig(buf, format='png') | |
buf.seek(0) | |
st.image(buf) | |