public function marchOpponents()

{

$rstep = Yii::$app->params[‘ratingStep’];//(随机范围)

$rsN=100;

$db=Yii::$app->db;

$m= $this->streak*$rstep;//根据连败取人数

$c = GmPlayerRating::find()->where(“rating > :rating”,[‘:rating’=>$this->rating])->count();//分数所在排名

Yii::error(“gid “.$this->gid.” 排名 “.$c );

if ($c<$m)//如50名 要取6连胜后的-10-0名

{

$m=0;

Yii::error(” c < m “);

}else {//否则取开头 如取3连胜则取 20-30区间

$m = $c-$m;

}

//从上到下取匹配到的玩家

$sql = “select gid from gm_player_rating where gid !=:uid and protect_tm<:nowtm order by rating desc limit :m,:n”;

$values = [‘:uid’=>$this->gid,‘:nowtm’=>time(),‘:m’=>$m,‘:n’=>$rsN];

$res = $db->createCommand($sql)->bindValues($values)

->queryAll();

//         if ($this->streak > 0 && count($res==0)){//连胜 取高分,上方无人

//             $sql = “select gid from gm_player_rating where protect_tm<:nowtm order by rating desc limit :n”;

//             $values = [‘:nowtm’=>time(),':n’=>$rstep];

//             $res = $db->createCommand($sql)->bindValues($values)

//             ->queryAll();

//         }

if ($this->streak < 0 && count($res)==0){//连败取低分,下方无人

//

$sql = “select gid from gm_player_rating where  gid !=:uid and protect_tm<:nowtm order by rating asc limit :n”;

$values = [‘:uid’=>$this->gid,‘:nowtm’=>time(),‘:n’=>$rsN];

$res = $db->createCommand($sql)->bindValues($values)

->queryAll();

}

//         echo “count rest:”.count($res);

if ($res==“” || count($res)==0)

return 0;

$rx=$res[array_rand($res)];

//         print_r($rx);

return $rx[‘gid’];

}

///核心 elo 算法内容计算期望值

public static function eloRatingScore($pa,$pb,$win=1)

{//按照rating 获取期望所得的声望值

$Ra=GmPlayerRating::findOne($pa)->rating;

$Rb=GmPlayerRating::findOne($pb)->rating;

$Ea = 1/(1+pow(10, ($Rb-$Ra)/400));

//         $Eb = 1/(1+pow(10, ($Ra-$Rb)/400));

//胜利期望值

$rssss=(1 – $Ea);

if ($rssss<(1/Yii::$app->params[‘ratingK’]/2))$rssss=0;

$RSa = intval(Yii::$app->params[‘ratingK’] *$rssss);

//失败期望值

if ($win==-1) $RSa = intval(Yii::$app->params[‘ratingK’] * (0 – $Ea));

return $RSa;

}

