ID.nl logo
MidJourney: wat is het en hoe gebruik je het?
© ER - ID.nl
Huis

MidJourney: wat is het en hoe gebruik je het?

Er is een nieuwe speler in de wereld van kunst en technologie die de aandacht trekt en je hebt de naam vast al eens horen vallen: MidJourney. Deze revolutionaire AI-tool transformeert tekstbeschrijvingen in unieke, hoogwaardige afbeeldingen. Maar wat is MidJourney precies, wat kun je ermee en hoe gebruik je het? In dit artikel geven we antwoord op die vragen en leggen we alles uit wat je moet weten.

In dit artikel leer je wat MidJourney is en wat je er zoal mee kunt. Daarbij gaan we onder meer in op:

  • De geschiedenis van MidJourney

  • De verschillen met concurrerende platforms

  • Hoe je MidJourney gebruikt

  • Hoe je omgaat met prompts

  • Hoe je eigen afbeeldingen gebruikt

  • De verschillende parameters

  • De verschillende modellen

  • Ook lezen: Social media verandert razendsnel door AI

MidJourney is een onafhankelijk onderzoekslab dat met zijn gelijknamige AI-programma momenteel voor een heuse revolutie zorgt in de wereld van kunstmatige intelligentie. Het programma is ontworpen om afbeeldingen te creëren op basis van tekstbeschrijvingen, vergelijkbaar met OpenAI's DALL-E en Stable Diffusion.

Terwijl de onderliggende technologie vermoedelijk is gebaseerd op Stable Diffusion, hebben de makers van MidJourney hun eigen unieke stijl ontwikkeld voor de gegenereerde afbeeldingen die veel aandacht trekken van zowel AI-enthousiastelingen als kunstenaars. 

MidJourney geeft steeds vier resultaten van jouw opdracht weer, in dit geval een rockstar-versie van Albert Einstein.

Geschiedenis van MidJourney

David Holz, medeoprichter van Leap Motion, is de drijvende kracht achter MidJourney. Holz is een bekend figuur in de tech-industrie, die in 2010 Leap Motion mede-oprichtte, een bedrijf dat bewegingssensortechnologie produceert voor computers en virtual reality-headsets. 

MidJourney debuteerde voor het eerst op 14 maart 2022, toen de Discord-server werd gelanceerd met een verzoek om hoogwaardige foto's op Twitter en Reddit te posten voor de training van dit nieuwe systeem. Sindsdien heeft het bedrijf onvermoeibaar doorgewerkt om zijn algoritmen te verbeteren en verschijnt er om de paar maanden wel een nieuwe versie. Versie 2 van het algoritme werd in april 2022 gelanceerd, gevolgd door versie 3 in juli van hetzelfde jaar. Op 10 november 2022 werd de alfaversie van versie 4 uitgebracht. 

Met versie 5, dat verscheen op 16 maart 2023, zette MidJourney opeens reusachtige stappen ten opzichte van concurrerende platforms als DALL-E van OpenAI (dat we inmiddels ook kennen van ChatGPT) en Stable Diffusion. Dat werd nog een pijnlijk duidelijk toen op 4 mei 2023 versie 5.1 werd vrijgegeven, waarmee verrassend realistische afbeeldingen kunnen gegenereerd.

MidJourney in de kunstwereld MidJourney heeft de aandacht getrokken van kunstenaars over de hele wereld, die het gebruiken om unieke en boeiende kunstwerken te creëren. Door de mogelijkheid om gedetailleerde, artistieke afbeeldingen te genereren vanuit eenvoudige tekstprompts, biedt MidJourney een ongeëvenaarde mogelijkheid voor kunstenaars om hun creativiteit te verkennen en te uiten.

Verschillen tussen MidJourney en DALL-E 2 / Stable Diffusion

Hoewel het concept van deze beeldgeneratietools vergelijkbaar is, verschillen de resultaten die sterk van model tot model. Het is daarnaast maar net wat je het meest aanspreekt.

MidJourney vs Dall-E

Hoewel MidJourney en DALL-E 2 beide geweldige kwaliteit leveren, is er een significant verschil in de stijl van afbeeldingen die ze genereren. Afbeeldingen gegenereerd door DALL-E 2 zijn meer schilderachtig. MidJourney streeft naar een meer realistische stijl. 

Al met al is MidJourney een stuk beter in het maken van gedetailleerde afbeeldingen. 

MidJourney vs Stable Diffusion

