Hi Tiago, thanks for your prompt reply.
Quoting Tiago de Paula Peixoto (2016-09-21 10:35:39)
> I am toying around with a particular class of graphs for which I wrote a
> subclass of `graph_tools.Graph`. It should be great to be able to use
> `GraphView` for filtering (I'm implementing a divide-and-conquer
> algorithm and want to recur on subgraphs), but it seems that those will
> always behave as `Graph`, even if I instantiate them with an object of
> my subclass.
Of course, GraphView is a subclass of Graph, not of your subclass.
Sure I understand. I was hoping for some magic via mixins or the like
to make this work anyway..
> Is there a better way to filter my graphs than writing a custom
> `GraphView` subclass for it?
You can just use the set_edge/vertex_filter() methods of Graph.
Yes, but as far as I understand one cannot add multiple vertex-filters
right? I mean in order to solve my problem recursively on subgraphs,
I can of course set a filter and then recur. But then "setting a
filter" would amount to amending an already existing one...
Another related question: my algorithm could potentially parallelize the
recursive calls dealing with subgraphs.
If I use filters as you suggest to identify subgraphs, does the fact
that concurrent recursive calls handle the same graph object with
different filters cause any problems?
Could you point me towards example (python) code that utilizes parallel
threads? Or is this done only on a libboost level?
Thanks again for your help and apologies for my rather vague noob questions.
Best,
Patrick
BTW: I believe there is a typo in the docstring for `Graph.set_filters`:
"Only the vertices and edges with value different than True are kept in
the filtered graph"
Shouldn't it say values different from `False`, as in `set_vertex_filter`?