2016-09-13 19:14:16 +08:00
|
|
|
#include <cstring>
|
|
|
|
#include <ctime>
|
|
|
|
|
2017-02-04 16:01:15 +08:00
|
|
|
#include "database/graph_db.hpp"
|
2016-09-13 19:14:16 +08:00
|
|
|
#include "import/csv_import.hpp"
|
|
|
|
#include "logging/default.hpp"
|
|
|
|
#include "logging/streams/stdout.hpp"
|
|
|
|
#include "utils/command_line/arguments.hpp"
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
// Adds double property with random value of max to all vertices.
|
|
|
|
void add_scores(Db &db, double max_value, std::string const &property_name)
|
|
|
|
{
|
|
|
|
DbAccessor t(db);
|
|
|
|
|
|
|
|
auto key_score = t.vertex_property_family_get(property_name)
|
|
|
|
.get(Flags::Double)
|
|
|
|
.family_key();
|
|
|
|
|
|
|
|
std::srand(time(0));
|
|
|
|
t.vertex_access().fill().for_all([&](auto v) {
|
|
|
|
double value = ((std::rand() + 0.0) / RAND_MAX) * max_value;
|
|
|
|
v.set(StoredProperty<TypeGroupVertex>(Double(value), key_score));
|
|
|
|
});
|
|
|
|
|
|
|
|
t.commit();
|
|
|
|
}
|
|
|
|
|
2016-09-14 00:53:40 +08:00
|
|
|
// Tool to add double propertys to all vertices.
|
|
|
|
// // Accepts flags for csv import.
|
|
|
|
// -db name , will create database with that name.
|
|
|
|
// -pn name , will name property with that name,default: name=score.
|
|
|
|
// -max number , will set range of property [0,max], default: max=1
|
2016-09-13 19:14:16 +08:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
logging::init_async();
|
|
|
|
logging::log->pipe(std::make_unique<Stdout>());
|
|
|
|
|
|
|
|
auto para = all_arguments(argc, argv);
|
|
|
|
|
|
|
|
std::string property_name = get_argument(para, "-pn", "score");
|
|
|
|
double max_value = std::stod(get_argument(para, "-max", "1"));
|
|
|
|
|
|
|
|
Db db(get_argument(para, "-db", "default"));
|
|
|
|
|
|
|
|
add_scores(db, max_value, property_name);
|
|
|
|
|
|
|
|
db.snap_engine.make_snapshot();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|