• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EST 20:41
CET 02:41
KST 10:41
  • 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
RSL Revival - 2025 Season Finals Preview8RSL Season 3 - Playoffs Preview0RSL Season 3 - RO16 Groups C & D Preview0RSL Season 3 - RO16 Groups A & B Preview2TL.net Map Contest #21: Winners12
Community News
Weekly Cups (Dec 15-21): Classic wins big, MaxPax & Clem take weeklies3ComeBackTV's documentary on Byun's Career !10Weekly Cups (Dec 8-14): MaxPax, Clem, Cure win4Weekly Cups (Dec 1-7): Clem doubles, Solar gets over the hump1Weekly Cups (Nov 24-30): MaxPax, Clem, herO win2
StarCraft 2
General
The Grack before Christmas Weekly Cups (Dec 15-21): Classic wins big, MaxPax & Clem take weeklies ComeBackTV's documentary on Byun's Career ! Micro Lags When Playing SC2? When will we find out if there are more tournament
Tourneys
$5,000+ WardiTV 2025 Championship $100 Prize Pool - Winter Warp Gate Masters Showdow Sparkling Tuna Cup - Weekly Open Tournament Winter Warp Gate Amateur Showdown #1 RSL Offline Finals Info - Dec 13 and 14!
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 505 Rise From Ashes Mutation # 504 Retribution Mutation # 503 Fowl Play Mutation # 502 Negative Reinforcement
Brood War
General
BGH Auto Balance -> http://bghmmr.eu/ Recommended FPV games (post-KeSPA) BW General Discussion FlaSh on: Biggest Problem With SnOw's Playstyle soO on: FanTaSy's Potential Return to StarCraft
Tourneys
Small VOD Thread 2.0 [Megathread] Daily Proleagues [BSL21] LB QuarterFinals - Sunday 21:00 CET [BSL21] WB SEMIFINALS - Saturday 21:00 CET
Strategy
Simple Questions, Simple Answers Game Theory for Starcraft Current Meta Fighting Spirit mining rates
Other Games
General Games
Nintendo Switch Thread Stormgate/Frost Giant Megathread Beyond All Reason Path of Exile General RTS Discussion Thread
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
Mafia Game Mode Feedback/Ideas Survivor II: The Amazon Sengoku Mafia TL Mafia Community Thread
Community
General
The Games Industry And ATVI Russo-Ukrainian War Thread US Politics Mega-thread How Does UI/UX Design Influence User Trust? Things Aren’t Peaceful in Palestine
Fan Clubs
White-Ra Fan Club
Media & Entertainment
Anime Discussion Thread [Manga] One Piece
Sports
2024 - 2026 Football Thread Formula 1 Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
The Automated Ban List TL+ Announced Where to ask questions and add stream?
Blogs
The (Hidden) Drug Problem in…
TrAiDoS
I decided to write a webnov…
DjKniteX
James Bond movies ranking - pa…
Topin
Thanks for the RSL
Hildegard
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1493 users

SC2 World Ranking, Part 12: Graphs

Blogs > Entirety
Post a Reply
Entirety
Profile Blog Joined April 2012
1423 Posts
August 18 2012 17:30 GMT
#1
Part 11: http://www.teamliquid.net/blogs/viewblog.php?id=361272

+ Show Spoiler [Introduction] +
Lately, I've heard lots of discussion about a StarCraft 2 World Ranking based on tournament results. Essentially, the concept is that you assign points for tournament rankings. Unfortunately, no matter how it is done, the ranking will always be subjective. One person may say that the GSL is worth as much as every other tournament combined, whereas another person may say that the GSL is worth about as much as a MLG.

How do I get around this "subjective" problem? Here's my answer: I'll let you choose the values!

That's right, I'm starting a project to create a World Ranking. The cool thing is that you get to choose how many points each victory is worth and more.


Now updated with GRAPHS! (Current Size: 232 KB)

http://dl.dropbox.com/u/43612415/World Ranking.xlsm

+ Show Spoiler [How to Use] +
+ Show Spoiler [Ratios] +
The first sheet is known as "Values" and it is the only spreadsheet you should edit. Only edit the highlighted areas!

Do not worry about the exact point values, only the ratios truly matter! Basically, having GSL = 10 points and MLG = 4 points is the same as having GSL = 5 points and MLG = 2 points.

