File size: 57,254 Bytes
216cc08
c982048
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ae80635
 
 
 
 
7af4a46
ae80635
9e0beed
 
 
ae80635
 
04baae5
 
ae80635
 
04baae5
e3c69e8
04baae5
 
 
 
 
 
 
 
0d50187
e80ae2e
 
 
0d50187
 
 
 
 
 
 
 
895cb38
6aa3c0c
e3c69e8
 
 
895cb38
63b25fa
3ab3bd7
895cb38
0d67e8d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6aa3c0c
895cb38
 
 
 
 
fd68eee
895cb38
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
fd68eee
895cb38
 
 
6aa3c0c
 
895cb38
9afdf10
cd17dbe
9afdf10
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6aa3c0c
 
cd17dbe
 
 
 
 
 
 
6aa3c0c
cd17dbe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6aa3c0c
cd17dbe
6aa3c0c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
216cc08
 
 
 
 
 
 
 
 
0b848ed
216cc08
 
 
 
 
 
 
 
 
 
 
 
 
 
133e695
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
216cc08
 
 
17574a3
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e3c69e8
0d50187
 
04baae5
 
 
 
ae80635
 
 
c982048
9e0beed
7af4a46
 
f8522bf
bf2e735
9e0beed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
f8522bf
9e0beed
 
 
52d4f49
145f602
9e0beed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
491411e
9e0beed
 
 
 
 
 
 
 
 
 
491411e
9e0beed
 
 
 
 
 
491411e
9e0beed
 
 
 
 
 
 
 
 
 
 
491411e
 
 
 
9e0beed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
f4b9e89
9e0beed
 
 
 
 
ecb159f
9e0beed
3aacff9
9e0beed
 
 
 
 
 
 
 
e3988ad
9e0beed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
0d66011
 
 
 
 
9e0beed
691afb3
bef78e8
9e0beed
 
 
 
 
 
b0eadb4
0d66011
 
 
 
 
 
 
b0eadb4
9e0beed
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e3988ad
9e0beed
 
e3988ad
4465bf6
 
9e0beed
 
 
 
 
4465bf6
 
 
9e0beed
e3988ad
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1841fe3
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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
182
183
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
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
# NonToxicGlazeAdvisor_Chat_with_Docs_Groq_Edition_1 - app.py - 05-04-2024

# STREAMLIT:
# https://www.datacamp.com/tutorial/streamlit:
#
# st.title(): This function allows you to add the title of the app. 
# st.header(): This function is used to set header of a section. 
# st.markdown(): This function is used to set a markdown of a section. 
# st.subheader(): This function is used to set sub-header of a section. 
# st.caption(): This function is used to write caption. 
# st.code(): This function is used to set a code. 
# st.latex(): This function is used to display mathematical expressions formatted as LaTeX.
# 
# st.title ("this is the app title")
# st.header("this is the header ")
# st.markdown("this is the markdown")
# st.subheader("this is the subheader")
# st.caption("this is the caption")
# st.code("x=2021")
# st.latex(r''' a+a r^1+a r^2+a r^3 ''')


# ========================================================================
# TABS
# 03-04-2024
import streamlit as st

tab1, tab2, tab3 = st.tabs(["AI Adviseur voor niet-giftige glazuren", "Uitleg", "Voorbeeld vragen"])

#with tab1:
#   st.header("A cat")
#   st.image("https://static.streamlit.io/examples/cat.jpg", width=200)

with tab2:
    st.header("Uitleg")
    st.image("De fritte oven - een schets van het proces.jpg", width=200)

with tab3:
    st.header("Voorbeeld vragen")
    st.write("De fritte oven - een schets van het proces:")
    st.image("De fritte oven - een schets van het proces.jpg", width=200)

    # https://docs.streamlit.io/library/api-reference/widgets/st.text_area
    # st.text_area
    # Streamlit Version -Version 1.32.0
    # Display a multi-line text input widget.


    # txt = st.text_area() # is voor text input !
    # st.header('This is a header with a divider', divider='rainbow')
    st.header('Hier alvast een klein aantal voorbeeldvragen die je aan deze AI adviseur voor niet-giftige glazuren zou kunnen stellen:', divider='rainbow')
    # st.write("**Hier alvast een klein aantal voorbeeldvragen die je aan deze AI adviseur voor niet-giftige glazuren zou kunnen stellen:**")
    st.write("\n")
    st.write("Hoe kan ik thuis als hobby keramiek maken? Geef het antwoord uitsluitend en alleen in de Nederlands taal  ")
    st.write("Geef een samenvatting in 10 zinnen. ")
    st.write("Geef een samenvatting in 25 bullet points. ")
    st.write("Geef een samenvatting in 25 bullet points. Geef het antwoord uitsluitend en alleen in de Nederlandse taal. ")
    st.write("Geef een samenvatting in 25 bullet points. Geef het antwoord uitsluitend en alleen in de Duitse taal. ")
    st.write("Explain glazing techniques to me as if I am 10 years old. ")
    st.write("Geef me uitleg over glazuurtechnieken alsof ik 5 jaar oud ben. Geef het antwoord uitsluitend en alleen in de Nederlandse taal.")

    st.write(" ---------------------------------------------------------------- ")

    st.header('Voorbeeldvragen met voorbeeldantwoorden die je aan deze AI adviseur voor niet-giftige glazuren zou kunnen stellen:', divider='rainbow')

    st.write("Wie ben ik? (selecteer als taal Nederlands)\n")
    st.write("assistant avatar:")
    st.write("Gezien de tekst is het waarschijnlijk dat u heer Victor Benckhuijsen bent. U bent iemand die ervaring heeft opgedaan met het maken van glazuren voor keramiek, met name alkalische fritten. U heeft deze ervaring opgedaan op verschillende plekken, zoals de kunstacademie, de agrarische hogeschool en de geologie en bodemkunde. U benadrukt de waarden van veiligheid en het belang van het gebruik van non-giftige materialen. U verkoopt geen recepten, maar verstrekt wel veiligheidsattesten op verzoek. U benadrukt ook de voordelen van het gebruik van industriële fritten voor hobbyisten, omdat dit een veilige en eenvoudige manier is om non-giftige keramische glazuren te maken.")

    st.write(" ---------------------------------------------------------------- ")

    st.write("Wat is een magisch vierkant?  (selecteer als taal Nederlands)\n")
    st.write("assistant avatar:")
    st.write("""
    In het gegeven context is geen enkele melding te vinden van een "magisch vierkant". Dus, in overeenstemming met het verzoek om een antwoord te baseren uitsluitend op de gegeven context, is mijn antwoord: Er is geen informatie over een "magisch vierkant" in de opgegeven tekst.""")

    st.write(" ---------------------------------------------------------------- ")

    st.write("Wat is een magisch vierkant? Geef ook antwoord, ook al staat dat antwoord niet in je huidige context van pdf files! (selecteer als taal Nederlands)\n")
    st.write("assistant avatar:")
    st.write("""
    In deze context wordt geen vermelding gemaakt van een magisch vierkant. Een magisch vierkant is een vierkante matrix waarbij de som van de getallen in elke rij, elke kolom en elke diagonaal gelijk is aan een vastgesteld getal, de magische constante. Het is dus onafhankelijk van de opgegeven context.

Voorbeeld van een magisch vierkant van orde 3 (dus 3 bij 3 matrix) met magische constante 15:

5 12 8

(MERK OP DAT DIT LAATSTE VOORBEELD VAN EEN MAGISCH VIERKANT WELISWAAR FOUT IS, 
MAAR DE AI GEEFT EERST WEL DEGELIJK EEN UITLEG VAN WAT EEN MAGISCH VIERKANT IS,
OMDAT WE DE AI IN ONZE VRAAG UITDRUKKELIJK HEBBEN OPGEDRAGEN OM HET ANTWOORD OOK BUITEN DE GEGEVEN CONTEXT VAN PDF's TE GAAN ZOEKEN.
DAT ANTWOORD KAN DE AI NU GEVEN, OMDAT DE AI INTERN ZELF OVER ALGEMENE WERELD KENNIS BESCHIKT !!!!!)
""")

    
    st.write(" ---------------------------------------------------------------- ")

    st.header('Geavanceerde voorbeeldvragen met voorbeeldantwoorden die je aan deze AI adviseur voor niet-giftige glazuren zou kunnen stellen:', divider='rainbow')

    st.write("Formulate 10 diverse hypotheses related to the context and then find arguments that support and refute these hypotheses  (selecteer als taal Engels)\n")
    st.write("assistant avatar:")
    st.write("""Formulate 10 diverse hypotheses related to the context and then find arguments that support and refute these hypotheses 


RESPONSE :

Response time: 0.42764801399999897 seconds

Hypothesis 1: The use of the Seger formula for representing the chemical structure of glazes in ceramics is a more accurate and reliable method than previous methods.

Argument for: The Seger formula represents the chemical structure of glazes in a way that is consistent with the periodic table, dividing the components into three categories: melting point depressants, amphoteric metals, and fusible metals. This systematic approach allows ceramicists to better understand the relationships between different components and their effects on the final product.

Argument against: While the Seger formula provides a systematic approach, it may not account for all the complexities and subtleties of ceramic glaze formulations. Other factors, such as particle size, impurities, and firing conditions, can also significantly impact the final product.


Hypothesis 2: The addition of Zirkoonsilicaat to a glaze recipe can result in a wider range of pastel colors.

Argument for: Zirkoonsilicaat has been identified as a component that can create pastel colors when added to a glaze recipe. This is because it can act as an opacifier, modifying the way light interacts with the glaze and leading to softer, pastel shades.

Argument against: The addition of Zirkoonsilicaat may also have unintended consequences, such as altering the viscosity or melting point of the glaze, which could impact its overall appearance and performance.


Hypothesis 3: The use of "gefritte" ceramic color pigments can result in more vibrant and consistent colors.

Argument for: "Gefritte" ceramic color pigments are created through a process of heating and cooling, which can result in more consistent and vibrant colors than other pigment types. This is because the heating and cooling process can help to ensure that the pigment particles are evenly distributed throughout the glaze.

Argument against: The use of "gefritte" pigments may not be suitable for all types of ceramic glazes, as the heating and cooling process can also alter the properties of the glaze itself. Additionally, the cost of "gefritte" pigments may be higher than other pigment types.


Hypothesis 4: The practice of alchemy, as described in the context, was a precursor to modern scientific methods.

Argument for: The alchemists described in the context were engaged in a systematic process of experimentation and observation, using a combination of objective and subjective methods. This approach bears some similarities to modern scientific methods, which emphasize careful observation, experimentation, and the development of hypotheses.

Argument against: However, the alchemists' approach was also fundamentally different from modern scientific methods in that it was heavily influenced by spiritual and mystical beliefs. While the alchemists did engage in systematic observation and experimentation, they also placed a strong emphasis on the role of the individual alchemist's subjective experiences and intuitions.


Hypothesis 5: The division of alchemy into "materiële" and "geestelijke" paths was a result of the increasing specialization and professionalization of scientific inquiry.

Argument for: As scientific inquiry became more specialized and professionalized, it became increasingly difficult for individual researchers to maintain a holistic perspective that integrated both material and spiritual concerns. The division of alchemy into "materiële" and "geestelijke" paths may have been a response to this trend, allowing researchers to specialize in one area or the other.

Argument against: However, it is also possible that the division of alchemy into "materiële" and "geestelijke" paths was a result of broader cultural and philosophical trends, rather than simply a response to the professionalization of scientific inquiry.


Hypothesis 6: The Seger formula can be used to accurately predict the properties of a ceramic glaze based on its component parts.

Argument for: The Seger formula provides a systematic approach to understanding the relationships between different components of a ceramic glaze, which could potentially be used to predict the properties of the final product.

Argument against: However, the properties of ceramic glazes can be influenced by a wide range of factors, including particle size, impurities, and firing conditions. As a result, it may be difficult or impossible to accurately predict the properties of a ceramic glaze based solely on its component parts.


Hypothesis 7: The use of clay as a starting material for ceramic glazes is a result of its unique physical and chemical properties.

Argument for: Clay has a number of unique physical and chemical properties that make it well-suited for use in ceramic glazes. For example, clay is highly plastic, which means it can be easily shaped and molded. Additionally, clay undergoes a number of physical and chemical changes when heated, which can result in the formation of strong, durable ceramic materials.

Argument against: However, clay is not the only possible starting material for ceramic glazes. Other materials, such as silica or alumina, can also be used to create ceramic glazes with a wide range of properties.


Hypothesis 8: The practice of alchemy was primarily focused on the transformation of base metals into gold.

Argument for: The transformation of base metals into gold was a central goal of many alchemists, who believed that this transformation was a symbol of spiritual enlightenment and transformation.

Argument against: However, the practice of alchemy was not limited to the transformation of base metals into gold. Alchemists were also interested in a wide range of other topics, including medicine, pharmacology, and spirituality.


Hypothesis 9: The properties of ceramic glazes can be altered through the addition of various additives.

Argument for: The properties of ceramic glazes can be significantly altered through the addition of various additives, such as opacifiers, colorants, and fluxes. These additives can modify the way that light interacts with the glaze, as well as its melting point, viscosity, and other properties.

Argument against: However, the addition of additives can also introduce new challenges and complexities into the glaze-making process. For example, some additives may interact with other components of the glaze in unpredictable ways, leading to unexpected results.


Hypothesis 10: The practice of alchemy was primarily focused on the manipulation of physical materials.

Argument for: The practice of alchemy did involve the manipulation of physical materials, such as metals, minerals, and chemicals. Alchemists engaged in a wide range of experimental techniques, including heating, cooling, dissolving, and mixing, in order to transform these materials.

Argument against: However, the practice of alchemy was not limited to the manipulation of physical materials. Alchemists were also interested in spiritual and mystical concepts, such as the unity of matter and spirit, the transformation of the self, and the pursuit of enlightenment.""")


    
    st.write(" ---------------------------------------------------------------- ")


    st.write("""
    Formulate 10 diverse hypotheses related to the context and then find arguments that support and refute these hypotheses . Answer only in the Dutch language 

Response time: 0.5270816530000104 seconds

Hypothesis 1: De smeltpuntverlagers in de chemische structuurformule van een glazuur, zoals door Herman Seger voorgesteld, zijn gebaseerd op de indeling van het periodiek systeem.

Argumenten voor:
- De smeltpuntverlagers staan links in de formule, wat overeenkomt met de indeling van het periodiek systeem.
- De amfotere metalen staan in het midden, wat ook overeenkomt met de indeling van het periodiek systeem.

Argumenten tegen:
- Er is geen bewijs dat de smeltpuntverlagers werkelijk gebaseerd zijn op de indeling van het periodiek systeem.


Hypothesis 2: De basistoffen in de chemische structuurformule van een glazuur, zoals door Herman Seger voorgesteld, zijn gesorteerd op smeltpunt.

Argumenten voor:
- De smeltpuntverlagers staan links in de formule, en de basistoffen staan rechts ervan, wat suggereert dat deze gesorteerd zijn op smeltpunt.

Argumenten tegen:
- Er is geen bewijs dat de basistoffen gesorteerd zijn op smeltpunt.


Hypothesis 3: De kleuren van keramische kleurpigmenten zijn afhankelijk van de hoeveelheid SiO2 die eraan toegevoegd wordt.

Argumenten voor:
- De kleur van keramische kleurpigmenten verandert als er SiO2 aan toegevoegd wordt.

Argumenten tegen:
- Er zijn andere factoren die de kleur van keramische kleurpigmenten kunnen beïnvloeden, zoals de temperatuur en de tijd van het branden.


Hypothesis 4: De alchemisten probeerden naast wetenschappelijke experimenten ook spirituele vragen te beantwoorden.

Argumenten voor:
- De alchemisten hadden naast wetenschappelijke kennis ook een gebedsruimte en een oven in hun werkruimte.
- De alchemisten bestudeerden chemische veranderingen met meditatie en objectiviteit.

Argumenten tegen:
- Er is geen direct bewijs dat de alchemisten spirituele vragen probeerden te beantwoorden.


Hypothesis 5: De alchemie is onafhankelijk van natuurwetenschappen en religie.

Argumenten voor:
- De alchemie is een totaalbeeld dat zich onafhankelijk ontwikkeld heeft van natuurwetenschappen en religie.

Argumenten tegen:
- De alchemie is historisch gezien nauw verbonden met zowel natuurwetenschappen als religie.


Hypothesis 6: De belangstelling voor de alchemie is uitgedoofd.

Argumenten voor:
- De belangstelling voor de alchemie is afgenomen sinds de opdeling van de alchemistische wetenschap in een materieel en een geestelijk deel.

Argumenten tegen:
- Er zijn nog steeds mensen die geïnteresseerd zijn in de alchemie en haar totaalbeeld.


Hypothesis 7: De alchemisten zochten naar antwoorden op natuurfenomenen met experimenten.

Argumenten voor:
- De alchemisten probeerden veel uit en hadden naast wetenschappelijke kennis ook een gebedsruimte en een oven in hun werkruimte.

Argumenten tegen:
- Er is geen direct bewijs dat de alchemisten experimenten deden om antwoorden op natuurfenomenen te vinden.


Hypothesis 8: De alchemie is een vorm van mystiek.

Argumenten voor:
- De mystiek is historisch gezien uit de alchemie voortgekomen.

Argumenten tegen:
- De alchemie is een totaalbeeld dat zich ontwikkeld heeft in de richting van zowel materiële als geestelijke vragen.


Hypothesis 9: De alchemisten bestudeerden chemische veranderingen met meditatie en objectiviteit.

Argumenten voor:
- De alchemisten hadden een gebedsruimte en een oven in hun werkruimte en bestudeerden chemische veranderingen met meditatie en objectiviteit.

Argumenten tegen:
- Er is geen direct bewijs dat de alchemisten chemische veranderingen bestudeerden met meditatie en objectiviteit.


Hypothesis 10: De alchemisten hadden een gebedsruimte en een oven in hun werkruimte.
Argumenten voor:

- De alchemisten hadden naast wetenschappelijke kennis ook een gebedsruimte en een oven in hun werkruimte.

Argumenten tegen:
- Er is geen direct bewijs dat de alchemisten een gebedsruimte en een oven in hun werkruimte hadden.""")


    st.write(" ---------------------------------------------------------------- ")


    st.write("""
    Formulate 10 diverse hypotheses related to the context and then find arguments that support and refute these hypotheses and express your confidence in the given answers in a score between 0 and 1. Answer only the Dutch language .



Response time: 0.7786305489999847 seconds

Hypothesis 1: The use of Kaliveldspaat in the basisglazuur can lower the melting point of the glaze.

Support: The text states that Kaliveldspaat is added to the basisglazuur in a percentage of 5-10% to enable the glaze to be applied on earthenware. This implies that Kaliveldspaat can lower the melting point of the glaze, making it suitable for use on earthenware.

Refutation: The text does not provide specific information on the effect of Kaliveldspaat on the melting point of the glaze. However, it is mentioned that Kaliveldspaat is added to the basisglaze for earthenware, which suggests that it has a lower melting point.
Confidence score: 0.8


Hypothesis 2: Zirkoonsilicaat is used to create pastel colors in the glaze.

Support: The text states that Zirkoonsilicaat is added to the basisglaze in a percentage of 10% to enable the glaze to be written and mattered. It is also mentioned that it is used for creating pastel colors.

Refutation: The text does not provide specific information on how Zirkoonsilicaat creates pastel colors. However, it is mentioned that it is added to the basisglaze for this purpose.

Confidence score: 0.7


Hypothesis 3: The chemical structure of Quartz changes due to heating and erosion.

Support: The text states that the chemical structure of Quartz changes due to heating and erosion. It also mentions that the finest and most eroded form of Quartz on earth is clay.

Refutation: The text does not provide specific information on the mechanism of this change. However, it is mentioned that the chemical structure of Quartz changes due to heating and erosion.

Confidence score: 0.9


Hypothesis 4: The melting point of a glaze can be determined by the position of the oxides in the periodic table.

Support: The text describes a system for representing the chemical structure of a glaze, where the melting point regulators are placed on the left, the amphoteric metals in the middle, and the fusible metals on the right. This suggests that the position of the oxides in the periodic table can be used to determine the melting point of a glaze.

Refutation: The text does not provide specific information on how the position of the oxides in the periodic table can be used to determine the melting point of a glaze. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.6


Hypothesis 5: The glaze recipe is traditionally kept secret among potters.

Support: The text states that in the past, glaze recipes were not shared among potters due to competition.

Refutation: The text also states that this secrecy is no longer necessary due to the introduction of Hr. Seger's system for representing the chemical structure of a glaze.

Confidence score: 0.8


Hypothesis 6: The melting point of a glaze can be adjusted by adding certain oxides.

Support: The text describes a system for representing the chemical structure of a glaze, where the melting point regulators are placed on the left.

Refutation: The text does not provide specific information on how the melting point of a glaze can be adjusted by adding certain oxides. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.7


Hypothesis 7: The chemical structure of a glaze can be represented using the periodic table.

Support: The text describes a system for representing the chemical structure of a glaze, where the oxides are placed in the positions corresponding to their position in the periodic table.

Refutation: The text does not provide specific information on how the chemical structure of a glaze can be represented using the periodic table. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.7


Hypothesis 8: The melting point of a glaze can be determined by the position of the oxides in the system for representing the chemical structure of a glaze.

Support: The text describes a system for representing the chemical structure of a glaze, where the melting point regulators are placed on the left.

Refutation: The text does not provide specific information on how the melting point of a glaze can be determined by the position of the oxides in the system for representing the chemical structure of a glaze. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.6

Hypothesis 9: The chemical structure of a glaze can be represented using the periodic table and the system for representing the chemical structure of a glaze.

Support: The text describes a system for representing the chemical structure of a glaze, where the oxides are placed in the positions corresponding to their position in the periodic table.

Refutation: The text does not provide specific information on how the chemical structure of a glaze can be represented using the periodic table and the system for representing the chemical structure of a glaze. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.6


Hypothesis 10: The chemical structure of a glaze can be represented using the system for representing the chemical structure of a glaze and the position of the oxides in the periodic table.

Support: The text describes a system for representing the chemical structure of a glaze, where the oxides are placed in the positions corresponding to their position in the periodic table.

Refutation: The text does not provide specific information on how the chemical structure of a glaze can be represented using the system for representing the chemical structure of a glaze and the position of the oxides in the periodic table. However, it is mentioned that the chemical structure of a glaze can be represented in this way.

Confidence score: 0.6""")

    st.write(" ---------------------------------------------------------------- ")


    st.write("""
    Brainstorm a list of potentially useful text retrieval tasks.

Response time: 0.5215754939999897 seconds

Based on the provided context, here are some potential text retrieval tasks that could be useful:

1. Retrieve all instances where a specific element or compound is mentioned, such as "CaO" or "SiO2".
2. Find all instances where the concept of "smeltpunt" (melting point) is discussed.
3. Retrieve all instances where the Seger structuurformule or Segerkegels are mentioned.
4. Find all instances where the process of "gefrit" or "fritting" is explained.
5. Retrieve all instances where the dangers of certain substances in glazes are mentioned.
6. Find all instances where the concept of "amfotere metalen" (amphoteric metals) is discussed.
7. Retrieve all instances where the process of ontleding van mineralen (decomposition of minerals) is explained.
8. Find all instances where the use of keramische glazuren (ceramic glazes) is mentioned.
9. Retrieve all instances where the German chemist Hermann Seger is mentioned.
10. Find all instances where the concept of "smeltpuntverlaging" (lowering of the melting point) is discussed.""")

    st.write(" ---------------------------------------------------------------- ")

    st.write("""
    Brainstorm met mij in de Nederlandse taal over innovatieve toepassingen van glazuurtechnieken gegeven de context.

Response time: 0.5649652280000055 seconds

In het Nederlands:

Innovatieve toepassingen van glazuurtechnieken in de context van keramiek kunnen op verschillende manieren worden bekeken. Een interessante richting is het ontwikkelen van milieuvriendelijke en minder giftige glazuren. Prof. Dr. Hermann Seger's bijdrage aan de keramische industrie met zijn veilige basisglazuurrecepten is hier een goed voorbeeld van.

Een andere innovatieve richting is het combineren van traditionele keramische glazuurtechnieken met moderne technologie, zoals 3D-printtechnieken en sensorintegratie. Dit kan leiden tot unieke en praktische toepassingen, zoals intelligente keramische oppervlakken met temperatuur- of vochtigheidsgevoelige sensoren.

Een andere mogelijkheid is het ontwikkelen van glazuren met bijzondere optische eigenschappen, zoals warmte-reflecterende of doorschijnende glazuren voor architectonische toepassingen. Ook glazuren met antibacteriële of zelfreinigende eigenschappen zijn interessante innovatieve toepassingen.

Ten slotte kunnen keramische glazuren ook worden ontwikkeld met betrekking tot duurzame en circulaire productieproces. Bijvoorbeeld, glazuren met herbruikbare materialen of glazuren die het hergebruik van afvalproducten mogelijk maken.

In samenvatting, innovatieve toepassingen van keramische glazuurtechnieken kunnen zich richten op milieuvriendelijke en veiligere glazuren, moderne technologie integratie, unieke optische en functionele eigenschappen en circulaire productieproces.""")


    st.write(" ---------------------------------------------------------------- ")


    st.header('Filosofische voorbeeldvragen met voorbeeldantwoorden die je aan deze AI adviseur voor niet-giftige glazuren zou kunnen stellen:', divider='rainbow')

    
    st.write("""
    Schrijf een filosofisch essay over de glazuurkunst. Raak daarbij zoveel mogelijk filosofische verbanden aan

assistant avatar

In de wereld van de keramiek is het creëren van glazuren een kunstvorm die zich richt op het verkennen van materiaal, kleur en textuur. Het is een oud vak dat reeds duizenden jaren bestaat en zich ontwikkeld heeft tot een vorm van expressie die vergelijkbaar is met schilderen of beeldhouwen. Het filosofisch aspect van glazuren ligt in de combinatie van chemie, kunst en intuïtie die nodig is om unieke en mooie oppervlakken te creëren.

Als keramist begint men vaak met de traditionele recepten en technieken, maar al snel ontdekt men dat het mengen en aanpassen van deze recepten de kern is van de glazuurkunst. Het is een proces van experimenteren en observeren, waarbij men steeds beter begint te begrijpen hoe de verschillende materialen reageren op elkaar. Dit proces is vergelijkbaar met de filosofische opvatting van het leven als een reeks ervaringen die ons helpen om begrip en wijsheid te ontwikkelen.

Een belangrijke filosofische overweging bij het maken van glazuren is de relatie tussen toeval en controle. Hoewel er een chemische formule achter elk glazuurrecept zit, is het resultaat nooit helemaal voorspelbaar. De manier waarop het glazuur op het aardewerk aansluit, de kleur en de textuur die het creëert, zijn allemaal afhankelijk van vele factoren, zoals de temperatuur van de oven, de tijd dat het glazuur moet bakken en de samenstelling van het aardewerk zelf. Als keramist moet men leren om te werken met deze onzekerheden en te leren hoe men ze kan benutten om unieke en mooie resultaten te bereiken.

Een andere filosofische overweging is de relatie tussen de materie en de geest. Glazuren zijn een perfect voorbeeld van hoe materie en geest samenkomen om iets nieuws en unieks te creëren. De chemische formules en de materiële eigenschappen van de grondstoffen zijn de materie, maar het creatieve proces en de beslissingen die de keramist maakt tijdens het maken van het glazuur, zijn de geest. Het resultaat is een uniek en moois object dat zowel de materiële als de geestelijke aspecten van de mens vertegenwoordigt.

Ten slotte is de glazuurkunst ook een reflectie van de tijd en de cultuur. Glazuren zijn een manier om de geschiedenis en de cultuur van een bepaald gebied of periode weer te geven. De verschillende technieken, materialen en stijlen die gebruikt worden, zijn allemaal een reflectie van de tijd en de cultuur waarin ze gemaakt zijn. Als keramist maakt men deel uit van deze traditie en maakt men ook deel uit van de continuïteit van de glazuurkunst.

In deze zin is de glazuurkunst een filosofische praktijk die ons helpt om te reflecteren op de relatie tussen materie en geest, toeval en controle, en tijd en cultuur. Het is een kunstvorm die ons helpt om te begrijpen hoe we ons verhouden tot de wereld en hoe we ons kunnen uitdrukken in een manier die uniek en persoonlijk is.
    
    """)


    st.write("""
    MAAR JE KUNT OOK EEN IETS ANDER ANTWOORD KRIJGEN ALS JE DEZELFDE VRAAG NOGMAALS STELT! DE AI IS CREATIEF IN ZIJN ANTWOORDEN! :
    
In de wereld van de keramiek is het creëren van glazuren een kunstvorm die zich richt op het verkennen van materiaal, kleur en textuur. Het is een oud vak dat reeds duizenden jaren bestaat en dat ondanks de vooruitgang van technologie en wetenschap, zijn mysteries behoudt. Het proces van glazuren is een filosofisch avontuur dat ons leert over de natuurwetten, de schoonheid van toeval en de essentie van het maken.

Een filosofische kijk op de glazuurkunst brengt ons naar de kern van de materie. Glazuren zijn een mengsel van chemische stoffen die, wanneer verhit, samensmelten tot een glasachtige substantie. Deze substantie is transparant of doorschijnend, waardoor de kleur en structuur van de onderliggende klei zichtbaar blijft. Het is deze transparantie die de aandacht vestigt op de natuurlijke schoonheid van de materie en ons herinnert aan de essentie van het leven: alles is samengesteld uit elementaire deeltjes.

Het maken van glazuren is ook een spel met binaire reeksen, waarbij twee stoffen worden gemengd om de gewenste eigenschappen te verkrijgen. Dit proces vereist een diepe begrip van de chemische en fysische eigenschappen van de materialen en de manier waarop zij reageren op temperatuur en tijd. Het is een dans tussen wetenschap en kunst, waarbij de kunstenaar zich laat leiden door zijn intuïtie en ervaring.

Het specialisme in het glazuren is een "zijweg" die pas ontstaat na veel voorbereiding en oefening. Het is een pad dat leidt naar de geheimen van de materie en de kunst van het maken. Het is een pad dat ons leert over de natuurwetten en de schoonheid van toeval. Het is een pad dat ons herinnert aan de essentie van het leven: alles is samengesteld uit elementaire deeltjes.

In de wereld van de glazuurkunst is er geen einde aan de mogelijkheden en de ontdekkingen. Het is een vak dat ons leert over de natuurwetten, de schoonheid van toeval en de essentie van het maken. Het is een filosofisch avontuur dat ons inspireert om verder te zoeken en verder te leren. Het is een kunstvorm die ons herinnert aan de schoonheid van de materie en de essentie van het leven.
    
    """)

    st.write(" ---------------------------------------------------------------- ")


    st.write("""
    OF NOG WEER EEN ANDER FILOSOFISCH ANTWOORD:

    In de wereld van de keramiek is het creëren van glazuren een kunstvorm die zowel technisch als filosofisch kan worden benaderd. Het proces van glazuren is een spel met vele binaire reeksen, waarbij verschillende stoffen op systematische wijze met elkaar worden gemengd om de perfecte samenstelling te vinden. Dit is althans de technische kant van het verhaal.

Filosofisch gezien is het creëren van keramische glazuren een zoektocht naar harmonie en evenwicht tussen de elementen. Het is een manier om de natuur te observeren, te begrijpen en te imiteren. De samenstelling van de aarde, vuur en water spelen hierbij een cruciale rol. De aarde levert ons de grondstoffen, het vuur verandert deze grondstoffen in een vloeibare substantie en het water helpt bij het vormen van het glazuur.

Het mengen van de grondstoffen is vergelijkbaar met het mengen van kleuren op een palet van een schilder. Elke kleur heeft zijn eigen eigenschappen en effecten, en door ze te combineren ontstaan nieuwe kleuren en effecten. Het is een manier om de natuur te interpreteren en te hercréëren.

Het specialisme in het glazuren is een reis van voorbereiding, oefening en ontdekking. Het is een zijweg die pas na veel studie en praktijk kan worden bereikt. Het is een pad van zelfontdekking en zelfverwerkelijking. Het is een manier om de grenzen van de materie te testen en te verleggen.

Het creëren van keramische glazuren is ook een manier om de tijd te overwinnen. Het is een manier om de eeuwige cyclus van het leven en de dood te herdenken. Het vuur verandert de grondstoffen in een vloeibare substantie, maar als het afkoelt, verandert het weer in een vaste substantie. Het is een manier om de vergankelijkheid van het leven te herinneren en te eren.

In de wereld van de keramiek is het creëren van glazuren een kunstvorm die zowel technisch als filosofisch is. Het is een manier om de natuur te observeren, te begrijpen en te imiteren. Het is een manier om de grenzen van de materie te testen en te verleggen. Het is een manier om de vergankelijkheid van het leven te herinneren en te eren. Het is een manier om de grenzen van de creativiteit en de menselijke verbeeldingskracht te verkennen.
    
    """)
    
    st.write("(wordt vervolgd)")



    
    
