This is version . It is not the current version, and thus it cannot be edited.
[Back to current version]   [Restore this version]

El Pimp Masiin (pimp=pairing in mcmahon pits) on Tapio Vuorisen 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. 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 ja ohjelman lopetus.

PelaajamääräMuistinkulutusTurnaustallenteen kokoP2/350MHz LinuxAthlon/1GHz LinuxAthlon/1GHz W2k+CygwinP4/2.4GHz Linux
200 n. 0,5Mt 135kt 10s 2,4s 3,2s 1,7s
600 n. 4,5Mt 1,1Mt 2min50s 41s 47,2s 28s
2000 n.48Mt 12Mt 72min 21min12s 19min10s 11min47s

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? Matti
A: Ei ainakaan vielä. Laitetaan korvan taakse.

Add new attachment

Only authorized users are allowed to upload new attachments.
« This particular version was published on 01-Feb-2004 04:38 by TapioVuorinen.