• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 10:20
CEST 16:20
KST 23:20
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
Code S Season 1 (2026) - RO4 & Finals Preview5[ASL21] Ro4 Preview: On Course12Code S Season 1 - RO8 Preview7[ASL21] Ro8 Preview Pt2: Progenitors8Code S Season 1 - RO12 Group A: Rogue, Percival, Solar, Zoun13
Community News
Code S Season 1 (2026) - RO8 Results2Weekly Cups (May 4-10): Clem, MaxPax, herO win1Maestros of The Game 2 announcement and schedule !15Weekly Cups (April 27-May 4): Clem takes triple0RSL Revival: Season 5 - Qualifiers and Main Event12
StarCraft 2
General
Code S Season 1 (2026) - RO4 & Finals Preview Team Liquid Map Contest #22 - The Finalists Code S Season 1 (2026) - RO8 Results Code S Season 1 (2026) - RO12 Results MaNa leaves Team Liquid
Tourneys
Maestros of The Game 2 announcement and schedule ! GSL Code S Season 1 (2026) Sparkling Tuna Cup - Weekly Open Tournament KSL Week 89 2026 GSL Season 2 Qualifiers
Strategy
Custom Maps
[D]RTS in all its shapes and glory <3 [A] Nemrods 1/4 players
External Content
The PondCast: SC2 News & Results Mutation # 526 Rubber and Glue Mutation # 525 Wheel of Misfortune Mutation # 524 Death and Taxes
Brood War
General
25 Years Since Brood War Patch 1.08 vespene.gg — BW replays in browser BW General Discussion Data needed BGH Auto Balance -> http://bghmmr.eu/
Tourneys
[ASL21] Semifinals B [BSL22] RO8 Bracket Stage + Another TieBreaker [ASL21] Ro8 Day 4 Escore Tournament StarCraft Season 2
Strategy
Muta micro map competition Fighting Spirit mining rates [G] Hydra ZvZ: An Introduction Simple Questions, Simple Answers
Other Games
General Games
Warcraft III: The Frozen Throne ZeroSpace Megathread Stormgate/Frost Giant Megathread War of Dots, 2026 minimalst RTS Nintendo Switch Thread
Dota 2
The Story of Wings Gaming
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Vanilla Mini Mafia Mafia Game Mode Feedback/Ideas TL Mafia Community Thread Five o'clock TL Mafia
Community
General
US Politics Mega-thread European Politico-economics QA Mega-thread YouTube Thread Russo-Ukrainian War Thread UK Politics Mega-thread
Fan Clubs
The herO Fan Club!
Media & Entertainment
[Manga] One Piece Anime Discussion Thread [Req][Books] Good Fantasy/SciFi books
Sports
2024 - 2026 Football Thread McBoner: A hockey love story Formula 1 Discussion
World Cup 2022
Tech Support
streaming software Strange computer issues (software) [G] How to Block Livestream Ads
TL Community
The Automated Ban List
Blogs
Why RTS gamers make better f…
gosubay
How EEG Data Can Predict Gam…
TrAiDoS
ramps on octagon
StaticNine
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1999 users

Variability in the SC2 ladder

Blogs > PickyProtoss
Post a Reply
PickyProtoss
Profile Blog Joined April 2014
Ireland74 Posts
Last Edited: 2016-02-09 22:31:30
February 09 2016 16:07 GMT
#1
On the 17th, 25th of December and the 2nd of January, I scraped the first 2,111 pages of the Starcraft 2 ladder on http://nios.kr/sc2/global/1v1/lotv/1.

On the 17th of December there were 211,086 players
On the 25th of December there were 211,012 players
On the 2th of January there were 210,868 players

(Please be aware that since then I have read on Reddit that there were problems with this website showing inaccurate game scores)

First, I removed all of the duplicate names within the datasets. This is problematic, because it has the unintended consequence of removing many barcodes, i.e., IIIIIIIII, still this is a necessary evil. Also using multiple accounts with the same name across different regions are excluded.

On the 17th of December there were 149,919 players
On the 25th of December there were 149,518 players
On the 02th of January there were 141,666 players

Because I have 3 datasets, I can compare Ladder time 1 to Ladder time 2 and Ladder time 2 to Ladder time 3.

