Lekcije inženjerke iz Shopifya: kako koristiti AI za brži, bolji i lakši razvoj softvera?

Lekcije inženjerke iz Shopifya: kako koristiti AI za brži, bolji i lakši razvoj softvera?

Umjetna inteligencija i inženjeri. Nekada se vole, nekada mrze, ali činjenica je da AI inženjerima može olakšati pisanje koda... (ako i sami znaju što rade).

AI ubrzava razumijevanje novih stvari, izvršavanje starih procesa, ubacuje naš um i kreativnost u petu brzinu i uočava tipfelere koje inženjerske oči više ne vide. Ovo je u ono što vjeruje Monica Restrepo, inženjerka u Shopifyju koja je bila na Digital Labinu, konferenciji koja pretvara mali rudarski gradić u središte IT scene u Hrvatskoj na jedan dan.

Monica smatra kako je Hollywood najviše utjecao na samu percepciju AI-a pa vjerojatno mnogi ljudi AI asociraju s likom HAL 9000 iz filma Odiseja u svemiru, ali stvarnost je posve drugačija. Govorimo o tehnologiji koja se oslanja na tehnike strojnog učenja, čiji razvoj još uvijek trebaju nadzirati i voditi ljudi.

AI koristi neuronske mreže, stablo odlučivanja i natural language processing kako bi mogao upijati ogromne količine podataka i potom iz njih učiti te na temelju tih saznanja raditi predviđanja, ali to ne može raditi samostalno, istaknula je Monica na početku svog predavanja:

Ipak, ovdje se Monica pita što AI može učiniti za developere. U svom predavanju Better, Faster, Stronger: Incorporating AI to your development process, uronila je u načine kako najbolje iskoristiti AI alate u svakodnevnom stvaranju tehnoloških proizvoda.

3 načina kako AI može ubrzati pisanje koda i smanjiti mogućnost pogreške

U pripremi boilerplate koda

AI danas može pomoći sa stvaranjem koda, a svi inženjeri znaju bolne trenutke kada moraju pisati boilerplate kod (dio  koda koji je kod svake aplikacije potpuno isti). Govorimo o zadatku koji je u većini slučajeva vrlo repetitivan za inženjere, ali im AI može pomoći.

S ispravnim upitom, koji je vrlo važan kada je riječ o korištenju umjetne inteligencije, alati kao što je Chat GPT mogli bi generirati onaj početni boilerplate za učenje koji nam je potreban za aplikacije, pod uvjetom da je taj alat pravilno obučen.

Ovako inženjeri mogu uštediti mnogo vremena kako bi mogli više vremena posvetiti kreativnom procesu stvaranja same aplikacije, a konkretan alat koji preporučuje developerima je Codex, iza kojeg stoji OpeanAI:

Codex može generirati funkcije transformacije podataka u mnogim programskim jezicima i uzeti te neobrađene podatke te ih pripremiti za analizu. Možda ste također upoznati s alatima kao što je GitHub Copilot koje također pokreće Codex. Oni mogu predvidljivo pisati cijele funkcije na temelju vaših inline komentara.

Lakše debuggiranje

Standardni debugger pokazuje inženjerima gdje je kod pogrešan, ali AI može napraviti korak više, može pokazati zašto je kod pogrešan, objašnjava Monica:

Programi za debugging koje pokreće AI mogu identificirati manje očite probleme, poput race conditionsa, ili čak predložiti kako poboljšati performanse.

Naravno, ovo ovisi o tome koliko ste dobri u treniranju samog AI-ja. Tvrtke poput Mete već su stvorile ovakve alate. Njihov SapFix je bot koji generira popravke za bot koji je prisutan u kodu. SapFix je sposoban raditi pull zahtjeve, ali treba čovjekovo odobrenje prije integracije. Također, DeepCode, osim što može identificirati probleme, on pruža i kontekst koji programeri trebaju znati kako bi razumjeli zašto je greška – greška.

Za automatsko testiranje

