igraph-help
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [igraph] Retrieve nodes forming a motif with subgraph_isomorphisms


From: Phil Cui
Subject: Re: [igraph] Retrieve nodes forming a motif with subgraph_isomorphisms
Date: Tue, 11 Aug 2015 09:17:20 -0400

Hi Tamas,

Is there a similar function to as_edgelist( graph ) but only providing edges incident to the specified vertices in the following way: as_edgelist( graph, vertices ). This is based on my experience that the numeric matrix returned by as_edgelist is more convenient and faster to further process than list. Right now, as_edgelist returned the edges of the complete graph in matrix form. If a brother/sister version of as_edgelist gives edges incident to only some vertices, it will be faster and more convenient for further processing, e.g. call isomorphism_class to check the motif type of the combination of  the vertices. 

On the other hand,  I'm using python as well.  So what is situation on the python side? Is there an alternative solution with the python interface?

Thank you very much!

Best,
Phil

___________________________________________________________

Phil Hengjun Cui
Drexel University | Electrical and Computer Engineering
Philadelphia, USA
___________________________________________________________

On Tue, Aug 11, 2015 at 5:22 AM, Tamas Nepusz <address@hidden> wrote:
Hi Phil,

> I tried make_line_graph according to your suggestion. And it works very
> well for small scale graph.
> However, when the graph include millions of nodes, it becomes hard to
> create a complete line graph.
Yes, true, the line graph would probably be huge (but its exact size depends on
the degree distribution). In that case, one thing that you can try before
diving into the C code is to store an incidence list representation of the
graph and work from that:

inc <- incident_edges(graph, V(graph))

Basically, inc will be a list that can be indexed with vertex indices and it
would give you the IDs of the edges incident on a specific vertex. This is
probably somewhat similar to your original approach but it might be faster
because the indicent edges of a vertex are pre-computed so you can trade a call
to incident() for an index lookup in the incidence list, which is likely to be
faster.

> I already come out a draft version of that, but I don't know how to test
> it. My plan is to fork the igraph package to my local computer through
> Github and then test it on my side so that it won't affect the original
> package in case I make some mistake.
Yes, that's the right thing to do.

> The problem I encounter now is: how to
> embed my code to the igraph package so that I can test the code.
I'm not that familiar with the development of the R interface (I am mostly
working on the C core and the Python interface), but I think that this file in
the repository is meant to explain the process:

https://github.com/igraph/rigraph/blob/dev/CONTRIBUTING.md

Best,
T.

_______________________________________________
igraph-help mailing list
address@hidden
https://lists.nongnu.org/mailman/listinfo/igraph-help


reply via email to

[Prev in Thread] Current Thread [Next in Thread]