MidJourney werkt makkelijker en vereist minder prompt-tinkering in vergelijking met Stable Diffusion, terwijl die laatste het voordeel heeft van opensource-ontwikkeling en dus met specifieke datasets kan worden getraind om te krijgen wat je wilt. 

MidJourney heeft niettemin de bovenhand als het gaat om kwaliteit van afbeeldingen die de platforms produceren. Ook de grafische stijl van MidJourney is een stuk aantrekkelijker (al is dat een kwestie van smaak), maar het is ook een van de belangrijkste redenen voor de wereldwijde populariteit. Al de genoemde platforms bevinden zich nog in de bètafase en evolueren voortdurend, dus wie weet welke kant het nog op gaat. 

Dezelfde prompt als van de afbeelding hierboven, maar dan door DALL-E.

Hoe gebruik je MidJourney AI?

Momenteel kan MidJourney alleen worden benaderd via de Discord-server, dus om het te gebruiken, heb je om te beginnen een Discord-account nodig. Discord is een communicatieplatform dat oorspronkelijk is ontworpen voor gamers, maar nu wordt gebruikt door allerlei soorten online community's – waaronder dus MidJourney. Het biedt spraak-, video- en tekstcommunicatie, evenals gedeelde kanalen om discussies te organiseren.

Om aan de slag te gaan met MidJourney, bezoek je eerst de website en klik je op de knop linksonder om deel te nemen aan het bètaprogramma. Helaas bestaat er geen gratis deelname meer, dus om MidJourney te gebruiken, zul je een betaald abonnement moeten afsluiten.

Daarna moet je een uitnodiging accepteren voor de MidJourney Discord-server. Open of download nu de Discord-app en klik op het bootvormige pictogram van de MidJourney-server. Je kunt elke nieuwkomerskamer met de naam 'newbie' betreden (zichtbaar in de balk links). 

Om een afbeelding te maken, moet je eerst het scherm van de MidJourney Bot tevoorschijn toveren. Dat doe je door in de app linksboven op het Discord-logo te klikken. Vervolgens verschijnt er nieuwe balk met daarin je Discord-contacten. Als het goed is, staat daar nu ook de MidJourney Bot tussen. Klik daarop om een chatvenster te openen; dit is de plek waar we met beeldgeneratie aan de slag gaan!

Abonnementsprijzen voor MidJourney beginnen bij 10 dollar (exclusief belasting).

Prompt engineering in MidJourney

Je gebruikt zogenaamde prompts (de gangbare term voor opdrachten) om de MidJourney Bot aan het werk te zetten en afbeeldingen te laten genereren. Prompts dienen trouwens in het Engels te worden ingediend; MidJourney begrijpt (nog) geen Nederlands. Je geeft een tekstbeschrijving van het beeld dat je wilt maken en stuurt daarmee de bot in zijn generatieproces. Of je nu een foto, schilderij of gewoon zomaar een doodle wilt, de prompt kan de bot helpen het exacte type afbeelding te produceren dat jij voor ogen hebt. De prompts worden gebruikt met het /imagine-commando.

Je tikt /imagine in de regel waarin je normaal gesproken een chatbericht verstuurt, gevolgd door Enter. Daarna tik je direct achter het woordje prompt een Engelstalige opdracht (de prompt dus), bijvoorbeeld: photo of a man on a horse (foto van een man op een paard).

Basisprompts zijn zo eenvoudig als een enkel woord, zin of zelfs een emoji. De bot hecht geen waarde aan grammatica of zinsstructuur, maar woordkeuze is enorm belangrijk. Meer specifieke synoniemen werken beter dan generieke, en minder woorden betekent dat elk woord een krachtiger invloed heeft. 

Om ervoor te zorgen dat de bot specifieke details genereert, voeg je extra elementen toe. Je schildert als het ware met woorden. Denk aan het onderwerp, het medium, de omgeving, de verlichting, kleur, stemming en compositie. Alles wat ongezegd blijft, wordt gerandomiseerd en geeft MidJourney vrij spel – en de uitkomsten kunnen echt bizar zijn. 

Een voorbeeld van een 'chat' met de MidJourney Bot in Discord, met het beeld als resultaat.

Geavanceerde prompts voor MidJourney