# ========================================================================

    

with tab1:
    st.header("AI Adviseur voor niet-giftige glazuren")
    st.image("De fritte oven - een schets van het proces.jpg", width=200)

    
    # JB:
    # LangChainDeprecationWarning: Importing embeddings from langchain is deprecated. 
    # Importing from langchain will no longer be supported as of langchain==0.2.0.
    # Please import from langchain-community instead:
    # `from langchain_community.embeddings import FastEmbedEmbeddings`.
    # To install langchain-community run `pip install -U langchain-community`.
    from langchain_community.embeddings import FastEmbedEmbeddings

    import os
    import streamlit as st
    from langchain_groq import ChatGroq
    from langchain_community.document_loaders import WebBaseLoader
    # JB:
    from langchain_community.document_loaders import PyPDFLoader
    from langchain_community.embeddings import OllamaEmbeddings

    # JB:
    from langchain_community.embeddings import FastEmbedEmbeddings
    from langchain_community.document_loaders import PyPDFDirectoryLoader

    # JB:
    # File Directory
    # This covers how to load all documents in a directory.
    # Under the hood, by default this uses the UnstructuredLoader.
    from langchain_community.document_loaders import DirectoryLoader
    from langchain_community.document_loaders import TextLoader
    import chardet

    from langchain_community.vectorstores import FAISS
    # from langchain.vectorstores import Chroma
    # from langchain_community.vectorstores import Chroma

    from langchain.text_splitter import RecursiveCharacterTextSplitter
    from langchain.chains.combine_documents import create_stuff_documents_chain
    from langchain_core.prompts import ChatPromptTemplate
    from langchain.chains import create_retrieval_chain
    import time
    from dotenv import load_dotenv

    import glob

    load_dotenv()  #

    groq_api_key = os.environ['GROQ_API_KEY']
    # groq_api_key = "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" # os.environ['GROQ_API_KEY']
    # groq_api_key = "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" # JB OK 24-03-2024
    # print("groq_api_key: ", groq_api_key)

    # st.title("Chat with Docs - Groq Edition :) ")
    # # st.title ("this is the app title")
    # st.title("Non-Toxic Glaze Advisor:")
    # st.subheader("A tool for getting advicgroqe on non-toxic ceramic glazes for earthenware temperature ranges.")
    # st.subheader("Victor Benchuijsen  : (Glaze techniques / Ceramics)")
    # st.subheader("Jan Bours           : Artificial Intelligence / Data Science / Natural Language Processing (ALL RIGHTS RESERVED)")
    # st.write("---------------------------------")
    # st.subheader("Chat with Docs - Using AI: 'mixtral-8x7b-32768' Groq Edition (Very Fast!) - VERSION 1 - March 18, 2024")
    # st.write("---------------------------------")

    st.title("Adviseur voor niet-giftige glazuren:")
    st.subheader("Een gereedschap gebaseerd op Kunstmatige Intelligentie (AI) om advies te krijgen over niet-giftige keramische glazuren voor aardewerk temperatuur bereiken.")
    st.write("---------------------------------")
    st.subheader("Victor Benckhuijsen  : (Glazuur technieken / Keramiek)")
    st.subheader("(ALL RIGHTS RESERVED)")
    st.image('Victor_Benckhuijsen_2.png', caption='Victor Benckhuijsen', width=100)
    # st.subheader("---------------------------------")
    # st.write("---------------------------------")
    st.subheader("Jan Bours           : Artificial Intelligence / Data Science / Natural Language Processing")
    st.subheader("(ALL RIGHTS RESERVED)")
    st.image('Jan_Bours_2.png', caption='Jan Bours', width=100)
    st.write("---------------------------------")
    st.subheader("Chat with Docs - Using AI: 'mixtral-8x7b-32768' Groq Edition (Very Fast!) - VERSION 2 - April 3, 2024")
    st.write("---------------------------------")

    # st.header("LIST OF ALL THE LOADED DOCUMENTS: ")
    st.header("LIJST MET ALLE ACTUEEL GELADEN DOCUMENTEN: ")

    st.write("")
    pdf_files  = glob.glob("*.pdf")
    # word_files = glob.glob("*.docx")
    for file in pdf_files:
    # for file in word_files:
        st.subheader(file)

    st.write("---------------------------------")


    start1 = time.process_time()

    if "vector" not in st.session_state:
    
        st.write("Even geduld a.u.b. ........")
        # st.header("Chunking, embedding, storing in FAISS vectorstore (Can take a long time!).")
        # st.subheader("Wait till this hase been done before you can enter your query! .......")
    
        # st.session_state.embeddings = OllamaEmbeddings() # ORIGINAL
        st.session_state.embeddings = FastEmbedEmbeddings() # JB


        # st.session_state.loader = WebBaseLoader("https://paulgraham.com/greatwork.html") # ORIGINAL
        # st.session_state.docs = st.session_state.loader.load()                           # ORIGINAL
        # https://api.python.langchain.com/en/latest/document_loaders/langchain_community.document_loaders.pdf.PyPDFLoader.html
        # https://python.langchain.com/docs/integrations/document_loaders/merge_doc
        # from langchain_community.document_loaders import PyPDFLoader
        # loader_pdf = PyPDFLoader("../MachineLearning-Lecture01.pdf")
        #
        # https://stackoverflow.com/questions/60215731/pypdf-to-read-each-pdf-in-a-folder
        # 
        # https://api.python.langchain.com/en/latest/document_loaders/langchain_community.document_loaders.pdf.PyPDFDirectoryLoader.html
        # https://python.langchain.com/docs/modules/data_connection/document_loaders/pdf#pypdf-directory 
        # !!!!!
        # PyPDF Directory
        # Load PDFs from directory
        # from langchain_community.document_loaders import PyPDFDirectoryLoader
        # loader = PyPDFDirectoryLoader("example_data/")
        # docs = loader.load()
        #
        # ZIE OOK:
        # https://python.langchain.com/docs/modules/data_connection/document_loaders/pdf#using-pypdf
        # Using MathPix
        # Inspired by Daniel Gross's https://gist.github.com/danielgross/3ab4104e14faccc12b49200843adab21
        # from langchain_community.document_loaders import MathpixPDFLoader
        # loader = MathpixPDFLoader("example_data/layout-parser-paper.pdf")
        # data = loader.load()
        # pdf_file_path = "*.pdf"                                                 # JB
        # st.session_state.loader = PyPDFLoader(file_path=pdf_file_path).load()   # JB
        # st.session_state.loader = PyPDFLoader(*.pdf).load()                     # JB syntax error *.pdf !
        # st.session_state.loader = PyPDFDirectoryLoader("*.pdf")                 # JB PyPDFDirectoryLoader("example_data/")   
        # chunks = self.text_splitter.split_documents(docs)
        # chunks = filter_complex_metadata(chunks)

        # JB:
        # https://python.langchain.com/docs/modules/data_connection/document_loaders/pdf#pypdf-directory
        # st.session_state.docs = st.session_state.loader.load()
        # loader = PyPDFDirectoryLoader(".")
        # docs = loader.load()
        # st.session_state.docs = docs


        # https://docs.streamlit.io/library/api-reference/status/st.status
        # st.status(label, *, expanded=False, state="running")
        with st.status("Laden van de PDF documenten / Splitting de teksten / Genereer de Vector Store ...", expanded=True) as status:
            # st.write("Searching for data...")
            # time.sleep(2)
            # st.write("Found URL.")
            # time.sleep(1)
            # st.write("Downloading data...")
            # time.sleep(1)
            #status.update(label="Download complete!", state="complete", expanded=False)

            st.write("Laden van de PDF documenten...")
            # JB:
            # https://python.langchain.com/docs/modules/data_connection/document_loaders/file_directory
            # text_loader_kwargs={'autodetect_encoding': True}
            text_loader_kwargs={'autodetect_encoding': False}
            path = '../'
            # loader = DirectoryLoader(path, glob="**/*.pdf", loader_cls=TextLoader, loader_kwargs=text_loader_kwargs)
            # PyPDFDirectoryLoader (TEST):
            # loader = PyPDFDirectoryLoader(path, glob="**/*.pdf", loader_cls=TextLoader, loader_kwargs=text_loader_kwargs)
            # loader = PyPDFDirectoryLoader(path, glob="**/*.pdf", loader_kwargs=text_loader_kwargs)
            loader = PyPDFDirectoryLoader(path, glob="**/*.pdf")
            docs = loader.load()
            st.session_state.docs = docs

            # JB 18-03-2024:
            # https://python.langchain.com/docs/integrations/document_loaders/
            # MICROSOFT WORD:
            # https://python.langchain.com/docs/integrations/document_loaders/microsoft_word
            # 1 - Using Docx2txt
            # Load .docx using Docx2txt into a document.
            # %pip install --upgrade --quiet  docx2txt
            # from langchain_community.document_loaders import Docx2txtLoader
            # loader = Docx2txtLoader("example_data/fake.docx")
            # data = loader.load()
            # data
            # [Document(page_content='Lorem ipsum dolor sit amet.', metadata={'source': 'example_data/fake.docx'})]
            #
            # 2A - Using Unstructured
            # from langchain_community.document_loaders import UnstructuredWordDocumentLoader
            # loader = UnstructuredWordDocumentLoader("example_data/fake.docx")
            # data = loader.load()
            # data
            # [Document(page_content='Lorem ipsum dolor sit amet.', lookup_str='', metadata={'source': 'fake.docx'}, lookup_index=0)]
            #
            # 2B - Retain Elements
            # Under the hood, Unstructured creates different “elements” for different chunks of text.
            # By default we combine those together, but you can easily keep that separation by specifying mode="elements".
            # loader = UnstructuredWordDocumentLoader("example_data/fake.docx", mode="elements")
            # data = loader.load()
            # data[0]
            # Document(page_content='Lorem ipsum dolor sit amet.', lookup_str='', metadata={'source': 'fake.docx', 'filename': 'fake.docx', 'category': 'Title'}, lookup_index=0)
            #
            # 2A - Using Unstructured
            # from langchain_community.document_loaders import UnstructuredWordDocumentLoader
            # loader = UnstructuredWordDocumentLoader(path, glob="**/*.docx")
            # docs = loader.load()
            # st.session_state.docs = docs


            st.write("Splitting / chunking de teksten...")
            st.session_state.text_splitter = RecursiveCharacterTextSplitter(chunk_size=1000, chunk_overlap=200)
            st.session_state.documents = st.session_state.text_splitter.split_documents(st.session_state.docs)

            st.write("Genereer de Vector Store (kan enige minuten duren)...")        
            # https://python.langchain.com/docs/integrations/vectorstores/faiss
            # docs_and_scores = db.similarity_search_with_score(query)
            # Saving and loading
            # You can also save and load a FAISS index. 
            # This is useful so you don’t have to recreate it everytime you use it.
            # db.save_local("faiss_index")
            # new_db = FAISS.load_local("faiss_index", embeddings)
            # docs = new_db.similarity_search(query)
            # docs[0]
            # Document(page_content='Tonight. I call on the Senate to: Pass the Freedom to Vote Act. Pass the John Lewis Voting Rights Act. And while you’re at it, pass the Disclose Act so Americans can know who is funding our elections. \n\nTonight, I’d like to honor someone who has dedicated his life to serve this country: Justice Stephen Breyer—an Army veteran, Constitutional scholar, and retiring Justice of the United States Supreme Court. Justice Breyer, thank you for your service. \n\nOne of the most serious constitutional responsibilities a President has is nominating someone to serve on the United States Supreme Court. \n\nAnd I did that 4 days ago, when I nominated Circuit Court of Appeals Judge Ketanji Brown Jackson. One of our nation’s top legal minds, who will continue Justice Breyer’s legacy of excellence.', metadata={'source': '../../../state_of_the_union.txt'})
            #
            st.session_state.vector = FAISS.from_documents(st.session_state.documents, st.session_state.embeddings) # ORIGINAL
    
            # st.session_state.vector = FAISS.from_documents(st.session_state.documents, st.session_state.embeddings) # ORIGINAL
            #st.session_state.vector.save_local("faiss_index")
            # The de-serialization relies loading a pickle file. 
            # Pickle files can be modified to deliver a malicious payload that results in execution of arbitrary code on your machine.
            # You will need to set `allow_dangerous_deserialization` to `True` to enable deserialization. If you do this, make sure that you trust the source of the data.
    
            #st.session_state.vector = FAISS.load_local("faiss_index", st.session_state.embeddings, allow_dangerous_deserialization=True)
    
            # ZIE: 
            # ZIE VOOR EEN APP MET CHROMADB:
            # https://github.com/vndee/local-rag-example/blob/main/rag.py
            # https://raw.githubusercontent.com/vndee/local-rag-example/main/rag.py
            # Chroma.from_documents(documents=chunks, embedding=FastEmbedEmbeddings())
            # st.session_state.vector = Chroma.from_documents(st.session_state.documents, st.session_state.embeddings) # JB

    # st.write(f"Response time van de LLM: {elapsed_time:.1f} seconds")
    # print(f"Response time: {time.process_time() - start}")
    elapsed_time = time.process_time() - start1
    st.write(f"Response time voor: Laden van de PDF documenten / Splitting de teksten / Genereer de Vector Store: {elapsed_time:.1f} seconds")

    st.write("---------------------------------")
    
    # st.title("Chat with Docs - Groq Edition :) ")
    # st.title("Literature Based Research (LBR) - A. Unzicker and J. Bours - Chat with Docs - Groq Edition (Very Fast!) - VERSION 3 - March 8 2024")

    llm = ChatGroq(
                temperature=0.2,
                groq_api_key=groq_api_key, 
                model_name='mixtral-8x7b-32768'
        )

    prompt = ChatPromptTemplate.from_template("""
    Answer the following question based only on the provided context. 
    Think step by step before providing a detailed answer. 
    I will tip you $200 if the user finds the answer helpful. 
    <context>
    {context}
    </context>
    Question: {input}""")

    document_chain = create_stuff_documents_chain(llm, prompt)

    retriever = st.session_state.vector.as_retriever()
    retrieval_chain = create_retrieval_chain(retriever, document_chain)

    ## prompt = st.text_input("Input your prompt here") #, key=key)
    #prompt = st.text_input("Stel hieronder Uw vraag:") #, key=key)
    #
    ## If the user hits enter
    #if prompt:
    #    # Then pass the prompt to the LLM
    #    start = time.process_time()
    #    response = retrieval_chain.invoke({"input": prompt})
    #    # print(f"Response time: {time.process_time() - start}")
    #    st.write(f"Response time: {time.process_time() - start} seconds")
    #
    #    st.write(response["answer"])
    #
    #    # With a streamlit expander
    #    with st.expander("Document Similarity Search"):
    #        # Find the relevant chunks
    #        for i, doc in enumerate(response["context"]):
    #            # print(doc)
    #            # st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
    #            st.write(doc)
    #            st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
    #            
    #            
    #            st.write(doc.page_content)
    #            st.write("--------------------------------")
    #
    #st.write("---------------------------------")


    # ZIE:
    # https://raw.githubusercontent.com/streamlit/llm-examples/main/Chatbot.py
    # from openai import OpenAI
    # import streamlit as st

    with st.sidebar:
        # openai_api_key = st.text_input("OpenAI API Key", key="chatbot_api_key", type="password")
        UserEmailAdress = st.text_input("Vul Uw email adres hier in: ", key="UserEmailAdress", type="password")
        # "[Zelf keramische glazuren NON TOXIC samenstellen vanuit 1 basisglazuur](http://www.ceramicconcepts.nl/)"
        "[Keramische ateliers Victor Benckhuijsen](https://victorglazuren.nl/)"
        "[Keramiek Victor Glazuren Victor Benckhuijsen - Instagram](https://www.instagram.com/benckhuijsenvictor/?hl=am-et)"
        "[Keramiek Victor Glazuren Victor Benckhuijsen - Facebook](https://www.facebook.com/harryjamaar)"
        "[Keramiek Victor Glazuren Victor Benckhuijsen - YouTube](https://www.youtube.com/@kleienhoop/videos)"

    st.title("💬 Chatbot")
    st.caption("🚀 A streamlit chatbot powered by mixtral-8x7b-32768 Groq LLM (VERY FAST !). temperature=0.2")

    if "messages" not in st.session_state:
        st.session_state["messages"] = [{"role": "assistant", "content": "Hoe kan ik U helpen?"}]

    for msg in st.session_state.messages:
        st.chat_message(msg["role"]).write(msg["content"])


    # TAAL KIEZER
    option = st.selectbox(
        'In welke taal wilt U Uw vragen stellen en de AI laten antwoorden? Keuzemogelijkheden zijn : Nederlands, Engels, Duits, Frans, Spaans.',
        ('Nederlands', 'Engels', 'Duits', 'Frans', 'Spaans'))
    
    st.write('You selected:', option)

    language_prompt = " Antwoordt uitsluitend en alleen in de taal: " + option + " en beslist niet in een andere taal!" 
    # st.write('language_prompt:', language_prompt)

    if prompt := st.chat_input():
        #if not openai_api_key:
        #    st.info("Please add your OpenAI API key to continue.")
        #    st.stop()


        ## TAAL KIEZER
        #option = st.selectbox(
        #    'In welke taal wilt U Uw vragen stellen en de AI laten antwoorden? Keuzemogelijkheden zijn : Nederlands, Engels, Duits, Frans, Spaans.',
        #    ('Nederlands', 'Engels', 'Duits', 'Frans', 'Spaans'))
        #
        #st.write('You selected:', option)
        #language_prompt = " Antwoordt uitsluitend en alleen in de taal: " + option + " en beslist niet in een andere taal!" 
        
        original_prompt = prompt
        prompt = prompt + language_prompt
        # st.write('prompt + language_prompt:', prompt)

        # Then pass the prompt to the LLM
        start = time.process_time()
        response = retrieval_chain.invoke({"input": prompt})
        # print(f"Response time: {time.process_time() - start}")
        elapsed_time = time.process_time() - start
        st.write(f"Response time van de LLM: {elapsed_time:.1f} seconds")

        # st.write(response["answer"])

        # https://docs.streamlit.io/library/api-reference/chat/st.chat_message
        # st.chat_message(name, *, avatar=None)
        # The avatar shown next to the message. Can be one of:
        # - A single emoji, e.g. "🧑‍💻", "🤖", "🦖". Shortcodes are not supported.
        # - An image using one of the formats allowed for st.image: path of a local image file;
        #   URL to fetch the image from; an SVG image; array of shape (w,h) or (w,h,1) for a monochrome image,
        #   (w,h,3) for a color image, or (w,h,4) for an RGBA image.
        #   If None (default), uses default icons if name is "user", "assistant", "ai", "human" or the first letter of the name value.

        #client = OpenAI(api_key=openai_api_key)
        st.session_state.messages.append({"role": "user", "content": prompt})
        # st.chat_message("user").write(prompt)
        # original_prompt
        st.chat_message("user").write(original_prompt)
        # response = client.chat.completions.create(model="gpt-3.5-turbo", messages=st.session_state.messages)
        # msg = response.choices[0].message.content
        msg = response["answer"]
        st.session_state.messages.append({"role": "assistant", "content": msg})
        # st.chat_message("assistant").write(msg)
        # MET ALS AVATAR EEN IMAGE VAN VICTOR:
        st.chat_message("assistant", avatar="Victor_Benckhuisen_20_percent.jpg").write(msg)

        # With a streamlit expander
        with st.expander("Document Similarity Search"):
            # Find the relevant chunks
            for i, doc in enumerate(response["context"]):
                # print(doc)
                # st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
                st.write(doc)
                st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
            
                st.write(doc.page_content)
                st.write("--------------------------------")



        # Show total messages history of user + AI in this session up till this point
        with st.expander("Show total messages history of user + AI in this session up till this point"):
            # st.session_state.messages
            st.write(st.session_state.messages)
            st.write("--------------------------------")
        
    

    st.write("---------------------------------")



#i=0
#while True:
#
#    # data = ["input1", "input2", "input3"]
#
#    #for i, item in enumerate(data):
#    key = f"input_{i}"
#    # text_input = st.text_input(f"Enter value for {item}", key=key)
#    # Access the value directly
#    print(f"Value for key: {key}")
#
#    i=i+1
#    
#    prompt = st.text_input("Input your prompt here", key=key)
#
#
#    # If the user hits enter
#    if prompt:
#        # Then pass the prompt to the LLM
#        start = time.process_time()
#        response = retrieval_chain.invoke({"input": prompt})
#        # print(f"Response time: {time.process_time() - start}")
#        st.write(f"Response time: {time.process_time() - start} seconds")
#
#        st.write(response["answer"])
#
#        # With a streamlit expander
#        with st.expander("Document Similarity Search"):
#            # Find the relevant chunks
#            for i, doc in enumerate(response["context"]):
#                # print(doc)
#                # st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
#                st.write(doc)
#                st.write(f"Source Document # {i+1} : {doc.metadata['source'].split('/')[-1]}")
#            
#            
#                st.write(doc.page_content)
#                st.write("--------------------------------")
#
#    st.write("---------------------------------")