El Pimp Masiin (pimp=pairing in mcmahon pits) on [Tapio Vuorisen|TapioVuorinen] kyhäämä paritusohjelma go-turnauksiin. Ohjelmassa on suurinpiirtein kaikki peruskäytössä tarvittavat ominaisuudet.

Ohjelma sai alkunsa ToiGon juhannusleirillä 2003, kun muut pelasivat bonusturnausta. Minä sain ajatuksen round robin -paritusohjelmasta, joka hanskaisi myös bonusturnaukset. Kun RR-puolelle ei keksitty enää uusia ominaisuuksia, päätin toteuttaa McMahon-parituksen.

Ohjelmaa testattiin "tositoimissa" ensimmäistä kertaa KenraaliKutosessa 17.-18.1.2004. Tällöin paljastui puute paritusalgoritmin back-trackissä. Korjattu algoritmi selviytyi suht nätisti Kani6:n parituksesta viikkoa myöhemmin. Seuraavana maanantaina algoritmi muutettiin täysin back-trackääväksi rekursiota hyväksikäyttäen. Rekursiiviseksi muunnetun paritusalgoritmin ensimmäinen testaus antoi lupaavia tuloksia, ohjelma paritti ilman ongelmia 13 kierrosta 14:ää pelaajaa ja debug-tulosteiden perusteella algoritmi toimii oikein. Takapotkussa jyrähtää.

Ohjelma on tekstipohjainen. Konsolilta ohjelma vaatii aika reilusti, vaakasuunnassa kokoa saisi olla 100 merkkiä ja pystysuunnassa niin paljon kuin näytölle vaan mahtuu. Käytännössä tämä tarkoittaa sitä, että ajoympäristö on *NIX tai Windows-käyttäjille [Cygwin|http://www.cygwin.com/]. Softa on kehitetty x86-Linuxissa ja se on testattu toimivaksi Cygwinissä.

Ohjelman C++-lähdekoodit eivät (ainakin kehittäjälle ymmärrettävistä syistä) ole julkiset, mutta kääntelen binäärejä niitä tarvitseville. Ainakin Solaris/Sparc, Linux/Alpha, Linux/i386 ja Cygwin luonnistuvat. Kunhan ohjelma saavuttaa jonkinlaisen koodillisen vakauden asteen, softalle tehdään täydellinen re-write.

!Avainominaisuudet
*McMahon- ja RR-paritus
*Tasa-avaus-, tasoitus- ja vajaatasoitusturnaukset
*Tekijä muokkaa ohjelmaansa esitettyjen ehdotusten pohjalta

!Todo
Osa kiireellisempiä kuin muut
*Tulosten tulostaminen EGF-luokituslistan mukaisessa formaatissa
*I18N
*Konfiguraatiotiedosto paritusparametreille
*Virhetarkastelut

!Kiitokset
*Suvi Leppänen, Markku Jantunen, muutama muu tamperelainen - Kannustuksesta
*Olli Lounela - Kannustuksesta ja monista parannusehdotuksista

!Kuriositeettina nopeustestejä
Data saattaa muuttua, koska paritusalgoritmiin tehdään muutoksia. Pelaajadatan luokitusjakauman pitäisi olla suht tasainen, jos Perlin satunnaislukugeneraattoriin on uskominen.
Suoritus, josta aika on otettu = ohjelman käynnistys, McMahon-ryhmien luonti, parituksen ajo, parituksen tulostaminen tiedostoon, turnauksen tallennus ja ohjelman lopetus.

||Pelaajamäärä||Muistinkulutus||Turnaustallenteen koko||P2/350MHz Linux||Athlon/1GHz Linux||Athlon/1GHz W2k+Cygwin||P4/2.4GHz Linux
|200  | n. 0,5Mt | 135kt | 6,4s*    | 1,5s    | 3,2s*     | 0,8s
|600  | n. 4,5Mt | 1,1Mt | 1min13s* | 18,4s   | 47,2s*    | 10,1s
|2000 | n.48Mt   | 12Mt  | 36min*   | 5min39s | 19min10s* | 3min7s

Vanhalla versiolla testatut (ts. ne, jotka pitää mitata uudestaan) merkattu tähdellä.

Joku voisi mittailla Gerlachin vemputtimella vastaavia aikoja ja muistinkulutuksia, tosin se taitaa rajoittua alle 1000 pelaaja turnauksiin :-)

----

Kysymyksiä softasta voi esittää vaikkapa täällä ja niihin pyritään jopa vastaamaan.

__Q:__ Saaks sitä kokeilla?\\
__A:__ Kyllä saa, erikseen kauniisti pyytämällä.

__Q:__ Saako siitä tulokset ulos EGF luokituslistan [formaatissa|http://www.european-go.org/rating/format.html]? [Matti]\\
__A:__ Ei ainakaan vielä. Laitetaan korvan taakse.