Het vertrouwen in computers en applicaties is groot. Bedrijfsprocessen worden ondersteund door een keten van applicaties. Wanneer een computer “Nee” zegt nemen we dat meestal aan. Dit is goed weergegeven in de sketches van Little Britain: - Little Britain - Computer says no - Bij artificiële intelligentie (AI) stellen we een vraag aan de computer en de computer antwoordt nu: “Ja”. Als we de AI applicaties behandelen als traditionele applicaties kan dit leiden tot catastrofale gevolgen. Denk hierbij aan de ‘racistische’ Tesla auto’s of aan de toeslagenaffaire. Dit terwijl AI een grote verrijking is voor bedrijven en de maatschappij. Maar als we niet oppassen missen we draagvlak om AI in te zetten en alle voordelen die deze applicaties kunnen bieden. Als IT manager kan je ervoor zorgen dat je de voordelen van AI kunt inzetten in je bedrijf en de maatschappij, door beter het verschil te begrijpen tussen traditionele applicaties en AI applicaties.
Deze twee type applicaties verschillen dag en nacht. De applicaties verschillen in de uitkomst en wat je met de uitkomst doet, de interactie tussen mens en computer, het ontwikkelproces, kosten allocatie, het testen van de applicaties, foutafhandeling en de bias van de programma’s. In deze blog ga ik in op een paar cruciale verschillen.
De uitkomst & het vervolg proces
Traditionele applicaties zijn deterministisch en AI applicaties zijn probabilistisch. Deterministisch betekent dat de uitkomst op voorhand is bepaald. Probabilistisch betekent dat er een grote kans is dat de uitkomst juist is.
Wanneer een fraudeur wordt opgespoord door een traditionele applicatie, zijn alle regels in de applicatie op voorhand bepaald en zijn de processen gedefinieerd en getest. Daardoor kan het vervolgproces gelijk ingaan als een persoon als fraudeur bestempeld is door een traditionele applicatie. Enkel in een heel uitzonderlijk proces is een persoon onschuldig.
Bij een AI applicatie is dit niet zo rechtlijnig. Hierbij is de kans reëel dat een persoon correct wordt geclassificeerd als fraudeur aan de hand van het model en de data. Maar er bestaat een kans dat de persoon geen fraudeur is. Aangezien de uitkomst grote consequenties kan hebben voor een persoon, is het beter om aan de hand van deze uitkomst een gedegen onderzoek te doen naar die persoon en aan de hand van dat onderzoek je het model aan te passen. In dit geval is het doel van de applicatie niet fraudeurs te straffen, maar mensen en bedrijven te helpen om te voldoen aan de regels.
Bij traditionele applicaties volgt de mens de beslissing die uit machine komt. Bij AI applicaties ondersteunt de machine de mens in het maken van de beslissing.
Ontwikkelproces en kosten van applicaties
Het ontwikkelen en gebruiken van een applicatie kent verschillende kenmerken zoals ontwikkel kosten, operationele kosten, de uitlegbaarheid van het proces, snelheid van in productie namen, security en privacy van de data. In dit hoofdstuk belicht ik een aantal aspecten voor het ontwikkelen van traditionele en artificiële applicaties.
Bij traditionele applicaties begin je bij het proces dat je automatiseert. Er bestaan verschillende soorten methodes zoals Waterfall, Scrum, Kanban, Safe om het ontwikkelproces van applicaties te ondersteunen. Deze methodes maken in de basis allemaal gebruik van dezelfde zes stappen:
- Plan de wijziging
- Analiseer het proces
- Ontwikkel een applicatie die het proces automatiseert
- Test de applicatie (of het geautomatiseerde proces)
- Publiceer de applicatie
- Support de applicatie
In de stappen maak je gebruik van verschillende kennis en skills van mensen. Daarom gebruiken ze in IT een OTAP* straat die ervoor zorgt dat mensen met verschillende kennis en skills tegelijkertijd aan een product kunnen werken. Hierdoor is het eenvoudig om de toegang tot data te scheiden in het ontwikkelproces. De data die gebruikt wordt in elk van deze stappen is verschillend en wordt voornamelijk gebruikt om de applicatie te testen in de verschillende fasen van het project. In dit ontwikkelproces alloceer je als manager 20% voor de bouw en 80% voor het beheer en operationele kosten voor de leeftijd van een applicatie.
Bij AI applicaties begin je bij de vraag en de data die nodig is om de vraag te beantwoorden. Daarna worden deze 8 stappen gevolgd om de applicatie te maken:
- Stel hypothese op
- Verzamel data
- Maak de data schoon
- Analyseer data
- Bepaal een (statisch) model
- Valideer je hypothese
- Publiceer de applicatie
- Support de applicatie
Het ontwikkelen van nieuwe applicaties gaat vele male sneller doordat er allemaal modellen beschikbaar zijn en er zelfs modules zijn die het beste model voor je selecteren. Door het gebruik van de gevalideerde en geteste modellen zijn de applicaties vele male kleiner. Applicaties kunnen zo klein zijn als 10 regels code. Hierdoor is het ontwikkelen van een nieuwe applicatie een peulenschil t.o.v. traditionele applicaties, onder de voorwaarde dat je datasets in orde zijn. De bulk van het werk ligt in het maken van je datasets en het afhandelen van de uitkomsten. Bij deze applicaties zijn data en applicatie nauw verbonden aan elkaar en is het scheiden van de toegang tot data in het ontwikkelproces niet meer mogelijk. Het ontwikkelen van Artificial Intelligence of machine learning oplossingen kan alleen gedaan worden met productiedata. De kosten voor het gebruiken van deze applicaties ligt voornamelijk in data cleaning, data governance en de acties die worden ondernomen nadat het programma gedraaid heeft.
Bias en herleidbaarheid
Bij traditionele applicaties die voortkomen uit het automatiseren van processen, is gemakkelijk te herleiden welke verschillende stappen de data heeft doorlopen. Alle bias die in deze applicaties zit, is bewust of onbewust geprogrammeerd. Wanneer zo een bias aanwezig is, is deze te herleiden en kan relatief gemakkelijk worden aangepast.
Bij AI applicaties maak je gebruik van de data om je model op te stellen. De bias in je applicatie is dan gekoppeld met de bias in je data. Als je dataset bijvoorbeeld allemaal rode bloemen bevat, kan het zijn dat het model moeite heeft met het herkennen van paarse bloemen. Dit is een voorbeeld van wat er is gebeurd met de collectiedetectie van de zelfrijdende auto’s van Tesla. Hierbij waren de modellen getraind met gezichten van blanke mensen, waardoor mensen met een andere huidskleur moeilijker of soms zelfs niet als mens werden geïdentificeerd. Ook kan het zijn dat je een parameter hebt gebruikt, die gevoelig kan liggen zoals bijvoorbeeld een tweede nationaliteit bij de toeslagenaffaire. Bedenk hierbij: data, code en programma’s zijn niet bevooroordeeld.
Wanneer je als manager de kracht van AI tools wilt gaan gebruiken, is het belangrijk om te onthouden dat :
- De uitkomst (computer says ‘yes’) niet altijd 100% correct is,
- De grote vraag is: Wat te doen met de uitkomst? Op dit moment is het in de ontwikkeling van AI het beste om processen zo in te richten dat je customer intimacy wordt vergroot.
- Je op een andere manier moet omgaan met het ontwikkelen en gebruiken van deze applicaties.
- De traditionele methodes voor het ontwikkelen van de applicaties niet werken voor het ontwikkelen van AI.
- Data kwaliteit en data governance cruciaal zijn bij het ontwikkelen van AI applicaties.
Hulp nodig bij het definiëren van uw datastrategie? Schroom dan niet om contact op te nemen met Wouter Claeys