ID.nl logo
Prompt engineering: zo maak je precies het beeld dat je voor ogen hebt
© siraanamwong - stock.adobe.com
Huis

Prompt engineering: zo maak je precies het beeld dat je voor ogen hebt

Plaatjes maken met behulp van kunstmatige intelligentie (AI) is leuk. Alleen hoe krijg je wat je wilt hebben? Die vaardigheid heet prompt engineering. Dit artikel vertelt je er meer over.

Na het lezen van dit artikel bij jij meester in het bedenken van een goede prompt, zodat je precies de afbeelding voorgeschoteld krijgt die jij voor ogen had.

  • Voeg een specifieke stijl toe aan je prompt
  • Voeg de naam van een kunstenaar aan je prompt toe om dat effect te creëren
  • Laat een prompt builder je helpen met het vervolmaken van je vraag
  • Vraag een taalbot als ChatGPT om prompts voor je te genereren

Lees ook: Dall-E of SDXL: wie maakt betere plaatjes?

Bij zowel Dall-E als SDXL vertel je wat voor soort beeld je wilt maken. Dat doe je via een geschreven opdracht die we een prompt noemen. Omdat de kunstmatige intelligentie achter deze systemen is getraind met combinaties van afbeeldingen en Engelstalige beschrijvingen, werken ze het best wanneer je ze in het Engels toespreekt. Als je Nederlandse opdrachten geeft, dan worden deze eerst automatisch in het Engels vertaald. Daarbij gaat enige nuance verloren, als het al niet helemaal misgaat. Wij werken daarom in deze workshop met Engelstalige prompts, maar de principes die we bespreken werken ook bij Nederlandse opdrachten.

Engineering

Bij zowel Dall-E als SDXL kun je terecht met uiterst beknopte prompts, zoals a cute kitten. Bij deze opdracht laten beide programma’s je keer op keer een jong katje zien; elke keer een ander als je de prompt herhaalt. Meestal zijn dit foto’s, omdat deze vaak voorkwamen in de data waarmee de AI-modellen voor dit onderwerp zijn getraind. Soms krijg je als resultaat een tekening, of zelfs een plaatje van iets heel anders. Geen enkel model is honderd procent accuraat.

Wil je meer controle over het resultaat? Dan moet je meer gedetailleerde prompts geven. De kunst van het vinden van de juiste formulering noemen we prompt engineering. Dat is overigens een algemene benaming die van toepassing is op elk generatief AI-systeem. De kunst om SDXL de beste plaatjes te ontlokken, is wel een andere vaardigheid dan die je nodig hebt bij een taalmodel, zoals ChatGPT. Deze workshop richt zich specifiek op prompt engineering voor het maken van plaatjes.

Lees ook: Haal betere resultaten uit ChatGPT met slimme prompts

Scholen

Het is nu iets meer dan drie jaar geleden dat AI de eerste plaatjes kon maken op basis van tekst. Dat is nog vrij recent, maar toch zijn er al verschillende scholen als het gaat om prompt engineering. Vooral mensen die uit de traditionele kunsten komen, willen exact het plaatje maken dat ze voor zich zien. Zo doen ze dat ook als ze werken met een traditioneel medium. Alleen bij AI lopen ze tegen beperkingen op. Kunstmatige intelligentie laat zich bijvoorbeeld maar moeilijk instrueren in het exact positioneren van objecten. Daarnaast is AI ook slecht in tellen. Daardoor geeft een prompt als a man looking at eight cubes in the bottom left corner zelfs na vele pogingen niet het gehoopte resultaat.

Dall-E (links) positioneert de kubussen beter, maar telt net zo slecht als SDXL.

Gelukkig voor deze mensen kent SDXL verschillende mogelijkheden om te beginnen met een eigen schetsje. Dat kan de AI de weg wijzen naar het gewenste resultaat. Tegenover de puristen die AI als een traditioneel medium benaderen, zijn er de mensen die AI omarmen als een snelle manier om heel veel plaatjes te maken. Ze kiezen voor een bepaalde sfeer en gebruiken de afbeeldingen als concept of vinden ze gewoon fraai. Zij geven AI graag alle vrijheid.

Zowel Dall-E (links) als SDXL krijgen alle vrijheid met deze prompt (abstract transcendental bubbles).

Stijlen en technieken