Geavanceerde prompts kunnen één of meer afbeeldings-url's, meerdere tekstzinnen en een of meer parameters (zie volgende paragraaf) bevatten. Afbeeldings-url's (links naar foto's die je als voorbeeld wilt gebruiken) kunnen aan een prompt worden toegevoegd om de stijl en inhoud van het eindresultaat te beïnvloeden, en parameters kunnen de manier waarop een afbeelding wordt gegenereerd veranderen, zoals beeldverhoudingen, negatieve prompts, modellen, upscalers en meer. 

Bij het uitschrijven van een prompt moet je vooral focussen op wat je in beeld wilt hebben, in plaats van wat je niet wilt zien. Als je een afbeelding genereert van bijvoorbeeld een boerderij, maar je wilt dat er geen koeien te zien zijn, gebruik dan niet 'no cows' in de prompt zelf, maar gebruik geavanceerde prompting met de '--no'-parameter om 'no cows' als negatieve prompt in te zetten. Voorbeeld: image of a farm with animals --no cows.

ChatGPT als prompt engineer Mocht je het zelf lastig vinden om prompts (in het Engels) te schrijven, dan kun je met een beetje hulp van het AI-taalmodel ChatGPT toch de mooiste omschrijvingen creëren. Het enige dat je dan nog hoeft te doen, is ChatGPT vragen een mooie prompt over een bepaald onderwerp voor je te bedenken.

Stel dat je MidJourney een foto van een brandweerman in actie wilt laten genereren. Dan voer je eerst in ChatGPT de volgende prompt in: "Creëer een prompt voor MidJourney. Ik wil graag een foto van een brandweerman in actie laten genereren." Vraag ChatGPT vervolgens de uitkomst naar het Engels te vertalen, waarna je dat kopieert en in MidJourney (of eigenlijk Discord) plakt.

Zie de foto hieronder hoe ChatGPT dat heeft opgepakt. Direct daaronder zie je het resultaat nadat we de prompt aan MidJourney hebben gevoerd.

©ER - ID.nl

Eigen afbeelding als voorbeeld gebruiken

Sinds MidJourney v5 kun je ook eigen afbeeldingen gebruiken om je creaties te beïnvloeden. Dat doe je door je afbeelding naar de Discord-server te uploaden en er een prompt aan te plakken. De resultaten zijn soms verbluffend en soms regelrecht hilarisch.

Om een afbeelding toe te voegen, sleep je die naar Discords chatventer met de MidJourney Bot (of je drukt op het plusje links van de chatregel onderaan), waarna je de afbeelding die je wilt gebruiken opzoekt. Druk daarna op Enter om hem up te loaden. Vervolgens klik je met je rechtermuisknop op de geüploade afbeelding en selecteer je onderaan Kopieer link. Daarna plak je de url van de afbeelding in je prompt (controleer of die url eindigt op .png, .gif of .jpg). Daarna kun je nog wat tekst of parameters toevoegen om je prompt af te maken. Bijvoorbeeld: /imagine [afbeeldings-URL] [jouw prompt].

Je kunt ook bepalen hoeveel invloed je afbeelding heeft op het eindresultaat. Gebruik hiervoor de parameter --iw X, waarbij X een waarde is tussen 0,5 en 2. Standaard is dat 1,0, maar je kunt het verminderen of verhogen door --iw 0,5 of --iw 2 te gebruiken. Let op: het eindresultaat zal geen exacte kopie van jouw afbeelding zijn. Het is meer een invloed, dus verwacht geen perfecte gelijkenis.

MidJourney-parameters

Parameters zijn opties die aan een prompt worden toegevoegd en van invloed zijn op de manier waarop een afbeelding in MidJourney wordt gegenereerd. Deze parameters kunnen de beeldverhoudingen van een afbeelding veranderen, negatieve prompts aangeven of schakelen tussen verschillende MidJourney-modelversies (zie volgende paragraaf). Parameters worden altijd aan het eind van een prompt toegevoegd en er kunnen meerdere parameters aan elke prompt worden toegevoegd. Je gebruikt parameters altijd door eerst twee streepjes (--) te typen. Hieronder een overzicht van de verschillende parameters die MidJourney gebruikt.

  • Aspect Ratio (--aspect of --ar): Met deze parameter kun je de beeldverhouding van je creatie aanpassen, bijvoorbeeld --ar 16:9 of --ar 2:3.

  • Chaos (--chaos): Wil je wat meer variatie in je afbeeldingen (MidJourney creëert er namelijk altijd vier)? Verhoog de chaos en laat je verrassen door wat er gebeurt. Kies een getal tussen 0 en 100 (bijvoorbeeld --c 82): hoe hoger het getal, hoe groter de variatie.

  • No (--no): Als je bepaalde elementen liever niet in je afbeelding wilt zien, is deze parameter je vriend. We hebben al eerder uitgelegd hoe deze parameter werkt.

  • Quality (--quality of --q): Als je de tijd van het renderen van een afbeelding wilt verkorten, kun je met deze parameter de kwaliteit iets verlagen. Standaard staat hij ingesteld op 1, maar je kun --q .5 of --q .25 gebruiken om het proces te versnellen.

  • Seed (--seed): Wil je een specifiek startpunt voor je beeldgeneratie, bijvoorbeeld omdat je tevreden bent met een bepaald beeld en verder wilt met een soortgelijke variant? Geef een zelf bedacht seed-nummer op (bijvoorbeeld --seed 12345) en je ziet dat een volgende opdracht met hetzelfde seed-nummer in een zelfde stijl wordt gegenereerd.

  • Stop (--stop): Met deze parameter kun je de taak vroegtijdig stoppen, wat kan leiden tot wat waziger, maar nog steeds interessante resultaten. Gebruik hiervoor --stop 10 tot en met --stop 100 (waarbij 100 een uitgerenderde versie van de afbeelding is).

  • Style (--style): Hiermee kun je schakelen tussen verschillende versies van het MidJourney-model. Experimenteer er lekker op los en kijk welke stijl je het best bevalt.

  • Stylize (--stylize of --s): Wil je de esthetische stijl van MidJourney sterker toepassen op je afbeeldingen? Pas deze parameter aan en zie het verschil. Hier geldt een range van 0-1000, waarbij 100 de standaard is. Hoe hoger je deze optie afstelt, hoe sterker een bepaald zichtbaar is.

  • Tile (--tile): Deze parameter laat je afbeeldingen genereren die als herhalende tegels kunnen worden gebruikt. Heel erg handig voor het maken van patronen!

  • Version (--version of --v): Als je een andere versie van het MidJourney-algoritme wilt proberen, is dit de parameter die je nodig hebt.

©ER - ID.nl

Met de Tile-functie kun je tegels met repeterende patronen laten genereren.

Verschillende modellen

MidJourney heeft verschillende versies om uit te kiezen, die door de ontwikkelaar 'modellen' worden genoemd. Het nieuwste en meest geavanceerde model is V5.1, dat uitblinkt in het nauwkeurig interpreteren van natuurlijke taalprompts en het produceren van scherpe afbeeldingen met minder ongewenste artefacten.

Het oudere V5-model was al meer gericht op het produceren van fotografische generaties, terwijl V4, dat de standaard was van november 2022 tot mei 2023, een geheel andere codebasis en AI-architectuur had. Deze versie had in vergelijking met eerdere modellen een geavanceerde kennis van wezens, plaatsen en objecten.

Daarnaast is er het Niji-model, een samenwerking tussen MidJourney en Spellbrush, dat is afgestemd op het produceren van anime en illustratieve stijlen. Het is dan ook vooral geschikt voor het creëren van manga- en anime-achtige afbeeldingen en niet zozeer voor het genereren van fotorealistische creaties.

Je kunt elk model selecteren door de juiste parameter aan het eind van je prompt toe te voegen of door het /settings-commando te gebruiken en een standaard modelversie te selecteren. Experimenteer gerust met de verschillende modellen om te zien welke versie het best bij jouw favoriete stijl past. En vergeet niet: het resulterende beeld valt of staat bij de kwaliteit van jouw ingegeven prompt. De kwaliteit van de gekozen woorden en de samenhang ervan betekent dat het beeld een nauwkeurige weergave is van de prompttekst.

Iedereen is kunstenaar

Zoals je hebt kunnen lezen is MidJourney meer dan alleen een tool. We durven gerust te stelle dat het een revolutie is in de manier waarop we over kunst en creativiteit denken. Door de kracht van AI kunnen we onze verbeelding en fantasie op nieuwe manieren verkennen. Of je nu een door de wol geverfde fotograaf of illustrator bent die op zoek is naar nieuwe manieren om je creativiteit te uiten, of gewoon een AI-enthousiasteling die geïnteresseerd is in de nieuwste technologie, MidJourney heeft iets te bieden voor iedereen. Wij zijn fan in elk geval.

▼ Volgende artikel
SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?
© arinahabich
Huis

SSD vs. HDD: waarom is een SSD zo veel sneller dan een harde schijf?

Waarom start een computer met een SSD binnen enkele seconden op, terwijl een oude harde schijf blijft ratelen? Het vervangen van een HDD door een SSD is de beste upgrade voor een trage laptop of pc. We leggen in dit artikel uit waar die enorme snelheidswinst vandaan komt en wat het fundamentele verschil is tussen deze twee opslagtechnieken.

Iedereen die zijn computer of laptop een tweede leven wil geven, krijgt vaak hetzelfde advies: vervang de oude harde schijf door een SSD. De snelheidswinst is direct merkbaar bij het opstarten en het openen van programma's. Maar waar komt dat enorme verschil in prestaties vandaan? Het antwoord ligt in de fundamentele technologie die schuilgaat onder de behuizing van deze opslagmedia.

De vertraging van mechanische onderdelen

Om te begrijpen waarom een Solid State Drive (SSD) zo snel is, moeten we eerst kijken naar de beperkingen van de traditionele harde schijf (HDD). Een HDD werkt met magnetische roterende platen. Dat kun je vergelijken met een geavanceerde platenspeler. Wanneer je een bestand opent, moet een fysieke lees- en schrijfkop zich naar de juiste plek op de draaiende schijf verplaatsen om de data op te halen. Dat fysieke proces kost tijd, wat we latentie noemen. Hoe meer de data op de schijf verspreid staat, hoe vaker de kop heen en weer moet bewegen en wachten tot de juiste sector onder de naald doordraait. Dit mechanische aspect is de grootste vertragende factor in traditionele opslag.

©Claudio Divizia

Flashgeheugen en directe gegevensoverdracht

Een SSD rekent definitief af met deze wachttijden omdat er geen bewegende onderdelen in de behuizing zitten. De naam 'Solid State' verwijst hier ook naar; het is een vast medium zonder rammelende componenten. In plaats van magnetische platen gebruikt een SSD zogenoemd NAND-flashgeheugen. Dat is vergelijkbaar met de technologie in een usb-stick, maar dan veel sneller en betrouwbaarder. Omdat de data op microchips wordt opgeslagen, is de toegang tot bestanden volledig elektronisch. Er hoeft geen schijf op toeren te komen en er hoeft geen arm te bewegen. De controller van de SSD stuurt simpelweg een elektrisch signaal naar het juiste adres op de chip en de data is direct beschikbaar.

Toegangstijd en willekeurige leesacties

Hoewel de maximale doorvoersnelheid van grote bestanden bij een SSD indrukwekkend is, zit de echte winst voor de consument in de toegangstijd. Een besturingssysteem zoals Windows of macOS is constant bezig met het lezen en schrijven van duizenden kleine systeembestandjes. Een harde schijf heeft daar enorm veel moeite mee, omdat de leeskop als een bezetene heen en weer moet schieten. Een SSD kan deze willekeurige lees- en schrijfopdrachten (random read/write) nagenoeg gelijktijdig verwerken met een verwaarloosbare vertraging. Dat is de reden waarom een pc met een SSD binnen enkele seconden opstart, terwijl een computer met een HDD daar soms minuten over doet.

©KanyaphatStudio

Van SATA naar NVMe-snelheden

Tot slot speelt de aansluiting een rol in de snelheidsontwikkeling. De eerste generaties SSD's gebruikten nog de SATA-aansluiting, die oorspronkelijk was ontworpen voor harde schijven. Hoewel dat al een flinke verbetering was, liepen snelle SSD's tegen de grens van deze aansluiting aan. Moderne computers maken daarom gebruik van het NVMe-protocol via een M.2-aansluiting. Deze technologie communiceert rechtstreeks via de snelle PCIe-banen van het moederbord, waardoor de vertragende tussenstappen van de oude SATA-standaard worden overgeslagen. Hierdoor zijn snelheden mogelijk die vele malen hoger liggen dan bij de traditionele harde schijf.

Populaire merken voor SSD's

Als je op zoek bent naar een betrouwbare en snelle SSD, is er een aantal fabrikanten dat de markt domineert. Samsung wordt door velen gezien als de marktleider op het gebied van flashgeheugen en staat bekend om de uitstekende prestaties van hun EVO- en PRO-series. Daarnaast is Western Digital (WD) een vaste waarde; dit merk heeft de transitie van traditionele harde schijven naar SSD's succesvol gemaakt met hun kleurgecodeerde (Blue, Black en Red) series voor verschillende doeleinden. Ook Transcend is een uitstekende keuze; dit merk staat al jaren bekend om zijn betrouwbare geheugenproducten en biedt duurzame SSD's die lang meegaan. Tot slot bieden merken als Kingston en Seagate betrouwbare alternatieven die vaak net iets vriendelijker geprijsd zijn, zonder dat je daarbij veel inlevert op stabiliteit.

▼ 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.