awacke1 commited on
Commit
ece7ba2
·
verified ·
1 Parent(s): d4f465b

Create Torch Demo by Aaron Wacker

Browse files
Files changed (1) hide show
  1. Torch Demo by Aaron Wacker +110 -0
Torch Demo by Aaron Wacker ADDED
@@ -0,0 +1,110 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Create a torch demonstration and use data created with this program below for input and output. Design a torch demo that uses simple convolutions to explain correlation between one word and another and add to IO patterns of this program and use requests and nlp including nltk to remix a demonstration app that uses the text files as input. Have this allow users to build their library of prompts and add it to their user file defined by email address named text file. Add links to sites with reference documentation. Use this as teaching lesson in python streamlit UI and ccode yet remove all comments and just have variable names be super descriptive: import streamlit as st
2
+ import os
3
+ import json
4
+ import base64
5
+
6
+ def save_user_data(email, data):
7
+ """Save user data to a file named after the user's email."""
8
+ with open(f"{email}.txt", "w") as file:
9
+ file.write(json.dumps(data))
10
+
11
+ def load_user_data(email):
12
+ """Load user data from a file named after the user's email, or create a new file if it doesn't exist."""
13
+ if not os.path.isfile(f"{email}.txt"):
14
+ return {'email': '', 'phone': '', 'password': '', 'social': {}}
15
+ with open(f"{email}.txt", "r") as file:
16
+ return json.loads(file.read())
17
+
18
+ def list_saved_users():
19
+ """List all files (users) with saved states containing '@' in filename."""
20
+ return [f[:-4] for f in os.listdir() if f.endswith('.txt') and '@' in f]
21
+
22
+ def get_file_download_link(filename):
23
+ """Generate a file download link."""
24
+ with open(filename, "rb") as file:
25
+ base64_file = base64.b64encode(file.read()).decode()
26
+ href = f'<a href="data:file/txt;base64,{base64_file}" download="{filename}">Download {filename}</a>'
27
+ return href
28
+
29
+ def display_social_links(social_data):
30
+ """Display social media links as Markdown."""
31
+ st.markdown("## Social Media Links")
32
+ for platform, url in social_data.items():
33
+ if url:
34
+ emoji = {"instagram": "📷", "twitter": "🐦", "facebook": "📘", "huggingface": "🤗", "github": "💻", "linkedin": "🔗"}.get(platform, "")
35
+ st.markdown(f"{emoji} [{platform.capitalize()}]({url})")
36
+
37
+ def main():
38
+ st.title('User Data Management')
39
+
40
+ # Sidebar for selecting a user file
41
+ st.sidebar.title("Saved Users")
42
+ saved_users = list_saved_users()
43
+ selected_user = st.sidebar.selectbox("Select a user", options=['New User'] + saved_users)
44
+
45
+ # Load or initialize data
46
+ if selected_user and selected_user != 'New User':
47
+ cached_data = load_user_data(selected_user)
48
+ else:
49
+ cached_data = {'email': '', 'phone': '', 'password': '', 'social': {}}
50
+
51
+ # Input fields with emojis
52
+ new_email = st.text_input("📧 Email Address", value=cached_data['email'])
53
+ new_phone = st.text_input("📱 Mobile Phone", value=cached_data['phone'])
54
+ new_password = st.text_input("🔑 Password", value=cached_data['password'], type='password')
55
+
56
+ # Social media fields
57
+ st.markdown("### Social Media Profiles")
58
+ social_fields = ["instagram", "twitter", "facebook", "huggingface", "github", "linkedin"]
59
+ for field in social_fields:
60
+ emoji = {"instagram": "📷", "twitter": "🐦", "facebook": "📘", "huggingface": "🤗", "github": "💻", "linkedin": "🔗"}.get(field, "")
61
+ cached_data['social'][field] = st.text_input(f"{emoji} {field.capitalize()}", value=cached_data['social'].get(field, ''))
62
+
63
+ # Save data when changes are made
64
+ if st.button("Save Data"):
65
+ save_user_data(new_email, {'email': new_email, 'phone': new_phone, 'password': new_password, 'social': cached_data['social']})
66
+ st.sidebar.success("Data updated and saved!")
67
+
68
+ # Download link for user data file
69
+ if selected_user and selected_user != 'New User':
70
+ st.sidebar.markdown(get_file_download_link(f"{selected_user}.txt"), unsafe_allow_html=True)
71
+
72
+ # File uploader
73
+ uploaded_file = st.sidebar.file_uploader("📤 Upload User File", type='txt')
74
+ if uploaded_file is not None:
75
+ uploaded_data = json.loads(uploaded_file.getvalue().decode())
76
+ save_user_data(uploaded_data['email'], uploaded_data)
77
+ st.sidebar.success("Uploaded and saved!")
78
+
79
+ # Display current data without password
80
+ display_data = cached_data.copy()
81
+ display_data['password'] = '*****' # Hide the password
82
+ st.write("Current Data:")
83
+ st.json(display_data)
84
+
85
+ # Display social media links
86
+ display_social_links(cached_data['social'])
87
+
88
+ # Password Reset Simulation
89
+ if st.sidebar.button("Reset Password"):
90
+ reset_email = st.sidebar.text_input("Enter email for password reset")
91
+ if reset_email and reset_email in saved_users:
92
+ reset_data = load_user_data(reset_email)
93
+ reset_data['password'] = 'new_password' # Reset password
94
+ save_user_data(reset_email, reset_data)
95
+ st.sidebar.success(f"Password reset for {reset_email}")
96
+
97
+ # Run the app
98
+ if __name__ == "__main__":
99
+ main()
100
+ ChatGPT
101
+ To create a Python Streamlit application that demonstrates simple convolution operations in PyTorch and uses text files as input for NLP tasks, we'll integrate several components:
102
+
103
+ Streamlit UI: The interface where users interact with the application.
104
+ File Management: To load, save, and manage user-specific text files based on their email addresses.
105
+ PyTorch Convolution Demonstration: A simple demonstration of convolution operations to find correlations between words.
106
+ NLP Processing: Using NLTK and other NLP libraries to analyze the text data.
107
+ External References: Links to relevant documentation for learning purposes.
108
+ The application will allow users to upload their text files, perform NLP tasks on these files using NLTK, and demonstrate simple convolution operations in PyTorch to show relationships between words. Additionally, users can save their data and retrieve it later using their email address.
109
+
110
+ Here is the full Python Streamlit code for the described application: