Posted by Antibody on January 20, 2020
Sitting at home on this cold and wintry day, I thought it’d be good to dig out the old “by the numbers” code to see what 2019 looked like for Xonotic in XonStatDB. Let’s have a look! Also, let’s do a bit more data exploration just for the heck of it, shall we?
First up is the number of games per month throughout the year:
Given the huge popularity of WTWRP’s votable server, I chose to include the clan arena game type in the chart this time around. The result is a major bump in the number of games per month versus when we last did this for 2017. Nice! Overall CTF and DM still hold the top spots, which is unsurprising.
Next up let’s see when people are hitting the servers to get their frag on. This chart tracks the most popular hours in which games are recorded:
There’s just something about 8PM UTC that always takes the cake! For the previous two years that has been the witching hour for fragging. I suppose we just don’t want to spoil a good thing.
How about the number of distinct players per month? Let’s have a looksie:
As compared to 2017 we’re trending quite a bit upwards. Hooray! Keep playing, folks, and keep telling your friends to join you. Another interesting thing is that the both years of data share the same basic “shape”, which is to say around summer time there’s an appreciable dip. I wonder if that’s because everyone is going on vacation…
Next up let’s take a look at the damage done by weapons, broken down into monthly increments:
I always look for adequate representation for all weapons in this chart. If we saw disproportionate numbers for any one weapon it would warrant some additional design discussion amongst the community at large (oh no, balance discussions! Eeeek!). Fortunately that’s not what we see here - for the most part we see each weapon staking claim to a reasonable percentage of the damage dealt. Okay, okay… except for the devastator in August. I have no explanation for THAT.
Next up is the frags attained by those weapons:
It’s always a contest between mortar, devastator, shotgun, and vortex for the lead when it comes to closing the deal on frags. What’s interesting is that vortex is clearly NOT the front runner here - in every single month the devastator edges it out for more frags. Maybe some of these forum discussions about balance should turn their attention towards rockets! Nah, that’s just wishful thinking.
So that’s it for the charts. Let’s turn our attention to something more fun and completely irrelevant for once. How about who had the most kills? First, the query:
SELECT p.player_id, p.stripped_nick, sum(pgs.kills) FROM player_game_stats pgs join players p on pgs.player_id = p.player_id WHERE pgs.kills is not null and p.player_id > 2 and pgs.create_dt between '2019-01-01' and '2019-12-31' GROUP BY p.player_id, p.stripped_nick ORDER BY sum(kills) desc LIMIT 10;
…and the results (drum roll please):
player_id | stripped_nick | sum -----------+--------------------------+-------- 50029 | C2 | 144984 62373 | Speardriver | 141570 18179 | EAC · Kult | 110760 77131 | umnu | 109104 10042 | SealBeater | 105606 130686 | GAYDOW SHADOW | 90747 134788 | Anonymous Player #134788 | 85226 136382 | Phoenix (XHC) ←😈→ | 78629 25311 | AFKPEK | 75894 76328 | nAnXiety | 73883
Holy moly that’s a lot of frags!
How about something a bit sillier? Let’s flip that query around and look for who had the most deaths in 2019:
player_id | stripped_nick | sum -----------+-----------------------+------- 136382 | Phoenix (XHC) ←😈→ | 99180 130686 | GAYDOW SHADOW | 98115 110074 | [BOT]SeeK-y | 88913 30937 | draco | 85272 10042 | SealBeater | 81335 77131 | umnu | 79693 137126 | ♩♪♫ мµѕιcgoαт ♫♪♩ | 79173 74883 | Visse.exe | 78864 31622 | wındaxg | 78782 33241 | Lts9 | 74700
Whoa! I’m surprised to see some of the same names on here, but that’s probably just by virtue of their time in-game. Either way it’s cool to see.
Now let’s have a look at who had the best K:D for the year, with some entrance criteria to weed out some bad data: those having a minimum amount of 5K frags for the year and a non-zero amount of deaths. First the query:
select p.player_id, p.stripped_nick, round(cast(sum(pgs.kills) as decimal)/sum(pgs.deaths), 2) kd from player_game_stats pgs join players p on pgs.player_id = p.player_id where pgs.deaths is not null and pgs.kills is not null and pgs.deaths > 0 and p.player_id > 2 and pgs.create_dt between '2019-01-01' and '2019-12-31' group by p.player_id, p.stripped_nick having sum(kills) > 5000 order by 3 desc limit 10;
…and its results:
player_id | stripped_nick | kd -----------+--------------------------+------ 59519 | Anonymous Player #59519 | 4.61 101655 | Alex | 4.26 8848 | Gayger^^ | 3.74 30489 | Yurashina | 3.06 81836 | ☢☢ | 2.98 132731 | snor | 2.83 164623 | cliffstah 😈 | 2.74 160051 | Anonymous Player #160051 | 2.67 50029 | C2 | 2.66 104542 | Rascal | 2.64
Very cool indeed. We definitely have some efficient fraggers roaming the servers out there.
That’s all for this year’s data spelunking. I hope you enjoyed! You can find the code behind all of these charts up on Github should you be interested to poke around. In the interim, I’ll be seeing you out on the servers. Happy fragging to you in 2020!
Xonotic is a fast paced first person shooter where
crisp movement, nuanced weapons, and in-your-face action
combine to create addictive arena-style gameplay.
Xonotic is free to play and modify under the copyleft GPLv3+ license. Download it today!