Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/graphaware/neo4j-noderank
GraphAware Timer-Driven Runtime Module that executes PageRank-like algorithm on the graph
https://github.com/graphaware/neo4j-noderank
java neo4j neo4j-graphaware-framework
Last synced: 4 months ago
JSON representation
GraphAware Timer-Driven Runtime Module that executes PageRank-like algorithm on the graph
- Host: GitHub
- URL: https://github.com/graphaware/neo4j-noderank
- Owner: graphaware
- Archived: true
- Created: 2014-08-04T10:38:51.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2017-10-17T12:21:32.000Z (over 7 years ago)
- Last Synced: 2023-07-26T22:10:58.865Z (over 1 year ago)
- Topics: java, neo4j, neo4j-graphaware-framework
- Language: Java
- Homepage:
- Size: 233 KB
- Stars: 26
- Watchers: 30
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
GraphAware Neo4j NodeRank - RETIRED
=====================================NodeRank Has Been Retired
---------------------------As of October 17th 2017, this module is retiring. This means it will no longer be maintained and released together with
new versions of the GraphAware Framework and Neo4j. The last compatible Neo4j version is 3.2.5.NodeRank is superseded by a much more active Neo4j Graph Algorithms project.
This repository will remain public. Please get in touch if you've been using NodeRank and would like to migrate to
Neo4j Graph Algorithms.=====================================
[![Build Status](https://travis-ci.org/graphaware/neo4j-noderank.png)](https://travis-ci.org/graphaware/neo4j-noderank) | Downloads | Javadoc | Latest Release: 3.2.5.51.5
GraphAware NodeRank is a [GraphAware](https://github.com/graphaware/neo4j-framework) Runtime Module that executes a configurable
Page Rank-like algorithm on the Neo4j graph. It is a reference implementation of a [Timer-Driven GraphAware Runtime Module](https://github.com/graphaware/neo4j-framework/tree/master/runtime#building-a-timer-driven-graphaware-runtime-module).The module "crawls" the graph continuously behind the scenes, slowing down as the database gets busier and speeding up
in quiet periods. It starts by selecting a node at random (obeying configured node inclusion policy). At each step of the
algorithm, it follows a random relationship (obeying configured relationship inclusion policy) and increments a property
(with configurable key) of the other node of the relationship. With a probability 1-p, where p is the configurable damping
factor, it selects another random node rather than following a relationship. Also, if there are no suitable relationships
to follow from a node, a jump to another suitable random node is performed.Over time, the node ranks written to the nodes in the graph converge to the results of Page Rank, had it been computed
analytically. The amount of time it takes to converge greatly depends on the size of the graph, the load on the database,
and the [Timer-Driven Module Scheduling Configuration](https://github.com/graphaware/neo4j-framework/tree/master/runtime#building-a-timer-driven-graphaware-runtime-module).
With default settings and 100 nodes in the database, the top 10 nodes are identical for NodeRank and Page Rank within a
few seconds of running the module.Getting the Software
--------------------### Server Mode
When using Neo4j in the standalone server mode,
you will need the GraphAware Neo4j Framework and GraphAware Neo4j NodeRank .jar files (both of which you can download here) dropped
into the `plugins` directory of your Neo4j installation. After a change in neo4.properties (described later) and Neo4j restart, you will be able to use the REST APIs of the NodeRank
and the computation will take place continuously.### Embedded Mode / Java Development
Java developers that use Neo4j in embedded mode
and those developing Neo4j server plugins,
unmanaged extensions,
GraphAware Runtime Modules, or Spring MVC Controllers can include use the NodeRank as a dependency for their Java project.#### Releases
Releases are synced to Maven Central repository. When using Maven for dependency management, include the following dependency in your pom.xml.
...
com.graphaware.neo4j
noderank
3.2.5.51.5
...
#### Snapshots
To use the latest development version, just clone this repository, run `mvn clean install` and change the version in the
dependency above to 3.2.5.51.6-SNAPSHOT.#### Note on Versioning Scheme
The version number has two parts. The first four numbers indicate compatibility with Neo4j GraphAware Framework.
The last number is the version of the NodeRank library. For example, version 2.1.4.19.1 is version 1 of the NodeRank
compatible with GraphAware Neo4j Framework 2.1.4.19.Setup and Configuration
=======================### Server Mode
Edit `conf/neo4j.conf` to register the NodeRank module:
```
com.graphaware.runtime.enabled=true#NR becomes the module ID:
com.graphaware.module.NR.1=com.graphaware.module.noderank.NodeRankModuleBootstrapper#optional number of top ranked nodes to remember, the default is 10
com.graphaware.module.NR.maxTopRankNodes=10#optional daming factor, which is a number p such that a random node will be selected at any step of the algorithm
#with the probability 1-p (as opposed to following a random relationship). The default is 0.85
com.graphaware.module.NR.dampingFactor=0.85#optional key of the property that gets written to the ranked nodes, default is "nodeRank"
com.graphaware.module.NR.propertyKey=nodeRank#optionally specify nodes to rank using an expression-based node inclusion policy, default is all business (i.e. non-framework-internal) nodes
com.graphaware.module.NR.node=hasLabel('Person')#optionally specify relationships to follow using an expression-based relationship inclusion policy, default is all business (i.e. non-framework-internal) relationships
com.graphaware.module.NR.relationship=isType('FRIEND_OF')
```Note that "NR" becomes the module ID. It is possible to register the NodeRank module multiple times with different
configurations, provided that their IDs are different. This ID is important for querying the top ranked nodes (read on).### Embedded Mode / Java Development
To use the NodeRank programmatically, register the module like this
```java
GraphAwareRuntime runtime = GraphAwareRuntimeFactory.createRuntime(database); //where database is an instance of GraphDatabaseService
NodeRankModule module = new NodeRankModule("NR");
runtime.registerModule(module);
runtime.start();
```Alternatively:
```java
GraphDatabaseService database = new TestGraphDatabaseFactory().newEmbeddedDatabaseBuilder(pathToDb)
.loadPropertiesFromFile(this.getClass().getClassLoader().getResource("neo4j.properties").getPath())
.newGraphDatabase();RuntimeRegistry.getStartedRuntime(database);
//make sure neo4j.properties contain the lines mentioned in previous section
```Using GraphAware NodeRank
=========================### Cypher
The `ga.noderank.getTopRanked` procedure call can be used in Cypher to get a list of top ranked nodes, ordered by decreasing rank.
```
CALL ga.noderank.getTopRanked("moduleId", 10) YIELD node RETURN node
```There are 2 arguments to pass to the call :
* `moduleId`: a string representing the name of the module id you used to register the module in the configuration
* `limit` : an integer used to determine the size of the returned list of nodes### REST API
In Server Mode, the NodeRank is accessible via the REST API.
You can issue GET requests to `http://your-server-address:7474/graphaware/noderank/{moduleId}` to get a list of top ranked
nodes, ordered by decreasing rank. The maximum size of the list is determined by the `maxTopRankNodes` parameter configured
earlier. You can further limit the size of the results by provising a `limit` request parameter, e.g.
`http://your-server-address:7474/graphaware/noderank/{moduleId}?limit=10`.The REST API returns a JSON array of nodes, e.g.
```json
[
{
"id": 5,
"labels": ["Person", "Male"],
"properties":
{
"nodeRank": 3022,
"name": "Brandon Morley"
}
},
{
"id": 9,
"labels": ["Person", "Male"],
"properties":
{
"nodeRank": 2656,
"name": "Liam Rees"
}
},
{
"id": 8,
"labels": ["Person", "Female"],
"properties":
{
"nodeRank": 2280,
"name": "Amelie Green"
}
}
]
```### Java API
To use the Java API, obtain the module and ask for top nodes. You can also just interrogate the node properties as usual,
the property that NodeRank writes to the nodes is configured using the `propertyKey` parameter described above.```
NodeRankModule nodeRankModule = ProductionRuntime.getStartedRuntime(database).getModule("NR", NodeRankModule.class);
List topNodes = nodeRankModule.getTopNodes().getTopNodes();
```Please refer to Javadoc for more detail.
License
-------Copyright (c) 2014-2017 GraphAware
GraphAware is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License
as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program.
If not, see .