Move to DNW namespace

This commit is contained in:
Alex Wulf
2022-07-05 15:33:34 +02:00
parent a99a73e02c
commit 812e454dd4
77 changed files with 536 additions and 361 deletions

View File

@ -1,35 +1,21 @@
{
"name": "phpskills/phpskills",
"description": "Implementation of Microsoft's TrueSkill matchmaking system for PHP",
"name": "dnw/php-trueskill",
"keywords": ["trueskill", "matchmaking", "ranking", "skill", "elo"],
"homepage": "https://github.com/moserware/PHPSkills",
"version": "1.0.0",
"authors": [
{
"name": "Jeff Moser",
"email": "jeff@moserware.com",
"role": "Creator"
},
{
"name": "Alexander Liljengård",
"email": "alexander@paxxmedia.se",
"role": "Contributor"
}
],
"require": {
"php": ">=5.3.0"
"php": "^8.1"
},
"require-dev": {
"phpunit/phpunit": "~4.0"
},
"autoload": {
"psr-4": {
"Moserware\\Skills\\": "src/"
"DNW\\Skills\\": "src/"
}
},
"autoload-dev": {
"psr-4": {
"Moserware\\Skills\\Tests\\": "tests/"
"DNW\\Skills\\Tests\\": "tests/"
}
}
}

359
composer.lock generated
View File

