#include #include #include #include #include "clique.hpp" #include "query/plan_interface.hpp" #include "storage/edge_accessor.hpp" #include "storage/vertex_accessor.hpp" #include "using.hpp" #include "utils/assert.hpp" using std::cout; using std::endl; // Query: MATCH // (a:garment)-[:default_outfit]-(b:garment)-[:default_outfit]-(c:garment)-[:default_outfit]-(d:garment)-[:default_outfit]-(a:garment)-[:default_outfit]-(c:garment), // (b:garment)-[:default_outfit]-(d:garment), (e:profile {profile_id: 112, // partner_id: 55})-[s1:score]-(a:garment),(e:profile {profile_id: 112, // partner_id: 55})-[s2:score]-(b:garment), (e:profile {profile_id: 112, // partner_id: 55})-[s3:score]-(c:garment), (e:profile {profile_id: 112, // partner_id: 55})-[s4:score]-(d:garment) WHERE a.garment_id=1234 RETURN // a.garment_id,b.garment_id,c.garment_id,d.garment_id, // s1.score+s2.score+s3.score+s4.score ORDER BY // s1.score+s2.score+s3.score+s4.score DESC LIMIT 10 class CPUPlan : public PlanInterface { public: bool run(GraphDbAccessor &db_accessor, const PropertyValueStore<> &args, Stream &stream) { return run_general_query(db_accessor, args, stream, CliqueQuery::SCORE_AND_LIMIT); } ~CPUPlan() {} }; extern "C" PlanInterface *produce() { return new CPUPlan(); } extern "C" void destruct(PlanInterface *p) { delete p; }