|
import streamlit as st |
|
import numpy as np |
|
import time |
|
|
|
|
|
|
|
def is_prime(n): |
|
if n <= 1: |
|
return False |
|
for i in range(2, int(n**0.5) + 1): |
|
if n % i == 0: |
|
return False |
|
return True |
|
|
|
def fib_sequence(n): |
|
fib_seq = [0, 1] |
|
while fib_seq[-1] + fib_seq[-2] <= n: |
|
fib_seq.append(fib_seq[-1] + fib_seq[-2]) |
|
return fib_seq[2:] |
|
|
|
|
|
|
|
emoji_set = ["π²", "π³", "π", "π²", "πΏ", "π", "π ", "π°", "πΌ", "π€οΈ", "π", "ποΈ", "π", "πΎ", "ποΈ", "ποΈ", "π", "π€οΈ", "π£οΈ", "ποΈ", "π", "β°οΈ", "π§±", "π΅", "π", "πΌ", "π»", "πΊ", "π‘", "πΊοΈ", "π
", "π", "ποΈ", "ποΈ", "π»", "ποΈ", "ποΈ", "π―", "ποΈ", "π", "π", "π", "ποΈ"] |
|
|
|
|
|
|
|
def initialize_locations(size): |
|
"""Initialize different locations with unique emoji grids.""" |
|
|
|
|
|
np.random.seed(42) |
|
locations = { |
|
'forest edge': np.random.choice(emoji_set, (size, size)), |
|
'deep forest': np.random.choice(emoji_set, (size, size)), |
|
'mountain range': np.random.choice(emoji_set, (size, size)), |
|
'coastal town': np.random.choice(emoji_set, (size, size)), |
|
'desert oasis': np.random.choice(emoji_set, (size, size)), |
|
} |
|
return locations |
|
|
|
|
|
|
|
directions = {"North": (-1, 0), "South": (1, 0), "West": (0, -1), "East": (0, 1)} |
|
|
|
|
|
|
|
def move_emojis(locations, current_location, direction, velocity): |
|
"""Shift emojis in the specified direction with wrap-around for the current location.""" |
|
dx, dy = [coord * velocity for coord in directions[direction]] |
|
locations[current_location] = np.roll(locations[current_location], shift=(dx, dy), axis=(0, 1)) |
|
return locations |
|
|
|
|
|
|
|
def main(): |
|
st.title("Explore the Emoji World") |
|
size = st.sidebar.slider("Grid Size", 5, 40, 10) |
|
velocity = st.sidebar.slider("Velocity (emojis/sec)", 1, 10, 1) |
|
|
|
if 'locations' not in st.session_state: |
|
st.session_state.locations = initialize_locations(size) |
|
else: |
|
st.session_state.locations = initialize_locations(size) |
|
|
|
if 'direction' not in st.session_state: |
|
st.session_state.direction = "None" |
|
|
|
current_location = st.sidebar.selectbox("Select location", options=list(st.session_state.locations.keys())) |
|
emoji_map = st.session_state.locations[current_location] |
|
map_str = "\n".join(["".join(row) for row in emoji_map]) |
|
st.text(map_str) |
|
|
|
col1, col2, col3 = st.columns(3) |
|
|
|
with col1: |
|
if st.button("West"): |
|
st.session_state.direction = "West" |
|
|
|
with col2: |
|
if st.button("North"): |
|
st.session_state.direction = "North" |
|
if st.button("Stop"): |
|
st.session_state.direction = "None" |
|
if st.button("South"): |
|
st.session_state.direction = "South" |
|
|
|
with col3: |
|
if st.button("East"): |
|
st.session_state.direction = "East" |
|
|
|
if st.session_state.direction != "None": |
|
st.session_state.locations = move_emojis(st.session_state.locations, current_location, st.session_state.direction, velocity) |
|
|
|
time.sleep(1) |
|
st.experimental_rerun() |
|
|
|
if __name__ == "__main__": |
|
main() |