Treća stvar s kojom AI može pomoći inženjerima je automatsko testiranje. Sposoban je prilagoditi se promjenama baze koda pa čak i generirati nove testne slučajeve. U Shopifyju se već pokazao sposobnim pri optimiziranju unit testova.

Ako je AI dobro treniran, on može pružiti strukturu testa već dok ste u fazi developmenta.

Ovo je definitivno nešto za što koristimo AI u Shopifyju, a posebno je jako korisno kada je u pitanju samo izrada mape načina na koji će testovi biti napisani, ovisno o promjeni koju tada radite na bazi koda.

Gdje će inženjeri naletjeti na probleme s AI-jem?

Usprkos tome što AI može pomoći inženjerima da se usredotoče na kreativni dio u razvoju softvera, AI nije savršen alat. On primarno ima veliki manjak kreativnosti, točnije, sposobnosti kreativnog rješavanja problema…

AI trenutno ne može zamjeniti ljudsku intuiciju.

Na primjer, ako razvijamo algoritam za blockchain sigurnost, on nije na potrebnoj razini jer njegovo znanje ovisi o zadnjem danu kada je AI bio treniran. Ako uzmemo alate poput Chat GPT-a, koji je treniran s podacima do 2021. godine, on nije u skladu s današnjim tehnologijama kao što je blockchain sigurnost, ističe Monica:

Ako tražite od AI-ja da optimizira dio vašeg koda, a pritom nije pravilno obučen ili samo drugačije tumači ono što pokušavate tražiti, AI može predložiti širenje funkcija na različite stvari kako bi napravio kod više “suhim” što može rezultirati uvođenjem stvari koje nisu u skladu s logikom vaše aplikacije.

Monica zato napominje da ne očekujte čuda prije nego LLM istrenirate na vlastitim podacima…

Kada smo odlučili koristiti verziju ChatGPT-a za tvrtke, trebali smo ga neko vrijeme hraniti podacima kako bi on naučio što je Shopify i kakvi su naši projekti.

Kvaliteta odgovora ovisi o LLM-ovom, ali i vašem predznanju

Također, koliko će vam AI biti koristan ovisi o kvaliteti podataka na kojima je treniran. Ako radite aplikaciju na području zdravlja, a AI je treniran na podacima iz e-commercea, onda sigurno nećete dobivati dobre rezultate. Slično je i s debuggingom:

Ako je AI treniran na Pythonu, a počnete uklanjati greške u Ruby kodu ili bilo kojem drugom jeziku, nećete dobiti dobre rezultate. Ovo je poznato kao problem prilagodbe domene u strojnom učenju.

Za kraj, kao najstrašniju stranu AI-ja, Monica navodi “halucinacije”, točnije, lažne pozitivne rezultate. Dakle, ovo je situacija kada se AI pretvara da zna što pitate i da zna odgovor:

Od ChatGPT-a nećete dobiti nešto poput “žao mi je, ne znam o čemu govorite.” Uvijek ćete dobiti neki nasumični odgovor, a ako ne znate da je to nasumičan odgovor, možete primijeniti nešto vrlo krivo u kod.

Sukladno članku 94. Zakona o elektroničkim medijima, komentiranje članaka na Netokraciji dopušteno je samo korisnicima koji ostave svoje ime i prezime te mail adresu i prihvate pravila ponašanja.

Pravila ponašanja

Na Netokraciji za vas stvaramo kvalitetan, autorski potpisan sadržaj i zaista se veselimo vašim kvalitetnim, kontruktivnim komentarima. Poštujmo stoga jedni druge prilikom komentiranja, kao i Zakon, držeći se sljedećih pravila ponašanja:

  • Ne budite 💩: Nema vrijeđanja, diskriminiranja, ni psovanja (osim ako nije osobni izričaj, ali onda neka psovka bude općenita, a ne usmjerena prema nekome). Također, upoznajte se sa stavkom 2. članka 94. Zakona o elektroničkim medijima prije no što ostavite komentar.
  • Samo kvalitetna rasprava, manje trolanja: Ne morate se ni sa kim slagati, ali budite konstruktivni i doprinesite raspravi! Svako trolanje, flameanje, koliko god "plesalo" na granici, leti van.
  • Imenom i prezimenom, nismo Anonymous 👤: Autor sadržaja stoji iza svog sadržaja, stoga stojite i vi iza svog komentara. Koristimo ime i prezime te pravu email adresu.

