Kaya will open source parts and bits of the application incrementally over time, until a stable development community is achieved.
Open-source code is subject to as rigorous standards as the server. Code must have decent unit test coverage, and well documented.
OpenKaya has grown quite a bit and i've included a public tracker: https://www.pivotaltracker.com/projects/470995.
If you are working on something and dont have member access to edit the chores and such you can email [email protected].
If you want to do something but don't know what, visiting the tracker is a good start to see what is known to be missing. Any ideas are welcome and we will support it with advice, code, overview as it is fit, and finally integrate it into the Kaya experience.
This modules have been opened and are ready to be forked:
- Rating System
- Score estimator
- Game Scoring (Chinese rules missing )
- Tournament & League systems (Higher priority)
- Time System (Bronstein)
Code utilizes ruby 1.9.2 which is the version used by the server.
There are many rating systems, and even more implementations of each theoretical model. Although I (Gabriel) had an idea of a simple system, i concluded it would be better to compare options, and also making it open so it can be tweaked and improved by the community that wants to do so.
We dont know yet and this is a vital part on deciding what are we going to use in the end. This example is mean to be able to compare different systems under the same data. Our decision will be based mainly on the balance of Accuracy and Performance.
The impression and subjectivity players get from the system. An accurate system that leaves people unhappy by any reason has a negative impact.
Examples of the psychological aspect of a system.
- If the system makes players have a very heavy rating, it will push them into constantly making new accounts, worsening the whole experience.(KGS)
- It must not be frustrating to achieve the proper rank on an account, for example, by having to play too many games to get a confident rank. (Wbaduk/Tygem)
- Unrated accounts (new players) shouldnt be uninteresting to play with, due to risk/benefit of playing them.(KGS)
- Unfair Handicaps or uneven probabilities causing different rating values on game results. Kaya will disencourage playing with imbalanced handicap and that effect can be considered to be avoided within the same category. (i.e. Strong 5d gives komi to weak 5d, to prevent the former to have to win many more games than the latter).
Remember that there will be a handicap! The rating system must support that to some degree. There are basically 2 strategies to deal with this (and their mix):
- Making the rating impact differently if two players of different rating play even
- Making all games have equal importance for both players by adjusting the probabilities of winning with handicap (to any degree, including in the same rank)
Inside the rating folder there is a structure of files.
System : the mock of an application that would use the rating system. It is fairly straight-forward: it takes (game) results and holds the information of all players, which in turn is passed to the rating strategy.
Strategies : Inside the folder there is a ridicolously simple system as a demonstration to how to make a system. It is absolutely state-less. Systems that require other information such as date or such can be easily changed and accessed from the passed on hash. Having a more comprehensive history can also be done by Just extending the Player model under system.rb.
Runner: The script that runs the simulation. It will run with a sample data-set and simple point system and write to a file the final rating of all players, rank and a benchmark on how long the process took.
new Added arguments parsing on runner. You need to specify which rating system to use through the args (more than one possible).
ruby runner.rb Glicko SimplePoint
Use "Validate" argument to make the system validate users rating after each result is added. Good to check consistency at any point.
ruby runner.rb Glicko Validate
To make sure the rating systems do what they intended, unit tests must be implemented. After adding a rating system, you can add code under tests/#{rating_system}_test.rb that verifies its not giving crazy results. This is a vital requirement to merge rating systems into master, as it is the only way i have to know the code works without going deep into the details of each implementation.
To run tests:
gem install cutest
ruby tests/#{rating_system}_test.rb
Current code is pure Javascript and can be run from within the browser without any installation.
Score.js is the javascript that will calculate score based on an array of information of a Go Board. A first batch of tests is written that would cover most use cases of score. It is missing some more examples of chinese scoring which is secondary at this point.
The algorithm has to spit out an object with the score of each player. A "painted" array marking which intersection was counted for whom would be very convenient also.
Some caveats: be careful with Seki! it is counted as no points under japanese rules, regardless of eyes. There is a test case that will likely fail with any intuitive algorithm for determining score.
This will probably be extended for Score estimation.
To be documented and updated. Current code is not usable by Kaya.gs server.
Ruby 1.8.7 as required by mechanize.
Working on an interface to run bots remotely as if they were users. Bots will have a special dedicated api for simplicity, easy maintenance and increased performance.
WARNING: Current code is highly unstable and subject to big changes, depending on the implementation of the routes in the server.
Go to the tournament folder for specific documentation
Current code is pure Javascript and can be run from within the browser without any installation.
To run, just open the html files with your browser. To work on it, create a new html with test cases for your system, then work on the js files. Code without tests will be rejected!
A full interface wich supports time systems has been implemented. It's fully written in JavaScript and emulates the interaction between the board, the timesystem and the server. It's fully tested with QUnit. Further implementations must respect the interaction and testing structure.
Checkout the "time" folder if you're interested in working on this.
You can see some time systems explained in the link ahead.
http://en.wikipedia.org/wiki/Game_clock#Time_controls
OpenKaya grows thanks to the contributions of several collaborators. All of them receive the fire Kanji(火) recognition in Kaya.
- AOA
- (killerducky)yoyoma
- Enders
- (John Andrichak IV)Verse
OpenKaya by Kaya is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.