diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..f7275bb
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+venv/
diff --git a/py/.idea/.gitignore b/py/.idea/.gitignore
new file mode 100644
index 0000000..26d3352
--- /dev/null
+++ b/py/.idea/.gitignore
@@ -0,0 +1,3 @@
+# Default ignored files
+/shelf/
+/workspace.xml
diff --git a/py/.idea/inspectionProfiles/profiles_settings.xml b/py/.idea/inspectionProfiles/profiles_settings.xml
new file mode 100644
index 0000000..105ce2d
--- /dev/null
+++ b/py/.idea/inspectionProfiles/profiles_settings.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/py/.idea/misc.xml b/py/.idea/misc.xml
new file mode 100644
index 0000000..f5d7485
--- /dev/null
+++ b/py/.idea/misc.xml
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/py/.idea/modules.xml b/py/.idea/modules.xml
new file mode 100644
index 0000000..3a65488
--- /dev/null
+++ b/py/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/py/.idea/py.iml b/py/.idea/py.iml
new file mode 100644
index 0000000..451946f
--- /dev/null
+++ b/py/.idea/py.iml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/py/.idea/vcs.xml b/py/.idea/vcs.xml
new file mode 100644
index 0000000..6c0b863
--- /dev/null
+++ b/py/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/py/api.py b/py/api.py
index 09373b5..9e6b40d 100644
--- a/py/api.py
+++ b/py/api.py
@@ -1,11 +1,21 @@
import requests
import json
+from transformers import AutoTokenizer, LlamaForCausalLM
+class API:
+ @staticmethod
+ def process_text_transformers(prompt, model):
+ model = LlamaForCausalLM.from_pretrained(model)
+ tokenizer = AutoTokenizer.from_pretrained(model)
-class api:
- def initialize_ollama(self, prompt):
+ inputs = tokenizer(prompt, return_tensors="pt")
+
+ generate_ids = model.generate(inputs.input_ids, max_length=30)
+ return tokenizer.batch_decode(generate_ids, skip_special_tokens=True, clean_up_tokenization_spaces=False)[0]
+
+ @staticmethod
+ def process_text_local(prompt, model):
ollama_url = "http://localhost:11434"
- model = "phi3.5"
response = requests.post(
f"{ollama_url}/api/generate", json={"model": model, "prompt": prompt}
@@ -24,6 +34,17 @@ class api:
else:
return "Error: " + response.text
- def send_message(self, message):
- answer = self.initialize_ollama(message)
+ def send_message(self, message, model):
+ if model == 1:
+ answer = self.process_text_local(message, "phi3.5")
+ elif model == 2:
+ answer = self.process_text_local(message, "gemma2:2b")
+ elif model == 3:
+ answer = self.process_text_local(message, "qwen2:0.5b")
+ elif model == 4:
+ answer = self.process_text_local(message, "codegemma:2b")
+ elif model == 5:
+ answer = self.process_text_transformers(message, "meta-llama/Meta-Llama-3.1-8B")
+ else:
+ return "Invalid choice"
return answer
diff --git a/py/venv.sh b/py/venv.sh
new file mode 100644
index 0000000..4a3be2f
--- /dev/null
+++ b/py/venv.sh
@@ -0,0 +1,5 @@
+#!/bin/bash
+
+virtualenv venv
+source venv/bin/activate
+pip install transformers