-
Notifications
You must be signed in to change notification settings - Fork 10
Uploading Graphs, Covers and Centralities
- Graph ML
- GML
- Weighted, Unweighted, Node Weighted Edgelist
- Adjacency Matrix (Currently only with positive values)
- XGMML
- Custom Formats
- XML Content
- Text Content
- inputFormat: XML (The value XML will select the XMLGraphInputAdapter to parse the xml data)
- startDate: 2004-01-01 (Starting date from which the data rows are considered)
- endDate: 2004-01-01 (Ending date till which the data rows are considered)
- indexPath: C:\indexes (set the index directory for faster computation)
- filePath: ocd/test/input/stackexAcademia.xml (The path of the xml file)
The XMLGraphInputAdapter will parse the xml data in a specific format. If the data is not arranged as it should be, the service won’t work. The xml data rows should have those mandatory attributes,
Id ParentId CreationDate Body OwnerUserId/OwnerDisplayName
Here,
- Id: The id of the post.
- ParentId: If the post is the reply of another post.
- CreationDate: This is the creation date of the post.
- Body: It is the main post of message of the post.
- OwnerUserId: The user id who creates this post. If this attribute is not available OwnerDisplayName will be considered.
- OwnerDisplayName: The display name of the user who creates this post.
N.B.: Id and ParentId are mandatory for the structural method and creates eagles between nodes. Like someone asks a question inside another post. So the child post has its own id and also the parent post id. So the post node creates node with the parent node. To get an example of XML data which is supported by OCD service follow this file stackexAcademia.xml.
- inputFormat: NODE_CONTENT_EDGE_LIST (The value NODE_CONTENT_EDGE_LIST will select NodeContentEdgeListGraphInputAdapter to parse plain text file)
- startDate: 2004-01-01 (Starting date from which the data rows are considered)
- endDate: 2004-01-01 (Ending date till which the data rows are considered)
- indexPath: C:\indexes (set the index directory for faster computation)
- body: (This field will have the all text of the text file)
The NodeContentEdgeListGraphInputAdapter will parse the text file in a specific format. If the data is not arranged as it should be, the service won’t work. The text data rows should have those mandatory attributes:
SENT_BY REPLIES_TO CONTENT DATE
- SENT_BY: It is the id of the user who write the post
- REPLIES_TO: This is the id of the user in which post a user replies to
- CONTENT: The main message of the post.
- DATE: Creation date of the post.
N.B.: The 1st line of the text file should be the headers of the column. If there is no line break between lines that would be ok and if there is line break that would also alright. To get example of text data which is supported by OCD service follow these files: JMOL.txt, BioJava.txt, PGSQL_200.txt. There are also another text files UrchTest.txt and URCH_POSTS.txt. But for those two files the attribute CREATION_TIMESTAMP should be changed to DATE.
The API POST ocd/storegraph
can be used to store big graph step by step.
Parameters:
- name: Name of the graph.
- body: The content of the graph which will append with the previous content. For example, a graph of 360000 lines could be divided into any number of lines. For instance, that graph is divided into 36 parts and each part contains 10000 lines. Now, those parts could be sent step by step. Initially, the name and the content of the first part should send to the 'ocd/storegraph' API. For rest of the parts, the name should be same and the content should be the text of corresponding the pats.
The API POST /ocd/processgraph
can be used to insert the stored graph into the database. The processgraph API is same as uploading graph methods as described before in this page. But the graph name should be same as the name by which the graph was stored. And there is no body parameter of the request. After sending this request, A graph id will be generated.
Each line of input contains first the name of a community (optional, if a community name is the same as a nodes name in the graph, it will also be considered as a node name) and then the names of the member nodes (Nodes of these names must exist in the actual graph), using the space character (' ') as a delimiter:
Comm0 Javert Babet Brujon
Comm1 Valjean Javert Labarre
Nodes will be considered to have an equal membership degree for each community they are associated with.
Each line of input contains first a node name (which must exist in the actual graph) and then an arbitrary number of community names, using the space character (' ') as a delimiter. There must be exactly one line for each node. An example can be seen below:
Javert Comm0 Comm2
Valjean Comm1 Comm2
Nodes will be considered to have an equal membership degree for all communities they are associated with.
Each line of input contains first a node name (which must exist in the actual graph) and then n double values (where n is some natural number), using the space character (' ') as a delimiter. The i-th double value of a row will define the node's membership degree for the i-th community. An example of this is seen below:
Javert 0.4 0.6
Valjean 0.3 0.7
There must be exactly one line for each node of the graph and each line must have the same number ("n") of double values.
Each line of input contains first a node name (which must exist in the actual graph) and then one double value, using the space character (' ') as a delimiter:
Javert 0.8
Valjean 1.0