Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
#include <algorithm>
|
2017-10-09 20:18:37 +08:00
|
|
|
#include <experimental/optional>
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
#include <fstream>
|
|
|
|
#include <memory>
|
|
|
|
#include <random>
|
|
|
|
#include <unordered_map>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <fmt/format.h>
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
#include <json/json.hpp>
|
|
|
|
|
|
|
|
#include "communication/bolt/v1/encoder/base_encoder.hpp"
|
2017-10-25 19:01:53 +08:00
|
|
|
#include "durability/hashed_file_writer.hpp"
|
2017-10-19 18:56:16 +08:00
|
|
|
#include "durability/version.hpp"
|
|
|
|
#include "transactions/type.hpp"
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
#include "utils/string.hpp"
|
|
|
|
#include "utils/timer.hpp"
|
|
|
|
|
2018-03-22 23:33:03 +08:00
|
|
|
#include "snapshot_generation/graph_state.hpp"
|
|
|
|
#include "snapshot_generation/snapshot_writer.hpp"
|
|
|
|
|
|
|
|
DEFINE_int32(num_workers, 1, "number of workers");
|
|
|
|
DEFINE_string(out, "tmp", "Destination for the created snapshot file");
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
DEFINE_string(config, "", "Path to config JSON file");
|
|
|
|
|
2018-03-22 23:33:03 +08:00
|
|
|
using namespace snapshot_generation;
|
|
|
|
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
/**
|
|
|
|
* This file contains the program for generating a snapshot based on a JSON
|
|
|
|
* definition. The JSON config has the following form:
|
|
|
|
*
|
|
|
|
* {
|
|
|
|
* "indexes" : ["Person.id", "Company.id"],
|
|
|
|
* "nodes" : [
|
|
|
|
* {
|
2018-03-22 23:33:03 +08:00
|
|
|
* "count_per_worker" : 10000,
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* "labels" : ["Person"],
|
|
|
|
* "properties" : {
|
2017-10-09 20:18:37 +08:00
|
|
|
* "id" : { "type" : "counter", "param": "Person.id" },
|
|
|
|
* "name" : { "type" : "randstring", "param" :
|
|
|
|
* { "type": "randint", "param" : [10, 20]}},
|
|
|
|
* "is_happy" : { "type" : "bernoulli", "param" : 0.2 }
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* }
|
|
|
|
* },
|
|
|
|
* {
|
2018-03-22 23:33:03 +08:00
|
|
|
* "count_per_worker" : 200,
|
2017-10-09 20:18:37 +08:00
|
|
|
* "labels" : ["Company"],
|
|
|
|
* "properties" : {
|
|
|
|
* "id" : { "type" : "counter", "param": "Company.id" },
|
|
|
|
* "name" : { "type" : "randstring", "param" :
|
|
|
|
* { "type": "randint", "param" : [10, 20]}},
|
|
|
|
* "description" : { "type" : "optional", "param" :
|
|
|
|
* [0.2, { "type" : "randstring", "param": 1024 }]}
|
|
|
|
* }
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* }
|
|
|
|
* ],
|
|
|
|
* "edges" : [
|
|
|
|
* {
|
2018-03-22 23:33:03 +08:00
|
|
|
* "kind": "unique",
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* "from" : "Person",
|
|
|
|
* "to" : "Company",
|
2018-03-22 23:33:03 +08:00
|
|
|
* "type" : "WORKS_IN",
|
|
|
|
* "hop_probability": 0.05
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* },
|
|
|
|
* {
|
2018-03-22 23:33:03 +08:00
|
|
|
* "kind": "random",
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* "count" : 20,
|
|
|
|
* "from" : "Person",
|
|
|
|
* "to" : "Company",
|
2018-03-22 23:33:03 +08:00
|
|
|
* "type" : "LIKES",
|
|
|
|
* "hop_probability": 0.1
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
* }
|
|
|
|
* ]
|
|
|
|
* }
|
|
|
|
*/
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
|
|
|
|
// Read the config JSON
|
|
|
|
nlohmann::json config;
|
|
|
|
{
|
|
|
|
std::ifstream config_file(FLAGS_config);
|
|
|
|
config_file >> config;
|
|
|
|
}
|
|
|
|
|
2018-03-22 23:33:03 +08:00
|
|
|
GraphState state = BuildFromConfig(FLAGS_num_workers, config);
|
|
|
|
WriteToSnapshot(state, FLAGS_out);
|
Generate snapshot added
Summary:
A cool new graph generator. It's really cool!
It is currently being used for generating the Ravelin graph with the following config:
```
{
"indexes": ["Node.id"],
"nodes": [
{
"count": 40000000,
"labels": ["Node"],
"properties": {
"id" : {"type": "counter", "param" : "Node.id"},
"fradulent" : {"type" : "bernoulli", "param" : 0.0005}
}
}
],
"edges": [
{
"count": 80000000,
"from": "Node",
"to": "Node",
"type": "Edge"
}
]
}
```
Reviewers: buda, mislav.bradac
Reviewed By: mislav.bradac
Subscribers: pullbot
Differential Revision: https://phabricator.memgraph.io/D872
2017-10-06 20:14:15 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|