DTU strammer op på parallel-programmering

Parallel-programmering er en nøgletrend i applikationsudvikling, og derfor skal DTU-studerende undervises mere i programmerings-metoden. Også industrien kaster sig ud i parallel-programmering.

Artikel top billede

Foto: dtu.dk

Flere kerner. Flere parallelle processer.

Det er logik for forskere, der dagligt har hovedet dybt begravet i supercomputere med mange processorer.

Men i takt med, at chip-fabrikanterne Intel og AMD presser flere kerner ind i processerne til almindelige computere, får it-udviklingerne mere ud af processorerne, hvis de er i stand til at parallel-programmere.

"Parallel-programmering bliver vigtigt, hvis vi ønsker hurtigere applikationer eller meget tung regnekraft," konstaterer lektor Hans Henrik Løvengreen fra Danmarks Tekniske Universitet (DTU).

Derfor har DTU strammet op omkring undervisningen i parallel-programmering over for de studerende.

"Alle vores datalogi-studerende har de sidste mange år haft en begrebsmæssig forståelse for parallelisering, men nu gør vi en større dyd ud af at fortælle de studerende, at de kan få meget mere ud af computerne, hvis de programmerer til flere kerner," lyder det fra Hans Henrik Løvengreen.

Traditionelle sprog duer ikke

Hans Henrik Løvengreen forklarer, at der inden for parallel-programmering findes to hoveddiscipliner:

Traditionel multi-trådet parallel-programmering, hvor man eksplicit igangsætter flere aktiviteter (tråde), der ikke nødvendigvis bliver udført på samme tid, og som i praksis er en udbygning af almindelig programmering.

I modsætning står nye sprog og systemer, der er målrettede mod udnyttelse af mange kerner.

Her foretages paralleliseringen implicit af oversættere eller kørselsbiblioteker, eller der benyttes helt andre programmerings-paradigmer som eksempelvis funktionsprogrammering, som lægger op
til at tænke i små, uafhængige beregningsdele.

Nye programmeringssprog

I den fagre, nye multi-kerne-verden er det især de nye former for parallel-programmering, der er interessante.

"Vores nuværende programmeringssprog er dog ikke gode nok til at få tilstrækkeligt ud af de flere processorer," fortæller Hans Henrik Løvengreen.

Derfor er det nødvendigt med paralleliserede varianter af de klassiske programmeringssprog som Fortran og C. Et eksempel er sproget OpenMP, hvor almindelige sekventielle programmer kan opfattes med anvisninger på at udføre eksempelvis de enkelte grene i en for-løkke parallelt.

It-industrien kaster sig over parallelisering

It-mastodonten Sun Micrososystems har også taget konsekvensen af den øgede fokusering og udviklet et nyt parallel-sprog, der hedder Fortress ifølge Computerworlds svenske søsterblad Computer Sweden.

"Fortress er et funktionelt sprog, der bygger på samme principper som Erlang. Erlang er et rigtigt grundlag for parallel-programmering, ligesom Python også er det," forklarer SUN-udvikller Thorbiörn Fritzon til Computer Sweden.

Han peger derfor på, at Google har taget Python til sig til sine skalérbare tjenester, hvor selskabet benytter sig af parallelisering.

Også Microsoft har for nyligt taget parallel-programmering til sig med udgivelsen af ParallelFX til .Net Framework.

"For mig er det her et lille skridt, vi har taget," siger S.
'Soma' Somasegar, corporate vice president for Microsoft Developer Division.

"Parallel-programming skal bredes ud til flere programmører, det skal ikke kun være for de bedste programmører," forklarer han.

Computerworld Events

Vi samler hvert år mere end 6.000 deltagere på mere end 70 events for it-professionelle.

Ekspertindsigt – Lyt til førende specialister og virksomheder, der deler viden om den nyeste teknologi og de bedste løsninger.
Netværk – Mød beslutningstagere, kolleger og samarbejdspartnere på tværs af brancher.
Praktisk viden – Få konkrete cases, værktøjer og inspiration, som du kan tage direkte med hjem i organisationen.
Aktuelle tendenser – Bliv opdateret på de vigtigste dagsordener inden for cloud, sikkerhed, data, AI og digital forretning.

It-løsninger | Nordhavn

SAP Excellence Day 2026

Få konkrete erfaringer med S/4HANA, automatisering og AI i praksis. Hør hvordan danske virksomheder realiserer gevinster og etablerer effektive SAP-løsninger. Vælg fysisk deltagelse hos SAP eller deltag digitalt.

Infrastruktur | København

Datacenterstrategi 2026

Denne konference bidrager med viden om, hvordan du balancerer cloud, on-premise og hybrid infrastruktur med fokus på kontrol, compliance og forretning.

Sikkerhed | Aarhus C

Identity Festival 2026 - Aarhus

Er du klar til en dag, der udfordrer din forståelse af, hvad Identity & Access Management kan gøre for din organisation? En dag fyldt med indsigt, inspiration og løsninger, der sætter kursen for, hvordan vi arbejder med IAM i de kommende år.

Se alle vores events inden for it

Navnenyt fra it-Danmark

Connexa A/S har pr. 1. januar 2026 ansat Ivan Nielsen som IT Konsulent. Han skal især beskæftige sig med IT Infrastruktur og services. Han kommer fra en stilling som IT Konsulent hos IT Forum Gruppen A/S. Han har tidligere beskæftiget sig med IT Infrastruktur og konsulentopgaver. Nyt job

Ivan Nielsen

Connexa A/S

Sourcing IT har pr. 2. februar 2026 ansat Susanne Sønderskov som Salgsdirektør. Hun skal især beskæftige sig med at styrke Sourcing IT’s kommercielle fundament, skalere salgsindsatsen og øge tilstedeværelsen bl.a. hos jyske kunder. Hun kommer fra en stilling som Salgsdirektør hos Right People Group ApS. Hun har tidligere beskæftiget sig med salgsledelse inden for IT-freelanceleverancer og komplekse kundeaftaler, både privat og offentligt. Nyt job

Susanne Sønderskov

Sourcing IT

Idura har pr. 5. januar 2026 ansat Arjuna Enait, 34 år,  som software engineer. Han skal især beskæftige sig med videreudvikling af Verify-systemet samt arbejde på implementeringen af CIBA i Norsk BankID. Han kommer fra en stilling som software engineer hos Lasso X. Han er uddannet civilingeniør med speciale i geoteknik. Han har tidligere beskæftiget sig med at bygge microservices til dataindsamling og -processering, samt opdatere legacy-systemer. Nyt job

Arjuna Enait

Idura