• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 10:53
CEST 16:53
KST 23:53
  • 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
TL.net Map Contest #22 - Voting & Ladder Map Selection1Code S Season 2 (2026) - RO8 Preview4[ASL21] Finals Preview: Two Legacies21Code S Season 2 (2026) - RO12 Preview2herO wins GSL Code S Season 1 (2026)7
Community News
StarCraft II 5.0.16 PTR Patch Notes may 26th111Weekly Cups (May 18-25): MaxPax wins doubles0Crank Gathers Season 4: BW vs SC2 Team League5Weekly Cups (May 11-17): Classic wins double1Code S Season 1 (2026) - RO8 Results2
StarCraft 2
General
Code S Season 2 (2026) - RO8 Preview StarCraft II 5.0.16 PTR Patch Notes may 26th The death of cheese, from a professional cheeser. TL Poll: How do you feel about the 5.0.16 PTR balance changes? Changing from 12 to 8 is just asking for StarCraft
Tourneys
RSL Revival: Season 5 - Qualifiers and Main Event Crank Gathers Season 4: BW vs SC2 Team League GSL Code S Season 2 (2026) Maestros of The Game 2 announcement and schedule ! Sparkling Tuna Cup - Weekly Open Tournament
Strategy
[G] Having the right mentality to improve
Custom Maps
[D]RTS in all its shapes and glory <3 [A] Nemrods 1/4 players
External Content
The PondCast: SC2 News & Results Mutation # 528 Infection Detected Welcome to the External Content forum Mutation # 527 Hell Train
Brood War
General
Data needed BGH Auto Balance -> http://bghmmr.eu/ Quality of life changes in BW that you will like ? Soma's ASL Finals Review FlaShFTW vs A.Alm Grudge Match Event
Tourneys
[ASL21] Grand Finals [Megathread] Daily Proleagues Escore Tournament StarCraft Season 2 [BSL22] WB Final & LB Semis - Saturday 21:00 CEST
Strategy
Any training maps people recommend? Muta micro map competition [G] Hydra ZvZ: An Introduction Fighting Spirit mining rates
Other Games
General Games
Stormgate/Frost Giant Megathread Warcraft III: The Frozen Throne Nintendo Switch Thread ZeroSpace Megathread Path of Exile
Dota 2
Official 'what is Dota anymore' discussion
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 Russo-Ukrainian War Thread Trading/Investing Thread Things Aren’t Peaceful in Palestine Dating: How's your luck?
Fan Clubs
The herO Fan Club!
Media & Entertainment
[Manga] One Piece Anime Discussion Thread [Req][Books] Good Fantasy/SciFi books
Sports
McBoner: A hockey love story 2024 - 2026 Football Thread TeamLiquid Health and Fitness Initiative For 2023 Formula 1 Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread Facing Challenges in Mobile App Development
TL Community
The Automated Ban List
Blogs
Esportsmanship: How to NOT B…
TrAiDoS
Why RTS gamers make better f…
gosubay
ramps on octagon
StaticNine
ASL S21 English Commentary…
namkraft
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1695 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
Next event in 1h 7m
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
LamboSC2 633
Ryung 350
Rex 109
ProTech89
Codebar 1
StarCraft: Brood War
Mini 1400
EffOrt 864
Hyuk 488
actioN 276
Soulkey 187
Light 148
Zeus 117
Backho 112
hero 82
[sc1f]eonzerg 71
[ Show more ]
Pusan 57
sSak 54
Aegong 51
ToSsGirL 51
PianO 32
zelot 28
IntoTheRainbow 16
soO 15
Shine 15
Sacsri 12
ajuk12(nOOB) 9
Dota 2
qojqva2657
Dendi1577
Counter-Strike
kRYSTAL_80
Other Games
singsing2954
B2W.Neo1028
hiko1014
Lowko552
XaKoH 263
Hui .231
Liquid`RaSZi154
Liquid`VortiX72
Mew2King63
Trikslyr13
Organizations
Other Games
BasetradeTV206
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
[ Show 15 non-featured ]
StarCraft 2
• StrangeGG 81
• mYiSmile126
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• HerbMon 12
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• WagamamaTV405
League of Legends
• Jankos2796
Upcoming Events
Monday Night Weeklies
1h 7m
Replay Cast
9h 7m
Sparkling Tuna Cup
19h 7m
WardiTV Spring Champion…
20h 7m
Maestros of the Game
1d
The PondCast
1d 19h
Kung Fu Cup
1d 20h
uThermal 2v2 Circuit
2 days
Maestros of the Game
2 days
Replay Cast
2 days
[ Show More ]
Replay Cast
2 days
WardiTV Spring Champion…
2 days
Maestros of the Game
3 days
Replay Cast
3 days
uThermal 2v2 Circuit
4 days
Maestros of the Game
4 days
Replay Cast
4 days
Solar vs Classic
uThermal 2v2 Circuit
5 days
GSL
5 days
herO vs Rogue
Maru vs Cure
uThermal 2v2 Circuit
6 days
BSL
6 days
Replay Cast
6 days
Liquipedia Results

Completed

KK 2v2 League Season 1
RSL Revival: Season 5
Heroes Pulsing #1

Ongoing

BSL Season 22
IPSL Spring 2026
KCM Race Survival 2026 Season 2
Acropolis #4
CSCL: Masked Kings S4
YSL S3
SCTL 2026 Spring
WardiTV Spring 2026
Maestros of the Game 2
2026 GSL S2
Murky Cup 2026
Stake Ranked Episode 2
CS Asia Championships 2026
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

Upcoming

BSL 22 Non-Korean Championship
CSLAN 4
Blizzard Classic Cup 2026
Kung Fu Cup 2026 Grand Finals
CranK Gathers Season 4: BW vs SC2 Team League
HSC XXIX
uThermal 2v2 2026 Main Event
Heroes Pulsing #3
Heroes Pulsing #2
Esports World Cup 2026
BLAST Bounty Summer 2026
BLAST Bounty Summer Qual
Stake Ranked Episode 3
XSE Pro League 2026
IEM Cologne Major 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.