Kako koristimo podatke koje ostavljate? Bacite oko na našu izjavu o privatnosti.

Sve ostale komentare ćemo s guštom spaliti, jer ne zaslužuju svoje mjesto na internetu.

Odgovori

Tvoja e-mail adresa neće biti objavljena.

Popularno

Kolumna

Od Yahooa do ChatGPT-ja: Strategije uspjeha na tražilicama koje vrijede i danas

Neke strategije za pozicioniranje na internetskim tražilicama još funkcioniraju i nakon 10 godina. U ovom povratku u prošlost, prisjećamo se raznih praksi, što se od njih zadržalo, a što ne - te što je novo ušlo u igru...

Tehnologija

Tomislav Tipurić uoči ATD-a: Moramo poraditi na promjeni definicije junior developera

Uoči 18. konferencije Advanced Technology Days porazgovarali smo s osobom zaduženom za program, Tomislavom Tipurićem, o svemu što ne smijete propustiti na samom događaju, a i u svijetu tehnologije posljednjih godina i dana. Naravno, AI je neizostavna tema.

Netokracija Podcast

Ovo je email strategija kojom je Burazin privukao investitore poput direktora Stack Overflowa

U novoj epizodi ulazimo u detalje o: (vjerojatno) najvećoj pre-seed rundi u hrvatski startup; tome kako SAD namjerava kontrolirati AI sustave koji bi mogli napraviti atomsku bombu te zašto osnivača Netokracije Ivana Brezaka Brkana izbacuju iz zagrebačkih kavana?

Što ste propustili

Kolumna

Od Yahooa do ChatGPT-ja: Strategije uspjeha na tražilicama koje vrijede i danas

Neke strategije za pozicioniranje na internetskim tražilicama još funkcioniraju i nakon 10 godina. U ovom povratku u prošlost, prisjećamo se raznih praksi, što se od njih zadržalo, a što ne - te što je novo ušlo u igru...

Tehnologija

Najveća hrvatska luka u Pločama postat će pametna, uz sufinanciranje iz EU od skoro milijun eura

Luka Ploče postat će prva hrvatska pametna luka. Ujedno je ovo jedini projekt iz Hrvatske koji je Europska Komisija odobrila u sklopu fonda 5GSC - od ukupno 14 odobrenih u cijeloj Uniji.

Tvrtke i poslovanje

Bajke u digitalnom svijetu: Pinokio djeci priča o lažnom predstavljanju, a tri praščića o slabim lozinkama

Stotine ljudi podržale su humanitarnu akciju tvrtke Combis i Centra za nestalu i zlostavljanu djecu.

Programiranje

Upoznajte Retriever, platformu FER-ovog TakeLaba koja rudari po 30 domaćih web portala

Retriever zagrebačkog TakeLaba može analizirati milijune članaka objavljenih na hrvatskome u posljednjih 20 godina, a sprema se i na iskorak u regiju. 

Tvrtke i poslovanje

Od 1. siječnja država nadzire Wolt, Bolt, Glovo… – što to znači?

Teško je regulirati segment tržišta o kojem nemate konkretnih saznanja, srećom, za tzv. GIG ekonomiju to će se uskoro promijeniti. Više saznajemo u razgovoru s ravnateljom Uprave za rad i zaštitu na radu u Ministarstvu rada, mirovinskoga sustava, obitelji i socijalne skrbi.

Programiranje

“Infrastruktura kao kod” izazov je s kojim se isplati uhvatiti u koštac, pogotovo za ogromne okoline

Što je sustav veći, to IaC (Infrastructure-as-Code) donosi više prednosti. Kako to izgleda u praksi?