Upload folder using huggingface_hub
Browse files- static/javascript/rag_http.js +2 -2
- static/javascript/rag_mgr.js +4 -3
- static/javascript/rag_prompts.js +3 -2
- static/javascript/rag_rqs.js +35 -1
- static/javascript/rag_ui.js +13 -14
- static/js/ragrqs.min.js +10 -114
- static/less/ragrqs.less +28 -0
- static/ragrqs.html +5 -1
- static/ragrqs_.html +15 -3
static/javascript/rag_http.js
CHANGED
@@ -1,8 +1,8 @@
|
|
1 |
/** @format */
|
2 |
"use strict";
|
3 |
|
4 |
-
|
5 |
-
const model_name = "mistralai/Mixtral-8x7B-Instruct-v0.1";
|
6 |
// const model_name = "mistralai/Mixtral-8x22B-Instruct-v0.1"
|
7 |
|
8 |
async function requestGet(url) {
|
|
|
1 |
/** @format */
|
2 |
"use strict";
|
3 |
|
4 |
+
const model_name = "mistralai/Mistral-7B-Instruct-v0.3";
|
5 |
+
// const model_name = "mistralai/Mixtral-8x7B-Instruct-v0.1";
|
6 |
// const model_name = "mistralai/Mixtral-8x22B-Instruct-v0.1"
|
7 |
|
8 |
async function requestGet(url) {
|
static/javascript/rag_mgr.js
CHANGED
@@ -197,9 +197,9 @@ const Rag = {
|
|
197 |
const s = `DOCUMENTO : ${docName}_${npart}\n${answer}`;
|
198 |
this.answers.push(s);
|
199 |
} // end while
|
200 |
-
//implemntare build context
|
201 |
const docAnswersLen = docAnswersLst.length;
|
202 |
-
let docAnswresTxt = docAnswersLst.join("\n\n");
|
203 |
let docContext = "";
|
204 |
|
205 |
while (true) {
|
@@ -227,7 +227,6 @@ const Rag = {
|
|
227 |
break;
|
228 |
} //end while
|
229 |
UaLog.log(`context ${docAnswersLen} => ${docContext.length}`);
|
230 |
-
// docContext = cleanResponse(docContext); //AAA
|
231 |
docContext = `\n### DOCUMENTO: ${docName}\n ${docContext}`;
|
232 |
this.docContextLst.push(docContext);
|
233 |
} // end for document
|
@@ -289,6 +288,8 @@ const Rag = {
|
|
289 |
if (!this.ragContext) {
|
290 |
const ok = await confirm("Contesto vuoto. Vuoi continuare?");
|
291 |
if (!ok) return "";
|
|
|
|
|
292 |
}
|
293 |
if (ThreadMgr.isFirst()) {
|
294 |
ThreadMgr.init();
|
|
|
197 |
const s = `DOCUMENTO : ${docName}_${npart}\n${answer}`;
|
198 |
this.answers.push(s);
|
199 |
} // end while
|
200 |
+
//TODO implemntare build context
|
201 |
const docAnswersLen = docAnswersLst.length;
|
202 |
+
let docAnswresTxt = docAnswersLst.join("\n\n");
|
203 |
let docContext = "";
|
204 |
|
205 |
while (true) {
|
|
|
227 |
break;
|
228 |
} //end while
|
229 |
UaLog.log(`context ${docAnswersLen} => ${docContext.length}`);
|
|
|
230 |
docContext = `\n### DOCUMENTO: ${docName}\n ${docContext}`;
|
231 |
this.docContextLst.push(docContext);
|
232 |
} // end for document
|
|
|
288 |
if (!this.ragContext) {
|
289 |
const ok = await confirm("Contesto vuoto. Vuoi continuare?");
|
290 |
if (!ok) return "";
|
291 |
+
// HACK gestisce il pulsante verde che ha accettao il contetso vuoto
|
292 |
+
this.ragContext="Sei un assitente AI dispoibile a soddisfare tutte le mi richieste";
|
293 |
}
|
294 |
if (ThreadMgr.isFirst()) {
|
295 |
ThreadMgr.init();
|
static/javascript/rag_prompts.js
CHANGED
@@ -9,8 +9,8 @@ SYSTEM: Sei un assistente AI specializzato nell'analisi documentale e nell'estra
|
|
9 |
TASK: Analizza il testo estratto dal documento "${docName}" e identifica gli elementi rilevanti per rispondere alla domanda: "${domanda}".
|
10 |
|
11 |
INSTRUCTIONS:
|
12 |
-
1. Analizza attentamente il testo fornito.
|
13 |
-
2. Identifica gli elementi utili per rispondere alla domanda
|
14 |
3. Per ogni elemento individuato, fornisci un titolo ed una descrizione sintetica ma completa.
|
15 |
4. Riporta dettagli specifici (dati, citazioni, eventi, personaggi, luoghi, ..) se corelati alla domanda.
|
16 |
5. Se non ci sono informazioni rilevanti, rispondi con "NESSUNA INFORMAZIONE RILEVANTE".
|
@@ -29,6 +29,7 @@ RESPONSE:
|
|
29 |
`;
|
30 |
}
|
31 |
|
|
|
32 |
function promptBuildContext(informazioni, domanda = "") {
|
33 |
return `
|
34 |
SYSTEM: Sei un assistente AI esperto nella sintesi e nell'organizzazione mirata di informazioni. Rispondi sempre ed esclusivamente in italiano.
|
|
|
9 |
TASK: Analizza il testo estratto dal documento "${docName}" e identifica gli elementi rilevanti per rispondere alla domanda: "${domanda}".
|
10 |
|
11 |
INSTRUCTIONS:
|
12 |
+
1. Analizza attentamente il testo fornito compreso fra i marker <<<INIZIO_TESTO>>> e <<<FINE_TESTO>>> .
|
13 |
+
2. Identifica gli elementi utili per rispondere alla domanda:"${domanda}".
|
14 |
3. Per ogni elemento individuato, fornisci un titolo ed una descrizione sintetica ma completa.
|
15 |
4. Riporta dettagli specifici (dati, citazioni, eventi, personaggi, luoghi, ..) se corelati alla domanda.
|
16 |
5. Se non ci sono informazioni rilevanti, rispondi con "NESSUNA INFORMAZIONE RILEVANTE".
|
|
|
29 |
`;
|
30 |
}
|
31 |
|
32 |
+
|
33 |
function promptBuildContext(informazioni, domanda = "") {
|
34 |
return `
|
35 |
SYSTEM: Sei un assistente AI esperto nella sintesi e nell'organizzazione mirata di informazioni. Rispondi sempre ed esclusivamente in italiano.
|
static/javascript/rag_rqs.js
CHANGED
@@ -19,7 +19,7 @@
|
|
19 |
*/
|
20 |
|
21 |
"use strict";
|
22 |
-
const VERS = "0.1.
|
23 |
|
24 |
var xlog = console.log;
|
25 |
var xerror = console.error;
|
@@ -82,6 +82,18 @@ function openApp() {
|
|
82 |
}, 10);
|
83 |
}
|
84 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
85 |
// Visualizza la storia della conversazione
|
86 |
function showHistory() {
|
87 |
const txt = ThreadMgr.getThread();
|
@@ -252,6 +264,28 @@ async function help2(e) {
|
|
252 |
wnds.wdiv.show(text);
|
253 |
}
|
254 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
255 |
////////////////////////////////
|
256 |
// Solo Sviluppo
|
257 |
|
|
|
19 |
*/
|
20 |
|
21 |
"use strict";
|
22 |
+
const VERS = "0.1.58 (02-12-2024)";
|
23 |
|
24 |
var xlog = console.log;
|
25 |
var xerror = console.error;
|
|
|
82 |
}, 10);
|
83 |
}
|
84 |
|
85 |
+
// function openApp() {
|
86 |
+
// tm = umgm();
|
87 |
+
// wnds.init();
|
88 |
+
// Menu.init();
|
89 |
+
// TextInput.init();
|
90 |
+
// TextOutput.init();
|
91 |
+
// Rag.init();
|
92 |
+
// document.querySelector(".menu-btn").checked = false;
|
93 |
+
// release();
|
94 |
+
// showHistory();
|
95 |
+
// }
|
96 |
+
|
97 |
// Visualizza la storia della conversazione
|
98 |
function showHistory() {
|
99 |
const txt = ThreadMgr.getThread();
|
|
|
264 |
wnds.wdiv.show(text);
|
265 |
}
|
266 |
|
267 |
+
|
268 |
+
function getTheme() {
|
269 |
+
const t = localStorage.getItem("theme");
|
270 |
+
if (!!t && t == "dark") setDark();
|
271 |
+
}
|
272 |
+
|
273 |
+
function setLight() {
|
274 |
+
document.documentElement.classList.toggle("invert");
|
275 |
+
document.body.classList.remove("theme-dark");
|
276 |
+
document.body.classList.add("theme-light");
|
277 |
+
localStorage.setItem("theme", "ligth");
|
278 |
+
}
|
279 |
+
|
280 |
+
function setDark() {
|
281 |
+
document.documentElement.classList.toggle("invert");
|
282 |
+
document.body.classList.remove("theme-light");
|
283 |
+
document.body.classList.add("theme-dark");
|
284 |
+
localStorage.setItem("theme", "dark");
|
285 |
+
}
|
286 |
+
|
287 |
+
|
288 |
+
|
289 |
////////////////////////////////
|
290 |
// Solo Sviluppo
|
291 |
|
static/javascript/rag_ui.js
CHANGED
@@ -181,20 +181,19 @@ const setOutText = (txt) => {
|
|
181 |
};
|
182 |
|
183 |
// const setOutText2 = async (txt) => {
|
184 |
-
|
185 |
-
|
186 |
-
|
187 |
-
|
188 |
-
|
189 |
-
|
190 |
-
|
191 |
-
|
192 |
-
|
193 |
-
|
194 |
-
|
195 |
// };
|
196 |
|
197 |
-
|
198 |
const TextInput = {
|
199 |
wnd: null,
|
200 |
init() {
|
@@ -252,7 +251,8 @@ const TextInput = {
|
|
252 |
},
|
253 |
handleEnter(e) {
|
254 |
if (e.key === "Enter" && !e.shiftKey) {
|
255 |
-
|
|
|
256 |
e.preventDefault();
|
257 |
this.send2();
|
258 |
}
|
@@ -327,7 +327,6 @@ const TextInput = {
|
|
327 |
},
|
328 |
};
|
329 |
|
330 |
-
|
331 |
TextOutput = {
|
332 |
init() {
|
333 |
this.copyBtn = document.querySelector(".copy-output");
|
|
|
181 |
};
|
182 |
|
183 |
// const setOutText2 = async (txt) => {
|
184 |
+
// const t = p.textContent;
|
185 |
+
// if (t.trim().length < 2) {
|
186 |
+
// p.textContent = txt;
|
187 |
+
// p.scrollTop = p.scrollHeight;
|
188 |
+
// return;
|
189 |
+
// }
|
190 |
+
// for (let i = 0; i < txt.length; i++) {
|
191 |
+
// p.textContent += txt[i];
|
192 |
+
// p.scrollTop = p.scrollHeight;
|
193 |
+
// await new Promise((resolve) => setTimeout(resolve, 2));
|
194 |
+
// }
|
195 |
// };
|
196 |
|
|
|
197 |
const TextInput = {
|
198 |
wnd: null,
|
199 |
init() {
|
|
|
251 |
},
|
252 |
handleEnter(e) {
|
253 |
if (e.key === "Enter" && !e.shiftKey) {
|
254 |
+
// TODO gestire correttamnet enter quando il context è vuoto
|
255 |
+
// if (!Rag.returnOk()) return;
|
256 |
e.preventDefault();
|
257 |
this.send2();
|
258 |
}
|
|
|
327 |
},
|
328 |
};
|
329 |
|
|
|
330 |
TextOutput = {
|
331 |
init() {
|
332 |
this.copyBtn = document.querySelector(".copy-output");
|
static/js/ragrqs.min.js
CHANGED
@@ -5,7 +5,7 @@ function cleanResponse(a){try{return a=removeTag(a),a=a.replace(/[\u00AD\u200B\u
|
|
5 |
function cleanOut(a){return a=a.replace(/\n{3,}/g,"\n\n")};const ID_RESPONSES="id_responses",ID_DOC_NAMES="id_doc_names",ID_DOCS="id_docs;",ID_RAG="id_rag",ID_THREAD="id_thread",UaDb={create(a,b){localStorage.getItem(a)?xerror(`ID ${a} already exists.`):localStorage.setItem(a,b)},read(a){const b=localStorage.getItem(a);return null===b?(xlog(`UaDb.read ${a} not found.`),""):b},update(a,b){localStorage.getItem(a)?localStorage.setItem(a,b):xlog(`UaDb.update ${a} not found.`)},delete(a){localStorage.getItem(a)?localStorage.removeItem(a):xerror(`ID ${a} not found.`)},
|
6 |
save(a,b){localStorage.setItem(a,b)},getAllIds(){const a=[];for(let b=0;b<localStorage.length;b++)a.push(localStorage.key(b));return a},saveArray(a,b){b=JSON.stringify(b);UaDb.save(a,b)},readArray(a){a=UaDb.read(a);return 0==a.trim().length?[]:JSON.parse(a)},saveJson(a,b){b=JSON.stringify(b);UaDb.save(a,b)},readJson(a){return(a=UaDb.read(a))?JSON.parse(a):{}}},DataMgr={docs:[],doc_names:[],linkToName(a){a=a.split("/");return a[a.length-1]},async loadDoc(a){this.readDbDocNames();try{const b=await requestGet(a),
|
7 |
c=cleanDoc(b),d=this.linkToName(a);if(this.doc_names.includes(d))alert(`Il docuento ${d} \u00e8 gi\u00e0 caricato`);else return this.doc_names.push(d),this.docs.push(c),this.saveDbDocs(),c}catch(b){alert("loadDoc()\n"+b+"\n"+a)}},addDoc(a,b){b=cleanDoc(b);this.docs.push(b);this.doc_names.push(a);this.saveDbDocs()},saveDbDocs(){UaDb.saveArray(ID_DOC_NAMES,this.doc_names);UaDb.saveArray(ID_DOCS,this.docs)},readDbDocs(){this.docs=UaDb.readArray(ID_DOCS)},readDbDocNames(){this.doc_names=UaDb.readArray(ID_DOC_NAMES)},
|
8 |
-
deleteJsonDati(){const a=UaDb.getAllIds();for(const b of a)[ID_DOCS,ID_DOC_NAMES].includes(b)||UaDb.delete(b);Rag.ragQuery="";Rag.ragContext="";Rag.ragAnswer="";Rag.answers=[];Rag.prompts=[];ThreadMgr.rows=[]}};function umgm(){return["bWtkSGxRfVA=","aFN1b2dycm0=","WXBfclhfUGk=","TVhWTV1aW04=","fVJPa00="].map(a=>atob(a).split("").map(b=>String.fromCharCode((b.charCodeAt(0)-5+256)%256)).join("")).join("")};const model_name="mistralai/
|
9 |
const ERROR_TOKENS="ERROR_TOKENS",TIMEOUT_ERROR="TIMEOUT_ERROR",getErrorType=(a,b)=>500<=a?"SERVER_ERROR":400<=a&&500>a?"object"===typeof b&&"validation"===b.error_type?b.error.includes("tokens")?ERROR_TOKENS:"ERROR_VALIDATION":"CLIENT_ERROR":"UNKNOWN_ERROR",checkResponse=a=>a&&Array.isArray(a)&&0!==a.length?a[0].generated_text?"ok":"MISSING_GENERATED_TEXT":"INVALID_DATA",createErrorInfo=(a,b,c,d)=>JSON.stringify({status:a,statusText:b,errorType:d,message:c||"Errore sconosciuto"}),HfRequest={controller:null,
|
10 |
isCancelled:!1,baseUrl:"https://api-inference.huggingface.co/models",async post(a,b=5E4){this.isCancelled=!1;this.controller=new AbortController;let c;try{const d=setTimeout(()=>{this.controller.abort()},b);c=await fetch(`${this.baseUrl}/${model_name}`,{method:"POST",headers:{Authorization:`Bearer ${tm}`,"Content-Type":"application/json"},body:JSON.stringify(a),signal:this.controller.signal});clearTimeout(d);if(this.isCancelled)return null;const e=await c.json();if(!c.ok){const g=getErrorType(c.status,
|
11 |
e),k=createErrorInfo(c.status,c.statusText,e.error,g);throw Error(k);}const f=checkResponse(e);if("ok"!==f){const g=createErrorInfo(c.status,c.statusText,e.error,f);throw Error(g);}return e[0].generated_text.trim()}catch(d){if(this.isCancelled)return null;if("AbortError"===d.name)throw a=createErrorInfo(0,"Timeout","La richiesta \u00e8 scaduta",TIMEOUT_ERROR),Error(a);throw d;}},cancelRequest(){this.controller&&(this.isCancelled=!0,this.controller.abort())}};
|
@@ -38,7 +38,7 @@ saveRespToDb(){UaDb.saveArray(ID_RESPONSES,this.answers)},readRespsFromDb(){this
|
|
38 |
promptDoc("",a,""),h);if(10>r)break;[t,u]=getPartDoc(f,r);ragLog(`${c}) ${b},${d}`,t.length,u.length,this.answers);l=promptDoc(t,a,g);const p=getPayloadDoc(l);try{if(m=await HfRequest.post(p,TIMEOUT),!m)return""}catch(n){console.error("RR1)\n",n);const w=getErrorInfo(n);if(w.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Doc ${l.length}`);h+=PROMPT_DECR;continue}else if(w.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout Doc");continue}else UaLog.log(`Error ${n}`),m=`ERROR \n${n}\n`}d++;c++;
|
39 |
f=u;m=cleanResponse(m);v.push(m);this.answers.push(`DOCUMENTO : ${g}_${d}\n${m}`)}const x=v.length;let q=v.join("\n\n");for(d="";;){l=promptBuildContext(q,this.ragQuery);const r=getPayloadBuildContext(l);try{if(d=await HfRequest.post(r,TIMEOUT),!d)return""}catch(p){console.error("RR2)",p);const n=getErrorInfo(p);if(n.errorType===ERROR_TOKENS){UaLog.log(`Error tokens build Context ${l.length}`);q=truncInput(q,PROMPT_DECR);q=setMaxLen(q);continue}else if(n.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout build Context");
|
40 |
continue}else throw p;}break}UaLog.log(`context ${x} => ${d.length}`);d=`\n### DOCUMENTO: ${g}\n ${d}`;this.docContextLst.push(d)}}catch(e){throw console.error(e),e;}this.ragContext=this.docContextLst.join("\n\n");this.saveToDb();b="";c=this.ragContext;try{for(;;){let e=promptWithContext(c,a);const f=getPayloadWithContext(e);try{if(b=await HfRequest.post(f,TIMEOUT),!b)return""}catch(g){console.error("RR3)",g);const k=getErrorInfo(g);if(k.errorType===ERROR_TOKENS){UaLog.log(`Error tokens with Context ${e.length}`);
|
41 |
-
c=truncInput(c,PROMPT_DECR);c=setMaxLen(c);continue}else if(k.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout with Context");continue}else throw g;}break}this.ragAnswer=b=cleanResponse(b);this.saveRespToDb();ThreadMgr.init();this.saveToDb();UaLog.log(`Risposta (${this.ragAnswer.length})`)}catch(e){throw console.error(e),b=`${e}`,e;}finally{return b}},async requestContext(a){let b="";if(!this.ragContext
|
42 |
try{var c=this.ragContext;let d=ThreadMgr.getThread();for(;;){prompt=promptThread(c,d,a);const e=getPayloadThread(prompt);try{if(b=await HfRequest.post(e,TIMEOUT),!b)return""}catch(f){console.error("RR4)",f);const g=getErrorInfo(f);if(g.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Thread Init ${prompt.length}`);d=truncInput(d,PROMPT_DECR);c=setMaxLen(c);continue}else if(g.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout Thread Init");continue}else throw f;}break}b=cleanResponse(b);ThreadMgr.add(a,
|
43 |
b);b=ThreadMgr.getThread();UaLog.log(`Inizio Conversazione (${prompt.length})`)}catch(d){throw console.error(d),b=`${d}`,d;}finally{return b}}else try{let d=this.ragContext,e=ThreadMgr.getThread();for(c="";;){c=promptThread(d,e,a);const f=getPayloadThread(c);try{if(b=await HfRequest.post(f,TIMEOUT),!b)return""}catch(g){console.error("RR5)",g);const k=getErrorInfo(g);if(k.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Thread ${c.length}`);e=truncInput(e,PROMPT_DECR);continue}else if(k.errorType===
|
44 |
TIMEOUT_ERROR){UaLog.log("Error timeout Thread");continue}else throw g;}break}b=cleanResponse(b);ThreadMgr.add(a,b);b=ThreadMgr.getThread();UaLog.log(`Conversazione (${c.length})`)}catch(d){throw console.error(d),b=`${d}`,d;}finally{return b}}},LLM="## Assistant:",USER="## User:",ThreadMgr={rows:[],init(){this.rows=[];Rag.ragAnswer?this.add(Rag.ragQuery,Rag.ragAnswer):this.add("","")},add(a,b){this.rows.push([a,b]);UaDb.saveArray(ID_THREAD,ThreadMgr.rows)},getThread(){const a=[];for(const b of this.rows)a.push(`${USER}\n${b[0]}\n${LLM}\n${b[1]}\n`);
|
@@ -48,113 +48,8 @@ SYSTEM: Sei un assistente AI specializzato nell'analisi documentale e nell'estra
|
|
48 |
TASK: Analizza il testo estratto dal documento "${c}" e identifica gli elementi rilevanti per rispondere alla domanda: "${b}".
|
49 |
|
50 |
INSTRUCTIONS:
|
51 |
-
1. Analizza attentamente il testo fornito.
|
52 |
-
2. Identifica gli elementi utili per rispondere alla domanda
|
53 |
-
3. Per ogni elemento individuato, fornisci un titolo ed una descrizione sintetica ma completa.
|
54 |
-
4. Riporta dettagli specifici (dati, citazioni, eventi, personaggi, luoghi, ..) se corelati alla domanda.
|
55 |
-
5. Se non ci sono informazioni rilevanti, rispondi con "NESSUNA INFORMAZIONE RILEVANTE".
|
56 |
-
6. Assicurati di generare la risposta esattamente secondo il formato di output specificato.
|
57 |
-
|
58 |
-
DOMANDA: ${b}
|
59 |
-
|
60 |
-
TESTO DA ANALIZZARE:
|
61 |
-
<<<INIZIO_TESTO>>>
|
62 |
-
${a}
|
63 |
-
<<<FINE_TESTO>>>
|
64 |
-
|
65 |
-
OUTPUT_FORMAT: Genera una risposta strutturata come un elenco nel quale ogni elemento \u00e8 costituito da un breve titolo e da una descrizione concisa ma completa.
|
66 |
-
|
67 |
-
RESPONSE:
|
68 |
-
`}function promptBuildContext(a,b=""){return`
|
69 |
-
SYSTEM: Sei un assistente AI esperto nella sintesi e nell'organizzazione mirata di informazioni. Rispondi sempre ed esclusivamente in italiano.
|
70 |
-
|
71 |
-
TASK: Organizza e sintetizza le informazioni estratte da frammenti di testo di un documento, creando un contesto utile per rispondere alla domanda: "${b}".
|
72 |
-
|
73 |
-
INSTRUCTIONS:
|
74 |
-
1. Analizza tutte le informazioni fornite.
|
75 |
-
2. Seleziona e raggruppa le informazioni simili.
|
76 |
-
3. Per ogni informazioni, genera una descrizione concisa.
|
77 |
-
4. Elenca i punti chiave essenziali per comprendere il contesto.
|
78 |
-
5. Riporta elementi specifici (dati, citazioni, eventi, luoghi, personaggi, ..) se utili.
|
79 |
-
6. Elabora inferenze logiche basate sulle informazioni, se rilevanti per il contesto.
|
80 |
-
7. Genera una sintesi finale.
|
81 |
-
8. Assicurati di strutturare la tua risposta esattamente secondo il formato di output specificato.
|
82 |
-
|
83 |
-
INFORMAZIONI:
|
84 |
-
<<<INIZIO_INFORMAZIONI>>>
|
85 |
-
${a}
|
86 |
-
<<<FINE_INFORMAZIONI>>>
|
87 |
-
|
88 |
-
OUTPUT_FORMAT: Genera una risposta strutturata come un elenco nel quale ogni elemento \u00e8 costituito da un breve titolo e da una descrizione concisa ma completa, alla fine dell'elenco aggiungi una sintesi globale ed eventuali inferenze logiche e collegamenti fra le varie informazioni.
|
89 |
-
|
90 |
-
RESPONSE:
|
91 |
-
`}function promptWithContext(a,b){return`
|
92 |
-
SYSTEM: Sei un sistema AI specializzato nell'analisi di informazioni estratte da documenti.
|
93 |
-
|
94 |
-
TASK: Elabora la risposta alla domanda "${b}" sulla base del contesto fornito.
|
95 |
-
|
96 |
-
INSTRUCTIONS:
|
97 |
-
1. Analizza attentamente il contesto fornito, identificando le informazioni pertinenti alla domanda: "${b}".
|
98 |
-
2. Estrai i concetti chiave e formula inferenze ragionevoli basate sulle informazioni disponibili.
|
99 |
-
3. Inizia la risposta con una breve introduzione che presenta l'argomento e il contesto.
|
100 |
-
4. Procedi con un'analisi dettagliata delle informazioni rilevanti trovate nel contesto.
|
101 |
-
5. Concludi con una sintesi che riassume i punti chiave e fornisce una conclusione generale.
|
102 |
-
6. Se richiesto, cita le fonti facendo riferimento al "documento fornito" per il contesto dato, distinguendolo chiaramente da eventuali altre fonti citate all'interno del contesto stesso.
|
103 |
-
7. Mantieni uno stile di scrittura fluido durante tutta la risposta.
|
104 |
-
8. Assicurati che la risposta sia completa e risponda direttamente alla domanda posta.
|
105 |
-
|
106 |
-
CONTESTO:
|
107 |
-
<<<INIZIO_CONTESTO>>>
|
108 |
-
${a}
|
109 |
-
<<<FINE_CONTESTO>>>
|
110 |
-
|
111 |
-
DOMANDA: ${b}
|
112 |
-
|
113 |
-
OUTPUT_FORMAT: Fornisci la risposta in testo semplice e lineare suddiviso in paragrafi.
|
114 |
-
|
115 |
-
RESPONSE:
|
116 |
-
`}function promptThread(a,b,c){return`
|
117 |
-
SYSTEM: Sei un assistente AI versatile progettato per gestire conversazioni dinamiche e adattarti a varie richieste. Rispondi sempre in italiano.
|
118 |
-
|
119 |
-
TASK: Elabora la risposta alla richiesta "${c}" sulla base del contesto fornito e della conversazione.
|
120 |
-
|
121 |
-
INSTRUCTIONS:
|
122 |
-
1. Analizza attentamente il contesto, la conversazione precedente e la richiesta: "${c}".
|
123 |
-
2. Interpreta l'intento dell'utente senza limitarti a categorie predefinite.
|
124 |
-
3. Adatta la tua risposta in base all'intento percepito, sia esso una domanda, una richiesta di azione, un'istruzione specifica o altro.
|
125 |
-
4. Mantieni una stretta coerenza con il contesto della conversazione.
|
126 |
-
5. Basa la tua risposta sulle informazioni fornite nel contesto e nella conversazione.
|
127 |
-
6. Evita divagazioni o argomentazioni non direttamente pertinenti alla richiesta o al contesto.
|
128 |
-
7. Fai riferimento a informazioni precedenti quando sono pertinenti, citando specificamente la fonte.
|
129 |
-
8. Se l'intento non \u00e8 chiaro, chiedi gentilmente chiarimenti invece di fare supposizioni.
|
130 |
-
9. Sii flessibile: se la richiesta implica un'azione specifica, adattati di conseguenza.
|
131 |
-
10. Se \u00e8 necessario integrare con conoscenze generali, specifica chiaramente quando lo stai facendo.
|
132 |
-
|
133 |
-
CONTESTO:
|
134 |
-
<<<BEGIN_CONTESTO>>>
|
135 |
-
${a}
|
136 |
-
<<<END_CONTESTO>>>
|
137 |
-
|
138 |
-
<<<INIZIO_CONVERSAZIONE>>>
|
139 |
-
${b}
|
140 |
-
<<<FINE_CONVERSAZIONE>>>
|
141 |
-
|
142 |
-
RICHIESTA: ${c}
|
143 |
-
|
144 |
-
OUTPUT_FORMAT: Fornisci la risposta in testo semplice e lineare suddiviso in paragrafi.
|
145 |
-
|
146 |
-
RESPONSE:
|
147 |
-
`}function getPayloadDoc(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:2E3,num_return_sequences:1,temperature:.4,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:3,num_beams:4,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:90,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
148 |
-
function getPayloadBuildContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:5E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:6,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:180,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
149 |
-
function getPayloadWithContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:4E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
150 |
-
function getPayloadThread(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:4048,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}};function promptDoc(a,b,c){return`
|
151 |
-
SYSTEM: Sei un assistente AI specializzato nell'analisi documentale e nell'estrazione mirata di informazioni. Rispondi esclusivamente in italiano.
|
152 |
-
|
153 |
-
TASK: Analizza il testo estratto dal documento "${c}" e identifica gli elementi rilevanti per rispondere alla domanda: "${b}".
|
154 |
-
|
155 |
-
INSTRUCTIONS:
|
156 |
-
1. Analizza attentamente il testo fornito.
|
157 |
-
2. Identifica gli elementi utili per rispondere alla domanda ("${b}").
|
158 |
3. Per ogni elemento individuato, fornisci un titolo ed una descrizione sintetica ma completa.
|
159 |
4. Riporta dettagli specifici (dati, citazioni, eventi, personaggi, luoghi, ..) se corelati alla domanda.
|
160 |
5. Se non ci sono informazioni rilevanti, rispondi con "NESSUNA INFORMAZIONE RILEVANTE".
|
@@ -252,14 +147,15 @@ RESPONSE:
|
|
252 |
`}function getPayloadDoc(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:2E3,num_return_sequences:1,temperature:.4,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:3,num_beams:4,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:90,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
253 |
function getPayloadBuildContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:6E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:6,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:180,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
254 |
function getPayloadWithContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:4E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
255 |
-
function getPayloadThread(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:6048,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}};const VERS="0.1.
|
256 |
function openApp(){setTimeout(()=>{tm=umgm();wnds.init();Menu.init();TextInput.init();TextOutput.init();Rag.init();document.querySelector(".menu-btn").checked=!1;release();showHistory()},10)}function showHistory(){const a=ThreadMgr.getThread();setOutText(a)}function release(){document.querySelector(".release").innerHTML=VERS}const op0=async function(a){a=await requestGet("./help1.html");wnds.wdiv.show(a)};function showQuery(a){wnds.wpre.show(`\n${Rag.ragQuery}`)}
|
257 |
function showRagResponse(a){wnds.wpre.show(`\n${Rag.ragAnswer}`)}function showThread(a){a=ThreadMgr.getThread();wnds.wpre.show(a)}function elencoRisposte(a){a=[...Rag.answers];0==a.length&&(a=UaDb.readArray(ID_RESPONSES));0!=a.length&&(a=a.map((b,c)=>`\n[${c+1}]\n ${b.trim()}`).join("\n"),wnds.wpre.show(a))}function showContesto(a){wnds.wpre.show(`${Rag.ragContext}`)}
|
258 |
function elencoDati(a){var b=UaDb.getAllIds();a=[];for(var c of b)b=UaDb.read(c).length,a.push(`${c} (${b})`);c=a.join("\n ");wnds.wpre.show(c)}const showT=a=>{wnds.wpre.show(DataMgr.docs[a])};function elencoDocs(){DataMgr.readDbDocs();DataMgr.readDbDocNames();var a=DataMgr.doc_names,b=UaJtfh();let c=0;b.append("<ul>");for(const g of a){a=b;var d=a.append,e=g,f=c++;d.call(a,`
|
259 |
<li><a href="#" onCLick="showT(${f});">${f+1}.${e}</a></li>
|
260 |
`)}b.append("</ul>");b=b.html();wnds.wdiv.show(`<br><br>${b}`)}function calcQuery(){DataMgr.readDbDocs();DataMgr.readDbDocNames();var a=[];let b=0,c=0;a.push("Documento Num.Parti");a.push("==================");for(const d of DataMgr.docs){const e=DataMgr.doc_names[c];c+=1;const f=Math.ceil(d.length/MAX_PROMPT_LENGTH);b+=f;a.push(`${e} [${f}]`)}a.push("==================");a.push(`Totale num. Parti: ${b}`);a=a.join("\n");wnds.wpre.show(a)}
|
261 |
function deleteDati(a){confirm("Confermi cancellazione dati?")&&(DataMgr.deleteJsonDati(),wnds.wdiv.close(),wnds.wpre.close(),TextOutput.clear())}function deleteSttorage(a){confirm("Confermi cancellazione documenti & dati?")&&(DataMgr.deleteJsonDati(),localStorage.clear(),wnds.wdiv.close(),wnds.wpre.close(),TextOutput.clear(),DataMgr.docs=[],DataMgr.doc_names=[])}async function help1(a){a=await requestGet("./data/help_test.html");wnds.wdiv.show(a)}
|
262 |
-
function loadTestoEsempio(a){DataMgr.loadDoc(`data/${a}`);wnds.wdiv.close()}async function help2(a){a=await requestGet("./help2.html");wnds.wdiv.show(a)}function
|
|
|
263 |
<div class="window-text">
|
264 |
<div class="btn-wrapper">
|
265 |
<button class="btn-copy" title="Copia">
|
@@ -287,9 +183,9 @@ function loadTestoEsempio(a){DataMgr.loadDoc(`data/${a}`);wnds.wdiv.close()}asyn
|
|
287 |
closeAll(){UaWindowAdm.close("id_w0");UaWindowAdm.close("id_w1");UaWindowAdm.close("id_out")}},Menu={init(){const a=document.querySelector("#id-menu-btn");a.addEventListener("change",()=>{document.querySelector("body").classList.toggle("menu-open",a.checked)});const b=document.getElementById("id_log");UaLog.callHide=()=>{b.classList.contains("active")&&b.classList.remove("active")};UaLog.callShow=()=>{b.classList.contains("active")||b.classList.add("active")};UaLog.setXY(54,13).setZ(111).new();UaLog.log_show("")},
|
288 |
close(){const a=document.querySelector("#menu-toggle");document.querySelector("body").classList.remove("menu-open",a.checked);document.querySelector(".menu-btn").checked=!1},async help(){const a=await requestGet("./help0.html");wnds.wdiv.show(a)},upload(){RagUpload.open()},uploadDir(){RagUpload.openDir()},async load(){alert("load")},log(){UaLog.toggle()}},setOutText=a=>{const b=document.querySelector("#id-text-out .pre-text");b.textContent=a;b.scrollTop=b.scrollHeight},TextInput={wnd:null,init(){this.inp=
|
289 |
document.querySelector(".text-input");document.addEventListener("keydown",a=>{document.activeElement!==this.inp&&("F1 F2 F3 F4 F5 F6 F7 F8 F9 F10 F11 F12 Control Alt Shift Meta CapsLock Escape PrintScreen ScrollLock Pause Insert Delete Home End PageUp PageDown ArrowLeft ArrowRight ArrowUp ArrowDown".split(" ").includes(a.key)||a.ctrlKey||a.metaKey||a.preventDefault())});document.querySelector(".clear-button").addEventListener("click",()=>{this.inp.value="";this.inp.focus()});this.inp.addEventListener("keydown",
|
290 |
-
a=>this.handleEnter(a));document.querySelector(".send-input").addEventListener("click",()=>this.send());document.querySelector(".send2-input").addEventListener("click",()=>this.send2());document.querySelector(".clear-input").addEventListener("click",()=>this.clear())},handleEnter(a){"Enter"
|
291 |
-
|
292 |
-
|
293 |
TextOutput={init(){this.copyBtn=document.querySelector(".copy-output");this.copyBtn.addEventListener("click",()=>this.copy());document.querySelector(".clear-output").addEventListener("click",()=>this.clear());document.querySelector(".wnd-output").addEventListener("click",()=>this.openWnd())},openWnd(){const a=document.querySelector("#id-text-out .pre-text").textContent;wnds.wout.show(a)},async copy(){const a=document.querySelector("#id-text-out .pre-text"),b=a.textContent;if(!(2>b.trim().length)){a.classList.add("copied");
|
294 |
this.copyBtn.classList.add("copied");try{await navigator.clipboard.writeText(b)}catch(c){console.error("Errore ",c)}setTimeout(()=>{this.copyBtn.classList.remove("copied");a.classList.remove("copied")},5E3)}},clear(){document.querySelector("#id-text-out .pre-text").textContent=""}};const RagUpload={open(){const a=UaWindowAdm.create("id_upload");a.drag();a.setZ(12);a.vw_vh().setXY(16.5,10,-1);a.setHtml('\n <div class="window-text">\n <div class="btn-wrapper">\n <button class="btn-close" title="chiudi" onclick="UaWindowAdm.closeThis(this)">X</button>\n </div> \n <div class="upload"> \n <h4>Upload file Text / PDF</h4> \n <form id="uploadForm">\n <input class="file" type="file" id="id_fileupload" > \n <button type="button" onclick="RagUpload.upload();">Upload and Convert</button>\n </form>\n <div id="result" class="result"></div>\n </div>\n </div>\n ');
|
295 |
a.show()},async upload(){const a=document.getElementById("id_fileupload").files[0];if(a){var b=a.name;if(DataMgr.doc_names.includes(b))alert("Il file \u00e8 gi\u00e0 in archivio");else{var c=document.getElementById("result"),d=a.name.split(".").pop().toLowerCase();showSpinner();try{let e;if("pdf"===d){const f=new PdfHandler;await f.loadPdfJs();e=await f.extractTextFromPDF(a);f.cleanup()}else if("txt"===d)e=await readTextFile(a);else{alert("Formato file non supportato.");return}DataMgr.addDoc(b,e);
|
|
|
5 |
function cleanOut(a){return a=a.replace(/\n{3,}/g,"\n\n")};const ID_RESPONSES="id_responses",ID_DOC_NAMES="id_doc_names",ID_DOCS="id_docs;",ID_RAG="id_rag",ID_THREAD="id_thread",UaDb={create(a,b){localStorage.getItem(a)?xerror(`ID ${a} already exists.`):localStorage.setItem(a,b)},read(a){const b=localStorage.getItem(a);return null===b?(xlog(`UaDb.read ${a} not found.`),""):b},update(a,b){localStorage.getItem(a)?localStorage.setItem(a,b):xlog(`UaDb.update ${a} not found.`)},delete(a){localStorage.getItem(a)?localStorage.removeItem(a):xerror(`ID ${a} not found.`)},
|
6 |
save(a,b){localStorage.setItem(a,b)},getAllIds(){const a=[];for(let b=0;b<localStorage.length;b++)a.push(localStorage.key(b));return a},saveArray(a,b){b=JSON.stringify(b);UaDb.save(a,b)},readArray(a){a=UaDb.read(a);return 0==a.trim().length?[]:JSON.parse(a)},saveJson(a,b){b=JSON.stringify(b);UaDb.save(a,b)},readJson(a){return(a=UaDb.read(a))?JSON.parse(a):{}}},DataMgr={docs:[],doc_names:[],linkToName(a){a=a.split("/");return a[a.length-1]},async loadDoc(a){this.readDbDocNames();try{const b=await requestGet(a),
|
7 |
c=cleanDoc(b),d=this.linkToName(a);if(this.doc_names.includes(d))alert(`Il docuento ${d} \u00e8 gi\u00e0 caricato`);else return this.doc_names.push(d),this.docs.push(c),this.saveDbDocs(),c}catch(b){alert("loadDoc()\n"+b+"\n"+a)}},addDoc(a,b){b=cleanDoc(b);this.docs.push(b);this.doc_names.push(a);this.saveDbDocs()},saveDbDocs(){UaDb.saveArray(ID_DOC_NAMES,this.doc_names);UaDb.saveArray(ID_DOCS,this.docs)},readDbDocs(){this.docs=UaDb.readArray(ID_DOCS)},readDbDocNames(){this.doc_names=UaDb.readArray(ID_DOC_NAMES)},
|
8 |
+
deleteJsonDati(){const a=UaDb.getAllIds();for(const b of a)[ID_DOCS,ID_DOC_NAMES].includes(b)||UaDb.delete(b);Rag.ragQuery="";Rag.ragContext="";Rag.ragAnswer="";Rag.answers=[];Rag.prompts=[];ThreadMgr.rows=[]}};function umgm(){return["bWtkSGxRfVA=","aFN1b2dycm0=","WXBfclhfUGk=","TVhWTV1aW04=","fVJPa00="].map(a=>atob(a).split("").map(b=>String.fromCharCode((b.charCodeAt(0)-5+256)%256)).join("")).join("")};const model_name="mistralai/Mistral-7B-Instruct-v0.3";async function requestGet(a){try{var b=await fetch(a,{method:"GET",headers:{"Content-Type":"text/plain;charset=UTF-8"}});if(!b.ok)throw Error(`HTTP error! status: ${b.status}`);const c=await b.arrayBuffer();return(new TextDecoder("utf-8")).decode(c)}catch(c){throw console.error(c),b="AbortError"===c.name?"Request was aborted":c.message.includes("HTTP error! status")?c.message:"An error occurred",alert(`requestGet()\nurl: ${a}\n${b}`),c;}}
|
9 |
const ERROR_TOKENS="ERROR_TOKENS",TIMEOUT_ERROR="TIMEOUT_ERROR",getErrorType=(a,b)=>500<=a?"SERVER_ERROR":400<=a&&500>a?"object"===typeof b&&"validation"===b.error_type?b.error.includes("tokens")?ERROR_TOKENS:"ERROR_VALIDATION":"CLIENT_ERROR":"UNKNOWN_ERROR",checkResponse=a=>a&&Array.isArray(a)&&0!==a.length?a[0].generated_text?"ok":"MISSING_GENERATED_TEXT":"INVALID_DATA",createErrorInfo=(a,b,c,d)=>JSON.stringify({status:a,statusText:b,errorType:d,message:c||"Errore sconosciuto"}),HfRequest={controller:null,
|
10 |
isCancelled:!1,baseUrl:"https://api-inference.huggingface.co/models",async post(a,b=5E4){this.isCancelled=!1;this.controller=new AbortController;let c;try{const d=setTimeout(()=>{this.controller.abort()},b);c=await fetch(`${this.baseUrl}/${model_name}`,{method:"POST",headers:{Authorization:`Bearer ${tm}`,"Content-Type":"application/json"},body:JSON.stringify(a),signal:this.controller.signal});clearTimeout(d);if(this.isCancelled)return null;const e=await c.json();if(!c.ok){const g=getErrorType(c.status,
|
11 |
e),k=createErrorInfo(c.status,c.statusText,e.error,g);throw Error(k);}const f=checkResponse(e);if("ok"!==f){const g=createErrorInfo(c.status,c.statusText,e.error,f);throw Error(g);}return e[0].generated_text.trim()}catch(d){if(this.isCancelled)return null;if("AbortError"===d.name)throw a=createErrorInfo(0,"Timeout","La richiesta \u00e8 scaduta",TIMEOUT_ERROR),Error(a);throw d;}},cancelRequest(){this.controller&&(this.isCancelled=!0,this.controller.abort())}};
|
|
|
38 |
promptDoc("",a,""),h);if(10>r)break;[t,u]=getPartDoc(f,r);ragLog(`${c}) ${b},${d}`,t.length,u.length,this.answers);l=promptDoc(t,a,g);const p=getPayloadDoc(l);try{if(m=await HfRequest.post(p,TIMEOUT),!m)return""}catch(n){console.error("RR1)\n",n);const w=getErrorInfo(n);if(w.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Doc ${l.length}`);h+=PROMPT_DECR;continue}else if(w.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout Doc");continue}else UaLog.log(`Error ${n}`),m=`ERROR \n${n}\n`}d++;c++;
|
39 |
f=u;m=cleanResponse(m);v.push(m);this.answers.push(`DOCUMENTO : ${g}_${d}\n${m}`)}const x=v.length;let q=v.join("\n\n");for(d="";;){l=promptBuildContext(q,this.ragQuery);const r=getPayloadBuildContext(l);try{if(d=await HfRequest.post(r,TIMEOUT),!d)return""}catch(p){console.error("RR2)",p);const n=getErrorInfo(p);if(n.errorType===ERROR_TOKENS){UaLog.log(`Error tokens build Context ${l.length}`);q=truncInput(q,PROMPT_DECR);q=setMaxLen(q);continue}else if(n.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout build Context");
|
40 |
continue}else throw p;}break}UaLog.log(`context ${x} => ${d.length}`);d=`\n### DOCUMENTO: ${g}\n ${d}`;this.docContextLst.push(d)}}catch(e){throw console.error(e),e;}this.ragContext=this.docContextLst.join("\n\n");this.saveToDb();b="";c=this.ragContext;try{for(;;){let e=promptWithContext(c,a);const f=getPayloadWithContext(e);try{if(b=await HfRequest.post(f,TIMEOUT),!b)return""}catch(g){console.error("RR3)",g);const k=getErrorInfo(g);if(k.errorType===ERROR_TOKENS){UaLog.log(`Error tokens with Context ${e.length}`);
|
41 |
+
c=truncInput(c,PROMPT_DECR);c=setMaxLen(c);continue}else if(k.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout with Context");continue}else throw g;}break}this.ragAnswer=b=cleanResponse(b);this.saveRespToDb();ThreadMgr.init();this.saveToDb();UaLog.log(`Risposta (${this.ragAnswer.length})`)}catch(e){throw console.error(e),b=`${e}`,e;}finally{return b}},async requestContext(a){let b="";if(!this.ragContext){if(!await confirm("Contesto vuoto. Vuoi continuare?"))return"";this.ragContext="Sei un assitente AI dispoibile a soddisfare tutte le mi richieste"}if(ThreadMgr.isFirst()){ThreadMgr.init();
|
42 |
try{var c=this.ragContext;let d=ThreadMgr.getThread();for(;;){prompt=promptThread(c,d,a);const e=getPayloadThread(prompt);try{if(b=await HfRequest.post(e,TIMEOUT),!b)return""}catch(f){console.error("RR4)",f);const g=getErrorInfo(f);if(g.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Thread Init ${prompt.length}`);d=truncInput(d,PROMPT_DECR);c=setMaxLen(c);continue}else if(g.errorType===TIMEOUT_ERROR){UaLog.log("Error timeout Thread Init");continue}else throw f;}break}b=cleanResponse(b);ThreadMgr.add(a,
|
43 |
b);b=ThreadMgr.getThread();UaLog.log(`Inizio Conversazione (${prompt.length})`)}catch(d){throw console.error(d),b=`${d}`,d;}finally{return b}}else try{let d=this.ragContext,e=ThreadMgr.getThread();for(c="";;){c=promptThread(d,e,a);const f=getPayloadThread(c);try{if(b=await HfRequest.post(f,TIMEOUT),!b)return""}catch(g){console.error("RR5)",g);const k=getErrorInfo(g);if(k.errorType===ERROR_TOKENS){UaLog.log(`Error tokens Thread ${c.length}`);e=truncInput(e,PROMPT_DECR);continue}else if(k.errorType===
|
44 |
TIMEOUT_ERROR){UaLog.log("Error timeout Thread");continue}else throw g;}break}b=cleanResponse(b);ThreadMgr.add(a,b);b=ThreadMgr.getThread();UaLog.log(`Conversazione (${c.length})`)}catch(d){throw console.error(d),b=`${d}`,d;}finally{return b}}},LLM="## Assistant:",USER="## User:",ThreadMgr={rows:[],init(){this.rows=[];Rag.ragAnswer?this.add(Rag.ragQuery,Rag.ragAnswer):this.add("","")},add(a,b){this.rows.push([a,b]);UaDb.saveArray(ID_THREAD,ThreadMgr.rows)},getThread(){const a=[];for(const b of this.rows)a.push(`${USER}\n${b[0]}\n${LLM}\n${b[1]}\n`);
|
|
|
48 |
TASK: Analizza il testo estratto dal documento "${c}" e identifica gli elementi rilevanti per rispondere alla domanda: "${b}".
|
49 |
|
50 |
INSTRUCTIONS:
|
51 |
+
1. Analizza attentamente il testo fornito compreso fra i marker <<<INIZIO_TESTO>>> e <<<FINE_TESTO>>> .
|
52 |
+
2. Identifica gli elementi utili per rispondere alla domanda:"${b}".
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
53 |
3. Per ogni elemento individuato, fornisci un titolo ed una descrizione sintetica ma completa.
|
54 |
4. Riporta dettagli specifici (dati, citazioni, eventi, personaggi, luoghi, ..) se corelati alla domanda.
|
55 |
5. Se non ci sono informazioni rilevanti, rispondi con "NESSUNA INFORMAZIONE RILEVANTE".
|
|
|
147 |
`}function getPayloadDoc(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:2E3,num_return_sequences:1,temperature:.4,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:3,num_beams:4,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:90,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
148 |
function getPayloadBuildContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:6E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:6,repetition_penalty:1.2,return_full_text:!1,details:!1,max_time:180,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
149 |
function getPayloadWithContext(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:4E3,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}}
|
150 |
+
function getPayloadThread(a){return{inputs:a,parameters:{task:"text2text-generation",max_new_tokens:6048,num_return_sequences:1,temperature:.7,top_p:.85,top_k:30,do_sample:!1,no_repeat_ngram_size:4,num_beams:5,repetition_penalty:1.4,return_full_text:!1,details:!1,max_time:120,seed:42},options:{use_cache:!1,wait_for_model:!0}}};const VERS="0.1.58 (02-12-2024)";var xlog=console.log,xerror=console.error;const cancelRequest=()=>{confirm("Confermi Cancellazione Richeista ?")&&(HfRequest.cancelRequest(),hideSpinner())},showSpinner=()=>{const a=document.getElementById("spinner");a.classList.add("show-spinner");a.addEventListener("click",cancelRequest)},hideSpinner=()=>{const a=document.getElementById("spinner");a.classList.remove("show-spinner");a.removeEventListener("click",cancelRequest)};var tm;
|
151 |
function openApp(){setTimeout(()=>{tm=umgm();wnds.init();Menu.init();TextInput.init();TextOutput.init();Rag.init();document.querySelector(".menu-btn").checked=!1;release();showHistory()},10)}function showHistory(){const a=ThreadMgr.getThread();setOutText(a)}function release(){document.querySelector(".release").innerHTML=VERS}const op0=async function(a){a=await requestGet("./help1.html");wnds.wdiv.show(a)};function showQuery(a){wnds.wpre.show(`\n${Rag.ragQuery}`)}
|
152 |
function showRagResponse(a){wnds.wpre.show(`\n${Rag.ragAnswer}`)}function showThread(a){a=ThreadMgr.getThread();wnds.wpre.show(a)}function elencoRisposte(a){a=[...Rag.answers];0==a.length&&(a=UaDb.readArray(ID_RESPONSES));0!=a.length&&(a=a.map((b,c)=>`\n[${c+1}]\n ${b.trim()}`).join("\n"),wnds.wpre.show(a))}function showContesto(a){wnds.wpre.show(`${Rag.ragContext}`)}
|
153 |
function elencoDati(a){var b=UaDb.getAllIds();a=[];for(var c of b)b=UaDb.read(c).length,a.push(`${c} (${b})`);c=a.join("\n ");wnds.wpre.show(c)}const showT=a=>{wnds.wpre.show(DataMgr.docs[a])};function elencoDocs(){DataMgr.readDbDocs();DataMgr.readDbDocNames();var a=DataMgr.doc_names,b=UaJtfh();let c=0;b.append("<ul>");for(const g of a){a=b;var d=a.append,e=g,f=c++;d.call(a,`
|
154 |
<li><a href="#" onCLick="showT(${f});">${f+1}.${e}</a></li>
|
155 |
`)}b.append("</ul>");b=b.html();wnds.wdiv.show(`<br><br>${b}`)}function calcQuery(){DataMgr.readDbDocs();DataMgr.readDbDocNames();var a=[];let b=0,c=0;a.push("Documento Num.Parti");a.push("==================");for(const d of DataMgr.docs){const e=DataMgr.doc_names[c];c+=1;const f=Math.ceil(d.length/MAX_PROMPT_LENGTH);b+=f;a.push(`${e} [${f}]`)}a.push("==================");a.push(`Totale num. Parti: ${b}`);a=a.join("\n");wnds.wpre.show(a)}
|
156 |
function deleteDati(a){confirm("Confermi cancellazione dati?")&&(DataMgr.deleteJsonDati(),wnds.wdiv.close(),wnds.wpre.close(),TextOutput.clear())}function deleteSttorage(a){confirm("Confermi cancellazione documenti & dati?")&&(DataMgr.deleteJsonDati(),localStorage.clear(),wnds.wdiv.close(),wnds.wpre.close(),TextOutput.clear(),DataMgr.docs=[],DataMgr.doc_names=[])}async function help1(a){a=await requestGet("./data/help_test.html");wnds.wdiv.show(a)}
|
157 |
+
function loadTestoEsempio(a){DataMgr.loadDoc(`data/${a}`);wnds.wdiv.close()}async function help2(a){a=await requestGet("./help2.html");wnds.wdiv.show(a)}function getTheme(){const a=localStorage.getItem("theme");a&&"dark"==a&&setDark()}function setLight(){document.documentElement.classList.toggle("invert");document.body.classList.remove("theme-dark");document.body.classList.add("theme-light");localStorage.setItem("theme","ligth")}
|
158 |
+
function setDark(){document.documentElement.classList.toggle("invert");document.body.classList.remove("theme-light");document.body.classList.add("theme-dark");localStorage.setItem("theme","dark")}function showPrompts(a){0!=Rag.prompts.length&&(a=Rag.prompts.map((b,c)=>`[${c+1}]${b}\n`).join("\n"),wnds.wpre.show(a))};const WndPre=a=>({w:UaWindowAdm.create(a),out:null,show(b){wnds.closeAll();b=`
|
159 |
<div class="window-text">
|
160 |
<div class="btn-wrapper">
|
161 |
<button class="btn-copy" title="Copia">
|
|
|
183 |
closeAll(){UaWindowAdm.close("id_w0");UaWindowAdm.close("id_w1");UaWindowAdm.close("id_out")}},Menu={init(){const a=document.querySelector("#id-menu-btn");a.addEventListener("change",()=>{document.querySelector("body").classList.toggle("menu-open",a.checked)});const b=document.getElementById("id_log");UaLog.callHide=()=>{b.classList.contains("active")&&b.classList.remove("active")};UaLog.callShow=()=>{b.classList.contains("active")||b.classList.add("active")};UaLog.setXY(54,13).setZ(111).new();UaLog.log_show("")},
|
184 |
close(){const a=document.querySelector("#menu-toggle");document.querySelector("body").classList.remove("menu-open",a.checked);document.querySelector(".menu-btn").checked=!1},async help(){const a=await requestGet("./help0.html");wnds.wdiv.show(a)},upload(){RagUpload.open()},uploadDir(){RagUpload.openDir()},async load(){alert("load")},log(){UaLog.toggle()}},setOutText=a=>{const b=document.querySelector("#id-text-out .pre-text");b.textContent=a;b.scrollTop=b.scrollHeight},TextInput={wnd:null,init(){this.inp=
|
185 |
document.querySelector(".text-input");document.addEventListener("keydown",a=>{document.activeElement!==this.inp&&("F1 F2 F3 F4 F5 F6 F7 F8 F9 F10 F11 F12 Control Alt Shift Meta CapsLock Escape PrintScreen ScrollLock Pause Insert Delete Home End PageUp PageDown ArrowLeft ArrowRight ArrowUp ArrowDown".split(" ").includes(a.key)||a.ctrlKey||a.metaKey||a.preventDefault())});document.querySelector(".clear-button").addEventListener("click",()=>{this.inp.value="";this.inp.focus()});this.inp.addEventListener("keydown",
|
186 |
+
a=>this.handleEnter(a));document.querySelector(".send-input").addEventListener("click",()=>this.send());document.querySelector(".send2-input").addEventListener("click",()=>this.send2());document.querySelector(".clear-input").addEventListener("click",()=>this.clear())},handleEnter(a){"Enter"!==a.key||a.shiftKey||(a.preventDefault(),this.send2())},async send(){if(this.inp.value){if(Rag.ragContext&&!confirm("Vuoi iniziare una nuova elabrazione ?"))return"";showSpinner();setOutText("");var a=this.inp.value.trim();
|
187 |
+
try{let b=await Rag.requestDocsRAG(a);b=cleanOut(b);setOutText(b);this.inp.value="";UaLog.close()}catch(b){a=`send\n${b}`,console.error(a),alert(a),setOutText(a)}hideSpinner()}else alert("Ricorda di scrivere la Query ")},async send2(){if(this.inp.value){showSpinner();ThreadMgr.isFirst()&&setOutText("");var a=this.inp.value.trim();try{let b=await Rag.requestContext(a);if(""==b){hideSpinner();return}b=cleanOut(b);setOutText(b);this.inp.value=""}catch(b){a=`send2\n${b}`,console.error(a),alert(a),setOutText(a)}hideSpinner()}else alert("Ricorda di scrivere la Query ")},
|
188 |
+
clear(){confirm("Confermi cancellazione conversazione? ")&&(this.inp.value="",setOutText(""),ThreadMgr.init())}};
|
189 |
TextOutput={init(){this.copyBtn=document.querySelector(".copy-output");this.copyBtn.addEventListener("click",()=>this.copy());document.querySelector(".clear-output").addEventListener("click",()=>this.clear());document.querySelector(".wnd-output").addEventListener("click",()=>this.openWnd())},openWnd(){const a=document.querySelector("#id-text-out .pre-text").textContent;wnds.wout.show(a)},async copy(){const a=document.querySelector("#id-text-out .pre-text"),b=a.textContent;if(!(2>b.trim().length)){a.classList.add("copied");
|
190 |
this.copyBtn.classList.add("copied");try{await navigator.clipboard.writeText(b)}catch(c){console.error("Errore ",c)}setTimeout(()=>{this.copyBtn.classList.remove("copied");a.classList.remove("copied")},5E3)}},clear(){document.querySelector("#id-text-out .pre-text").textContent=""}};const RagUpload={open(){const a=UaWindowAdm.create("id_upload");a.drag();a.setZ(12);a.vw_vh().setXY(16.5,10,-1);a.setHtml('\n <div class="window-text">\n <div class="btn-wrapper">\n <button class="btn-close" title="chiudi" onclick="UaWindowAdm.closeThis(this)">X</button>\n </div> \n <div class="upload"> \n <h4>Upload file Text / PDF</h4> \n <form id="uploadForm">\n <input class="file" type="file" id="id_fileupload" > \n <button type="button" onclick="RagUpload.upload();">Upload and Convert</button>\n </form>\n <div id="result" class="result"></div>\n </div>\n </div>\n ');
|
191 |
a.show()},async upload(){const a=document.getElementById("id_fileupload").files[0];if(a){var b=a.name;if(DataMgr.doc_names.includes(b))alert("Il file \u00e8 gi\u00e0 in archivio");else{var c=document.getElementById("result"),d=a.name.split(".").pop().toLowerCase();showSpinner();try{let e;if("pdf"===d){const f=new PdfHandler;await f.loadPdfJs();e=await f.extractTextFromPDF(a);f.cleanup()}else if("txt"===d)e=await readTextFile(a);else{alert("Formato file non supportato.");return}DataMgr.addDoc(b,e);
|
static/less/ragrqs.less
CHANGED
@@ -100,6 +100,34 @@ body {
|
|
100 |
display: flex;
|
101 |
}
|
102 |
///////////////
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
103 |
.upload {
|
104 |
@primary-color: darken(@color2, 25%);
|
105 |
@background-color: #121212;
|
|
|
100 |
display: flex;
|
101 |
}
|
102 |
///////////////
|
103 |
+
|
104 |
+
// theme-dark {
|
105 |
+
// .btn-light {
|
106 |
+
// display: inline-block !important;
|
107 |
+
// }
|
108 |
+
// }
|
109 |
+
// .theme-light {
|
110 |
+
// .btn-dark {
|
111 |
+
// display: inline-block !important;
|
112 |
+
// }
|
113 |
+
// }
|
114 |
+
|
115 |
+
|
116 |
+
// .invert {
|
117 |
+
// filter: invert(100%);
|
118 |
+
// background-color: white;
|
119 |
+
// }
|
120 |
+
|
121 |
+
// .invert img,
|
122 |
+
// .invert video,
|
123 |
+
// .invert iframe {
|
124 |
+
// filter: invert(100%);
|
125 |
+
// }
|
126 |
+
|
127 |
+
|
128 |
+
|
129 |
+
|
130 |
+
/////////////////
|
131 |
.upload {
|
132 |
@primary-color: darken(@color2, 25%);
|
133 |
@background-color: #121212;
|
static/ragrqs.html
CHANGED
@@ -131,5 +131,9 @@
|
|
131 |
|
132 |
</html>
|
133 |
<script>
|
134 |
-
|
|
|
|
|
|
|
|
|
135 |
</script>
|
|
|
131 |
|
132 |
</html>
|
133 |
<script>
|
134 |
+
window.addEventListener('load', () => {
|
135 |
+
console.log("Tutti i file esterni (CSS, JavaScript, immagini) sono stati caricati");
|
136 |
+
openApp();
|
137 |
+
});
|
138 |
+
|
139 |
</script>
|
static/ragrqs_.html
CHANGED
@@ -4,14 +4,14 @@
|
|
4 |
<head>
|
5 |
<meta charset="utf-8" />
|
6 |
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
7 |
-
<meta name="description" content="Author:
|
8 |
<title>RagRqs</title>
|
9 |
|
10 |
<link rel="stylesheet" href="less/normalize.css" />
|
11 |
<link rel="stylesheet/less" href="less/ragrqs.less" />
|
12 |
<link rel="stylesheet/less" href="less/ualog3.less" />
|
13 |
<script src="less/less.js"></script>
|
14 |
-
|
15 |
<script src="javascript/uadrag.js"></script>
|
16 |
<script src="javascript/uawindow.js"></script>
|
17 |
<script src="javascript/uajtfh.js"></script>
|
@@ -142,5 +142,17 @@
|
|
142 |
|
143 |
</html>
|
144 |
<script>
|
145 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
146 |
</script>
|
|
|
4 |
<head>
|
5 |
<meta charset="utf-8" />
|
6 |
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
7 |
+
<meta name="description" content="Author:Giuseppe Materni" />
|
8 |
<title>RagRqs</title>
|
9 |
|
10 |
<link rel="stylesheet" href="less/normalize.css" />
|
11 |
<link rel="stylesheet/less" href="less/ragrqs.less" />
|
12 |
<link rel="stylesheet/less" href="less/ualog3.less" />
|
13 |
<script src="less/less.js"></script>
|
14 |
+
|
15 |
<script src="javascript/uadrag.js"></script>
|
16 |
<script src="javascript/uawindow.js"></script>
|
17 |
<script src="javascript/uajtfh.js"></script>
|
|
|
142 |
|
143 |
</html>
|
144 |
<script>
|
145 |
+
// document.addEventListener("DOMContentLoaded", function () {
|
146 |
+
// console.log("DOM completamente caricato e analizzato");
|
147 |
+
// window.addEventListener("load", function () {
|
148 |
+
// console.log("Tutti i file esterni (CSS, JavaScript, immagini) sono stati caricati");
|
149 |
+
// openApp();
|
150 |
+
// });
|
151 |
+
// });
|
152 |
+
|
153 |
+
window.addEventListener('load', () => {
|
154 |
+
console.log("Tutti i file esterni (CSS, JavaScript, immagini) sono stati caricati");
|
155 |
+
openApp();
|
156 |
+
});
|
157 |
+
|
158 |
</script>
|