-
Notifications
You must be signed in to change notification settings - Fork 69
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Graph functional interface #196
Comments
Thanks! I think we could add some of these functions as methods or as functions to the
This one is just one function call away: just run
This one feels too specialised to be included into the API. However, if there are many such graph statistics functions we could in principle put them into a separate module.
What is graph density? Again, this feels too specialised to me.
We already have this function, it's called
This sounds too specialised as well... Perhaps, it could at least be generalised to accept a predicate on edges, e.g.
This one is definitely very common, and I'd love to have it in the API.
Could you give examples? Are you talking about generating random graphs with desired statistical properties? If yes, I guess this could go into a separate statistics module (or even a separate package!). |
Okay, I was looking for functions that would make sense to extend the graph API and now that you replied I agree with them feeling too specialized. With this being said, I think it's more interesting for me to focus on the random graph generation and see where I can get. I'll start by adding the |
Speaking about Networkx: I think we should also implement the "Classic" graph generators. |
@Synthetica9 We already have some of the listed combinators, but I agree that it would be nice to have some others from this list too. As always, it is a matter of finding the right balance between the number of features in a library and the ease of navigating the library by a newcomer. To avoid overwhelming people, we might want to move some more sophisticated combinators in a separate module. |
@snowleopard Since there is already a PR on the implementation of |
So I have been looking for Graph APIs and the networkx for python is very rich and powerful. It has a lot of things but I just want to start with the ones that are simpler/useful.
In the link I provided a lot of them are already implemented so I thought that would be nice to have the following:
degree :: Graph a -> a -> Int
- Returns the degree of a certain vertexdegreehistogram :: Graph a -> [(a, Float)]
- Returns de list of the frequency of each degree value.density :: Graph a -> Float
- Returns the density of the graphreverse :: Graph a -> Graph a
- Returns the graph with the edges revertedselfLoops :: Graph a -> Int
- Returns the number of selfLoops in the graphI want to discuss some of the types of these functions, if it makes sense to add these kind of functions and how to integrate this in alga. I also am thinking of doing
isConnected :: Graph -> Bool
and implement graph generation functions like Erdos Renyi/Barabasi-Albert.should these functions be integrated in Graph API ?
The text was updated successfully, but these errors were encountered: