diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000000000000000000000000000000000000..0c339c36a638ddc58ba2c2cfcc33d9b1a3b97731
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,3 @@
+**/__pycache__/
+**/build/
+**/dist/
\ No newline at end of file
diff --git a/.idea/Asyst_code.iml b/.idea/Asyst_code.iml
index c5de4eb4005d5f40bb0f5459cb4e94850bdfa2ff..3d9d0762b49f41c8e1d383398af87a4f9d1995b8 100644
--- a/.idea/Asyst_code.iml
+++ b/.idea/Asyst_code.iml
@@ -2,9 +2,10 @@
 <module type="PYTHON_MODULE" version="4">
   <component name="NewModuleRootManager">
     <content url="file://$MODULE_DIR$">
+      <excludeFolder url="file://$MODULE_DIR$/.venv" />
       <excludeFolder url="file://$MODULE_DIR$/venv" />
     </content>
-    <orderEntry type="jdk" jdkName="Python 3.10 (Asyst_code)" jdkType="Python SDK" />
+    <orderEntry type="jdk" jdkName="Python 3.10 (ASYST)" jdkType="Python SDK" />
     <orderEntry type="sourceFolder" forTests="false" />
   </component>
 </module>
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
index aeb483921323486ab6e4a356a05cafb855de0ee1..e91440885d1535ea0f872c88bf2a2851ab35549a 100644
--- a/.idea/misc.xml
+++ b/.idea/misc.xml
@@ -3,7 +3,7 @@
   <component name="Black">
     <option name="sdkName" value="Python 3.8" />
   </component>
-  <component name="ProjectRootManager" version="2" project-jdk-name="Python 3.10 (Asyst_code)" project-jdk-type="Python SDK" />
+  <component name="ProjectRootManager" version="2" project-jdk-name="Python 3.10 (ASYST)" project-jdk-type="Python SDK" />
   <component name="PythonCompatibilityInspectionAdvertiser">
     <option name="version" value="3" />
   </component>
diff --git a/ASYST.exe b/ASYST.exe
index 36b1072d7d271f61261f0821dc19e5941cdf457c..3b623492466d5b5e41b86624b414d8d3da8ebfb6 100644
Binary files a/ASYST.exe and b/ASYST.exe differ
diff --git a/Source/Skript/german/run_LR_SBERT.py b/Source/Skript/german/run_LR_SBERT.py
index 6f3fd5ed57564160310c1e2c36c964bd58487aca..e7f302891bead5f20f69abaf4a5f07d687de8cf5 100644
--- a/Source/Skript/german/run_LR_SBERT.py
+++ b/Source/Skript/german/run_LR_SBERT.py
@@ -116,7 +116,7 @@ def main():
     # Y_test = np.array(dft['label'])
 
     # UP: read pre-trained LR model
-    clf_log = pickle.load(open(args.model_dir + "\\clf_BERT.pickle", "rb"))
+    clf_log = pickle.load(open(args.model_dir + "\\clf_BERT_SAF_DEEN_MiniLM.pickle", "rb"))
 
     # print('--------Evaluate on Testset------- ', file=out)
     predictions = clf_log.predict(X_test)
@@ -207,4 +207,8 @@ def main():
 
 
 if __name__ == "__main__":
+    if sys.stdout is None:
+        sys.stdout = open(os.devnull, "w")
+    if sys.stderr is None:
+        sys.stderr = open(os.devnull, "w")
     main()
diff --git a/Source/Skript/outputs/predictions.txt b/Source/Skript/outputs/predictions.txt
index 6f43d618f8fbc1be3f94a8aad004af542152714f..f2c19831a0e1b43be0a595c6d9c1bb6c683f2738 100644
--- a/Source/Skript/outputs/predictions.txt
+++ b/Source/Skript/outputs/predictions.txt
@@ -1,17 +1,17 @@
 question	referenceAnswer	studentAnswer	suggested_grade	observed_grade
 Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung:	weil sich die Namen von Tags aus einzelnen XML Dateien überschneiden können.Deshlab qualifizierte Namen das bedeuteet dass die Namen sich auf einen Namenraum beziehen und der Namenraum ist als Attribut an Elemente gebunden.	correct	correct
 Warum möchten Sie bei der Objektserialisierung mit Hilfe von transient bzw. serialPersistentFields[] die Kontrolle darüber haben, welche Felder serialisiert werden?	Wenn das Objekt schützenswerte Information enthält wie z.B. Passwörter, müssen diese bei der Serialisierung ausgeschlossen werden, da sie sonst aus dem serialisierten Objekt problemlos auszulesen sind.  Außerdem gibt es Felder, die nicht serialisierbar sind (z.B. Sockets oder Threads). Diese Felder möchte man auch ausschließen.	Wenn Attribute mit transient markiert werden, dann werden sie bei der Serialisierung übersprungen. serialPersistentFields[] kann man die zu serialisierenden Attribute aufzählen	correct	incorrect
-Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung: 	Namensräume verknüft ein XML-Element mit einer Anwendung. Der Gültigkeitsbereich gilt für den Bereich mit dem Präfix versehenen Elemente und Attribute.	correct	correct
+Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung: 	Namensräume verknüft ein XML-Element mit einer Anwendung. Der Gültigkeitsbereich gilt für den Bereich mit dem Präfix versehenen Elemente und Attribute.	correct	incorrect
 Sie möchten ein protected-Feld und mehrere unimplementierte Methoden vererben. Benutzen Sie eine Schnittstelle oder eine abstrakte Klasse? Warum?	abstrakte Klasse.  Schnittstellen können nur Konstanten vererben, abstrakte Klassen vererben Felder. alternativ: abstrakte Klassen vererben unimplementierte Methoden	ich würde eine abstrakte Klasse benutzen, weil die Schinttstellen können nur Konstanten haben.	correct	correct
-Warum braucht man bei der Arbeit mit Threads Synchronisation?	Man muss vermeiden, dass verschiedene Threads gleichzeitig auf Daten oder Objekte zugreifen, weil es dadurch zur Zerstörung von Werten und zu inkonsistenten Zuständen kommen kann.	Wenn zwei oder mehrere parallel laufende Threads dasselbe Objekt ansprechen, kann es zu Problemem kommen, da beide gleichzeitig das Objekt ändern. Deswegen benutzt man Monitore, wobei die dazugehörigen Objekte in ein Monitor eingeschlossen werden. Eingekapselt werden kritische Abschnitte.	incorrect	incorrect
-Wie wird bei Methodenschablonen ermittelt, welchen konkreten Typ T zur Laufzeit annimmt? Wie wird dies bei Klassenschablonen ermittelt?	Bei Methodenschablonen wird T aus den angegebenen Parametern abgeleitet (deshalb muss T als einer der Parametertypen vorliegen). Wenn die Parameter nicht den gleichen Typ haben, wird T als der unterste gemeinsame Muttertyp in der Ableitungshierarchie gewählt. Bei Klassenschablonen wird beim Erstellen eines neuen Objekts die Typinstanziierung angegeben.	Bei der instanzierung. Die in der Klammer verwendeten Typen.	incorrect	correct
+Warum braucht man bei der Arbeit mit Threads Synchronisation?	Man muss vermeiden, dass verschiedene Threads gleichzeitig auf Daten oder Objekte zugreifen, weil es dadurch zur Zerstörung von Werten und zu inkonsistenten Zuständen kommen kann.	Wenn zwei oder mehrere parallel laufende Threads dasselbe Objekt ansprechen, kann es zu Problemem kommen, da beide gleichzeitig das Objekt ändern. Deswegen benutzt man Monitore, wobei die dazugehörigen Objekte in ein Monitor eingeschlossen werden. Eingekapselt werden kritische Abschnitte.	incorrect	correct
+Wie wird bei Methodenschablonen ermittelt, welchen konkreten Typ T zur Laufzeit annimmt? Wie wird dies bei Klassenschablonen ermittelt?	Bei Methodenschablonen wird T aus den angegebenen Parametern abgeleitet (deshalb muss T als einer der Parametertypen vorliegen). Wenn die Parameter nicht den gleichen Typ haben, wird T als der unterste gemeinsame Muttertyp in der Ableitungshierarchie gewählt. Bei Klassenschablonen wird beim Erstellen eines neuen Objekts die Typinstanziierung angegeben.	Bei der instanzierung. Die in der Klammer verwendeten Typen.	correct	incorrect
 Warum können verschiedene Instanzen von Enumerationstypen in switch-case-Konstrukten genutzt werden?	Weil es von jedem Objekt nur eine Instanz gibt, so dass == mit equals() identisch ist.	Weil die Enumerationstypen stets public, final und static sind.	incorrect	incorrect
-Wie bestimmen Sie bei einem XML-Dokument Gültigkeit und Wohlgeformtheit? Kann eines ohne das andere vorkommen?	Wohlgeformtheit bestimmt sich aus den Syntaxvorschriften für XML-Dokumente (z.B. müssen alle Tags geschlossen werden, es darf nur ein Wurzelelement geben, reservierte Zeichen müssen vermieden werden). Gültigkeit liegt vor, wenn das XML-Dokument darüber hinaus der Elementdefinition aus der DTD entspricht. Ein XML-Dokument kann wohlgeformt sein, ohne gültig zu sein, aber zur Gültigkeit ist die Wohlgeformtheit Voraussetzung. Alternativ: Dokumente werden mit ""validate"" auf Gültigkeit und Wohlgeformtheit geprüft	Ein XML Dokument muss einen internen und externen DTD enthalten. Die DTD-Datei beschreibt die Struktur. Diese muss gut geformt sein. Eine XML Datei kann ohne DTD nicht vorkommen, denn dann ist Struktur nicht wohlgeformt.	incorrect	incorrect
-In einer Swing-Demo ändert sich beim Klick auf einen Button der Text auf dem Button. Wie sieht der mehrschrittige Ablauf hinter den Kulissen aus?	Der Klick auf den Button erzeugt ein ActionEvent. Das ActionEvent wird von einem Listener aufgefangen, der beim Button registriert ist. Dieser Listener führt daraufhin seinen Code aus, der den Text ändert.	es wird mit einer actionEvent erzeugt	incorrect	correct
+Wie bestimmen Sie bei einem XML-Dokument Gültigkeit und Wohlgeformtheit? Kann eines ohne das andere vorkommen?	Wohlgeformtheit bestimmt sich aus den Syntaxvorschriften für XML-Dokumente (z.B. müssen alle Tags geschlossen werden, es darf nur ein Wurzelelement geben, reservierte Zeichen müssen vermieden werden). Gültigkeit liegt vor, wenn das XML-Dokument darüber hinaus der Elementdefinition aus der DTD entspricht. Ein XML-Dokument kann wohlgeformt sein, ohne gültig zu sein, aber zur Gültigkeit ist die Wohlgeformtheit Voraussetzung. Alternativ: Dokumente werden mit ""validate"" auf Gültigkeit und Wohlgeformtheit geprüft	Ein XML Dokument muss einen internen und externen DTD enthalten. Die DTD-Datei beschreibt die Struktur. Diese muss gut geformt sein. Eine XML Datei kann ohne DTD nicht vorkommen, denn dann ist Struktur nicht wohlgeformt.	correct	incorrect
+In einer Swing-Demo ändert sich beim Klick auf einen Button der Text auf dem Button. Wie sieht der mehrschrittige Ablauf hinter den Kulissen aus?	Der Klick auf den Button erzeugt ein ActionEvent. Das ActionEvent wird von einem Listener aufgefangen, der beim Button registriert ist. Dieser Listener führt daraufhin seinen Code aus, der den Text ändert.	es wird mit einer actionEvent erzeugt	correct	incorrect
 
-Classification Report:
+Classification Report - high Precision for classes correct or incorrect indicates that the class prediction is reliable:
 	 precision 	 recall 	 f1-score 	 support
-correct	0.75	0.60	0.67	5
-incorrect	0.60	0.75	0.67	4
-accuracy			0.67	9
-weighted avg	0.68	0.67	0.67	9
\ No newline at end of file
+correct	0.29	0.67	0.40	3
+incorrect	0.50	0.17	0.25	6
+accuracy			0.33	9
+weighted avg	0.43	0.33	0.30	9
\ No newline at end of file
diff --git a/Source/Skript/outputs/test.tsv b/Source/Skript/outputs/test.tsv
index 70965c74870201cb17f5281a842d5a837e84cf64..8cbfadfafa618cdd015a401b4a5bac09557c7463 100644
--- a/Source/Skript/outputs/test.tsv
+++ b/Source/Skript/outputs/test.tsv
@@ -1,10 +1,10 @@
 question	referenceAnswer	studentAnswer	observed grade
 Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung:	weil sich die Namen von Tags aus einzelnen XML Dateien überschneiden können.Deshlab qualifizierte Namen das bedeuteet dass die Namen sich auf einen Namenraum beziehen und der Namenraum ist als Attribut an Elemente gebunden.	correct
 Warum möchten Sie bei der Objektserialisierung mit Hilfe von transient bzw. serialPersistentFields[] die Kontrolle darüber haben, welche Felder serialisiert werden?	Wenn das Objekt schützenswerte Information enthält wie z.B. Passwörter, müssen diese bei der Serialisierung ausgeschlossen werden, da sie sonst aus dem serialisierten Objekt problemlos auszulesen sind.  Außerdem gibt es Felder, die nicht serialisierbar sind (z.B. Sockets oder Threads). Diese Felder möchte man auch ausschließen.	Wenn Attribute mit transient markiert werden, dann werden sie bei der Serialisierung übersprungen. serialPersistentFields[] kann man die zu serialisierenden Attribute aufzählen	incorrect
-Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung: 	Namensräume verknüft ein XML-Element mit einer Anwendung. Der Gültigkeitsbereich gilt für den Bereich mit dem Präfix versehenen Elemente und Attribute.	correct
+Warum braucht man für XML-Tags Namensräume?	Da jeder Benutzer frei XML-Tags definieren kann, kann es passieren, dass dasselbe Tag in mehreren Dokumenten vorkommt und jeweils eine unterschiedliche Bedeutung hat. Namensräume sorgen dafür, dass diese unterschiedlichen Bedeutungen eindeutig auseinandergehalten werden können, indem die Tags qualifiziert werden. Namensräume verknüpfen Tags mit einer Anwendung: 	Namensräume verknüft ein XML-Element mit einer Anwendung. Der Gültigkeitsbereich gilt für den Bereich mit dem Präfix versehenen Elemente und Attribute.	incorrect
 Sie möchten ein protected-Feld und mehrere unimplementierte Methoden vererben. Benutzen Sie eine Schnittstelle oder eine abstrakte Klasse? Warum?	abstrakte Klasse.  Schnittstellen können nur Konstanten vererben, abstrakte Klassen vererben Felder. alternativ: abstrakte Klassen vererben unimplementierte Methoden	ich würde eine abstrakte Klasse benutzen, weil die Schinttstellen können nur Konstanten haben.	correct
-Warum braucht man bei der Arbeit mit Threads Synchronisation?	Man muss vermeiden, dass verschiedene Threads gleichzeitig auf Daten oder Objekte zugreifen, weil es dadurch zur Zerstörung von Werten und zu inkonsistenten Zuständen kommen kann.	Wenn zwei oder mehrere parallel laufende Threads dasselbe Objekt ansprechen, kann es zu Problemem kommen, da beide gleichzeitig das Objekt ändern. Deswegen benutzt man Monitore, wobei die dazugehörigen Objekte in ein Monitor eingeschlossen werden. Eingekapselt werden kritische Abschnitte.	incorrect
-Wie wird bei Methodenschablonen ermittelt, welchen konkreten Typ T zur Laufzeit annimmt? Wie wird dies bei Klassenschablonen ermittelt?	Bei Methodenschablonen wird T aus den angegebenen Parametern abgeleitet (deshalb muss T als einer der Parametertypen vorliegen). Wenn die Parameter nicht den gleichen Typ haben, wird T als der unterste gemeinsame Muttertyp in der Ableitungshierarchie gewählt. Bei Klassenschablonen wird beim Erstellen eines neuen Objekts die Typinstanziierung angegeben.	Bei der instanzierung. Die in der Klammer verwendeten Typen.	correct
+Warum braucht man bei der Arbeit mit Threads Synchronisation?	Man muss vermeiden, dass verschiedene Threads gleichzeitig auf Daten oder Objekte zugreifen, weil es dadurch zur Zerstörung von Werten und zu inkonsistenten Zuständen kommen kann.	Wenn zwei oder mehrere parallel laufende Threads dasselbe Objekt ansprechen, kann es zu Problemem kommen, da beide gleichzeitig das Objekt ändern. Deswegen benutzt man Monitore, wobei die dazugehörigen Objekte in ein Monitor eingeschlossen werden. Eingekapselt werden kritische Abschnitte.	correct
+Wie wird bei Methodenschablonen ermittelt, welchen konkreten Typ T zur Laufzeit annimmt? Wie wird dies bei Klassenschablonen ermittelt?	Bei Methodenschablonen wird T aus den angegebenen Parametern abgeleitet (deshalb muss T als einer der Parametertypen vorliegen). Wenn die Parameter nicht den gleichen Typ haben, wird T als der unterste gemeinsame Muttertyp in der Ableitungshierarchie gewählt. Bei Klassenschablonen wird beim Erstellen eines neuen Objekts die Typinstanziierung angegeben.	Bei der instanzierung. Die in der Klammer verwendeten Typen.	incorrect
 Warum können verschiedene Instanzen von Enumerationstypen in switch-case-Konstrukten genutzt werden?	Weil es von jedem Objekt nur eine Instanz gibt, so dass == mit equals() identisch ist.	Weil die Enumerationstypen stets public, final und static sind.	incorrect
 Wie bestimmen Sie bei einem XML-Dokument Gültigkeit und Wohlgeformtheit? Kann eines ohne das andere vorkommen?	Wohlgeformtheit bestimmt sich aus den Syntaxvorschriften für XML-Dokumente (z.B. müssen alle Tags geschlossen werden, es darf nur ein Wurzelelement geben, reservierte Zeichen müssen vermieden werden). Gültigkeit liegt vor, wenn das XML-Dokument darüber hinaus der Elementdefinition aus der DTD entspricht. Ein XML-Dokument kann wohlgeformt sein, ohne gültig zu sein, aber zur Gültigkeit ist die Wohlgeformtheit Voraussetzung. Alternativ: Dokumente werden mit ""validate"" auf Gültigkeit und Wohlgeformtheit geprüft	Ein XML Dokument muss einen internen und externen DTD enthalten. Die DTD-Datei beschreibt die Struktur. Diese muss gut geformt sein. Eine XML Datei kann ohne DTD nicht vorkommen, denn dann ist Struktur nicht wohlgeformt.	incorrect
-In einer Swing-Demo ändert sich beim Klick auf einen Button der Text auf dem Button. Wie sieht der mehrschrittige Ablauf hinter den Kulissen aus?	Der Klick auf den Button erzeugt ein ActionEvent. Das ActionEvent wird von einem Listener aufgefangen, der beim Button registriert ist. Dieser Listener führt daraufhin seinen Code aus, der den Text ändert.	es wird mit einer actionEvent erzeugt	correct
+In einer Swing-Demo ändert sich beim Klick auf einen Button der Text auf dem Button. Wie sieht der mehrschrittige Ablauf hinter den Kulissen aus?	Der Klick auf den Button erzeugt ein ActionEvent. Das ActionEvent wird von einem Listener aufgefangen, der beim Button registriert ist. Dieser Listener führt daraufhin seinen Code aus, der den Text ändert.	es wird mit einer actionEvent erzeugt	incorrect
diff --git a/Source/hook_stdout.py b/Source/hook_stdout.py
new file mode 100644
index 0000000000000000000000000000000000000000..bc2884335003d58e5aebc9ba5c4f6d868cc9db21
--- /dev/null
+++ b/Source/hook_stdout.py
@@ -0,0 +1,7 @@
+import sys
+import os
+
+if sys.stdout is None:
+    sys.stdout = open(os.devnull, "w")
+if sys.stderr is None:
+    sys.stderr = open(os.devnull, "w")
\ No newline at end of file
diff --git a/Source/main.py b/Source/main.py
index fb4df26612af61ef54dc4f317accc62a040da19f..c572e5e4d0de7571109b7dd9a646b97f3a37f344 100644
--- a/Source/main.py
+++ b/Source/main.py
@@ -16,11 +16,11 @@ import tkinter
 import pandas as pd
 import sys
 import os
-from sklearn.metrics import f1_score
-from matplotlib import pyplot as plt
-from sklearn.metrics import confusion_matrix, classification_report
-import seaborn as sns
-from Skript.english.run_SAG_mnli import main as english_backend
+#from sklearn.metrics import f1_score
+#from matplotlib import pyplot as plt
+#from sklearn.metrics import confusion_matrix, classification_report
+#import seaborn as sns
+# from Skript.english.run_SAG_mnli import main as english_backend
 from Skript.german.run_LR_SBERT import main as german_backend
 
 
@@ -34,8 +34,11 @@ class App(ttk.Frame):
             self.columnconfigure(index=index, weight=1)
             self.rowconfigure(index=index, weight=1)
 
-        # Create value list
-        self.combo_list = ["Choose language of input data", "English", "German"]
+        # # # Create value list
+        # self.combo_list = ["Choose language of input data", "English", "German"]
+
+        #Create a label
+        self.label = tk.Label(root, text="Please upload an Excel file:", font=("Arial", 12, "bold"))
 
         # Create a Frame for input widgets
         self.widgets_frame = ttk.Frame(self)
@@ -249,18 +252,19 @@ class App(ttk.Frame):
             root.update()
 
             # start the correct backend pipeline
-            if self.combobox.get() == 'English':
-                showinfo(
-                    title="Information",
-                    message="Generating grade suggestions for English student answers. This may take a little while.")
-                # run English backend
-                english_backend()
-            elif self.combobox.get() == 'German':
-                showinfo(
-                    title="Information",
-                    message="Generating grade suggestions for German student answers. This may take a little while.")
-                # run German/multilingual backend
-                german_backend()
+            # if self.combobox.get() == 'English':
+            #     showinfo(
+            #         title="Information",
+            #         message="Generating grade suggestions for English student answers. This may take a little while.")
+            #     # run English backend
+            #     english_backend()
+            # elif self.combobox.get() == 'German':
+            #     showinfo(
+            #         title="Information",
+            #         message="Generating grade suggestions for German student answers. This may take a little while.")
+            #     # run German/multilingual backend
+            #     german_backend()
+            german_backend()
 
             self.button1.config(state=NORMAL)
             self.button2.config(state=NORMAL)
@@ -269,26 +273,28 @@ class App(ttk.Frame):
             # Evaluation window
             open_new_window()
 
-        self.button2 = ttk.Button(self.widgets_frame, text="Input file", command=import_csv_data, state=DISABLED)
+        self.button2 = ttk.Button(self.widgets_frame, text="Input file", command=import_csv_data, state="normal")
         self.button2.grid(row=9, column=0, padx=5, pady=10, sticky="nsew")
 
         # select language, "Choose language" as default
