ai_chatbot 0.1.4 → 0.1.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/ai_chatbot/version.rb +1 -1
- data/lib/ai_chatbot.rb +34 -0
- data/lib/ml_model.py +9 -7
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 726472f08ac5fcbed289fcd127215efb58823399b4c1e960ef4a9ae35a4ce368
|
4
|
+
data.tar.gz: 59cc5bbe59655f7863970fb32ee66279d308208af82b5ca7d3462748146972de
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4611e846bcb29c1a0f5466a7b9269640ab8bb74ad8bb221e885f0c5fe07d2ec92e9a98aedec1b855fcc8ff6590a885c8f3522e4d8b5863724e7495ebc2a963fe
|
7
|
+
data.tar.gz: bb5dfc83841117e9f001d7691fa0fc4a1d439bf53cd7dc535b34a2f5a1f3b24c999d5a34d8cc407af7f4a036128fd280cf8998804c346a07364251bf885176ba
|
data/lib/ai_chatbot/version.rb
CHANGED
data/lib/ai_chatbot.rb
CHANGED
@@ -23,5 +23,39 @@ module AiChatbot
|
|
23
23
|
raise "Error: #{stderr}"
|
24
24
|
end
|
25
25
|
end
|
26
|
+
|
27
|
+
|
28
|
+
# Method to train the model with a new question-answer pair
|
29
|
+
def self.update_answer(existing_question, new_answer)
|
30
|
+
stdout, stderr, status = Open3.capture3("python3", "#{__dir__}/ml_model.py", "update_answer", new_question, new_answer)
|
31
|
+
|
32
|
+
if status.success?
|
33
|
+
return stdout.strip
|
34
|
+
else
|
35
|
+
raise "Error: #{stderr}"
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
def self.update_question(existing_question, new_question)
|
40
|
+
stdout, stderr, status = Open3.capture3("python3", "#{__dir__}/ml_model.py", "update_question", new_question, new_answer)
|
41
|
+
|
42
|
+
if status.success?
|
43
|
+
return stdout.strip
|
44
|
+
else
|
45
|
+
raise "Error: #{stderr}"
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
def self.list_of_questions
|
50
|
+
stdout, stderr, status = Open3.capture3("python3", "#{__dir__}/ml_model.py", "list_questions")
|
51
|
+
|
52
|
+
if status.success?
|
53
|
+
return stdout.strip
|
54
|
+
else
|
55
|
+
raise "Error: #{stderr}"
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
|
26
60
|
end
|
27
61
|
end
|
data/lib/ml_model.py
CHANGED
@@ -34,9 +34,11 @@ def main(action, query=None, new_answer=None):
|
|
34
34
|
return get_prediction(query)
|
35
35
|
elif action == "train":
|
36
36
|
return train_model(query, new_answer)
|
37
|
-
elif action == "
|
37
|
+
elif action == "update_answer":
|
38
38
|
return update_answer(query, new_answer)
|
39
|
-
elif action == "
|
39
|
+
elif action == "update_question":
|
40
|
+
return update_question(query, new_answer) # Corrected here, calling the right function
|
41
|
+
elif action == "list_questions":
|
40
42
|
return list_questions()
|
41
43
|
|
42
44
|
# Function to predict the response with confidence check
|
@@ -90,21 +92,21 @@ def update_answer(existing_question, new_answer):
|
|
90
92
|
return "Question not found. Please provide a valid question."
|
91
93
|
|
92
94
|
def update_question(existing_question, new_question):
|
93
|
-
global
|
95
|
+
global questions # Only 'questions' is global, not 'new_question'
|
94
96
|
|
95
97
|
if existing_question in questions:
|
96
98
|
# Find the index of the existing question
|
97
99
|
index = questions.index(existing_question)
|
98
|
-
# Update the
|
99
|
-
|
100
|
+
# Update the question
|
101
|
+
questions[index] = new_question
|
100
102
|
# Retrain the model with updated data
|
101
103
|
model.fit(questions, answers)
|
102
104
|
# Save the updated model and data
|
103
105
|
with open("qa_model.pkl", "wb") as f:
|
104
106
|
pickle.dump({"questions": questions, "answers": answers}, f)
|
105
|
-
return f"
|
107
|
+
return f"Question updated from '{existing_question}' to '{new_question}'"
|
106
108
|
else:
|
107
|
-
return "Question not found. Please provide a valid question."
|
109
|
+
return "Question not found. Please provide a valid question."
|
108
110
|
|
109
111
|
def list_questions():
|
110
112
|
global questions
|