Saturday, June 05, 2004

This is a new experimental Reflector Add-In that will be part of the upcoming Reflector.Graph addin (see Assembly Grapher and Il Grapher). The objective of this addin is to rank methods using a method similar to google.

The graph

Consider a graph where the vertices are the methods of the classes, and each edge represents the fact that the source method calls the target method. For example, take the following dummy class:

public class Test
{
   public void Hello()
   {...}
   public void HelloWorld()
   {
       this.Hello();
   }
}

The method graph from this class will contain

  • 2 vertices: Test.Hello and Test.HelloWorld
  • 1 edge: Test.HelloWorld -> Test.Hello.

PageRank, The Algorithm

PageRank, which is the algorithm that Google uses to rank pages, is a well known and easy to implement algorithm (it is implemented in QuickGraph). The idea behing is very simple and elegant: important pages are reference by other important pages. So basically, PageRank algorithms can help you order the vertices of your graph by order of importance.

PageRank and MethodRank

Contrary to Google, where the vertices are pages and edges are the hyperlinks, the vertices are methods. However, the PageRank idea translates naturally to the method graph: important methods are called by other important methods. Why would we need to know which are the important vertices ? Here are my intuition (not tested) about this:

  • if a important method contains a bug, it is likely that a lot of test cases will fail, (this a BIG assumption)
  • using the previous point, it is clear that important methods are a good target for mutation testing,
  • if you have to start testing, it can give you a "test writting" order,
  • it's fun

The AddIn

for the pleasure of the eyes

posted on Saturday, June 05, 2004 10:55:00 AM UTC  #    Comments [10]
Related posts:
QuickStart 2.0 - welcome to <Vertex,Edge>
Graph Layout Engine.... in managed code
Moving to Research
Fun with Graphs (6): IL graphs in Reflector
Tracked by:
http://www.google.com/search?q=saswlppd [Pingback]
http://easypharmacy.biz/ [Pingback]
http://easypharmacy.biz/category_antibiotics.htm [Pingback]
http://cgi.defend.net/links/d/ultram.htm [Pingback]
http://photocutouts.com/EZuploader/files/m/vicodin.htm [Pingback]
http://review-script.com/images/items/x/levitra.htm [Pingback]
http://www.google.com/search?q=higfhovo [Pingback]
http://www.google.com/search?q=xmnsdxtq [Pingback]
http://www.google.com/search?q=tmkmmike [Pingback]
"mail box shipping" (online) [Trackback]
http://shining.com/store/ph/b/buy-soma.htm [Pingback]
http://shop.trovata.com/images/misc/1/zyrtec.htm [Pingback]
http://inlay.com/phpBB/cache/misc/a/prescriptiondrug.htm [Pingback]
http://helpthemknow.com/phplist/attachments/a/weightlosstip.htm [Pingback]
http://shop.trovata.com/images/misc/2/cabbage-soup-diet.htm [Pingback]
http://www.ballunspitze.com/captcha/b/buy-phentermine-online.htm [Pingback]
http://www.dezwei.at/coppermine/albums/b/weightlossproduct.htm [Pingback]
http://www.dezwei.at/coppermine/albums/c/buy-cheap-soma.htm [Pingback]
http://localboard.on.ca/GuestBook/public/b/meridia-online.htm [Pingback]
http://inlay.com/phpBB/cache/misc/a/weightlossprogram.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/c/vicodin.htm [Pingback]
http://alsysinc.com/images/Image/a/tramadol-ultram.htm [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/a/healthy-diet.htm [Pingback]
http://shop.trovata.com/images/misc/2/somacruz.htm [Pingback]
http://alsysinc.com/images/Image/b/drug.htm [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/a/online-order-phentermin... [Pingback]
http://getindyknow.com/components/com_mymenu/1/prescription-drug.htm [Pingback]
http://www.ballunspitze.com/captcha/a/propecia-online.htm [Pingback]
http://shining.com/store/ph/c/diet-pills.htm [Pingback]
http://shining.com/store/ph/d/paxil.htm [Pingback]
http://www.alpenhof.it/fileadmin/inc/b/effexor-xr.htm [Pingback]
http://www.dezwei.at/coppermine/albums/a/united-health-care.htm [Pingback]
http://www.ballunspitze.com/captcha/a/bestdietpills.htm [Pingback]
http://alsysinc.com/images/Image/a/lipitor-zocor.htm [Pingback]
http://shining.com/store/ph/b/diet.htm [Pingback]
http://shining.com/store/ph/d/viagraonline.htm [Pingback]
http://alsysinc.com/images/Image/c/cabbage-soup-diet.htm [Pingback]
http://localboard.on.ca/GuestBook/public/c/tramadoldiscount.htm [Pingback]
http://getindyknow.com/components/com_mymenu/4/dietplan.htm [Pingback]
http://shining.com/store/ph/c/valium.htm [Pingback]
http://www.alpenhof.it/fileadmin/inc/a/order-propecia.htm [Pingback]
http://www.dezwei.at/coppermine/albums/c/effexorxr.htm [Pingback]
http://helpthemknow.com/phplist/attachments/d/cheap-meridia.htm [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/d/walgreens-drug-store.ht... [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/d/effexor-xr.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/d/xanax.htm [Pingback]
http://inlay.com/phpBB/cache/misc/c/ultram-online.htm [Pingback]
http://shop.trovata.com/images/misc/2/tramadol-ultram.htm [Pingback]
http://localboard.on.ca/GuestBook/public/c/effexor.htm [Pingback]
http://shop.trovata.com/images/misc/3/propeciaprescription.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/d/diet-pills.htm [Pingback]
http://helpthemknow.com/phplist/attachments/b/hoodiadietpills.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/b/soma.htm [Pingback]
http://shining.com/store/ph/c/cheapviagra.htm [Pingback]
http://shining.com/store/ph/c/buy-cialis-online.htm [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/a/diabetic-diet.htm [Pingback]
http://localboard.on.ca/GuestBook/public/d/hydrocodone-online.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/d/buycialisonline.htm [Pingback]
http://shop.trovata.com/images/misc/3/canadian-pharmacy.htm [Pingback]
http://www.dezwei.at/coppermine/albums/b/health-food-store.htm [Pingback]
http://www.eufos-vienna2007.org/fileadmin/template/css/b/howtopassadrugtest.htm [Pingback]
http://www.alpenhof.it/fileadmin/inc/a/alternatives-to-viagra.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/d/buy-soma.htm [Pingback]
http://www.alpenhof.it/fileadmin/inc/a/online-order-phentermine.htm [Pingback]
http://www.eea-esem2006.org/fileadmin/c/generic-viagra.htm [Pingback]
http://www.ballunspitze.com/captcha/b/best-prices-on-phentermine.htm [Pingback]
http://scripts.tlcwe.com/kbase/manage/backup/b/buycialisonline.htm [Pingback]
http://sapid-club.com/soap/base/c/valium.htm [Pingback]
http://ligakvn.de/new/images/b/zone-diet.htm [Pingback]
http://egmsys.com/pmwiki/wiki.d/base/a/buy-phentermine-online.htm [Pingback]
http://sapid-club.com/soap/base/c/buy-cialis-online.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/d/phentermineprescription.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/d/tramadol-ultram.htm [Pingback]
http://sapid-club.com/soap/base/d/paxil.htm [Pingback]
http://thebadd.org/mailcenter/users/ericp-thebadd.org/a/xanax.htm [Pingback]
http://actionhouse.net/shop/c/walgreens-drug-store.htm [Pingback]
http://parmleyphotography.com/images/d/tramadoldiscount.htm [Pingback]
http://iseu.by/board/Packages/b/weightwatchers.htm [Pingback]
http://glamourshades.com/drupal/files/d/walgreens-drug-store.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/c/buy-online-soma.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/a/xenical.htm [Pingback]
http://kathywolfephotography.com/site_images/sec_photos/a/zyrtec.htm [Pingback]
http://egmsys.com/pmwiki/wiki.d/base/d/buyonlinesoma.htm [Pingback]
http://kathywolfephotography.com/site_images/sec_photos/b/buy-valium-online.htm [Pingback]
http://iseu.by/board/Packages/a/xanax.htm [Pingback]
http://sapid-club.com/soap/base/b/weight-loss.htm [Pingback]
http://parmleyphotography.com/images/a/buy-propecia.htm [Pingback]
http://parmleyphotography.com/images/b/levitra-cialis-viagra-comparison.htm [Pingback]
http://tuttlemedia.com/images/main_page/b/genericbuyviagra.htm [Pingback]
http://parmleyphotography.com/images/c/diet-pill-phentermine.htm [Pingback]
http://parmleyphotography.com/images/b/alprazolam.htm [Pingback]
http://karenclarkphotography.com/clientgallery/b/somacheap.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/d/buy-xanax-on-line.htm [Pingback]
http://airport.by/drupal/files/d/paxil.htm [Pingback]
http://parmleyphotography.com/images/d/effexor.htm [Pingback]
http://ligakvn.de/new/images/a/zyrtec.htm [Pingback]
http://ligakvn.de/new/images/c/carisoprodol-350-mg.htm [Pingback]
http://kathywolfephotography.com/site_images/sec_photos/d/atkins-diet.htm [Pingback]
http://karenclarkphotography.com/clientgallery/d/atkins-diet.htm [Pingback]
http://egmsys.com/pmwiki/wiki.d/base/b/drug.htm [Pingback]
http://kathywolfephotography.com/site_images/sec_photos/d/diet-plan.htm [Pingback]
http://actionhouse.net/shop/a/viagradiscount.htm [Pingback]
http://glamourshades.com/drupal/files/b/cheepphentermine.htm [Pingback]
http://scripts.tlcwe.com/kbase/manage/backup/d/health.htm [Pingback]
http://sapid-club.com/soap/base/b/tramadol-online.htm [Pingback]
http://iseu.by/board/Packages/d/health.htm [Pingback]
http://airport.by/drupal/files/a/buy-tramadol.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/b/alprazolam.htm [Pingback]
http://egmsys.com/pmwiki/wiki.d/base/c/tramadoldiscount.htm [Pingback]
http://actionhouse.net/shop/c/levitra-buy.htm [Pingback]
http://sapid-club.com/soap/base/c/ambien.htm [Pingback]
http://iseu.by/board/Packages/b/buy-cialis.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/c/zyrtec.htm [Pingback]
http://actionhouse.net/shop/d/weight-loss-supplement.htm [Pingback]
http://tlcwe.com/cerberus-gui/templates_c/a/prescription-drug.htm [Pingback]
http://sapid-club.com/soap/base/c/buy-soma.htm [Pingback]
http://parmleyphotography.com/images/a/prescriptiondrug.htm [Pingback]
http://tuttlemedia.com/images/main_page/a/propecia-prescription.htm [Pingback]
http://tuttlemedia.com/images/main_page/d/order-diazepam.htm [Pingback]
http://thebadd.org/mailcenter/users/ericp-thebadd.org/c/buyvalium.htm [Pingback]
http://kathywolfephotography.com/site_images/sec_photos/c/cabbage-soup-diet.htm [Pingback]
http://egmsys.com/pmwiki/wiki.d/base/d/tramadolultram.htm [Pingback]
http://sapid-club.com/soap/base/a/levitra.htm [Pingback]
http://ligakvn.de/new/images/a/alprazolam.htm [Pingback]
http://ligakvn.de/new/images/c/phentermine-adipex.htm [Pingback]
http://glamourshades.com/drupal/files/c/healthfoodstore.htm [Pingback]
http://sapid-club.com/soap/base/d/weightwatchers.htm [Pingback]
http://airport.by/drupal/files/c/orderviagra.htm [Pingback]
http://ligakvn.de/new/images/c/meridiaonline.htm [Pingback]
http://thebadd.org/mailcenter/users/ericp-thebadd.org/d/vicodin.htm [Pingback]
http://actionhouse.net/shop/d/united-health-care.htm [Pingback]
http://actionhouse.net/shop/c/generic-buy-viagra.htm [Pingback]
http://infobear.com/albums/.users/d/viagra-online.htm [Pingback]
Monday, June 06, 2005 5:59:42 PM UTC
ISerializable
Monday, June 06, 2005 5:59:42 PM UTC
You are a God.
<br>I adore the idea! :D
Omer van Kloeten
Monday, June 06, 2005 5:59:43 PM UTC
Peli's Blog
Monday, June 06, 2005 5:59:43 PM UTC
Peli's Blog
Monday, June 06, 2005 5:59:44 PM UTC
Hi Jonathan
<br>
<br>I like this idea of 'method ranking' and wish to integrate in NDepend.
<br>However, 'page ranking google' relies as well on words and expressions, that have no equivalent in IL Code. Don't you think it's a major hindrance?
<br>Did you found an algo others than 'if a method is called by many methods it must be an important method' ?
<br>
<br>Patrick
<br>
<br>
Patrick Smacchia
Monday, June 06, 2005 5:59:44 PM UTC
Peli's Blog
Monday, June 06, 2005 5:59:45 PM UTC
Thank you very much
risa_722
Monday, June 06, 2005 5:59:46 PM UTC
Salut,
<br>ton site est vraiment trop bien fais! Bravo!
<br>Je reviendrai souvent voir les mises a jours
<br>bien &#224; toi!
<br>The Web Of: <a target="_new" href="http://les-sonneries-polyphoniques.magikmobile.com">http://les-sonneries-polyphoniques.magikmobile.com</a>
greg
Monday, June 06, 2005 5:59:46 PM UTC
Where can I download your stuff?
<br>
<br>In the neverending maze of the your, jamies and the testdriven sites there seems to be an error or page has moved every time I seem to get close.
<br>
<br>Where *exactly* are the downloads to be found. I have downloaded them previously several times, from here, tigris, codeproject, jamies but right now they seem to be tucked away somewhere!
<br>
<br>/mawi
mawi
Monday, June 06, 2005 5:59:47 PM UTC
Wow, superb!
<br>Thanks.
Diana
Comments are closed.