The Cisco and Microsoft joint Cross-Animal Technology Project, a well-established player in the field of multi-species collaborative initiatives, is pleased to introduce its next project: a revolution in High Performance Computing (HPC): LOLCODE language bindings for the Message Passing Interface (MPI).
CATP believes that cats are natural predatory programmers. Who better to take advantage of all the world’s spare, unused computing cycles than cats? They’re at home when we’re not. They’re clever, they can problem-solve, and they have lots of free time on their… paws.
To target cats, we needed a computing language that speaks their language. Rather than create our own, we found that the brilliant researchers at LOLCODE continue to push the boundaries of human-cat collaborative programming. We are therefore thrilled to bring the work of LOLCODE to the world of HPC.
The MPI LOLBINDINGS fit naturally within Cisco’s “Internet of Everything” philosophy; we believe that everything, everywhere will eventually be connected to the internet. The network that already connects us will also connect our devices, and our cats. Enabled by Microsoft’s Big Compute capabilities, our goal is to push the frontiers of computing: we want to provide greater access to High Performance Computing (HPC), to more devices, and more species.
Enough human talk; let’s look at some examples, adhering to v1.2 of the LOLCODE specification. This is the canonical “hello world” in MPI LOLBINDINGS:
HAI CAN HAS MPI? MPI_HAI BTW Lines beginning with "BTW" are comments BTW MPI's "Communicator" translates to "catinator" I HAS A ME ITS MPI_CATZ_RANK MPI_CATZ_WORLD I HAS A BIGNIS ITS MPI_CATZ_SIZE MPI_CATZ_WORLD VISIBLE "HAI WORLD! ME IZ " ME " OF " BIGNIS MPI_KTHXBYE KTHXBYE
And here’s the traditional “compute Pi in parallel” example in MPI LOLBINDINGS:
HAI
CAN HAS MPI?
MPI_HAI
I HAS A PIE ITZ 3.141592653589793238462643
I HAS A ME ITZ MPI_CATZ_RANK MPI_CATZ_WORLD
I HAS A BIGNIS ITZ MPI_CATZ_SIZE MPI_CATZ_WORLD
IM IN YR MATHS
I HAS A ITERASHUN
ME IZ 0 O RLY?
YA RLY
VISIBLE "I CAN HAS ITERASHUN?"
GIMMEH ITERASHUN
OIC
MPI_BCATZ ITERASHUN 1 MPI_NUMBR 0 MPI_CATZ_WORLD
BOTH SAEM ITERASHUN AN 0, O RLY?
YA RLY, GTFO
OIC
I HAS A H ITZ QUOSHUNT OF 1.0 AN ITERASHUN
I HAS A REZULT ITZ 0.0
I HAS A COUNT ITZ ME
IM IN YR LOOP
I HAS A TMP ITZ PRODUKT OF H AN SUM OF COUNT AN 0.5
REZULT R SUM OF REZULT AN QUOSHUNT OF 4.0 AN SUM OF 1.0 AN ...
PRODUKT OF TMP AN TMP
COUNT R SUM OF COUNT AN BIGNIS
BOTH SAEM COUNT AN BIGGR OF COUNT AN ITERASHUN, O RLY?
YA RLY, GTFO
OIC
IM OUTTA YR LOOP
REZULT R PRODUKT OF H AN REZULT
BOTH SAEM ME AN 0, O RLY?
YA RLY
MPI_REDUSEZ MPI_IN_PLACEZ REZULT 1 MPI_NUMBAR SUM 0 MPI_CATZ_WORLD
VISIBLE "YUR PIE IZ " AN REZULT AN " ERRORZ IZ " AN ...
FABZ DIFF OF REZULT AN PIE
NO WAI
MPI_REDUSEZ REZULT ZZZ 1 MPI_NUMBAR SUM 0 MPI_CATZ_WORLD
OIC
IM OUTTA YR MATHS
MPI_KTHXBYE
KTHXBYE
We here at CATP are excited to see the potential of MPI LOLBINIDINGS, especially as we venture into the era of exascale computing. To that end, CATP engineers will present the LOLBINDINGS proposal to the MPI Forum for inclusion in MPI-4 (a.k.a. MPI4CATZ).
Kthxbye.
🙂
I see what you did there! Commendable effort by Jeff and Fab! Just in case someone is taking straw votes, I vote for it!
No chickens?
Chicken support is on the roadmap, but will not be included in the initial proposal.