@ -1,43 +1,40 @@
{
"_readme": [
"This file locks the dependencies of your project to a known state",
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
"hash": "ca336cd0f49a8c9a484b63e136d9d56f",
"content-hash": "3234f646e10fd3a36d2c43cec6d54677",
"content-hash": "8bdf9d30bce45e34bf0b58a01c2c92f3",
"packages": [],
"packages-dev": [
{
"name": "doctrine/instantiator",
"version": "1.0.5",
"version": "1.4.1",
"source": {
"type": "git",
"url": "https://github.com/doctrine/instantiator.git",
"reference": "8e884e78f9f0eb1329e445619e04456e64d8051d"
"reference": "10dcfce151b967d20fde1b34ae6640712c3891bc"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/doctrine/instantiator/zipball/8e884e78f9f0eb1329e445619e04456e64d8051d",
"reference": "8e884e78f9f0eb1329e445619e04456e64d8051d",
"url": "https://api.github.com/repos/doctrine/instantiator/zipball/10dcfce151b967d20fde1b34ae6640712c3891bc",
"reference": "10dcfce151b967d20fde1b34ae6640712c3891bc",
"shasum": ""
},
"require": {
"php": ">=5.3,<8.0-DEV"
"php": "^7.1 || ^8.0"
},
"require-dev": {
"athletic/athletic": "~0.1.8",
"doctrine/coding-standard": "^9",
"ext-pdo": "*",
"ext-phar": "*",
"phpunit/phpunit": "~4.0",
"squizlabs/php_codesniffer": "~2.0"
"phpbench/phpbench": "^0.16 || ^1",
"phpstan/phpstan": "^1.4",
"phpstan/phpstan-phpunit": "^1",
"phpunit/phpunit": "^7.5 || ^8.5 || ^9.5",
"vimeo/psalm": "^4.22"
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.0.x-dev"
}
},
"autoload": {
"psr-4": {
"Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/"
@ -51,29 +48,47 @@
{
"name": "Marco Pivetta",
"email": "ocramius@gmail.com",
"homepage": "http://ocramius.github.com/"
"homepage": "https://ocramius.github.io/"
}
],
"description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors",
"homepage": "https://github.com/doctrine/instantiator",
"homepage": "https://www.doctrine-project.org/projects/instantiator.html",
"keywords": [
"constructor",
"instantiate"
],
"time": "2015-06-14 21:17:01"
"support": {
"issues": "https://github.com/doctrine/instantiator/issues",
"source": "https://github.com/doctrine/instantiator/tree/1.4.1"
},
"funding": [
{
"url": "https://www.doctrine-project.org/sponsorship.html",
"type": "custom"
},
{
"url": "https://www.patreon.com/phpdoctrine",
"type": "patreon"
},
{
"url": "https://tidelift.com/funding/github/packagist/doctrine%2Finstantiator",
"type": "tidelift"
}
],
"time": "2022-03-03T08:28:38+00:00"
},
{
"name": "phpdocumentor/reflection-docblock",
"version": "2.0.4",
"version": "2.0.5",
"source": {
"type": "git",
"url": "https://github.com/phpDocumentor/ReflectionDocBlock.git",
"reference": "d68dbdc53dc358a816f00b300704702b2eaff7b8"
"reference": "e6a969a640b00d8daa3c66518b0405fb41ae0c4b"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/phpDocumentor/ReflectionDocBlock/zipball/d68dbdc53dc358a816f00b300704702b2eaff7b8",
"reference": "d68dbdc53dc358a816f00b300704702b2eaff7b8",
"url": "https://api.github.com/repos/phpDocumentor/ReflectionDocBlock/zipball/e6a969a640b00d8daa3c66518b0405fb41ae0c4b",
"reference": "e6a969a640b00d8daa3c66518b0405fb41ae0c4b",
"shasum": ""
},
"require": {
@ -109,28 +124,30 @@
"email": "mike.vanriel@naenius.com"
}
],
"time": "2015-02-03 12:10:50"
"support": {
"issues": "https://github.com/phpDocumentor/ReflectionDocBlock/issues",
"source": "https://github.com/phpDocumentor/ReflectionDocBlock/tree/release/2.x"
},
"time": "2016-01-25T08:17:30+00:00"
},
{
"name": "phpspec/prophecy",
"version": "v1.6.0",
"version": "v1.5.0",
"source": {
"type": "git",
"url": "https://github.com/phpspec/prophecy.git",
"reference": "3c91bdf81797d725b14cb62906f9a4ce44235972"
"reference": "4745ded9307786b730d7a60df5cb5a6c43cf95f7"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/phpspec/prophecy/zipball/3c91bdf81797d725b14cb62906f9a4ce44235972",
"reference": "3c91bdf81797d725b14cb62906f9a4ce44235972",
"url": "https://api.github.com/repos/phpspec/prophecy/zipball/4745ded9307786b730d7a60df5cb5a6c43cf95f7",
"reference": "4745ded9307786b730d7a60df5cb5a6c43cf95f7",
"shasum": ""
},
"require": {
"doctrine/instantiator": "^1.0.2",
"php": "^5.3|^7.0",
"phpdocumentor/reflection-docblock": "~2.0",
"sebastian/comparator": "~1.1",
"sebastian/recursion-context": "~1.0"
"sebastian/comparator": "~1.1"
},
"require-dev": {
"phpspec/phpspec": "~2.0"
@ -138,7 +155,7 @@
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.5.x-dev"
"dev-master": "1.4.x-dev"
}
},
"autoload": {
@ -171,7 +188,11 @@
"spy",
"stub"
],
"time": "2016-02-15 07:46:21"
"support": {
"issues": "https://github.com/phpspec/prophecy/issues",
"source": "https://github.com/phpspec/prophecy/tree/master"
},
"time": "2015-08-13T10:07:40+00:00"
},
{
"name": "phpunit/php-code-coverage",
@ -233,20 +254,25 @@
"testing",
"xunit"
],
"time": "2015-10-06 15:47:00"
"support": {
"irc": "irc://irc.freenode.net/phpunit",
"issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
"source": "https://github.com/sebastianbergmann/php-code-coverage/tree/2.2"
},
"time": "2015-10-06T15:47:00+00:00"
},
{
"name": "phpunit/php-file-iterator",
"version": "1.4.1",
"version": "1.4.5",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/php-file-iterator.git",
"reference": "6150bf2c35d3fc379e50c7602b75caceaa39dbf0"
"reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/6150bf2c35d3fc379e50c7602b75caceaa39dbf0",
"reference": "6150bf2c35d3fc379e50c7602b75caceaa39dbf0",
"url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/730b01bc3e867237eaac355e06a36b85dd93a8b4",
"reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4",
"shasum": ""
},
"require": {
@ -280,7 +306,12 @@
"filesystem",
"iterator"
],
"time": "2015-06-21 13:08:43"
"support": {
"irc": "irc://irc.freenode.net/phpunit",
"issues": "https://github.com/sebastianbergmann/php-file-iterator/issues",
"source": "https://github.com/sebastianbergmann/php-file-iterator/tree/1.4.5"
},
"time": "2017-11-27T13:52:08+00:00"
},
{
"name": "phpunit/php-text-template",
@ -321,7 +352,11 @@
"keywords": [
"template"
],
"time": "2015-06-21 13:50:34"
"support": {
"issues": "https://github.com/sebastianbergmann/php-text-template/issues",
"source": "https://github.com/sebastianbergmann/php-text-template/tree/1.2.1"
},
"time": "2015-06-21T13:50:34+00:00"
},
{
"name": "phpunit/php-timer",
@ -365,20 +400,25 @@
"keywords": [
"timer"
],
"time": "2016-05-12 18:03:57"
"support": {
"irc": "irc://irc.freenode.net/phpunit",
"issues": "https://github.com/sebastianbergmann/php-timer/issues",
"source": "https://github.com/sebastianbergmann/php-timer/tree/master"
},
"time": "2016-05-12T18:03:57+00:00"
},
{
"name": "phpunit/php-token-stream",
"version": "1.4.8",
"version": "1.4.12",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/php-token-stream.git",
"reference": "3144ae21711fb6cac0b1ab4cbe63b75ce3d4e8da"
"reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/3144ae21711fb6cac0b1ab4cbe63b75ce3d4e8da",
"reference": "3144ae21711fb6cac0b1ab4cbe63b75ce3d4e8da",
"url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/1ce90ba27c42e4e44e6d8458241466380b51fa16",
"reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16",
"shasum": ""
},
"require": {
@ -414,20 +454,25 @@
"keywords": [
"tokenizer"
],
"time": "2015-09-15 10:49:45"
"support": {
"issues": "https://github.com/sebastianbergmann/php-token-stream/issues",
"source": "https://github.com/sebastianbergmann/php-token-stream/tree/1.4"
},
"abandoned": true,
"time": "2017-12-04T08:55:13+00:00"
},
{
"name": "phpunit/phpunit",
"version": "4.8.26",
"version": "4.8.36",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/phpunit.git",
"reference": "fc1d8cd5b5de11625979125c5639347896ac2c74"
"reference": "46023de9a91eec7dfb06cc56cb4e260017298517"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/fc1d8cd5b5de11625979125c5639347896ac2c74",
"reference": "fc1d8cd5b5de11625979125c5639347896ac2c74",
"url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/46023de9a91eec7dfb06cc56cb4e260017298517",
"reference": "46023de9a91eec7dfb06cc56cb4e260017298517",
"shasum": ""
},
"require": {
@ -443,7 +488,7 @@
"phpunit/php-text-template": "~1.2",
"phpunit/php-timer": "^1.0.6",
"phpunit/phpunit-mock-objects": "~2.3",
"sebastian/comparator": "~1.1",
"sebastian/comparator": "~1.2.2",
"sebastian/diff": "~1.2",
"sebastian/environment": "~1.3",
"sebastian/exporter": "~1.2",
@ -486,7 +531,11 @@
"testing",
"xunit"
],
"time": "2016-05-17 03:09:28"
"support": {
"issues": "https://github.com/sebastianbergmann/phpunit/issues",
"source": "https://github.com/sebastianbergmann/phpunit/tree/4.8.36"
},
"time": "2017-06-21T08:07:12+00:00"
},
{
"name": "phpunit/phpunit-mock-objects",
@ -542,26 +591,32 @@
"mock",
"xunit"
],
"time": "2015-10-02 06:51:40"
"support": {
"irc": "irc://irc.freenode.net/phpunit",
"issues": "https://github.com/sebastianbergmann/phpunit-mock-objects/issues",
"source": "https://github.com/sebastianbergmann/phpunit-mock-objects/tree/2.3"
},
"abandoned": true,
"time": "2015-10-02T06:51:40+00:00"
},
{
"name": "sebastian/comparator",
"version": "1.2.0",
"version": "1.2.4",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/comparator.git",
"reference": "937efb279bd37a375bcadf584dec0726f84dbf22"
"reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/937efb279bd37a375bcadf584dec0726f84dbf22",
"reference": "937efb279bd37a375bcadf584dec0726f84dbf22",
"url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
"reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
"shasum": ""
},
"require": {
"php": ">=5.3.3",
"sebastian/diff": "~1.2",
"sebastian/exporter": "~1.2"
"sebastian/exporter": "~1.2 || ~2.0"
},
"require-dev": {
"phpunit/phpunit": "~4.4"
@ -606,7 +661,11 @@
"compare",
"equality"
],
"time": "2015-07-26 15:48:44"
"support": {
"issues": "https://github.com/sebastianbergmann/comparator/issues",
"source": "https://github.com/sebastianbergmann/comparator/tree/1.2"
},
"time": "2017-01-29T09:50:25+00:00"
},
{
"name": "sebastian/diff",
@ -658,7 +717,11 @@
"keywords": [
"diff"
],
"time": "2015-12-08 07:14:41"
"support": {
"issues": "https://github.com/sebastianbergmann/diff/issues",
"source": "https://github.com/sebastianbergmann/diff/tree/master"
},
"time": "2015-12-08T07:14:41+00:00"
},
{
"name": "sebastian/environment",
@ -708,20 +771,24 @@
"environment",
"hhvm"
],
"time": "2016-05-17 03:18:57"
"support": {
"issues": "https://github.com/sebastianbergmann/environment/issues",
"source": "https://github.com/sebastianbergmann/environment/tree/1.3.7"
},
"time": "2016-05-17T03:18:57+00:00"
},
{
"name": "sebastian/exporter",
"version": "1.2.1",
"version": "1.2.2",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/exporter.git",
"reference": "7ae5513327cb536431847bcc0c10edba2701064e"
"reference": "42c4c2eec485ee3e159ec9884f95b431287edde4"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/7ae5513327cb536431847bcc0c10edba2701064e",
"reference": "7ae5513327cb536431847bcc0c10edba2701064e",
"url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/42c4c2eec485ee3e159ec9884f95b431287edde4",
"reference": "42c4c2eec485ee3e159ec9884f95b431287edde4",
"shasum": ""
},
"require": {
@ -729,12 +796,13 @@
"sebastian/recursion-context": "~1.0"
},
"require-dev": {
"ext-mbstring": "*",
"phpunit/phpunit": "~4.4"
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.2.x-dev"
"dev-master": "1.3.x-dev"
}
},
"autoload": {
@ -774,7 +842,11 @@
"export",
"exporter"
],
"time": "2015-06-21 07:55:53"
"support": {
"issues": "https://github.com/sebastianbergmann/exporter/issues",
"source": "https://github.com/sebastianbergmann/exporter/tree/master"
},
"time": "2016-06-17T09:04:28+00:00"
},
{
"name": "sebastian/global-state",
@ -825,20 +897,24 @@
"keywords": [
"global state"
],
"time": "2015-10-12 03:26:01"
"support": {
"issues": "https://github.com/sebastianbergmann/global-state/issues",
"source": "https://github.com/sebastianbergmann/global-state/tree/1.1.1"
},
"time": "2015-10-12T03:26:01+00:00"
},
{
"name": "sebastian/recursion-context",
"version": "1.0.2",
"version": "1.0.5",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/recursion-context.git",
"reference": "913401df809e99e4f47b27cdd781f4a258d58791"
"reference": "b19cc3298482a335a95f3016d2f8a6950f0fbcd7"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/913401df809e99e4f47b27cdd781f4a258d58791",
"reference": "913401df809e99e4f47b27cdd781f4a258d58791",
"url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/b19cc3298482a335a95f3016d2f8a6950f0fbcd7",
"reference": "b19cc3298482a335a95f3016d2f8a6950f0fbcd7",
"shasum": ""
},
"require": {
@ -878,7 +954,11 @@
],
"description": "Provides functionality to recursively process PHP variables",
"homepage": "http://www.github.com/sebastianbergmann/recursion-context",
"time": "2015-11-11 19:50:13"
"support": {
"issues": "https://github.com/sebastianbergmann/recursion-context/issues",
"source": "https://github.com/sebastianbergmann/recursion-context/tree/master"
},
"time": "2016-10-03T07:41:43+00:00"
},
{
"name": "sebastian/version",
@ -913,31 +993,122 @@
],
"description": "Library that helps with managing the version number of Git-hosted PHP projects",
"homepage": "https://github.com/sebastianbergmann/version",
"time": "2015-06-21 13:59:46"
"support": {
"issues": "https://github.com/sebastianbergmann/version/issues",
"source": "https://github.com/sebastianbergmann/version/tree/1.0.6"
},
"time": "2015-06-21T13:59:46+00:00"
},
{
"name": "symfony/yaml",
"version": "v3.0.6",
"name": "symfony/polyfill-ctype",
"version": "v1.26.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/yaml.git",
"reference": "0047c8366744a16de7516622c5b7355336afae96"
"url": "https://github.com/symfony/polyfill-ctype.git",
"reference": "6fd1b9a79f6e3cf65f9e679b23af304cd9e010d4"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/yaml/zipball/0047c8366744a16de7516622c5b7355336afae96",
"reference": "0047c8366744a16de7516622c5b7355336afae96",
"url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/6fd1b9a79f6e3cf65f9e679b23af304cd9e010d4",
"reference": "6fd1b9a79f6e3cf65f9e679b23af304cd9e010d4",
"shasum": ""
},
"require": {
"php": ">=5.5.9"
"php": ">=7.1"
},
"provide": {
"ext-ctype": "*"
},
"suggest": {
"ext-ctype": "For best performance"
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "3.0-dev"
"dev-main": "1.26-dev"
},
"thanks": {
"name": "symfony/polyfill",
"url": "https://github.com/symfony/polyfill"
}
},
"autoload": {
"files": [
"bootstrap.php"
],
"psr-4": {
"Symfony\\Polyfill\\Ctype\\": ""
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Gert de Pagter",
"email": "BackEndTea@gmail.com"
},
{
"name": "Symfony Community",
"homepage": "https://symfony.com/contributors"
}
],
"description": "Symfony polyfill for ctype functions",
"homepage": "https://symfony.com",
"keywords": [
"compatibility",
"ctype",
"polyfill",
"portable"
],
"support": {
"source": "https://github.com/symfony/polyfill-ctype/tree/v1.26.0"
},
"funding": [
{
"url": "https://symfony.com/sponsor",
"type": "custom"
},
{
"url": "https://github.com/fabpot",
"type": "github"
},
{
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
"type": "tidelift"
}
],
"time": "2022-05-24T11:49:31+00:00"
},
{
"name": "symfony/yaml",
"version": "v3.4.47",
"source": {
"type": "git",
"url": "https://github.com/symfony/yaml.git",
"reference": "88289caa3c166321883f67fe5130188ebbb47094"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/yaml/zipball/88289caa3c166321883f67fe5130188ebbb47094",
"reference": "88289caa3c166321883f67fe5130188ebbb47094",
"shasum": ""
},
"require": {
"php": "^5.5.9|>=7.0.8",
"symfony/polyfill-ctype": "~1.8"
},
"conflict": {
"symfony/console": "<3.4"
},
"require-dev": {
"symfony/console": "~3.4|~4.0"
},
"suggest": {
"symfony/console": "For validating YAML files using the lint command"
},
"type": "library",
"autoload": {
"psr-4": {
"Symfony\\Component\\Yaml\\": ""
@ -962,7 +1133,24 @@
],
"description": "Symfony Yaml Component",
"homepage": "https://symfony.com",
"time": "2016-03-04 07:55:57"
"support": {
"source": "https://github.com/symfony/yaml/tree/v3.4.47"
},
"funding": [
{
"url": "https://symfony.com/sponsor",
"type": "custom"
},
{
"url": "https://github.com/fabpot",
"type": "github"
},
{
"url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
"type": "tidelift"
}
],
"time": "2020-10-24T10:57:07+00:00"
}
],
"aliases": [],
@ -971,7 +1159,8 @@
"prefer-stable": false,
"prefer-lowest": false,
"platform": {
"php": ">=5.3.0"
"php": "^8.1"
},
"platform-dev": []
"platform-dev": [],
"plugin-api-version": "2.2.0"
}

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
use Moserware\Skills\Rating;
use DNW\Skills\Rating;
/**
* An Elo rating represented by a single number (mean).

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
use Moserware\Skills\GameInfo;
use DNW\Skills\GameInfo;
/**
* Including Elo's scheme as a simple comparison.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
// see http://ratings.fide.com/calculator_rtd.phtml for details
class FideKFactor extends KFactor

View File

@ -1,18 +1,18 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\GameInfo;
use DNW\Skills\Numerics\GaussianDistribution;
class GaussianEloCalculator extends TwoPlayerEloCalculator
{
// From the paper
const STABLE_KFACTOR = 24;
public function __construct()
public function __construct()
{
parent::__construct(new KFactor(self::STABLE_KFACTOR));
}
public function getPlayerWinProbability(GameInfo $gameInfo, $playerRating, $opponentRating)
{
$ratingDifference = $playerRating - $opponentRating;

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
class KFactor
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
/**
* Indicates someone who has played less than 30 games.

View File

@ -1,19 +1,19 @@
<?php namespace Moserware\Skills\Elo;
<?php namespace DNW\Skills\Elo;
use Exception;
use Moserware\Skills\GameInfo;
use Moserware\Skills\PairwiseComparison;
use Moserware\Skills\RankSorter;
use Moserware\Skills\SkillCalculator;
use Moserware\Skills\SkillCalculatorSupportedOptions;
use Moserware\Skills\PlayersRange;
use Moserware\Skills\TeamsRange;
use DNW\Skills\GameInfo;
use DNW\Skills\PairwiseComparison;
use DNW\Skills\RankSorter;
use DNW\Skills\SkillCalculator;
use DNW\Skills\SkillCalculatorSupportedOptions;
use DNW\Skills\PlayersRange;
use DNW\Skills\TeamsRange;
abstract class TwoPlayerEloCalculator extends SkillCalculator
{
protected $_kFactor;
protected function __construct(KFactor $kFactor)
protected function __construct(KFactor $kFactor)
{
parent::__construct(SkillCalculatorSupportedOptions::NONE, TeamsRange::exactly(2), PlayersRange::exactly(1));
$this->_kFactor = $kFactor;
@ -23,16 +23,16 @@ abstract class TwoPlayerEloCalculator extends SkillCalculator
{
$this->validateTeamCountAndPlayersCountPerTeam($teamsOfPlayerToRatings);
RankSorter::sort($teamsOfPlayerToRatings, $teamRanks);
$result = array();
$isDraw = ($teamRanks[0] === $teamRanks[1]);
$team1 = $teamsOfPlayerToRatings[0];
$team2 = $teamsOfPlayerToRatings[1];
$player1 = each($team1);
$player2 = each($team2);
$player1Rating = $player1["value"]->getMean();
$player2Rating = $player2["value"]->getMean();
@ -75,13 +75,13 @@ abstract class TwoPlayerEloCalculator extends SkillCalculator
$this->validateTeamCountAndPlayersCountPerTeam($teamsOfPlayerToRatings);
$team1 = $teamsOfPlayerToRatings[0];
$team2 = $teamsOfPlayerToRatings[1];
$player1 = $team1[0];
$player2 = $team2[0];
$player1Rating = $player1[1]->getMean();
$player2Rating = $player2[1]->getMean();
$ratingDifference = $player1Rating - $player2Rating;
// The TrueSkill paper mentions that they used s1 - s2 (rating difference) to

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
use Exception;

View File

@ -1,8 +1,8 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
use Exception;
use Moserware\Skills\Guard;
use Moserware\Skills\HashMap;
use DNW\Skills\Guard;
use DNW\Skills\HashMap;
abstract class Factor
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class FactorGraph
{

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
// edit this
abstract class FactorGraphLayer
{
private $_localFactors = array();
private $_outputVariablesGroups = array();
private $_outputVariablesGroups = array();
private $_inputVariablesGroups = array();
private $_parentFactorGraph;

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
/**
* Helper class for computing the factor graph's normalization constant.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class KeyedVariable extends Variable
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class Message
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
abstract class Schedule
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class ScheduleLoop extends Schedule
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class ScheduleSequence extends Schedule
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class ScheduleStep extends Schedule
{

View File

@ -1,5 +1,5 @@
<?php
namespace Moserware\Skills\FactorGraphs;
namespace DNW\Skills\FactorGraphs;
class Variable
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\FactorGraphs;
<?php namespace DNW\Skills\FactorGraphs;
class VariableFactory
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Parameters about the game for calculating the TrueSkill.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
use Exception;

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Basic hashmap that supports object keys.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Indicates support for allowing partial play (where a player only plays a part of the time).

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
interface ISupportPartialUpdate
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
/**
* Basic math functions.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
class DiagonalMatrix extends Matrix
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
/**
* Computes Gaussian (bell curve) values.
@ -177,7 +177,7 @@ class GaussianDistribution
private static function errorFunctionCumulativeTo($x)
{
// Derived from page 265 of Numerical Recipes 3rd Edition
// Derived from page 265 of Numerical Recipes 3rd Edition
$z = abs($x);
$t = 2.0 / (2.0 + $z);
@ -229,7 +229,7 @@ class GaussianDistribution
private static function inverseErrorFunctionCumulativeTo($p)
{
// From page 265 of numerical recipes
// From page 265 of numerical recipes
if ($p >= 2.0) {
return -100;

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
class IdentityMatrix extends DiagonalMatrix
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
use Exception;

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
// The whole purpose of this class is to make the code for the SkillCalculator(s)
// look a little cleaner
@ -9,7 +9,7 @@ class Range
{
private $_min;
private $_max;
public function __construct($min, $max)
{
if ($min > $max)
@ -24,13 +24,13 @@ class Range
public function getMin()
{
return $this->_min;
}
}
public function getMax()
{
return $this->_max;
}
protected static function create($min, $max)
{
return new Range($min, $max);

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
class SquareMatrix extends Matrix
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Numerics;
<?php namespace DNW\Skills\Numerics;
class Vector extends Matrix
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Represents a comparison between two players.

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
class PartialPlay
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Represents a player who has a Rating.

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
use Moserware\Skills\Numerics\Range;
use DNW\Skills\Numerics\Range;
class PlayersRange extends Range
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
/**
* Helper class to sort ranks in non-decreasing order.
@ -13,7 +13,7 @@ class RankSorter
* @return array
*/
public static function sort(array &$teams, array &$teamRanks)
{
{
array_multisort($teamRanks, $teams);
return $teams;
}

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
// Container for a player's rating.
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Numerics\GaussianDistribution;
class Rating
{
@ -54,7 +54,7 @@ class Rating
$posteriorGaussian = new GaussianDistribution($fullPosterior->getMean(), $fullPosterior . getStandardDeviation());
// From a clarification email from Ralf Herbrich:
// "the idea is to compute a linear interpolation between the prior and posterior skills of each player
// "the idea is to compute a linear interpolation between the prior and posterior skills of each player
// ... in the canonical space of parameters"
$precisionDifference = $posteriorGaussian->getPrecision() - $priorGaussian->getPrecision();

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
class RatingContainer
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
use Exception;

View File

@ -1,11 +1,11 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
class Team extends RatingContainer
{
public function __construct(Player $player = null, Rating $rating = null)
{
parent::__construct();
if(!is_null($player))
{
$this->addPlayer($player, $rating);
@ -16,5 +16,5 @@ class Team extends RatingContainer
{
$this->setRating($player, $rating);
return $this;
}
}
}

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
class Teams
{

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills;
<?php namespace DNW\Skills;
use Moserware\Skills\Numerics\Range;
use DNW\Skills\Numerics\Range;
class TeamsRange extends Range
{
@ -8,7 +8,7 @@ class TeamsRange extends Range
{
parent::__construct($min, $max);
}
protected static function create($min, $max)
{
return new TeamsRange($min, $max);

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Numerics\GaussianDistribution;
final class DrawMargin
{

View File

@ -1,19 +1,19 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Guard;
use Moserware\Skills\ISupportPartialPlay;
use Moserware\Skills\ISupportPartialUpdate;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\Numerics\DiagonalMatrix;
use Moserware\Skills\Numerics\Matrix;
use Moserware\Skills\Numerics\Vector;
use Moserware\Skills\PartialPlay;
use Moserware\Skills\PlayersRange;
use Moserware\Skills\RankSorter;
use Moserware\Skills\SkillCalculator;
use Moserware\Skills\SkillCalculatorSupportedOptions;
use Moserware\Skills\TeamsRange;
use DNW\Skills\GameInfo;
use DNW\Skills\Guard;
use DNW\Skills\ISupportPartialPlay;
use DNW\Skills\ISupportPartialUpdate;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\Numerics\DiagonalMatrix;
use DNW\Skills\Numerics\Matrix;
use DNW\Skills\Numerics\Vector;
use DNW\Skills\PartialPlay;
use DNW\Skills\PlayersRange;
use DNW\Skills\RankSorter;
use DNW\Skills\SkillCalculator;
use DNW\Skills\SkillCalculatorSupportedOptions;
use DNW\Skills\TeamsRange;
/**
* Calculates TrueSkill using a full factor graph.

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Moserware\Skills\FactorGraphs\Factor;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\FactorGraphs\Factor;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\GaussianDistribution;
abstract class GaussianFactor extends Factor
{

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Moserware\Skills\Numerics\GaussianDistribution;
use Moserware\Skills\TrueSkill\TruncatedGaussianCorrectionFunctions;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\GaussianDistribution;
use DNW\Skills\TrueSkill\TruncatedGaussianCorrectionFunctions;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
/**
* Factor representing a team difference that has exceeded the draw margin.

View File

@ -1,10 +1,10 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Exception;
use Moserware\Skills\FactorGraphs\KeyedVariable;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\FactorGraphs\KeyedVariable;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\GaussianDistribution;
/**
* Connects two variables and adds uncertainty.

View File

@ -1,8 +1,8 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\GaussianDistribution;
/**
* Supplies the factor graph with prior information.

View File

@ -1,10 +1,10 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Moserware\Skills\Guard;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Guard;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\Numerics\GaussianDistribution;
/**
* Factor that sums together multiple Gaussians.

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\TrueSkill\Factors;
<?php namespace DNW\Skills\TrueSkill\Factors;
use Moserware\Skills\Numerics\GaussianDistribution;
use Moserware\Skills\TrueSkill\TruncatedGaussianCorrectionFunctions;
use Moserware\Skills\FactorGraphs\Message;
use Moserware\Skills\FactorGraphs\Variable;
use DNW\Skills\Numerics\GaussianDistribution;
use DNW\Skills\TrueSkill\TruncatedGaussianCorrectionFunctions;
use DNW\Skills\FactorGraphs\Message;
use DNW\Skills\FactorGraphs\Variable;
/**
* Factor representing a team difference that has not exceeded the draw margin.

View File

@ -1,10 +1,10 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Exception;
use Moserware\Skills\FactorGraphs\ScheduleLoop;
use Moserware\Skills\FactorGraphs\ScheduleSequence;
use Moserware\Skills\FactorGraphs\ScheduleStep;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\FactorGraphs\ScheduleLoop;
use DNW\Skills\FactorGraphs\ScheduleSequence;
use DNW\Skills\FactorGraphs\ScheduleStep;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
// The whole purpose of this is to do a loop on the bottom
class IteratedTeamDifferencesInnerLayer extends TrueSkillFactorGraphLayer

View File

@ -1,11 +1,11 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\PartialPlay;
use Moserware\Skills\FactorGraphs\ScheduleLoop;
use Moserware\Skills\FactorGraphs\ScheduleSequence;
use Moserware\Skills\FactorGraphs\ScheduleStep;
use Moserware\Skills\TrueSkill\Factors\GaussianWeightedSumFactor;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\PartialPlay;
use DNW\Skills\FactorGraphs\ScheduleLoop;
use DNW\Skills\FactorGraphs\ScheduleSequence;
use DNW\Skills\FactorGraphs\ScheduleStep;
use DNW\Skills\TrueSkill\Factors\GaussianWeightedSumFactor;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
class PlayerPerformancesToTeamPerformancesLayer extends TrueSkillFactorGraphLayer
{

View File

@ -1,11 +1,11 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\Rating;
use Moserware\Skills\FactorGraphs\ScheduleStep;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use Moserware\Skills\TrueSkill\Factors\GaussianPriorFactor;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\Rating;
use DNW\Skills\FactorGraphs\ScheduleStep;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\TrueSkill\Factors\GaussianPriorFactor;
// We intentionally have no Posterior schedule since the only purpose here is to
// start the process.

View File

@ -1,10 +1,10 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\FactorGraphs\ScheduleStep;
use Moserware\Skills\FactorGraphs\KeyedVariable;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use Moserware\Skills\TrueSkill\Factors\GaussianLikelihoodFactor;
use DNW\Skills\FactorGraphs\ScheduleStep;
use DNW\Skills\FactorGraphs\KeyedVariable;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\TrueSkill\Factors\GaussianLikelihoodFactor;
class PlayerSkillsToPerformancesLayer extends TrueSkillFactorGraphLayer
{

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\TrueSkill\DrawMargin;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use Moserware\Skills\TrueSkill\Factors\GaussianGreaterThanFactor;
use Moserware\Skills\TrueSkill\Factors\GaussianWithinFactor;
use DNW\Skills\TrueSkill\DrawMargin;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\TrueSkill\Factors\GaussianGreaterThanFactor;
use DNW\Skills\TrueSkill\Factors\GaussianWithinFactor;
class TeamDifferencesComparisonLayer extends TrueSkillFactorGraphLayer
{

View File

@ -1,8 +1,8 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\FactorGraphs\Variable;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use Moserware\Skills\TrueSkill\Factors\GaussianWeightedSumFactor;
use DNW\Skills\FactorGraphs\Variable;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\TrueSkill\Factors\GaussianWeightedSumFactor;
class TeamPerformancesToTeamPerformanceDifferencesLayer extends TrueSkillFactorGraphLayer
{
@ -26,7 +26,7 @@ class TeamPerformancesToTeamPerformanceDifferencesLayer extends TrueSkillFactorG
$newDifferencesFactor = $this->createTeamPerformanceToDifferenceFactor($strongerTeam, $weakerTeam, $currentDifference);
$this->addLayerFactor($newDifferencesFactor);
// REVIEW: Does it make sense to have groups of one?
// REVIEW: Does it make sense to have groups of one?
$outputVariablesGroup[] = array($currentDifference);
}
}

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\TrueSkill\Layers;
<?php namespace DNW\Skills\TrueSkill\Layers;
use Moserware\Skills\FactorGraphs\FactorGraphLayer;
use Moserware\Skills\TrueSkill\TrueSkillFactorGraph;
use DNW\Skills\FactorGraphs\FactorGraphLayer;
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
abstract class TrueSkillFactorGraphLayer extends FactorGraphLayer
{

View File

@ -1,19 +1,19 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Numerics\GaussianDistribution;
use Moserware\Skills\Rating;
use Moserware\Skills\RatingContainer;
use Moserware\Skills\FactorGraphs\FactorGraph;
use Moserware\Skills\FactorGraphs\FactorList;
use Moserware\Skills\FactorGraphs\ScheduleSequence;
use Moserware\Skills\FactorGraphs\VariableFactory;
use Moserware\Skills\TrueSkill\Layers\IteratedTeamDifferencesInnerLayer;
use Moserware\Skills\TrueSkill\Layers\PlayerPerformancesToTeamPerformancesLayer;
use Moserware\Skills\TrueSkill\Layers\PlayerPriorValuesToSkillsLayer;
use Moserware\Skills\TrueSkill\Layers\PlayerSkillsToPerformancesLayer;
use Moserware\Skills\TrueSkill\Layers\TeamDifferencesComparisonLayer;
use Moserware\Skills\TrueSkill\Layers\TeamPerformancesToTeamPerformanceDifferencesLayer;
use DNW\Skills\GameInfo;
use DNW\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Rating;
use DNW\Skills\RatingContainer;
use DNW\Skills\FactorGraphs\FactorGraph;
use DNW\Skills\FactorGraphs\FactorList;
use DNW\Skills\FactorGraphs\ScheduleSequence;
use DNW\Skills\FactorGraphs\VariableFactory;
use DNW\Skills\TrueSkill\Layers\IteratedTeamDifferencesInnerLayer;
use DNW\Skills\TrueSkill\Layers\PlayerPerformancesToTeamPerformancesLayer;
use DNW\Skills\TrueSkill\Layers\PlayerPriorValuesToSkillsLayer;
use DNW\Skills\TrueSkill\Layers\PlayerSkillsToPerformancesLayer;
use DNW\Skills\TrueSkill\Layers\TeamDifferencesComparisonLayer;
use DNW\Skills\TrueSkill\Layers\TeamPerformancesToTeamPerformanceDifferencesLayer;
class TrueSkillFactorGraph extends FactorGraph
{

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Numerics\GaussianDistribution;
class TruncatedGaussianCorrectionFunctions
{

View File

@ -1,20 +1,20 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Guard;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\PairwiseComparison;
use Moserware\Skills\RankSorter;
use Moserware\Skills\Rating;
use Moserware\Skills\RatingContainer;
use Moserware\Skills\SkillCalculator;
use Moserware\Skills\SkillCalculatorSupportedOptions;
use Moserware\Skills\PlayersRange;
use Moserware\Skills\TeamsRange;
use DNW\Skills\GameInfo;
use DNW\Skills\Guard;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\PairwiseComparison;
use DNW\Skills\RankSorter;
use DNW\Skills\Rating;
use DNW\Skills\RatingContainer;
use DNW\Skills\SkillCalculator;
use DNW\Skills\SkillCalculatorSupportedOptions;
use DNW\Skills\PlayersRange;
use DNW\Skills\TeamsRange;
/**
* Calculates the new ratings for only two players.
*
*
* When you only have two players, a lot of the math simplifies. The main purpose of this class
* is to show the bare minimum of what a TrueSkill implementation should have.
*/
@ -35,12 +35,12 @@ class TwoPlayerTrueSkillCalculator extends SkillCalculator
// Make sure things are in order
RankSorter::sort($teams, $teamRanks);
// Since we verified that each team has one player, we know the player is the first one
$winningTeamPlayers = $teams[0]->getAllPlayers();
$winner = $winningTeamPlayers[0];
$winnerPreviousRating = $teams[0]->getRating($winner);
$losingTeamPlayers = $teams[1]->getAllPlayers();
$loser = $losingTeamPlayers[0];
$loserPreviousRating = $teams[1]->getRating($loser);

View File

@ -1,19 +1,19 @@
<?php namespace Moserware\Skills\TrueSkill;
<?php namespace DNW\Skills\TrueSkill;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Guard;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\PairwiseComparison;
use Moserware\Skills\RankSorter;
use Moserware\Skills\Rating;
use Moserware\Skills\RatingContainer;
use Moserware\Skills\SkillCalculator;
use Moserware\Skills\SkillCalculatorSupportedOptions;
use DNW\Skills\GameInfo;
use DNW\Skills\Guard;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\PairwiseComparison;
use DNW\Skills\RankSorter;
use DNW\Skills\Rating;
use DNW\Skills\RatingContainer;
use DNW\Skills\SkillCalculator;
use DNW\Skills\SkillCalculatorSupportedOptions;
use Moserware\Skills\PlayersRange;
use Moserware\Skills\TeamsRange;
use DNW\Skills\PlayersRange;
use DNW\Skills\TeamsRange;
use Moserware\Skills\Team;
use DNW\Skills\Team;
/**
* Calculates new ratings for only two teams where each team has 1 or more players.

View File

@ -1,10 +1,10 @@
<?php namespace Moserware\Skills\Tests\Elo;
<?php namespace DNW\Skills\Tests\Elo;
use Moserware\Skills\Elo\EloRating;
use Moserware\Skills\Elo\FideEloCalculator;
use Moserware\Skills\GameInfo;
use Moserware\Skills\PairwiseComparison;
use Moserware\Skills\Tests\TestCase;
use DNW\Skills\Elo\EloRating;
use DNW\Skills\Elo\FideEloCalculator;
use DNW\Skills\GameInfo;
use DNW\Skills\PairwiseComparison;
use DNW\Skills\Tests\TestCase;
class EloAssert
{

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\Tests\Elo;
<?php namespace DNW\Skills\Tests\Elo;
use Moserware\Skills\Elo\FideEloCalculator;
use Moserware\Skills\Elo\ProvisionalFideKFactor;
use Moserware\Skills\PairwiseComparison;
use Moserware\Skills\Tests\TestCase;
use DNW\Skills\Elo\FideEloCalculator;
use DNW\Skills\Elo\ProvisionalFideKFactor;
use DNW\Skills\PairwiseComparison;
use DNW\Skills\Tests\TestCase;
class FideEloCalculatorTest extends TestCase
{

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\Tests\Numerics;
<?php namespace DNW\Skills\Tests\Numerics;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\Tests\TestCase;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\Tests\TestCase;
class BasicMathTest extends TestCase
{

View File

@ -1,8 +1,8 @@
<?php namespace Moserware\Skills\Tests\Numerics;
<?php namespace DNW\Skills\Tests\Numerics;
use Moserware\Skills\Numerics\BasicMath;
use Moserware\Skills\Numerics\GaussianDistribution;
use Moserware\Skills\Tests\TestCase;
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\Numerics\GaussianDistribution;
use DNW\Skills\Tests\TestCase;
class GaussianDistributionTest extends TestCase
{
@ -76,7 +76,7 @@ class GaussianDistributionTest extends TestCase
public function testLogRatioNormalization()
{
// Verified with Ralf Herbrich's F# implementation
// Verified with Ralf Herbrich's F# implementation
$m1s2 = new GaussianDistribution(1, 2);
$m3s4 = new GaussianDistribution(3, 4);
$lrn = GaussianDistribution::logRatioNormalization($m1s2, $m3s4);
@ -85,7 +85,7 @@ class GaussianDistributionTest extends TestCase
public function testAbsoluteDifference()
{
// Verified with Ralf Herbrich's F# implementation
// Verified with Ralf Herbrich's F# implementation
$standardNormal = new GaussianDistribution(0, 1);
$absDiff = GaussianDistribution::absoluteDifference($standardNormal, $standardNormal);
$this->assertEquals(0.0, $absDiff, '', GaussianDistributionTest::ERROR_TOLERANCE);

View File

@ -1,9 +1,9 @@
<?php namespace Moserware\Skills\Tests\Numerics;
<?php namespace DNW\Skills\Tests\Numerics;
use Moserware\Skills\Numerics\IdentityMatrix;
use Moserware\Skills\Numerics\Matrix;
use Moserware\Skills\Numerics\SquareMatrix;
use Moserware\Skills\Tests\TestCase;
use DNW\Skills\Numerics\IdentityMatrix;
use DNW\Skills\Numerics\Matrix;
use DNW\Skills\Numerics\SquareMatrix;
use DNW\Skills\Tests\TestCase;
class MatrixTest extends TestCase
{

View File

@ -1,6 +1,6 @@
<?php namespace Moserware\Skills\Tests;
<?php namespace DNW\Skills\Tests;
use Moserware\Skills\RankSorter;
use DNW\Skills\RankSorter;
class RankSorterTest extends TestCase
{

View File

@ -1,4 +1,4 @@
<?php namespace Moserware\Skills\Tests;
<?php namespace DNW\Skills\Tests;
class TestCase extends \PHPUnit_Framework_TestCase
{

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\Tests\TrueSkill;
<?php namespace DNW\Skills\Tests\TrueSkill;
use Moserware\Skills\Tests\TestCase;
use Moserware\Skills\TrueSkill\DrawMargin;
use DNW\Skills\Tests\TestCase;
use DNW\Skills\TrueSkill\DrawMargin;
class DrawMarginTest extends TestCase
{

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\Tests\TrueSkill;
<?php namespace DNW\Skills\Tests\TrueSkill;
use Moserware\Skills\Tests\TestCase;
use Moserware\Skills\TrueSkill\FactorGraphTrueSkillCalculator;
use DNW\Skills\Tests\TestCase;
use DNW\Skills\TrueSkill\FactorGraphTrueSkillCalculator;
class FactorGraphTrueSkillCalculatorTest extends TestCase
{

View File

@ -1,11 +1,11 @@
<?php namespace Moserware\Skills\Tests\TrueSkill;
<?php namespace DNW\Skills\Tests\TrueSkill;
use Moserware\Skills\GameInfo;
use Moserware\Skills\Player;
use Moserware\Skills\Rating;
use Moserware\Skills\Team;
use Moserware\Skills\Teams;
use Moserware\Skills\SkillCalculator;
use DNW\Skills\GameInfo;
use DNW\Skills\Player;
use DNW\Skills\Rating;
use DNW\Skills\Team;
use DNW\Skills\Teams;
use DNW\Skills\SkillCalculator;
class TrueSkillCalculatorTests
{

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\Tests\TrueSkill;
<?php namespace DNW\Skills\Tests\TrueSkill;
use Moserware\Skills\Tests\TestCase;
use Moserware\Skills\TrueSkill\TwoPlayerTrueSkillCalculator;
use DNW\Skills\Tests\TestCase;
use DNW\Skills\TrueSkill\TwoPlayerTrueSkillCalculator;
class TwoPlayerTrueSkillCalculatorTest extends TestCase
{

View File

@ -1,7 +1,7 @@
<?php namespace Moserware\Skills\Tests\TrueSkill;
<?php namespace DNW\Skills\Tests\TrueSkill;
use Moserware\Skills\Tests\TestCase;
use Moserware\Skills\TrueSkill\TwoTeamTrueSkillCalculator;
use DNW\Skills\Tests\TestCase;
use DNW\Skills\TrueSkill\TwoTeamTrueSkillCalculator;
class TwoTeamTrueSkillCalculatorTest extends TestCase
{