First, start with the point ratios. Simply enter the points that you think a 1st place is worth compared to a 2nd place, a 3rd place, a 4th place, etc.

For example, if I enter 1,000 points for 1st place and 500 points for 2nd place, that means 1st place is worth double the amount of points as 2nd place. If you think that 1st place is worth 3 times as much as 2nd place, you can put 1st place as 300 points and 2nd place at 100 points.

The section underneath that (highlighted with a darker shade, containing 3rd/4th, 5th/6th, etc.) are optional. You can choose the values yourself if you want. If you do not, they work using averages (3rd/4th averages the points you gave for 3rd place and 4th place).

Next, enter the tournament ratios. For example, if I enter 10 points for GSL and 4 points for MLG, that means GSL will give out 2.5x as many points as MLG. Use these ratios to gauge relative importance of the tournaments. If you think MLG is worth half as much as GSL, make MLG 5 points and GSL 10 points, and so on.

The points are calculated by multiplying the tournament ratios with the point ratios. If I put 100 points for 1st place and 10 points for GSL, it will multiply the two values and give you 1,000 points for GSL 1st place. Here's another example:

Let's say I choose these values: 1st place = 1,000 points, 2nd place = 500 points. GSL = 10 points, MLG = 4 points.

GSL 1st = 1,000*10 = 10,000 points
GSL 2nd = 500*10 = 5,000 points
MLG 1st = 1,000*4 = 4,000 points
MLG 2nd = 500*4 = 2,000 points


+ Show Spoiler [Regression] +
One thing that is very popular in point rankings such as this is the concept of regression. Basically, your points degrade over time, meaning that a GSL today is worth more than a GSL one year ago.

The sheet "Values" has a "Regression Factor" which you can edit. Right now, the spreadsheet only supports simple regression - exponential decay. Here's how the regression model works:

New Point Value = Original Point Value * (Regression Factor)^(# of Days since the Tournament)

The value I prefer is "0.99769217652702". If you use this value, the number of points will be halved after 300 days (so 10,000 points becomes 5,000 points), the number of points will be 25% after 600 days (so 10,000 points becomes 2,500 points), and so on.

You may choose your own value! If you do not wish to use regression (you think a GSL from one year ago is worth exactly the same as a GSL today), then simply use the value "1".

Some regression values:
50% after 120 days: 0.99424042381754732964045049128729
50% after 180 days: 0.99615658722058
50% after 300 days: 0.99769217652702


+ Show Spoiler [Dates] +
The concept of this is that you can go back in time and see what the rankings would look like in August 2011 or August 2010 or whatever date you choose. The way to use this is very simple:

In the "Values" spreadsheet, there is a section called "Date". Simply change this date to whatever date you want to go back to!


+ Show Spoiler [Sorting] +
Finally, when you are ready to produce your ranking, simply press the "Sort" button in the "Values" sheet. It will automatically sort every list in the spreadsheet. The sheet named "Ranking" will have your final ranking sorted from the greatest amount of points to the least amount of points.


+ Show Spoiler [Graphs] +
Just go to the sheet named "Graphs" and there is a highlighted cell near the top. Enter the player whose points you wish to track and it should automatically create a graph for you detailing his/her points over time.


However, this is not completed yet! In fact, I need your help!

+ Show Spoiler [Checklist] +
Red Bull LAN
WCS
HomeStory
OSL
ESWC
GSL Code A
Other major tournaments/one-off tournaments (such as IPL Hot Import Nights, GSL All-Stars Invitational, MLG Global Invitational, etc.)
Tournament rankings without prize pool (such as MLG 9th place)


+ Show Spoiler [My Progress] +
+ Show Spoiler +
Part 1: I started this project on Google Spreadsheets and added the three GSL Open Seasons. NesTea topped the rankings with his GSL Open Season win.

Part 2: I added all of the GSL Code S seasons including the World Championship, Super Tournament, and Blizzard Cup. I also moved the project to Microsoft Excel, which is much much faster than Google Spreadsheets. With the addition of more GSL seasons, the GSL king (also known as Mvp) topped the rankings.

Part 3: I added IPL. I changed the spreadsheet into a macro-enabled spreadsheet and protected each sheet except "Values". The addition of IPL allowed Squirtle to break the top ten!

Part 4: I added MLG. MLG gave a lot of points to DongRaeGu and MarineKing, and they rose many places. MC, MMA, and Leenock also rose some places, while NesTea didn't gain any points.

Part 5: I added DreamHack. A high placement in DreamHack allowed Genius to overtake aLive and break into the top 10.


+ Show Spoiler +
Part 6: I added IEM. Also, I changed the "Values" system to work with ratios rather than point values for each "cluster" of tournaments. Ratios are more flexible in general.

Part 7: I added Top 16 for each DreamHack tournament (before, only the placements with prize money were included in the ranking). Also, I added the NASL, causing PuMa and Stephano to enter the rankings.

Part 8: I added Top 16 for each MLG Arena this year. I added the Iron Squid, giving lots of points to MMA.

Part 9: I added TSL, not much accomplished today.

Part 10: I added Assembly and Seed falls in the rankings as Stephano, PuMa, and Polt gain significant amounts of points.


Part 11: I added WCG, giving Mvp even more points. Also, I added "Dates" which lets you go back in time and view rankings from an earlier date!

Part 12: I added BlizzCon and Mvp is uncontested once more. The "Graphs" feature was also added which allows you to track a player's points over time!


+ Show Spoiler [How You Can Help!] +
I need lists of tournament rankings. First, I need the name of the tournament, and the date it ended. Then, I need a list of players starting from 1st place until last place. Here's an example:

GSL Open Season 1
10/2/2010

FruitDealer
RainBOw
Ensnare
LiveForever
HongUn
InCa
Maka
TricKsteR
anypro
Check
Clide
Hyperdub
LegalMind
Nettie
San
TOP
IdrA
JookTo
justfake
Keeping
Maru
Polt
TaeJa
Tankboy
TheWinD
TLO
ZanDarke
Zenio
Aory
Artosis
Astraea
BrEEzE
Cella
Cezanne
Chipmunk
Dos
FoCuS
Genius
Gerrard
GuineaPig
Hansin
JiTaeHoon
jjonga
JSL
Junwi
LosirA
MC
miso
Myth
NesTea
New
RenieHouR
SengKun
Sopia
Spunky
SSoja
TorcH
Wind
Xian
Yong

My next goal is foreign tournaments. Do not worry about Code A yet!


Finally, here is my own ranking:

+ Show Spoiler +
1. 31,043 Mvp
2. 25,923 MC
3. 23,129 DongRaeGu
4. 22,008 MMA
5. 17,982 NesTea
6. 14,767 MarineKing
7. 12,411 Polt
8. 10,832 Stephano
9. 10,532 PuMa
10. 9,758 Seed

I added BlizzCon and once again, Mvp's lead is incredibly large. He broke 30,000 points which is pretty much insanity.


This time, I added BlizzCon and Mvp's lead skyrockets.

More importantly, I'd like to talk about the newest feature, "Graphs". Simply put, it calculates the amount of points that the player had at the start of each month. Then, it creates a simple line graph. Using this, you can check a player's peak. For example, Mvp's peak was at the start of 2012, shortly after his Blizzard Cup and WCG placements.

This is a really cool feature and I love the graphs as much as anyone, but I noticed something. Does anyone else notice that the spreadsheet is substantially slower? This makes me sad because I sense the limitations of Excel as well. D:

Right now, the speed is definitely okay. The speed just changed from "instantaneous" to "half a second wait" which isn't too bad. However, if this continues, then the spreadsheet might almost be unusable. I suspect that the slowness is caused by the arrays which create the player graphs.

The arrays are quite memory-intensive, I suspect. I have NOT protected the Graphs sheet because I want you to choose the player you want to track. Can someone who is experienced in Excel please take a look at my formulas and try to optimize them if possible? There's probably a better way, but with the "regression" feature, I'm not sure how.

If I could, I would add all the features imaginable. Memory is a serious issue, though, and I would like to hear your opinions before I continue to make this project larger.

My question for you: What tournament should I add next? Also, do you notice the spreadsheet running slower than normal? Is it getting to a point where I should not add more memory-intensive features? Do you have any ideas on how to make it faster?

*
IMMvp (정종현) | Fan Club: http://www.teamliquid.net/forum/viewmessage.php?topic_id=211431
felisconcolori
Profile Blog Joined October 2011
United States6168 Posts
Last Edited: 2012-08-18 19:19:55
August 18 2012 19:16 GMT
#2
Looking at your spreadsheet, you're doing all the heavy lifting through formulas... and then you're doing a sort through a VBA macro. :/

I would flip that as much as possible - sorting values is something Excel does really well if you put those values into a cell. Doing as much of the calculations on demand through VBA with custom functions would probably make it run faster. Or, you could go VBA Kung-Fu master and write your own custom class to handle a dictionary or library of players to speed up on-the-fly calculations. (I did something like this several years back on a program that ingested raw data files to track user performance at a detection task and generate statistical information. It could, without much problem, keep track of several thousand individuals over a period of several years. It did have some "chug" time to compile large data sets, but once the dictionary was in place it was much snappier. In the end, Excel was just a front-end and report formatting agent while the heavy lifting was in the VBA code behind it.)

Just in case R1CH or a real programmer looks in - yes, VBA isn't real coding, but it can be bent up to do things dirty when its all you've got to work with.
Yes, I email sponsors... to thank them. Don't post drunk, kids. My king, what has become of you?
Entirety
Profile Blog Joined April 2012
1423 Posts
August 18 2012 20:38 GMT
#3
That sounds very intelligent. Could you help me with that? I have no idea where to begin.

Would the "dictionary of players" be stored as part of the spreadsheet? I want to let other people make use of it as well, so it can't just be on my computer. I haven't done any programming before, but this might be a good time to learn how.

The only reason why I made sorting into a macro is because I couldn't find a really easy way to have the lists autosort, or a way to sort every list at once. The macro I made is primitive but it is suitable for my purposes.

Overall, I like where you're going with that. Running a database of players would probably allow for some more cool stuff and it wouldn't take up an insane amount of space. Could you take it one step further and keep a library of tournaments/tournament results?

Anyway, your help would be greatly appreciated. :D
IMMvp (정종현) | Fan Club: http://www.teamliquid.net/forum/viewmessage.php?topic_id=211431
Please log in or register to reply.
Live Events Refresh
Next event in 15h 19m
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
ProTech190
StarCraft: Brood War
Artosis 631
NaDa 35
Bale 3
Dota 2
monkeys_forever172
Super Smash Bros
Westballz38
Other Games
tarik_tv4637
JimRising 660
byalli480
Mew2King112
XaKoH 14
Liquid`Ken11
Organizations
Other Games
gamesdonequick588
BasetradeTV113
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 16 non-featured ]
StarCraft 2
• Hupsaiya 131
• musti20045 42
• intothetv
• AfreecaTV YouTube
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• Azhi_Dahaki26
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• masondota22325
League of Legends
• Doublelift5568
Other Games
• imaqtpie3075
Upcoming Events
Big Brain Bouts
15h 19m
Elazer vs Nicoract
Reynor vs Scarlett
Replay Cast
22h 19m
Sparkling Tuna Cup
2 days
Krystianer vs TBD
TriGGeR vs SKillous
Percival vs TBD
ByuN vs Nicoract
Replay Cast
3 days
Wardi Open
3 days
Liquipedia Results

Completed

KCM Race Survival 2025 Season 4
WardiTV 2025
META Madness #9

Ongoing

C-Race Season 1
IPSL Winter 2025-26
BSL Season 21
Slon Tour Season 2
CSL Season 19: Qualifier 2
eXTREMESLAND 2025
SL Budapest Major 2025
ESL Impact League Season 8
BLAST Rivals Fall 2025
IEM Chengdu 2025
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025

Upcoming

CSL 2025 WINTER (S19)
BSL 21 Non-Korean Championship
Acropolis #4
IPSL Spring 2026
Bellum Gens Elite Stara Zagora 2026
HSC XXVIII
Big Gabe Cup #3
OSC Championship Season 13
Nations Cup 2026
ESL Pro League Season 23
PGL Cluj-Napoca 2026
IEM Kraków 2026
BLAST Bounty Winter 2026
BLAST Bounty Winter Qual
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 © 2025 TLnet. All Rights Reserved.