-        self.combobox = ttk.Combobox(
-            self.widgets_frame, values=self.combo_list)
-        self.combobox.current(0)
-        self.combobox.grid(row=5, column=0, padx=5, pady=10, sticky="ew")
+        # self.combobox = ttk.Combobox(
+        #     self.widgets_frame, values=self.combo_list)
+        # self.combobox.current(0)
+        # self.combobox.grid(row=5, column=0, padx=5, pady=10, sticky="ew")
+        self.label = tk.Label(self.widgets_frame, text="Please upload an Excel file:", font=("Arial", 12, "bold"))
+        self.label.grid(row=5, column=0, padx=5, pady=10, sticky="w")
 
         # set state for button2("Input"-button) and if 'Spanish' is chosen in the combobox disable both buttons
-        def set_buttons_state(event):
-            self.button2.config(state="normal")
+        # def set_buttons_state(event):
+        #     self.button2.config(state="normal")
             # print('State changed')
-            if self.combobox.get() == 'Spanish':
-                showwarning(title="Information", message="Not available")
-                self.button1.config(state="disabled")
-                self.button2.config(state="disabled")
+            # if self.combobox.get() == 'Spanish':
+            #     showwarning(title="Information", message="Not available")
+            #     self.button1.config(state="disabled")
+            #     self.button2.config(state="disabled")
 
         # get events from changing combobox
-        self.combobox.bind('<<ComboboxSelected>>', set_buttons_state)
+        # self.combobox.bind('<<ComboboxSelected>>', set_buttons_state)
 
         self.button1 = ttk.Button(self.widgets_frame, text="Start",
                                   command=start_progress,
@@ -311,6 +317,8 @@ def resource_path(relative_path):
 class NullWriter:
     def write(self, data):
         pass
+    def flush(self):
+        pass
 
 
 if __name__ == "__main__":
@@ -323,6 +331,10 @@ if __name__ == "__main__":
 
     if sys.stderr is None:
         sys.stderr = NullWriter()
+    # if sys.stdout is None:
+    #     sys.stdout = open(os.devnull, "w")
+    # if sys.stderr is None:
+    #     sys.stderr = open(os.devnull, "w")
 
     root = tk.Tk()
     root.title("ASYST")
diff --git a/Source/main.spec b/Source/main.spec
index 162b882a594e786b723fa3b00d1c67341e555779..4dbbb1c7967ff78dd110139472f8138ac2429150 100644
--- a/Source/main.spec
+++ b/Source/main.spec
@@ -37,11 +37,12 @@ datas +=[('azure.tcl', '.'),
 ('.\\Skript','./Skript')]
 
 a = Analysis(
-    ['.\\main.py','.\\Skript\\german\\run_LR_SBERT.py','.\\Skript\\english\\run_SAG_mnli.py', ],
+#    ['.\\main.py','.\\Skript\\german\\run_LR_SBERT.py','.\\Skript\\english\\run_SAG_mnli.py', ],
+    ['.\\main.py','.\\Skript\\german\\run_LR_SBERT.py', ],
 # Hier den Pfad zu den site-packages (entweder des environments oder der zentralen Installation) angeben
     pathex=[
-    #'..\\venv\\Lib\\site-packages\\',
-    'C:\\Users\\ulrike\\AppData\\Local\\Programs\\Python\\Python310\\Lib\\site-packages',
+    '..\\venv\\Lib\\site-packages\\',
+#    'C:\\Users\\kaifm\\AppData\\Local\\Programs\\Python\\Python310\\Lib\\site-packages',
     '.\\Skript\\'
      ],
     binaries=[],
@@ -64,7 +65,7 @@ a = Analysis(
     'numpy'],
     hookspath=[],
     hooksconfig={},
-    runtime_hooks=[],
+    runtime_hooks=['.\\hook_stdout.py'],
     excludes=[],
     win_no_prefer_redirects=False,
     win_private_assemblies=False,