php实现dota天梯、wow竞技场、lol排位赛匹配加分算法ELO的更多相关文章

  1. 论文翻译 DOTA:A Large-scale Dataset for Object Detection in Aerial Images

      简介:武大遥感国重实验室-夏桂松和华科电信学院-白翔等合作做的一个航拍图像数据集 摘要: 目标检测是计算机视觉领域一个重要且有挑战性的问题.虽然过去的十几年中目标检测在自然场景已经有了较重要的成就 ...

  2. lol匹配算法

    这是Riot的Design Director Tom Cadwell专门为中国玩家写的解说匹配系统工作原理的帖子. 同一时候为了让大家更好的理解匹配系统,假设您认为您遇到了特别不公平的匹配,请回复游戏 ...

  3. elo system

    今天了解了一下游戏中的PVP模块的实现,大多数的游戏都使用到了ELO算法,刚开始的时候并不清楚这个算法是做什么的,对此开始大量查找有关于ELO算法的资源,功夫不负有心人,总算找到一些有用的资源了. 先 ...

  4. 《社交网络》里的评分公式——ELO排名系统

    <社交网络>里的Mark Zackburg被女朋友甩后,在舍友的启发下,充分发挥了技术宅男自娱自乐的恶搞天分,做出了Facemash网站,对学校女生的相貌进行排名打分,结果网站访问流量过大 ...

  5. 腾讯首度公开S级手游品质管理方法

    weimjsam   引言 在最新的手游市场占有率统计中,腾讯游戏稳稳占据一半江山,目前仍以每月一到两款的速度推出新品,在如此复杂多变.响应要求极高的市场环境下,能持续推出高质量产品并保持高效迭代更新 ...

  6. DOTA 2 Match History WebAPI(翻译)

    关于DOTA 2 Match History WebAPI 的 源网页地址: http://dev.dota2.com/showthread.php?t=47115 由于源网页全英文,这边做下翻译方便 ...

  7. dota 路人水平鉴定器

    测试的dota水平...目的是学习一下tornado框架 #coding:utf8 import tornado.web,tornado.httpserver,tornado.ioloop,torna ...

  8. 2018天梯赛第一次训练题解和ac代码

    随着评讲的进行代码和题解会逐步放上来 2018天梯赛第一次训练 1001 : 进制转换 Time Limit(Common/Java):1000MS/10000MS     Memory Limit: ...

  9. [转] 评 WOW技能天赋设计

    本文转至:http://bbs.chinaunix.net/thread-1692302-8-1.html(只作转载, 不代表本站和博主同意文中观点或证实文中信息)再比如,传说中的面向对象本该大显神威 ...

随机推荐

  1. 一文彻底解决Ubuntu上PHP的安装以及版本切换

    Ubuntu上官方的源,比如 Ubuntu14.04 默认源中的是 PHP5.6.x.Ubuntu16.04 默认源中的是 PHP7.0.x,那么如果想在 Ubuntu16.04 上安装 PHP7.1 ...

  2. ubuntu重启不清除 /tmp 设置

    gedit /etc/default/rcS, 把TMPTIME=0 修改成 TMPTIME=-1,保存退出即可.

  3. POJ3272 Cow Traffic

    题目链接:http://poj.org/problem?id=3272 题目意思:n个点m条边的有向图,从所有入度为0的点出发到达n,问所有可能路径中,经过的某条路的最大次数是多少.边全是由标号小的到 ...

  4. ubuntu安装wine的方法

    使用命令行安装: 1.打开终端,使用命令:sudo apt-get install wine 2.它可能会出现选择哪个版本的安装,develop是开发版本,stable是稳定版本. 通常我们选择sta ...

  5. GraphicsMagick 1.3.25 Linux安装部署

    1.安装相关依赖包 yum install -y gcc libpng libjpeg libpng-devel libjpeg-devel ghostscript libtiff libtiff-d ...

  6. 由link和@import的区别引发的CSS渲染杂谈

    我们都知道,外部引入 CSS 有2种方式,link标签和@import. 它们有何本质区别,有何使用建议,在考察外部引入 CSS 这部分内容时,经常被提起. 如今,很多学者本着知其然不欲知其所以然的学 ...

  7. sipp模拟freepbx分机测试(SIP协议调试)

    1.sipp的安装 1) 在centos 7.2下安装 yum install make gcc gcc-c++ ncurses ncurses.x86_64 ncurses-devel ncurse ...

  8. Spark2.0机器学习系列之2:基于Pipeline、交叉验证、ParamMap的模型选择和超参数调优

    Spark中的CrossValidation Spark中采用是k折交叉验证 (k-fold cross validation).举个例子,例如10折交叉验证(10-fold cross valida ...

  9. Linux mount Windows目录

    [问题描述] Windows 机器192.168.1.103共享了 /share/yasi 目录,并且赋予了写的权限,在Windows机器下可以用 yasi/pass 登录.在一台CentOS 6.3 ...

  10. (C++) Assertion failed: !"Bad error code", file VMem.c, line 715

    (C++) Assertion failed: !"Bad error code", file VMem.c, line 715 Misc error. myInterface F ...