Ben je een purist die uit is op een zeer specifiek plaatje? Of ben je een vrijbuiter die de AI gewoon interessante, bruikbare plaatjes wil laten maken? Het maakt niet uit; in beide gevallen moet je de visuele woordenschat leren. Daarmee kun je het resultaat sturen. Dat doe je door zogeheten modifiers in te zetten. Prompts bestaan doorgaans uit twee delen: het onderwerp en eventuele modifiers; dit zijn termen die de weergave sturen.

In a cute kitten zou je cute als modifier kunnen zien, omdat het iets zegt over het onderwerp. Maar doorgaans bedoelen we met modifier een meer technisch begrip. Denk aan een grafische techniek of medium of de visuele stijl van een bepaalde periode of van een kunstenaar. Ook termen uit de fotografie- en filmwereld of begrippen uit het 3D-ontwerp kunnen dienen als modifier.

Via deze GitHub-pagina ontdek je heel wat populaire modifiers. Hier vind je van heel veel begrippen voorbeelden terug. Laat je niet misleiden door het feit dat deze site op het commerciële MidJourney is gericht. De genoemde modifiers kun je binnen elk AI-model gebruiken. Ze gaan er alleen niet allemaal op exact dezelfde manier mee om. SDXL past modifiers soms wat steviger toe, Dall-E 3 is doorgaans wat subtieler.

Je kunt inmiddels op allerlei sites leren over vele verschillende modifiers.

Kunstenaars

Helaas is genoemde site wat karig als het aankomt op het laten zien van de stijlen van kunstenaars. Maar daarvoor (en heel wat meer) kun je dan weer inspiratie opdoen op www.midlibrary.io. Hier vind je niet alleen namen van schilders, maar bijvoorbeeld ook van architecten, modeontwerpers en fotografen. Je ziet daarbij direct een afbeelding van het effect dat de naam heeft. Overigens kunnen juist de namen van bekende fotografen nuttig zijn als je werk wilt maken dat er fotorealistisch uitziet.

Dit is een goede bron om te leren over de stijlen van kunstenaars.

Ook op deze site zijn de voorbeelden afkomstig van MidJourney. Over het algemeen kunnen SDXL en Dall-E deze stijlen reproduceren. Of je ook daadwerkelijk een afbeelding te zien krijgt, dat hangt af van het platform en de kunstenaar. Dall-E reproduceert het werk van bepaalde kunstenaars niet als er bijvoorbeeld naakt in voorkomt. Dat geldt tot op zekere hoogte ook voor SDXL op Playground AI. Gebruik je SDXL in Nightcafe Studio, dan krijgt zo’n plaatje een nsfw-label (not suitable for work). Draai je SDXL op je eigen hardware, dan heb je geen enkele beperking.

Dall-E (links) en SDXL proberen de stijl van de Amerikaanse schilder Ernie Barnes na te bootsen.

Afkijken

Naast de sites waar je de uitwerking van allerlei modifiers bekijkt, zijn er nog andere manieren om de kunst af te kijken. Zo is er een AI met de naam CLIP Interrogator. Deze probeert het omgekeerde te doen van een beeldgenerator; namelijk het maken van een mogelijke prompt op basis van een plaatje. Je kunt CLIP Interrogator op verschillende sites online proberen, bijvoorbeeld via deze pagina of deze pagina. Houd rekening met een wachtrij. Werk je lokaal met SDXL, bijvoorbeeld via Stable Diffusion WebUI, dan kun je CLIP Interrogator daarbinnen ook op je eigen systeem gebruiken. Overigens kunnen we iets soortgelijks inmiddels ook met Bing Chat (zie verderop).

Daarnaast zijn er sites waar je werk van anderen kunt bekijken. Dit is compleet met prompt, zodat je inspiratie opdoet en nieuwe trucs leert. Vaak zijn dat ook sites waar je (tegen betaling) plaatjes kunt maken. Kijk bijvoorbeeld eens op www.lexica.art of https://creator.nightcafe.studio/explore.

Je kunt veel leren door te kijken naar het werk van anderen.

Hulptroepen

Na het experimenteren met allerlei modifiers en het bekijken van de verschillende sites met voorbeelden, bouw je vanzelf een lijst op met favoriete termen. Die lijst kan best lang worden en dan vergeet een mens weleens wat. Gelukkig is er hulp in de vorm van Prompt Builder. Deze onlinetool helpt je bij het maken van prompts voor onder andere Stable Diffusion en MidJourney. Als je met Dall-E werkt, kun je op de websitepagina voor Generic kiezen.

