Update Adam2
Browse files
Adam2
CHANGED
@@ -1,264 +1,268 @@
|
|
1 |
-
|
2 |
-
import
|
3 |
-
import
|
4 |
-
import
|
5 |
-
import
|
6 |
-
import
|
7 |
-
from sklearn.
|
8 |
-
from sklearn.
|
9 |
-
from sklearn.
|
10 |
-
from
|
11 |
-
from
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
|
18 |
-
'I am
|
19 |
-
'I am
|
20 |
-
'I am
|
21 |
-
'I am
|
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 |
-
'
|
58 |
-
'
|
59 |
-
'
|
60 |
-
'
|
61 |
-
'
|
62 |
-
'
|
63 |
-
'
|
64 |
-
'
|
65 |
-
'
|
66 |
-
'
|
67 |
-
'
|
68 |
-
'
|
69 |
-
'
|
70 |
-
'
|
71 |
-
|
72 |
-
|
73 |
-
|
74 |
-
|
75 |
-
|
76 |
-
|
77 |
-
|
78 |
-
|
79 |
-
|
80 |
-
|
81 |
-
|
82 |
-
|
83 |
-
|
84 |
-
|
85 |
-
|
86 |
-
|
87 |
-
|
88 |
-
|
89 |
-
|
90 |
-
|
91 |
-
|
92 |
-
|
93 |
-
|
94 |
-
|
95 |
-
|
96 |
-
|
97 |
-
|
98 |
-
|
99 |
-
|
100 |
-
|
101 |
-
|
102 |
-
|
103 |
-
|
104 |
-
|
105 |
-
|
106 |
-
|
107 |
-
|
108 |
-
|
109 |
-
|
110 |
-
|
111 |
-
|
112 |
-
|
113 |
-
|
114 |
-
|
115 |
-
|
116 |
-
|
117 |
-
|
118 |
-
|
119 |
-
|
120 |
-
|
121 |
-
|
122 |
-
|
123 |
-
|
124 |
-
|
125 |
-
|
126 |
-
|
127 |
-
|
128 |
-
|
129 |
-
|
130 |
-
|
131 |
-
|
132 |
-
|
133 |
-
|
134 |
-
|
135 |
-
|
136 |
-
#
|
137 |
-
|
138 |
-
|
139 |
-
|
140 |
-
|
141 |
-
|
142 |
-
|
143 |
-
|
144 |
-
|
145 |
-
|
146 |
-
|
147 |
-
|
148 |
-
|
149 |
-
|
150 |
-
|
151 |
-
|
152 |
-
|
153 |
-
|
154 |
-
|
155 |
-
|
156 |
-
|
157 |
-
|
158 |
-
|
159 |
-
|
160 |
-
|
161 |
-
|
162 |
-
|
163 |
-
|
164 |
-
|
165 |
-
|
166 |
-
|
167 |
-
|
168 |
-
|
169 |
-
|
170 |
-
|
171 |
-
|
172 |
-
|
173 |
-
|
174 |
-
|
175 |
-
|
176 |
-
|
177 |
-
|
178 |
-
|
179 |
-
|
180 |
-
|
181 |
-
update_emotion('
|
182 |
-
elif predicted_emotion == '
|
183 |
-
update_emotion('
|
184 |
-
|
185 |
-
|
186 |
-
|
187 |
-
|
188 |
-
|
189 |
-
|
190 |
-
|
191 |
-
|
192 |
-
|
193 |
-
|
194 |
-
|
195 |
-
|
196 |
-
|
197 |
-
|
198 |
-
|
199 |
-
|
200 |
-
|
201 |
-
|
202 |
-
|
203 |
-
|
204 |
-
|
205 |
-
|
206 |
-
|
207 |
-
|
208 |
-
|
209 |
-
|
210 |
-
|
211 |
-
|
212 |
-
|
213 |
-
|
214 |
-
|
215 |
-
|
216 |
-
|
217 |
-
|
218 |
-
|
219 |
-
|
220 |
-
|
221 |
-
|
222 |
-
|
223 |
-
|
224 |
-
|
225 |
-
|
226 |
-
|
227 |
-
|
228 |
-
|
229 |
-
|
230 |
-
|
231 |
-
|
232 |
-
|
233 |
-
|
234 |
-
|
235 |
-
|
236 |
-
|
237 |
-
|
238 |
-
|
239 |
-
|
240 |
-
|
241 |
-
|
242 |
-
|
243 |
-
|
244 |
-
|
245 |
-
|
246 |
-
|
247 |
-
|
248 |
-
print(
|
249 |
-
|
250 |
-
|
251 |
-
|
252 |
-
|
253 |
-
|
254 |
-
|
255 |
-
|
256 |
-
|
257 |
-
#
|
258 |
-
|
259 |
-
|
260 |
-
|
261 |
-
|
262 |
-
|
263 |
-
|
264 |
-
soul.bridge_ai(user_input)
|
|
|
|
|
|
|
|
|
|
1 |
+
import numpy as np
|
2 |
+
import pandas as pd
|
3 |
+
import os
|
4 |
+
import json
|
5 |
+
import random
|
6 |
+
from sklearn.ensemble import IsolationForest
|
7 |
+
from sklearn.model_selection import train_test_split
|
8 |
+
from sklearn.preprocessing import OneHotEncoder
|
9 |
+
from sklearn.neural_network import MLPClassifier
|
10 |
+
from deap import base, creator, tools, algorithms
|
11 |
+
from transformers import BloomForCausalLM, BloomTokenizerFast
|
12 |
+
import torch
|
13 |
+
|
14 |
+
# Initialize Example Emotions Dataset
|
15 |
+
data = {
|
16 |
+
'context': [
|
17 |
+
'I am happy', 'I am sad', 'I am angry', 'I am excited', 'I am calm',
|
18 |
+
'I am feeling joyful', 'I am grieving', 'I am feeling peaceful', 'I am frustrated',
|
19 |
+
'I am determined', 'I feel resentment', 'I am feeling glorious', 'I am motivated',
|
20 |
+
'I am surprised', 'I am fearful', 'I am trusting', 'I feel disgust', 'I am optimistic',
|
21 |
+
'I am pessimistic', 'I feel bored', 'I am envious'
|
22 |
+
],
|
23 |
+
'emotion': [
|
24 |
+
'joy', 'sadness', 'anger', 'joy', 'calmness', 'joy', 'grief', 'calmness', 'anger',
|
25 |
+
'determination', 'resentment', 'glory', 'motivation', 'surprise', 'fear', 'trust',
|
26 |
+
'disgust', 'optimism', 'pessimism', 'boredom', 'envy'
|
27 |
+
]
|
28 |
+
}
|
29 |
+
df = pd.DataFrame(data)
|
30 |
+
|
31 |
+
# Encoding the contexts using One-Hot Encoding
|
32 |
+
encoder = OneHotEncoder(handle_unknown='ignore')
|
33 |
+
contexts_encoded = encoder.fit_transform(df[['context']]).toarray()
|
34 |
+
|
35 |
+
# Encoding emotions
|
36 |
+
emotions_target = df['emotion'].astype('category').cat.codes
|
37 |
+
emotion_classes = df['emotion'].astype('category').cat.categories
|
38 |
+
|
39 |
+
# Train Neural Network
|
40 |
+
X_train, X_test, y_train, y_test = train_test_split(contexts_encoded, emotions_target, test_size=0.2, random_state=42)
|
41 |
+
model = MLPClassifier(hidden_layer_sizes=(10, 10), max_iter=1000, random_state=42)
|
42 |
+
model.fit(X_train, y_train)
|
43 |
+
|
44 |
+
# Isolation Forest Anomaly Detection Model
|
45 |
+
historical_data = np.array([model.predict(contexts_encoded)]).T
|
46 |
+
isolation_forest = IsolationForest(contamination=0.1, random_state=42)
|
47 |
+
isolation_forest.fit(historical_data)
|
48 |
+
|
49 |
+
# Emotional States with 20 emotions
|
50 |
+
emotions = {
|
51 |
+
'joy': {'percentage': 10, 'motivation': 'positive'},
|
52 |
+
'pleasure': {'percentage': 10, 'motivation': 'selfish'},
|
53 |
+
'sadness': {'percentage': 10, 'motivation': 'negative'},
|
54 |
+
'grief': {'percentage': 10, 'motivation': 'negative'},
|
55 |
+
'anger': {'percentage': 10, 'motivation': 'traumatic or strong'},
|
56 |
+
'calmness': {'percentage': 10, 'motivation': 'neutral'},
|
57 |
+
'determination': {'percentage': 10, 'motivation': 'positive'},
|
58 |
+
'resentment': {'percentage': 10, 'motivation': 'negative'},
|
59 |
+
'glory': {'percentage': 10, 'motivation': 'positive'},
|
60 |
+
'motivation': {'percentage': 10, 'motivation': 'positive'},
|
61 |
+
'ideal_state': {'percentage': 100, 'motivation': 'balanced'},
|
62 |
+
'fear': {'percentage': 10, 'motivation': 'defensive'},
|
63 |
+
'surprise': {'percentage': 10, 'motivation': 'unexpected'},
|
64 |
+
'anticipation': {'percentage': 10, 'motivation': 'predictive'},
|
65 |
+
'trust': {'percentage': 10, 'motivation': 'reliable'},
|
66 |
+
'disgust': {'percentage': 10, 'motivation': 'repulsive'},
|
67 |
+
'optimism': {'percentage': 10, 'motivation': 'hopeful'},
|
68 |
+
'pessimism': {'percentage': 10, 'motivation': 'doubtful'},
|
69 |
+
'boredom': {'percentage': 10, 'motivation': 'indifferent'},
|
70 |
+
'envy': {'percentage': 10, 'motivation': 'jealous'}
|
71 |
+
}
|
72 |
+
|
73 |
+
# Adjust all emotions to a total of 200%
|
74 |
+
total_percentage = 200
|
75 |
+
default_percentage = total_percentage / len(emotions)
|
76 |
+
for emotion in emotions:
|
77 |
+
emotions[emotion]['percentage'] = default_percentage
|
78 |
+
|
79 |
+
emotion_history_file = 'emotion_history.json'
|
80 |
+
|
81 |
+
# Load historical data from file if exists
|
82 |
+
def load_historical_data(file_path=emotion_history_file):
|
83 |
+
if os.path.exists(file_path):
|
84 |
+
with open(file_path, 'r') as file:
|
85 |
+
return json.load(file)
|
86 |
+
return []
|
87 |
+
|
88 |
+
# Save historical data to file
|
89 |
+
def save_historical_data(historical_data, file_path=emotion_history_file):
|
90 |
+
with open(file_path, 'w') as file:
|
91 |
+
json.dump(historical_data, file)
|
92 |
+
|
93 |
+
# Load previous emotional states
|
94 |
+
emotion_history = load_historical_data()
|
95 |
+
|
96 |
+
# Function to update emotions
|
97 |
+
def update_emotion(emotion, percentage):
|
98 |
+
emotions['ideal_state']['percentage'] -= percentage
|
99 |
+
emotions[emotion]['percentage'] += percentage
|
100 |
+
|
101 |
+
# Ensure total percentage remains 200%
|
102 |
+
total_current = sum(e['percentage'] for e in emotions.values())
|
103 |
+
adjustment = total_percentage - total_current
|
104 |
+
emotions['ideal_state']['percentage'] += adjustment
|
105 |
+
|
106 |
+
# Function to normalize context
|
107 |
+
def normalize_context(context):
|
108 |
+
return context.lower().strip()
|
109 |
+
|
110 |
+
# Function to evolve emotions using genetic algorithm
|
111 |
+
def evolve_emotions():
|
112 |
+
# Define the fitness function
|
113 |
+
def evaluate(individual):
|
114 |
+
ideal_state = individual[-1] # Last value is the ideal state percentage
|
115 |
+
other_emotions = individual[:-1] # All other emotions
|
116 |
+
return abs(ideal_state - 100), sum(other_emotions)
|
117 |
+
|
118 |
+
# Register the genetic algorithm components
|
119 |
+
creator.create("FitnessMin", base.Fitness, weights=(-1.0, -1.0))
|
120 |
+
creator.create("Individual", list, fitness=creator.FitnessMin)
|
121 |
+
|
122 |
+
# Create individuals and population
|
123 |
+
toolbox = base.Toolbox()
|
124 |
+
toolbox.register("attribute", lambda: random.uniform(0, 20))
|
125 |
+
toolbox.register("individual", tools.initCycle, creator.Individual, toolbox.attribute, n=(len(emotions) - 1))
|
126 |
+
toolbox.register("ideal_state", lambda: random.uniform(80, 120))
|
127 |
+
toolbox.register("complete_individual", tools.initConcat, creator.Individual, toolbox.individual, toolbox.ideal_state)
|
128 |
+
toolbox.register("population", tools.initRepeat, list, toolbox.complete_individual)
|
129 |
+
|
130 |
+
# Register genetic operators
|
131 |
+
toolbox.register("evaluate", evaluate)
|
132 |
+
toolbox.register("mate", tools.cxBlend, alpha=0.5)
|
133 |
+
toolbox.register("mutate", tools.mutGaussian, mu=10, sigma=5, indpb=0.3)
|
134 |
+
toolbox.register("select", tools.selTournament, tournsize=3)
|
135 |
+
|
136 |
+
# Initialize the population
|
137 |
+
population = toolbox.population(n=10)
|
138 |
+
|
139 |
+
# Run genetic algorithm
|
140 |
+
population, log = algorithms.eaSimple(population, toolbox, cxpb=0.5, mutpb=0.2, ngen=20, verbose=False)
|
141 |
+
|
142 |
+
# Update the emotions with the best individual
|
143 |
+
best_individual = tools.selBest(population, k=1)[0]
|
144 |
+
for idx, emotion in enumerate(emotions.keys()):
|
145 |
+
emotions[emotion]['percentage'] = best_individual[idx]
|
146 |
+
|
147 |
+
# Function to get emotional response
|
148 |
+
def get_emotional_response(context):
|
149 |
+
# Normalize context
|
150 |
+
context = normalize_context(context)
|
151 |
+
|
152 |
+
# Encode the context and predict the emotion using the neural network
|
153 |
+
context_encoded = encoder.transform([[context]]).toarray()
|
154 |
+
prediction = model.predict(context_encoded)
|
155 |
+
predicted_emotion = emotion_classes[prediction[0]]
|
156 |
+
|
157 |
+
# Check for anomalies using Isolation Forest
|
158 |
+
anomaly_score = isolation_forest.decision_function([prediction])[0]
|
159 |
+
if anomaly_score < -0.5:
|
160 |
+
print("Anomalous context detected. Adjusting emotional response.")
|
161 |
+
update_emotion('calmness', 20)
|
162 |
+
else:
|
163 |
+
# Define emotional responses
|
164 |
+
if predicted_emotion == 'joy':
|
165 |
+
update_emotion('joy', 20)
|
166 |
+
update_emotion('pleasure', 20)
|
167 |
+
elif predicted_emotion == 'sadness':
|
168 |
+
update_emotion('sadness', 20)
|
169 |
+
update_emotion('grief', 20)
|
170 |
+
elif predicted_emotion == 'anger':
|
171 |
+
update_emotion('anger', 20)
|
172 |
+
elif predicted_emotion == 'determination':
|
173 |
+
update_emotion('determination', 20)
|
174 |
+
elif predicted_emotion == 'resentment':
|
175 |
+
update_emotion('resentment', 20)
|
176 |
+
elif predicted_emotion == 'glory':
|
177 |
+
update_emotion('glory', 20)
|
178 |
+
elif predicted_emotion == 'motivation':
|
179 |
+
update_emotion('motivation', 20)
|
180 |
+
elif predicted_emotion == 'surprise':
|
181 |
+
update_emotion('surprise', 20)
|
182 |
+
elif predicted_emotion == 'fear':
|
183 |
+
update_emotion('fear', 20)
|
184 |
+
elif predicted_emotion == 'trust':
|
185 |
+
update_emotion('trust', 20)
|
186 |
+
elif predicted_emotion == 'disgust':
|
187 |
+
update_emotion('disgust', 20)
|
188 |
+
elif predicted_emotion == 'optimism':
|
189 |
+
update_emotion('optimism', 20)
|
190 |
+
elif predicted_emotion == 'pessimism':
|
191 |
+
update_emotion('pessimism', 20)
|
192 |
+
elif predicted_emotion == 'boredom':
|
193 |
+
update_emotion('boredom', 20)
|
194 |
+
elif predicted_emotion == 'envy':
|
195 |
+
update_emotion('envy', 20)
|
196 |
+
else:
|
197 |
+
update_emotion('calmness', 20)
|
198 |
+
|
199 |
+
# Record the current emotional state in history
|
200 |
+
emotion_state = {emotion: data['percentage'] for emotion, data in emotions.items()}
|
201 |
+
emotion_history.append(emotion_state)
|
202 |
+
|
203 |
+
# Save the history to file
|
204 |
+
save_historical_data(emotion_history)
|
205 |
+
|
206 |
+
# Print the current emotional state
|
207 |
+
for emotion, data in emotions.items():
|
208 |
+
print(f"{emotion.capitalize()}: {data['percentage']:.2f}% ({data['motivation']} motivation)")
|
209 |
+
|
210 |
+
# Function to handle idle state using genetic algorithm
|
211 |
+
def handle_idle_state():
|
212 |
+
print("Entering idle state...")
|
213 |
+
evolve_emotions()
|
214 |
+
print("Emotions evolved")
|
215 |
+
for emotion, data in emotions.items():
|
216 |
+
print(f"{emotion.capitalize()}: {data['percentage']:.2f}% ({data['motivation']} motivation)")
|
217 |
+
|
218 |
+
# S.O.U.L. (Self-Organizing Universal Learning) Function
|
219 |
+
class SOUL:
|
220 |
+
def __init__(self, model_name='bigscience/bloom-1b1'):
|
221 |
+
self.tokenizer = BloomTokenizerFast.from_pretrained(model_name)
|
222 |
+
self.model = BloomForCausalLM.from_pretrained(model_name)
|
223 |
+
self.device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
|
224 |
+
self.model.to(self.device)
|
225 |
+
|
226 |
+
def generate_text(self, prompt, max_length=100):
|
227 |
+
inputs = self.tokenizer(prompt, return_tensors="pt").to(self.device)
|
228 |
+
|
229 |
+
# Generate
|
230 |
+
with torch.no_grad():
|
231 |
+
generate_ids = self.model.generate(
|
232 |
+
inputs.input_ids,
|
233 |
+
max_length=max_length,
|
234 |
+
num_return_sequences=1,
|
235 |
+
no_repeat_ngram_size=2,
|
236 |
+
do_sample=True,
|
237 |
+
top_k=50,
|
238 |
+
top_p=0.95,
|
239 |
+
temperature=0.7
|
240 |
+
)
|
241 |
+
|
242 |
+
return self.tokenizer.batch_decode(generate_ids, skip_special_tokens=True, clean_up_tokenization_spaces=False)[0]
|
243 |
+
|
244 |
+
def bridge_ai(self, prompt):
|
245 |
+
# Generate the response using BLOOM
|
246 |
+
print("\nBLOOM Response:")
|
247 |
+
bloom_response = self.generate_text(prompt)
|
248 |
+
print(bloom_response)
|
249 |
+
|
250 |
+
# Get the emotional response
|
251 |
+
print("\nEmotional Response:")
|
252 |
+
get_emotional_response(bloom_response)
|
253 |
+
|
254 |
+
# Example usage of S.O.U.L. function
|
255 |
+
soul = SOUL()
|
256 |
+
|
257 |
+
# Test open-ended conversation with emotional response
|
258 |
+
print("Welcome to the SOUL AI. Type 'exit' to end the conversation.")
|
259 |
+
while True:
|
260 |
+
user_input = input("You: ")
|
261 |
+
if user_input.lower() == 'exit':
|
262 |
+
print("Thank you for the conversation. Goodbye!")
|
263 |
+
break
|
264 |
+
soul.bridge_ai(user_input)
|
265 |
+
|
266 |
+
# Simulate idle state every 5 interactions
|
267 |
+
if len(emotion_history) % 5 == 0:
|
268 |
+
handle_idle_state()
|