NEWS
Chat GPT im Javascript Adapter verwenden
-
-
@codierknecht wie gut, dass ich "nur" 5$+Tax versenkt habe - schade eigentlich.
-
@Codierknecht & @haus-automatisierung macht es Sinn eine Issue Report gegen die JS Adapter aufzumachen?
Christian
-
@ch90045 Sich mit dem Thema zu beschäftigen und einen PR mit einer Lösung zu erstellen wäre besser Ich werde da erstmal keine Zeit für investieren, weil die Ergebnisse von ChatGPT bisher eigentlich nicht zu gebrauchen waren, ...
Also gern öffnen, aber nicht hoffen dass sich da bald jemand dran setzt
-
@ch90045 sagte in Chat GPT im Javascript Adapter verwenden:
on tokens per min (TPM): Limit 60000, Requested 62890.
du hast ein limit von 60000 tokens pro minute
das llm gpt-3.5-turbo-16k
kann eh nur 16000 tokens (16k) verarbeiten. alles andere wird ignorierthttps://platform.openai.com/docs/models#:~:text=updated%20GPT%2D3.5%20Turbo%20(16k%20context%20window
direkt kopiert funktioniert der link nicht, daher bitte hier kopieren und im browser öffnen
daher musst du deinen input verkleinern. als context wird auf der oberfläche immer der komplette chat mitgesendet. das gilt in der api eigentlich auch.
-
@oliverio Was meinst du genau mit "du musst deinen input verkleinern" - meine Anfrage für ein einfaches Script war "Schalte am Wochende scene.0.WohnzimmerLicht um 7:00 an" - noch weniger?
-
gemäß fehlermeldung wurden 62000 tokens versendet.
https://deinkikompass.de/blog/openai-gpt-token-guide
das verhältnis buchstaben zu tokens hängt von der sprache ab (von 1:1 bis 1:4 tokens/buchstaben)dann musst du prüfen warum da mehr tokens versendet wurden.
wahrscheinlich wurde als context das komplette script mit versendet -
@oliverio sagte in Chat GPT im Javascript Adapter verwenden:
wahrscheinlich wurde als context das komplette script mit versendet
Als Context wird immer die Dokumentation angehangen (als Markdown). Die ist halt alleine schon sehr lang. Und wenn man viele Geräte definiert hat, dann werden die auch noch mitgeliefert, damit ChatCPT auch die richtigen Objekt-IDs, Räume, usw. kennt.
Das wird ggf. natürlich sehr groß.
-
@oliverio Nun ja, skript war 0 gross, ChatGPT sollte, rein zum testen, ein Skript zur Änderung EINES Zustandes erstellen - denke die Frage war kleiner als 100 Token, der Rest waren Interna.
-
ist im Moment unbrauchbar...leider
Error: 400 This model's maximum context length is 16385 tokens. However, your messages resulted in 49186 tokens
-
@haus-automatisierung said in Chat GPT im Javascript Adapter verwenden:
@oliverio sagte in Chat GPT im Javascript Adapter verwenden:
wahrscheinlich wurde als context das komplette script mit versendet
Als Context wird immer die Dokumentation angehangen (als Markdown). Die ist halt alleine schon sehr lang. Und wenn man viele Geräte definiert hat, dann werden die auch noch mitgeliefert, damit ChatCPT auch die richtigen Objekt-IDs, Räume, usw. kennt.
Das wird ggf. natürlich sehr groß.
Lässt sich das mit der Dokumentation eigentlich ausschalten? Meiner Erfahrung nach macht GPT auch so ganz gute Skripte
-
@nerg Und dann gibst Du immer die Verison des Adapters mit, damit ChatGPT alle verfügbaren Funktionen der Version kennt?!
-
@haus-automatisierung mit ein bisschen Fingerspitzengefühl hab ich ihn bisher ganz gut angeleitet auch ganz ohne Anbindung an die Doku.
Da ich nur tier1 bei der API habe, sprengt die Doku direkt das token Limit. Im Gegensatz zu Lindner würde ich die Schnittstelle lieber schlecht als gar nicht nutzen 🥴Edit: falls jemand noch einen chatGPT Plus Account hat, dann könnte der-/diejenige auch einen individuellen iobroker GPT anlegen, der mit der Doku gefüttert wird und ein paar individuelle Anweisungen zur Codeerstellung bekommt. Zur Not würde ich auch noch Mal Plus abschließen, falls da Interesse besteht. Das würde auch die Schwelle reduzieren für Einsteiger
-
@nerg sagte in Chat GPT im Javascript Adapter verwenden:
mit ein bisschen Fingerspitzengefühl hab ich ihn bisher ganz gut angeleitet auch ganz ohne Anbindung an die Doku.
Da kommt sehr häufig unnötig komplexer Code raus, welcher dann erstmal fetch importiert, statt z.B die internen Methoden zu nutzen. Das Ergebnis ist in den meisten Fällen nicht gut. Das bestätigen auch zig Screenshots in der Facebook-Gruppe, wo Leute ihre "top Ergebnisse" gezeigt haben.
Ich habe schonmal überlegt ein Custom GPT (heißt das so?) zu erstellen, welches dann den ioBroker-Adapter kennt und dann nur noch die Version übergeben werden muss. Damit man auch vernünftigen Code bekommt, welcher die internen Methoden nutzt.
-
@haus-automatisierung ja das stimmt. Blind übernehmen kann man das nicht. Er ist aber auch mit 4o wieder deutlich besser geworden und auch kooperativer.
Ich glaube custom gpt ist richtig. Ich schau mir das Mal an. Hatte das seinerzeit Mal versucht, da waren die Tokens aber sehr niedrig, die man mitgeben konnte. -
@haus-automatisierung
ChatGPT Link
hier mal ein erster Wurf. Gefüttert mit den Docs aus Github, die auch bei der API genutzt werden und ein paar angepassten Anweisungen.// edit: Mit 3 Anweisungen zu diesem Ergebnis:
// Anwesenheitserkennung für verschiedene User anhand von boolean-Datenpunkten // Liste der zu überwachenden Datenpunkte für jeden User const userPresenceDataPoints = { user1: ['geofence.user1', 'wlan.user1'], user2: ['geofence.user2', 'wlan.user2'], // Weitere User und deren Datenpunkte hier hinzufügen }; // Funktion zur Überprüfung der Anwesenheit eines Users async function isUserPresent(user, dataPoints) { for (let dp of dataPoints) { let state = await getStateAsync(dp); if (state && state.val === true) { return true; } } return false; } // Funktion zur Überprüfung und Erstellung eines Datenpunkts async function checkAndCreateDataPoint(user) { const dpPath = `userdata.0.${user}.presence`; const dpObj = await getObjectAsync(dpPath); if (!dpObj) { await setObjectAsync(dpPath, { type: 'state', common: { name: `${user} Presence`, type: 'boolean', role: 'indicator', read: true, write: true, }, native: {}, }); } return dpPath; } // Anwesenheitsprüfung für alle User async function checkAllUsersPresence() { for (let user in userPresenceDataPoints) { let isPresent = await isUserPresent(user, userPresenceDataPoints[user]); const dpPath = await checkAndCreateDataPoint(user); await setStateAsync(dpPath, isPresent); console.log(`${user} ist ${isPresent ? 'anwesend' : 'abwesend'}`); } } // Starte die Anwesenheitsprüfung alle 17 Sekunden setInterval(checkAllUsersPresence, 17000);
habs nicht ausprobiert, aber schaut brauchbar aus.
-
@nerg sagte in Chat GPT im Javascript Adapter verwenden:
aber schaut brauchbar aus.
Auch wieder unnötig kompliziert, statt
setObjectAsync
kann man einfachcreateState
aus der Sandbox nutzen. Dann braucht man den Zugriff auf die Objekte auch nicht freigeben. Genauso gibt esexistsState
-
@haus-automatisierung ja das stimmt. wenn man das ganz nochmal probiert, kommt auch wieder anderer Code raus:
// Funktion, um Anwesenheit der User zu prüfen function checkUserPresence() { const users = ['user1', 'user2', 'user3']; // Liste der User const userPresenceDataPoints = { 'user1': ['geofence.user1', 'wifi.user1'], 'user2': ['geofence.user2', 'wifi.user2'], 'user3': ['geofence.user3', 'wifi.user3'] }; users.forEach(user => { let isPresent = false; // Überprüfe alle Datenpunkte für jeden User userPresenceDataPoints[user].forEach(dp => { if (getState(dp).val) { isPresent = true; } }); const userPresenceState = `userdata.0.${user}.presence`; // Falls der Datenpunkt nicht existiert, lege ihn an if (!existsState(userPresenceState)) { createState(userPresenceState, { type: 'boolean', def: false }); } // Setze den Anwesenheitsstatus setState(userPresenceState, isPresent); }); } // Die Funktion alle 17 Sekunden ausführen schedule("*/17 * * * * *", checkUserPresence); // Initiale Ausführung beim Start des Skripts checkUserPresence();
Eventuell muss man die Anweisungen nochmal konkreter fassen.
//edit: habe ihn nochmal konkreter angewiesen, die docs.md zu befolgen. Probiere es gerne aus: https://chatgpt.com/g/g-y65cMkHAC-iobroker-javascriptgpt