Prompt Builder helpt je bij het opbouwen van een prompt.

Heb je je favoriete model gekozen? Vul dan het onderwerp in en kies vervolgens uit allerlei categorieën de modifiers. Je krijgt van de gekozen modifiers een voorbeeld te zien. De prompt kun je vervolgens kopiëren en plakken in de AI waarmee je je plaatje wilt maken.

Met die prompt zet je vervolgens bijvoorbeeld SDXL aan het werk.

AI met AI

Een nog eigentijdsere hulpbron is natuurlijk Bing Chat, of ChatGPT. Deze taalmodellen kun je op verschillende manieren gebruiken. Stel, je wilt plaatjes maken van sportwagens in SDXL die een gevoel van snelheid overbrengen. Vraag je dit in het Nederlands, dan geeft Bing Chat Nederlandse prompts, zelfs als je om Engelse vraagt. We geven daarom een Engelse opdracht:

Give me 5 prompts I can use to create images in Stable Diffusion. The images must show a sports car and convey a sense of speed.

We krijgen vervolgens keurig vijf Engelse prompts die we in SDXL kunnen gebruiken.

AI wil de bestuurder nog weleens achterwege laten, maar we hebben wel een snelle wagen.

Je kunt Bing Chat ook gebruiken voor het toevoegen van details. Vooral in combinatie met Dall-E 3 werkt dit goed. Dall-E 3 kan in vergelijking met SDXL veel beter uit de voeten met lange gedetailleerde prompts. Vraag aan Bing Chat bijvoorbeeld:

Give me 5 detailed visual descriptions of an upper class woman in a 1950s living room. Each description must have 70 words or less.

Je krijgt hiermee vijf zeer uitgebreide beschrijvingen. Die kun je aan Dall-E geven om er een plaatje van te maken. Uiteraard kun je deze nog naar wens aanpassen.

Dall-E (links) neemt meer details mee van de zeer lange prompts.

Beschrijving

Behalve dat je Bing Chat kunt benutten om prompts te maken, kun je inmiddels ook plaatjes uploaden. De AI kan deze vervolgens analyseren. Na het uploaden van een plaatje vraag je bijvoorbeeld:

I want to use Dalle 3 to create similar images. Can you give me 5 prompts of at most 70 words to do that?

Vervolgens krijg je vijf visuele beschrijvingen van de gevraagde lengte die je kunt testen in je favoriete beeldgenerator. De reden dat we er vijf vragen is overigens dat niet elke prompt even goed werkt. Ook hoeven we zo minder opdrachten aan Bing Chat te geven.

Ook interessant om te lezen: Boost de bot! Met deze extensies kan ChatGPT nog veel meer

Genuanceerd

Dall-E maakt weliswaar geweldige plaatjes, maar het is helaas een zwarte doos. Je stopt er een prompt in en er rolt een plaatje uit. Breng je een kleine verandering aan in de prompt, dan krijg je een ander plaatje. Alleen dat zou ook zijn gebeurd zonder die verandering. Bij SDXL kun je wel precies zien hoe een kleine wijziging in een prompt uitpakt, zeker wanneer je in Playground gebruikmaakt van de Preview-modus.

Zo zal a foggy forest in autumn een net iets ander plaatje opleveren dan an autumn forest, foggy. Dat zelfs de kleinste wijziging in een prompt effect heeft, kun je zien wanneer je een preview van Portrait of a man by Rembrandt vergelijkt met Portrait of a man, by Rembrandt. Voeg je meer komma’s toe dan is het resultaat steeds een beetje anders totdat ineens (bij ongeveer 140 komma’s) de herkenbare stijl van Rembrandt verdwijnt!

Dol op de stijl van Rembrandt

Hang een schilderij van deze meester op in huis

Loze woorden

Een andere manier om (subtiele) variaties op een prompt te creëren, is het toevoegen van willekeurige namen. Voeg je bijvoorbeeld aan een van bovenstaande prompts ,by Willem de Groot toe, dan wordt het resultaat net wat anders dan wanneer je ,by Karel Sinaasappel toevoegt. Zet je in plaats daarvan ,by Karel Appel erbij, dan is het resultaat flink anders. SDXL herkent de naam als kunstenaar en probeert die stijl te combineren met de stijl van Rembrandt.

