org.neo4j.gds.betweenness.BetweennessCentralityWriteProc Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of proc-centrality Show documentation
Show all versions of proc-centrality Show documentation
Neo4j Graph Data Science :: Procedures :: Centrality
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* Neo4j 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 .
*/
package org.neo4j.gds.betweenness;
import org.neo4j.gds.BaseProc;
import org.neo4j.gds.core.write.NodePropertyExporterBuilder;
import org.neo4j.gds.executor.ExecutionContext;
import org.neo4j.gds.executor.MemoryEstimationExecutor;
import org.neo4j.gds.executor.ProcedureExecutor;
import org.neo4j.gds.results.MemoryEstimateResult;
import org.neo4j.procedure.Context;
import org.neo4j.procedure.Description;
import org.neo4j.procedure.Name;
import org.neo4j.procedure.Procedure;
import java.util.Map;
import java.util.stream.Stream;
import static org.neo4j.gds.betweenness.BetweennessCentrality.BETWEENNESS_DESCRIPTION;
import static org.neo4j.procedure.Mode.READ;
import static org.neo4j.procedure.Mode.WRITE;
public class BetweennessCentralityWriteProc extends BaseProc {
@Context
public NodePropertyExporterBuilder nodePropertyExporterBuilder;
@Procedure(value = "gds.betweenness.write", mode = WRITE)
@Description(BETWEENNESS_DESCRIPTION)
public Stream write(
@Name(value = "graphName") String graphName,
@Name(value = "configuration", defaultValue = "{}") Map configuration
) {
return new ProcedureExecutor<>(
new BetweennessCentralityWriteSpecification(),
executionContext()
).compute(graphName, configuration);
}
@Procedure(value = "gds.betweenness.write.estimate", mode = READ)
@Description(BETWEENNESS_DESCRIPTION)
public Stream estimate(
@Name(value = "graphNameOrConfiguration") Object graphNameOrConfiguration,
@Name(value = "algoConfiguration") Map algoConfiguration
) {
return new MemoryEstimationExecutor<>(
new BetweennessCentralityWriteSpecification(),
executionContext(),
transactionContext()
).computeEstimate(graphNameOrConfiguration, algoConfiguration);
}
@Override
public ExecutionContext executionContext() {
return super.executionContext().withNodePropertyExporterBuilder(nodePropertyExporterBuilder);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy