views:

552

answers:

10

I guess those who have worked in communities and social networks might have some experience in this.

I am trying to plot a graph of all the friendships that exists on my site and in doing so identify clusters of strongly interconnected users.

Does anyone have any experience in doing something like this? Also, does SQL Server 2008 BI have tools that allows for this type of modelling?

Thanks

+4  A: 

Take a look at neato from the Graphviz command line tool suite. AS input it takes a so called .dot file. The format is straight forward you should just be able to iterate over all friendship relations in your system and write them into the file.

Adrian
looks good i'll check it out thanks
Nai
A: 

If you want visualize graph data follow this link with same question

Sergey Mirvoda
... assuming you want .NET, that is :-)
whybird
A: 

Check out Wikipedia -- Social Network which does talk about social network analysis and graphing relations between users. I think the basic idea is you use a graph to map all the relations and then the more shared relations there are, the higher the interconnected relationships.

+4  A: 

Hi, Programming Collective Intelligence's chapter 5 is dedicated to optimization and network visualization. Using the modules available here and the snippet below, I could make the following image:

>>> import optimization
>>> import socialnetwork
>>> sol = optimization.annealingoptimize(socialnetwork.domain, socialnetwork.crosscount, step=50, cool=0.99)
>>> socialnetwork.drawnetwork(sol)

chart

The advantages of this approach is that you can easily change the cost function, use different optimization algorithms, or use another library to view the solution.

jbochi
+1  A: 

For visualization, have a look at the Javascript Infovis Toolkit.

Gregory Pakosz
A: 

You might take a look at the Girvan-Newman algorithm, the output of which gives you an idea of community structure in the form of a dendrogram.

ergosys
+1  A: 

You should look at Mark Shepherd's SpringGraph which is a neat and sexy way of showing big graphs.

Simon
+1  A: 

Please take a look at the prefuse visualization toolkit

prp
+1  A: 

Your graph will be probably reasonably large, so GraphViz is a poor choice. It does a nice job for tiny graphs, but not for huge ones. I'd recommend that you try aiSee instead (here are some example graphs). It requires graphs to be specified in a simple human-readable format called GDL.

Sample social network


Sample social network


Sample social network

RegDwight
+1  A: 

For inspiration, take a look at these social graphs from "Visual Complexity" collection.

Many visualizations have explanatory papers and articles mentioning graphing tools, libraries and algorithms used to obtain the images.

Examples from "Social Networks" category:

alt text

alt text

Constantin