A dataset containing names which corresponded on both Ladder time 1 and Ladder time 2 was created. This dataframe consisted of 83,965 players (I wonder how the difference between time 1 and time 2 can be so high! probably due to removing duplicates and looking for unique names consistent across time 1 and 2). Thereafter, I added the wins and losses columns to get a measure of overall games played.

At time 1, an average of 62 games were played per player.
At time 2, an average of 71 games were played per player.
At time 3, an average of 80 games were played per player.

[image loading]

I then removed any player whose number of games played at time 1 was equal to number of games played at time 2 – essentially removing any player who did not play a game. The final dataset contained 33,815 players. These fit the criteria of having played at least 1 game over the two week period and only having 1 unique name on the ladder at time 1 and time 2.

This is the sample which I will use to describe the propensity to rank-up your league.

First I changed the league from levels of a factor to numbers, in other words, Bronze was changed to 1, Silver was changed to 2, etc. At this point I checked which players had ranked up from Time 1 to Time 2. The logic is if league 2 > league 1 score the person ranked up, if league 2 < league 1 score the person ranked down and if league 2 = league 1 score the person remained in the same league.

From time 1 to time 2, 412 player’s league standing went down, whereas 182 player’s league standing went up.

[image loading]

The same steps were undertaken for ladder time 2 to ladder time 3. From time 2 to time 3, 235 players standing went up, while 182 players went down.

[image loading]

These results do appear rather weird, but please be aware of the assumptions undertaken during the analysis. For instance, removing duplicates, making sure that players played across the two weeks. I have also made my analysis, which was undertaken in R, and data files available if anyone would like to check for errors - I am sure there are flaws in my code.

R
Time 1 data
Time 2 data
Time 3 data

brickrd
Profile Blog Joined March 2014
United States4894 Posts
Last Edited: 2016-02-09 20:55:07
February 09 2016 20:54 GMT
#2
i don't understand why you removed duplicate names, can you explain that?
TL+ Member
PickyProtoss
Profile Blog Joined April 2014
Ireland74 Posts
February 09 2016 22:30 GMT
#3
On February 10 2016 05:54 brickrd wrote:
i don't understand why you removed duplicate names, can you explain that?


Great question!

And here is my explanation:

When I have two separate databases of games played at time 1 and time 2. I have to merge these databases together.I use Name as the key which merges the databases, in other words, where brickrd is a player in database 1 slot the information from database 2 next to this, this is a left join in SQL or a Vlookup with Excel.

In order to make this more efficient I removed duplicates. Cause if I want to merge on name brickrd but there is one playing in Korea and the other in US, where does the value go? This is a common problem with Vlookup! That being said, I do think that this was foolish and with SQL I could left join where region = region in the code, in other words, in database 1, where brickrd plays in Korea join database 2 where brrickrd plays in Korea, this would prevent the step of removing duplicates

Nevertheless, even if I did this, I am afraid I am ignorant when it comes to barcodes. Are they unique? Can two separate players have the same barcode? If so all barcodes need to be removed. How are the barcodes created? If these questions were answered, I could perhaps avoid the removing of duplicates process and that would lead to more data and better estimations.

Thanks for reading.
The_Masked_Shrimp
Profile Joined February 2012
425 Posts
Last Edited: 2016-02-09 23:54:42
February 09 2016 23:51 GMT
#4
Barcodes are.all unique, you can't duplicate.names in the same region. They are just sequences of upper case i and lower case L so as long as you use a case sensitive languages there is no reason to not include barcodes (except that bar codes are assholes, but that's another story)

And you should nit merge regions together since it should be expected that the regional trends are so different that presenting a global average would be kind of meaningless for anyone
Daimai
Profile Blog Joined July 2010
Sweden762 Posts
February 10 2016 00:01 GMT
#5
On February 10 2016 08:51 The_Masked_Shrimp wrote:
Barcodes are.all unique, you can't duplicate.names in the same region. They are just sequences of upper case i and lower case L so as long as you use a case sensitive languages there is no reason to not include barcodes (except that bar codes are assholes, but that's another story)

And you should nit merge regions together since it should be expected that the regional trends are so different that presenting a global average would be kind of meaningless for anyone


What? Afaik, you can duplicate names, since you have your character code which distinguishes you from others.
To pray is to accept defeat.
PickyProtoss
Profile Blog Joined April 2014
Ireland74 Posts
February 10 2016 21:07 GMT
#6
So are barcodes duplicates or not?
Korakys
Profile Blog Joined November 2014
New Zealand272 Posts
February 11 2016 01:40 GMT
#7
I think maybe half of barcodes are unique and half aren't, pure guess on my part though. The non-unique ones are differentiated by the 3 or 4 digit character code as mentioned by Daimai.
Swing away sOs, swing away.
Please log in or register to reply.
Live Events Refresh
Wardi Open
11:00
#87
IntoTheiNu 1276
WardiTV1195
OGKoka 503
Rex132
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
TKL 782
OGKoka 503
Rex 132
StarCraft: Brood War
Sea 10877
Bisu 2970
Horang2 1827
Jaedong 1424
EffOrt 629
BeSt 535
Mini 502
ggaemo 482
Soulkey 456
Light 339
[ Show more ]
Hyuk 300
firebathero 275
Snow 189
Rush 167
Pusan 125
Hyun 114
Mong 95
Sharp 73
hero 72
Zeus 70
Aegong 69
Backho 58
Sea.KH 58
Sexy 52
scan(afreeca) 51
ToSsGirL 51
[sc1f]eonzerg 48
sorry 41
Barracks 38
Movie 25
910 24
soO 18
GoRush 17
Rock 15
Sacsri 10
zelot 10
Noble 9
Terrorterran 8
Dota 2
syndereN404
Counter-Strike
zeus1082
byalli509
allub315
edward96
Other Games
singsing2814
B2W.Neo1361
hiko757
Lowko386
crisheroes281
Hui .256
Pyrionflax215
monkeys_forever101
ArmadaUGS33
Organizations
Counter-Strike
PGL1650
StarCraft: Brood War
UltimateBattle 1484
lovetv 7
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
[ Show 15 non-featured ]
StarCraft 2
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• Michael_bg 5
• HerbMon 3
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Nemesis5353
Other Games
• WagamamaTV363
• Shiphtur23
Upcoming Events
Monday Night Weeklies
1h 40m
Replay Cast
9h 40m
The PondCast
19h 40m
Kung Fu Cup
20h 40m
GSL
1d 19h
Cure vs sOs
SHIN vs ByuN
Replay Cast
2 days
GSL
2 days
Classic vs Solar
GuMiho vs Zoun
WardiTV Spring Champion…
2 days
Replay Cast
3 days
Sparkling Tuna Cup
3 days
[ Show More ]
WardiTV Spring Champion…
3 days
Replay Cast
4 days
RSL Revival
4 days
Classic vs SHIN
Rogue vs Bunny
BSL
5 days
Replay Cast
5 days
Afreeca Starleague
5 days
Flash vs Soma
RSL Revival
5 days
BSL
6 days
Patches Events
6 days
Universe Titan Cup
6 days
Rogue vs Percival
Wardi Open
6 days
Liquipedia Results

Completed

Escore Tournament S2: W7
2026 GSL S1
Nations Cup 2026

Ongoing

BSL Season 22
ASL Season 21
IPSL Spring 2026
KCM Race Survival 2026 Season 2
Acropolis #4
KK 2v2 League Season 1
BSL 22 Non-Korean Championship
YSL S3
SCTL 2026 Spring
RSL Revival: Season 5
Heroes Pulsing #1
Asian Champions League 2026
IEM Atlanta 2026
PGL Astana 2026
BLAST Rivals Spring 2026
IEM Rio 2026
PGL Bucharest 2026
Stake Ranked Episode 1
BLAST Open Spring 2026
ESL Pro League S23 Finals
ESL Pro League S23 Stage 1&2

Upcoming

Escore Tournament S2: W8
CSLAN 4
Kung Fu Cup 2026 Grand Finals
HSC XXIX
uThermal 2v2 2026 Main Event
Maestros of the Game 2
WardiTV Spring 2026
2026 GSL S2
Bounty Cup 2026
BLAST Bounty Summer 2026
BLAST Bounty Summer Qual
Stake Ranked Episode 3
XSE Pro League 2026
IEM Cologne Major 2026
Stake Ranked Episode 2
CS Asia Championships 2026
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2026 TLnet. All Rights Reserved.