Behalve willekeurige namen kun je ook onzinwoorden ergens in een prompt plaatsen voor meer of minder subtiele variaties, bijvoorbeeld Portrait of a nubiunmkfa man, by Rembrandt. Naast onzinwoorden kunnen typfouten soms tot gelukkige ongelukken leiden en die kun je natuurlijk ook bewust maken.

Het toevoegen van willekeurige namen of woorden kan het resultaat subtiel beïnvloeden.

Magische prompts

Zoals we eerder al zeiden, zijn er – naast mensen die exact het plaatje proberen te maken dat ze voor zich zien – ook gebruikers die het werken met AI meer zien als een ontdekkingsreis. Het zijn virtuele fotografen die hier en daar een plaatje schieten in de wereld van alle denkbare beelden die in een AI-model zitten verstopt. Zulke mensen zijn altijd op zoek naar magische prompts; opdrachten die een AI heel veel vrijheid geven en zeer uiteenlopende resultaten opleveren. Probeer bijvoorbeeld eens a female portrait from a mandelbulb.

Omdat Dall-E een beter taalbegrip heeft, kun je daar prompts aan geven waar SDXL echt niets van bakt. Probeer maar eens: an image that contains a copy of itself, eventueel in combinatie met je favoriete modifiers. Met die ene prompt maakt Dall-E genoeg verschillend materiaal voor jaren kijkplezier. Als dat niet magisch is!

Zowel Dall-E (links) als SDXL kunnen iets met dezelfde magische prompt.

Tot slot

Zowel Dall-E 3 als SDXL hebben hun charmes en hun voor- en nadelen. Er is dan ook geen reden om ze niet te laten samenwerken. Zo kun je een zeer coherent plaatje laten maken door Dall-E (dat is de grote kracht van dit systeem) en dat vervolgens als startpunt gebruiken voor SDXL. Daar kun je weer profiteren van de extra mogelijkheden van inpainting en outpainting. Bovendien kun je zo bepaalde beperkingen van Dall-E omzeilen, bijvoorbeeld als het gaat om het afbeelden van bestaande personen.

Weet je nu alles over het maken van prompts? Nee, prompt engineering is een ontdekkingsreis waar geen eind aan komt en deze vaardigheid stuit met elk nieuw AI-model op verrassingen. Veel plezier daarmee!

Of schiet zelf het beeld wat jij voor ogen hebt:

▼ Volgende artikel
AI zonder programmeren: Zo bouw je je eigen chatbot
© ID.nl
Huis

AI zonder programmeren: Zo bouw je je eigen chatbot

Misschien heb je wel eens een vraag gesteld aan een AI-chatbot als ChatGPT, Microsoft Copilot of Perplexity. Maar hoe ontwerp je zelf nu zo'n chatbot? Met de juiste tools is daar zelfs weinig tot geen programmeerwerk voor vereist. We bekijken twee uiteenlopende oplossingen.

Een AI-chatbot is een digitale gesprekspartner die wordt aangedreven door kunstmatige intelligentie. Meestal is de intelligentie gebaseerd op een taalmodel dat is getraind om mensachtige gesprekken te voeren. In tegenstelling tot traditionele op regels gebaseerde chatbots, die alleen vooraf ingestelde antwoorden geven, kan een AI-chatbot vrije tekst begrijpen en ‘natuurlijke’ reacties geven.

In dit artikel kijken we naar het bouwen van een eigen chatbot die je op je desktop of mobiel kunt gebruiken en zelfs op een eigen website kunt plaatsen. We bespreken twee manieren. De eenvoudigste is een no-code chatbotplatform dat het AI-gedeelte achter de schermen afhandelt en je via een gebruiksvriendelijke interface laat bepalen hoe de gespreksflow verloopt. Typische voorbeelden zijn Chatfuel en Chatbot voor zakelijke toepassingen. Daarnaast zijn er de meer toegankelijke Poe en Coze, die we hier behandelen. Onze tweede oplossing is technischer, maar flexibeler. Daarbij gebruik je de Application Programming Interface (API) van een AI-taalmodel om de AI-functionaliteit in je eigen omgeving te integreren. Hiervoor werken we graag met de online omgeving Google Colab.

Poe

Laten we starten met een gebruiksvriendelijke optie: het no-code chatbotplatform Poe (www.poe.com). Je kunt hier ook de app voor desktop of mobiel downloaden en installeren, met vrijwel dezelfde interface en functies als in de browser. De eerste keer maak je een account aan of meld je je aan met je Google- of Apple-account. Via Bots and apps kun je met allerlei AI-chatbots praten, maar in dit geval willen we vooral een eigen chatbot maken. Concreet gaat het om het creëren van een eigen ‘persona’ binnen een gekozen AI-model. Zo’n persona kun je zien als het perspectief, de rol of identiteit die je een AI-bot meegeeft.

Klik hiervoor op Create +. Je krijgt nu verschillende opties, zoals Image generation bot, Video generation bot en Prompt bot. Wij kiezen dit laatste.

Poe bestaat ook als desktop-app en biedt toegang tot vele tientallen AI-modellen.

Creatie

Je hoeft nu eigenlijk alleen maar een onlineformulier in te vullen. We doorlopen kort de belangrijkste onderdelen. Naast het gekozen bottype moet je een naam verzinnen. Omdat deze deel uitmaakt van de url, kies je bij voorkeur een originele, korte naam in kleine letters. Voeg ook een beschrijving toe, die zichtbaar is voor gebruikers van je bot.

Bij Base bot selecteer je een geschikt AI-model, bijvoorbeeld Claude-Haiku-3, GPT-4o-mini, GPT-5 of Grok-4. Afhankelijk van het model gelden er soms beperkingen. Poe-abonnees krijgen doorgaans uitgebreidere toegang tot de duurdere modellen.

Bij Prompt beschrijf je nauwkeurig en uitgebreid hoe de bot moet reageren. De optie Optimize prompt for Previews kun je uitgeschakeld laten. Vul bij Greeting message een welkomstwoord in dat de bot bij elke start toont. Het onderdeel Advanced kun je eigenlijk ongemoeid laten, maar interessant is wel dat je bij Custom temperature het ‘creativiteitsgehalte’ van de bot kunt instellen: hoe hoger de waarde, hoe creatiever en onvoorspelbaarder.

Bij Access kies je de zichtbaarheid van je bot. Wellicht is Only people with the access link de handigste optie, waarna de url zichtbaar wordt en je deze kunt verspreiden. Klik bovenin op Edit picture en kies of ontwerp een passend pictogram. Is alles ingevuld, klik dan onderin op Publish. Je bot is nu klaar voor gebruik. Om je bot te bewerken, hoef je deze maar bij Bots and apps te selecteren en via het knopje met de drie puntjes op Edit te klikken. Ook de optie Delete is beschikbaar.

Geef duidelijk aan wat je bot precies moet doen.
GPT's van OpenAI

Binnen de omgeving van OpenAI (https://chat.openai.com) kun je ook je eigen AI-chatbots maken, de zogeheten GPT’s. Hiervoor heb je wel een plusabonnement nodig (23 euro per maand). Je bent daarbij ook beperkt tot de GPT-modellen van OpenAI, maar je kunt je creaties wel delen via een link of in de GPT-store.

In het kort werkt dit als volgt. Meld je aan en klik links op GPT’s. Klik rechtsboven op + Maken. Via Configureren stel je alles handmatig in, maar via Maken kan het ook ‘al converserend’. Beschrijf kort wat je GPT moet doen en voor wie. Laat de tool een naam en profielfoto voorstellen en beantwoord de vragen om toon en werking af te stemmen. Test je GPT in de preview en ga daarna naar Configureren, waar je naam, beschrijving, instructies en gespreksopeningen ziet. Bij Kennis kun je bestanden uploaden zodat je GPT ook informatie uit je eigen documenten haalt. Via Nieuwe handeling maken koppel je eventueel acties aan externe API’s, gebruik alleen API’s die je vertrouwt. Bevestig met Maken en bepaal hoe je je GPT deelt: Alleen ik, Iedereen met de link of GPT-winkel (in een zelfgekozen categorie). Rond af met Opslaan. Je kunt de link (https://chatgpt.com/g/<code><naam>) daarna kopiëren en verspreiden. Via GPT’s / Mijn GPT’s kun je eerder gemaakte GPT’s bewerken of verwijderen.

Je kunt ook je ook eigen ‘chatbots’ (GPT’s) ontwerpen, gebruiken en met anderen delen.

Poe biedt ook geavanceerdere mogelijkheden als een Server bot-type (waarmee je ook andere API’s kunt aanroepen). Via Knowledge base kun je verder eigen informatiebronnen toevoegen waaruit de bot kan putten. Voor complexere bots gebruiken we toch liever het no-code platform Coze (www.coze.com) dat veel extra opties kent. Meld je aan met je Google-account, klik op + Create in de linkerkolom en daarna op + Create bij Create agent.

Coze

Coze gebruikt de term agent in plaats van bot om duidelijk te maken dat je er een digitale assistent mee kunt maken die niet alleen met een AI-model antwoorden geeft, maar ook geheugen of context kan gebruiken en meerdere kanalen kan bedienen, zoals een website of een Discord-server, maar zover gaan we hier niet.

Vul een passende naam voor je bot of agent in en schrijf een korte maar duidelijke omschrijving, bijvoorbeeld “Deze bot haalt allerlei informatie uit onze eigen documenten rond computerbeveiliging.” Laat Personal geselecteerd bij Workspace en klik linksonder op het knopje om een geschikt pictogram te uploaden of klik op het sterretje om er een te laten genereren. Klik daarna op Confirm.

De start van je eigen AI-chatbot (of agent) in Coze.

Uitwerking

Je komt nu in je dashboard waar je de bot verder vorm kunt geven. Ontwerp de persona door in het linkerdeelvenster een uitvoerige omschrijving van de bot in te vullen. Optimaliseer deze omschrijving snel met het blauwe knopje Auto Optimize prompt rechtsboven. Na bevestiging met Auto-optimize werkt Coze meteen een geoptimaliseerde prompt uit voor de persona. Klik op Replace om deze te gebruiken. In het rechterdeelvenster kun je je bot direct testen. De antwoorden komen uit de kennisdatabank van het geselecteerde model (zoals GPT-4o).



Wil je dat de bot ook uit eigen bronnen put, dan moet je deze eerst uploaden. Dit doe je in het middelste deelvenster, bij

Knowledge, waar je uit Text, Table en Images kunt kiezen. Klik op het plusknopje bij bijvoorbeeld Text en daarna op Create knowledge. Selecteer Text format en geef een naam aan je informatiebundel. Je kunt data ophalen uit bronnen als Notion of Google Doc, maar wij kiezen voor Local documents om eigen bestanden te uploaden. Klik op Create and import en versleep de gewenste documenten naar het venster. Klik daarna op Next (3x) en wat later zijn je documenten verwerkt. Rond af met Confirm en met Add to Agent rechtsboven. Je vindt je informatiebundel nu terug bij Knowledge en de bot put voortaan (ook) uit deze gegevens.

Om je bot beschikbaar te maken, klik je rechtsboven op Publish en daarna op Confirm. Je kunt hem op diverse platformen publiceren, onder meer in de Coze Agent Store. Selecteer een passende categorie en bevestig met Publish.

Laat AI je helpen bij het ontwerpen van een optimale persona.

Extra's

Daarnaast biedt Coze nog diverse andere nuttige opties, zoals talrijke plug-ins. Klik hiervoor op het plusknopje bij Plugins of gebruik het A-knopje om automatisch geschikte plug-ins te laden op basis van je persona-beschrijving. Deze kun je meteen inzetten, eventueel na optimale afstelling via het tandwielpictogram.

Je kunt de functionaliteit van je bot eenvoudig uitbreiden met talrijke plug-ins.

API-sleutels

No code-platformen als Poe en Coze zijn handig, maar wil je meer flexibiliteit en schrik je niet terug voor enige basiscodering, dan werk je beter met de API van een AI-model. Deze fungeert als tussenpersoon die je script en de AI-dienst laat communiceren via een set regels en commando’s. We gaan uit van de API van OpenAI (GPT) en maken eerst een sleutel aan om de API-interface te gebruiken. Ga naar https://platform.openai.com/api-keys, meld je aan met je account (zoals Google) en klik op +Create new secret key. Geef de sleutel een naam, bijvoorbeeld aibot, en klik op Create secret key. Klik daarna op Copy en bewaar de sleutel op een veilige plek. Rond af met Done: de sleutel is nu toegevoegd. Je kunt deze hier op elk moment ook weer intrekken.

Je hebt een sleutel nodig om de API te kunnen gebruiken.

Interactie

Een snelle manier om een script te maken dat deze API aanroept, is via het gratis Google Colab (https://colab.research.google.com), een online notitieboek voor Python. Meld je aan met je Google-account, klik op + Nieuw notebook of ga naar Bestand en kies Nieuw notebook in Drive, en geef het ipynb-bestand (Interactive PYthon NoteBook) een zinvolle naam. Het notebook wordt automatisch in je Google Drive bewaard en is bereikbaar via het pictogram met de oranje cirkels.

Klik nu op + Code voor je eerste codecel, waarmee je de OpenAI-bibliotheek installeert:

!pip install openai

Voer dit uit met het pijlknopje en klik vervolgens op + Code voor de tweede cel met de volgende code:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

response = client.chat.completions.create(

    model="gpt-3.5-turbo",

    messages=[{"role": "user", "content": "Wat weet je over Haarlem( Nederlands)?"}]

)

print(response.choices[0].message.content)


Je laadt hierbij eerst de geïnstalleerde Python-bibliotheek en zet je geheime sleutel in de clientconfiguratie. Vervolgens stuur je een chataanvraag naar OpenAI en bewaar je het antwoord in de variabele ‘response’. Vervolgens haal je de tekst van het (eerste) antwoord op en druk je dit af in de uitvoer van de code-cel.

Een eenvoudige interactie tussen je script en GPT via de API.

Eigen chatbot

 We gaan nu een stap verder en maken er een heuse chatbot van die via een while-lus een doorlopend gesprek kan voeren:


from openai import OpenAI

client = OpenAI(api_key="<je_API-sleutel>")

messages=[

    {"role":"system","content":"Je beantwoordt elke prompt leuk, maar correct, met een rijmschema zoals ABAB of ABBA"}]

while True:

  user_input=input("Jij:")

  if user_input.lower() in ["stop","exit","quit"]:

    break

  messages.append({"role":"user","content":user_input})

  response=client.chat.completions.create(

      model="gpt-4o",messages=messages)

  bot_reply=response.choices[0].message.content

  print("Bot:",bot_reply)

  messages.append({"role":"assistant","content":bot_reply})


Zolang de gebruiker geen stopwoord invoert, blijft de lus actief. De bot antwoordt in de stijl en taal die je zelf hebt vastgelegd in de systeemrol (zie coderegel 3). Met de methode-aanroep messages.append voeg je telkens een nieuw bericht van zowel de gebruiker (user) als de bot (assistant) toe aan de gespreksgeschiedenis.

Mocht je ergens een fout hebben gemaakt in je script, dan is de kans groot dat je via de knop Fout uitleggen nuttige feedback krijgt en met de knop Accepteren (en uitvoeren) de fout zelfs automatisch kunt laten verbeteren.

In het kader ‘Mooi gepresenteerd’ lichten we kort toe hoe je dit script bijvoorbeeld ook op een eigen webpagina kunt laten draaien.

Onze rijmende chatbot wordt wakker geschud vanuit Colab.
Mooi gepresenteerd

Je Colab-script werkt, maar het oogt niet fraai en je wilt het natuurlijk mooi gepresenteerd met anderen delen. Dit doe je het makkelijkst met Gradio, een opensource-Python-bibliotheek waarmee je snel een webinterface rond je script bouwt. Installeer en importeer daarvoor eerst Gradio in je Colab-omgeving:

!pip install -q gradio

import gradio

Via www.kwikr.nl/colabcode vind je de code (als py-bestand) waarmee je rond het Colab-script met Gradio een eenvoudige webinterface genereert. Deze verschijnt in je Colab-omgeving, maar je krijgt ook een publieke url te zien waar je de interface rechtstreeks kunt openen (https://<code>.gradio.live).

Dankzij de volgende aanroep in de laatste coderegel kunnen bezoekers van deze webpagina je chatbot-script ook als PWA-app op hun pc bewaren en starten:

demo.launch(share=True,pwa=True)

Een alternatief is deze webpagina via een <iframe>-instructie in de html-code van je eigen site op te nemen:

<iframe src=https://<code>.gradio.live></iframe>

Gradio heeft een eenvoudige webinterface gecreëerd voor ons chatbotscript.
▼ Volgende artikel
De beste koptelefoon voor in de trein: rustig reizen met noise cancelling
© Svetlana - stock.adobe.com
Huis

De beste koptelefoon voor in de trein: rustig reizen met noise cancelling

Behoefte aan totale rust tijdens je treinreis? De juiste koptelefoon filtert lawaai weg en verhoogt je concentratie. Ontdek waarom active noise cancelling (ANC) niet mag ontbreken. Wij laten je zien welke functies, zoals comfort en lange accuduur, belangrijk zijn voor de forens of gelegenheidsreiziger.

Reizen met de trein kan heerlijk zijn, maar luidruchtige medepassagiers en het gedender over het spoor verstoren nogal eens de rust. Een goede koptelefoon maakt hier het verschil tussen irritatie en ontspanning. Als je op zoek bent naar de beste optie voor onderweg, is er eigenlijk maar één technologie die er echt toe doet: active noise cancelling. In dit artikel lees je waar je precies op moet letten.

Waarom active noise cancelling onmisbaar is

De absolute topprioriteit voor elke treinreiziger is active noise cancelling, oftewel ANC. Deze techniek gebruikt microfoons aan de buitenkant van de oorschelpen om omgevingsgeluid op te vangen en een tegengeluidsgolf te produceren. Vooral het constante, lage gebrom van de treinmotor en de wielen op de rails worden hiermee effectief weggefilterd. Hoewel geen enkele koptelefoon álle geluiden volledig blokkeert, zorgen modellen met hoogwaardige ANC ervoor dat je op een normaal volume naar muziek of podcasts kunt luisteren zonder dat je het volume ongezond hard hoeft te zetten om het lawaai te overstemmen.

Over-ear versus in-ear in het openbaar vervoer

Naast de technologie is de pasvorm van groot belang voor de demping. Over-ear modellen, die volledig over je oren vallen, bieden van nature al een goede passieve isolatie. De oorkussens sluiten je gehoorgang af van de buitenwereld, wat de actieve ruisonderdrukking aanzienlijk ondersteunt. Voor de meeste forenzen is dit de beste keuze. In-ear oordopjes zijn weliswaar compacter en makkelijker mee te nemen, maar laten vaak toch iets meer geluid door omdat ze minder fysieke barrière opwerpen. Als comfort en maximale stilte voorop staan, wint de over-ear variant het sowieso.

©ER | ID.nl

Comfort en accuduur voor lange ritten

Omdat je in de trein vaak langere tijd stilzit, mag de koptelefoon niet gaan knellen. Let daarom goed op de kwaliteit van de hoofdband en de oorkussens; traagschuim (memory foam) is hierbij een aanrader omdat dit materiaal zich naar je hoofd vormt en de druk verdeelt. Daarnaast is de accuduur een belangrijke factor voor de frequente reiziger. Zoek naar modellen die minimaal 20 tot 30 uur meegaan met ANC ingeschakeld. Veel moderne koptelefoons beschikken bovendien over snellaadfuncties, waardoor je na 10 minuten laden weer uren vooruit kunt. Daarmee voorkom je dat je halverwege je reis opeens zonder muziek komt te zitten.

Connectiviteit en handige functies

Een functie die specifiek in de trein van pas komt, is de transparantiemodus. Hiermee versterk je tijdelijk het omgevingsgeluid via de microfoons, zodat je een omroepbericht van de conducteur kunt horen zonder je koptelefoon af te zetten. Ook multipoint-bluetooth is een waardevolle toevoeging voor forenzen die werken tijdens het reizen. Hiermee koppel je de koptelefoon gelijktijdig aan zowel je smartphone als je laptop, zodat je naadloos kunt wisselen tussen een videocall en je favoriete afspeellijst zonder opnieuw verbinding te hoeven maken.

Populaire merken voor noise cancelling koptelefoons

Als we kijken naar de marktleiders op het gebied van ruisonderdrukking, springen een paar namen er direct uit. Sony wordt al jaren geprezen om hun toonaangevende XM-serie, die bekendstaat om uitstekende ANC-prestaties en uitgebreide app-ondersteuning. Bose is de directe concurrent en blinkt vaak uit in draagcomfort en zeer effectieve stilte, wat bijvoorbeeld de QuietComfort-serie enorm populair maakt onder zakelijke reizigers. Voor liefhebbers van een meer audiofiele geluidsweergave is Sennheiser een sterke optie, waarbij geluidskwaliteit en functionaliteit in balans zijn, zoals de Momentum 4. Tot slot kiezen Apple-gebruikers vaak voor de AirPods Max en AirPods Pro vanwege de naadloze integratie met hun andere apparaten, hoewel deze in een aanzienlijk hoger prijssegment vallen.