@ladybugmem/icebug 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -0
- package/binding.gyp +54 -0
- package/build/Release/.deps/Release/icebug.node.d +1 -0
- package/build/Release/.deps/Release/obj.target/icebug/src/addon.o.d +291 -0
- package/build/Release/icebug.node +0 -0
- package/build/Release/obj.target/icebug/src/addon.o +0 -0
- package/lib/index.d.ts +361 -0
- package/lib/index.js +102 -0
- package/package.json +42 -0
- package/src/addon.cpp +1253 -0
- package/vendor/include/networkit/GlobalState.hpp +86 -0
- package/vendor/include/networkit/Globals.hpp +41 -0
- package/vendor/include/networkit/algebraic/AlgebraicGlobals.hpp +27 -0
- package/vendor/include/networkit/algebraic/CSRGeneralMatrix.hpp +1292 -0
- package/vendor/include/networkit/algebraic/CSRMatrix.hpp +11 -0
- package/vendor/include/networkit/algebraic/DenseMatrix.hpp +537 -0
- package/vendor/include/networkit/algebraic/DynamicMatrix.hpp +514 -0
- package/vendor/include/networkit/algebraic/GraphBLAS.hpp +323 -0
- package/vendor/include/networkit/algebraic/MatrixTools.hpp +156 -0
- package/vendor/include/networkit/algebraic/Semirings.hpp +171 -0
- package/vendor/include/networkit/algebraic/SparseAccumulator.hpp +111 -0
- package/vendor/include/networkit/algebraic/Vector.hpp +371 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicBFS.hpp +72 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicBellmanFord.hpp +88 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicMatchingCoarsening.hpp +96 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicPageRank.hpp +145 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicSpanningEdgeCentrality.hpp +122 -0
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicTriangleCounting.hpp +76 -0
- package/vendor/include/networkit/auxiliary/AlignedAllocator.hpp +113 -0
- package/vendor/include/networkit/auxiliary/ArrayTools.hpp +85 -0
- package/vendor/include/networkit/auxiliary/BloomFilter.hpp +70 -0
- package/vendor/include/networkit/auxiliary/BucketPQ.hpp +142 -0
- package/vendor/include/networkit/auxiliary/Enforce.hpp +117 -0
- package/vendor/include/networkit/auxiliary/FunctionTraits.hpp +74 -0
- package/vendor/include/networkit/auxiliary/HashUtils.hpp +28 -0
- package/vendor/include/networkit/auxiliary/IncrementalUniformRandomSelector.hpp +52 -0
- package/vendor/include/networkit/auxiliary/Log.hpp +119 -0
- package/vendor/include/networkit/auxiliary/MissingMath.hpp +48 -0
- package/vendor/include/networkit/auxiliary/Multiprecision.hpp +17 -0
- package/vendor/include/networkit/auxiliary/NumberParsing.hpp +307 -0
- package/vendor/include/networkit/auxiliary/NumericTools.hpp +57 -0
- package/vendor/include/networkit/auxiliary/Parallel.hpp +56 -0
- package/vendor/include/networkit/auxiliary/Parallelism.hpp +33 -0
- package/vendor/include/networkit/auxiliary/PrioQueue.hpp +252 -0
- package/vendor/include/networkit/auxiliary/Random.hpp +122 -0
- package/vendor/include/networkit/auxiliary/SetIntersector.hpp +72 -0
- package/vendor/include/networkit/auxiliary/SignalHandling.hpp +39 -0
- package/vendor/include/networkit/auxiliary/SortedList.hpp +128 -0
- package/vendor/include/networkit/auxiliary/SparseVector.hpp +215 -0
- package/vendor/include/networkit/auxiliary/SpinLock.hpp +23 -0
- package/vendor/include/networkit/auxiliary/StringBuilder.hpp +322 -0
- package/vendor/include/networkit/auxiliary/StringTools.hpp +76 -0
- package/vendor/include/networkit/auxiliary/TemplateUtils.hpp +76 -0
- package/vendor/include/networkit/auxiliary/Timer.hpp +145 -0
- package/vendor/include/networkit/auxiliary/VectorComparator.hpp +32 -0
- package/vendor/include/networkit/base/Algorithm.hpp +41 -0
- package/vendor/include/networkit/base/DynAlgorithm.hpp +31 -0
- package/vendor/include/networkit/centrality/ApproxBetweenness.hpp +62 -0
- package/vendor/include/networkit/centrality/ApproxCloseness.hpp +136 -0
- package/vendor/include/networkit/centrality/ApproxElectricalCloseness.hpp +156 -0
- package/vendor/include/networkit/centrality/ApproxGroupBetweenness.hpp +124 -0
- package/vendor/include/networkit/centrality/ApproxSpanningEdge.hpp +84 -0
- package/vendor/include/networkit/centrality/Betweenness.hpp +47 -0
- package/vendor/include/networkit/centrality/Centrality.hpp +98 -0
- package/vendor/include/networkit/centrality/Closeness.hpp +107 -0
- package/vendor/include/networkit/centrality/ComplexPaths.hpp +113 -0
- package/vendor/include/networkit/centrality/CoreDecomposition.hpp +161 -0
- package/vendor/include/networkit/centrality/DegreeCentrality.hpp +55 -0
- package/vendor/include/networkit/centrality/DynApproxBetweenness.hpp +95 -0
- package/vendor/include/networkit/centrality/DynBetweenness.hpp +99 -0
- package/vendor/include/networkit/centrality/DynBetweennessOneNode.hpp +98 -0
- package/vendor/include/networkit/centrality/DynKatzCentrality.hpp +115 -0
- package/vendor/include/networkit/centrality/DynTopHarmonicCloseness.hpp +223 -0
- package/vendor/include/networkit/centrality/EigenvectorCentrality.hpp +41 -0
- package/vendor/include/networkit/centrality/EstimateBetweenness.hpp +51 -0
- package/vendor/include/networkit/centrality/ForestCentrality.hpp +112 -0
- package/vendor/include/networkit/centrality/GedWalk.hpp +225 -0
- package/vendor/include/networkit/centrality/GroupCloseness.hpp +115 -0
- package/vendor/include/networkit/centrality/GroupClosenessGrowShrink.hpp +78 -0
- package/vendor/include/networkit/centrality/GroupClosenessLocalSearch.hpp +77 -0
- package/vendor/include/networkit/centrality/GroupClosenessLocalSwaps.hpp +106 -0
- package/vendor/include/networkit/centrality/GroupDegree.hpp +155 -0
- package/vendor/include/networkit/centrality/GroupHarmonicCloseness.hpp +83 -0
- package/vendor/include/networkit/centrality/HarmonicCloseness.hpp +48 -0
- package/vendor/include/networkit/centrality/KPathCentrality.hpp +52 -0
- package/vendor/include/networkit/centrality/KadabraBetweenness.hpp +242 -0
- package/vendor/include/networkit/centrality/KatzCentrality.hpp +62 -0
- package/vendor/include/networkit/centrality/LaplacianCentrality.hpp +44 -0
- package/vendor/include/networkit/centrality/LocalClusteringCoefficient.hpp +60 -0
- package/vendor/include/networkit/centrality/LocalPartitionCoverage.hpp +43 -0
- package/vendor/include/networkit/centrality/LocalSquareClusteringCoefficient.hpp +42 -0
- package/vendor/include/networkit/centrality/PageRank.hpp +101 -0
- package/vendor/include/networkit/centrality/PermanenceCentrality.hpp +48 -0
- package/vendor/include/networkit/centrality/Sfigality.hpp +45 -0
- package/vendor/include/networkit/centrality/SpanningEdgeCentrality.hpp +86 -0
- package/vendor/include/networkit/centrality/TopCloseness.hpp +136 -0
- package/vendor/include/networkit/centrality/TopHarmonicCloseness.hpp +151 -0
- package/vendor/include/networkit/clique/MaximalCliques.hpp +83 -0
- package/vendor/include/networkit/coarsening/ClusteringProjector.hpp +59 -0
- package/vendor/include/networkit/coarsening/CoarsenedGraphView.hpp +156 -0
- package/vendor/include/networkit/coarsening/GraphCoarsening.hpp +57 -0
- package/vendor/include/networkit/coarsening/MatchingCoarsening.hpp +43 -0
- package/vendor/include/networkit/coarsening/ParallelPartitionCoarsening.hpp +33 -0
- package/vendor/include/networkit/coarsening/ParallelPartitionCoarseningView.hpp +62 -0
- package/vendor/include/networkit/community/AdjustedRandMeasure.hpp +31 -0
- package/vendor/include/networkit/community/ClusteringGenerator.hpp +75 -0
- package/vendor/include/networkit/community/CommunityDetectionAlgorithm.hpp +58 -0
- package/vendor/include/networkit/community/Conductance.hpp +32 -0
- package/vendor/include/networkit/community/CoverF1Similarity.hpp +53 -0
- package/vendor/include/networkit/community/CoverHubDominance.hpp +38 -0
- package/vendor/include/networkit/community/Coverage.hpp +25 -0
- package/vendor/include/networkit/community/CutClustering.hpp +62 -0
- package/vendor/include/networkit/community/DissimilarityMeasure.hpp +31 -0
- package/vendor/include/networkit/community/DynamicNMIDistance.hpp +44 -0
- package/vendor/include/networkit/community/EdgeCut.hpp +24 -0
- package/vendor/include/networkit/community/GraphClusteringTools.hpp +103 -0
- package/vendor/include/networkit/community/GraphStructuralRandMeasure.hpp +28 -0
- package/vendor/include/networkit/community/HubDominance.hpp +46 -0
- package/vendor/include/networkit/community/IntrapartitionDensity.hpp +44 -0
- package/vendor/include/networkit/community/IsolatedInterpartitionConductance.hpp +40 -0
- package/vendor/include/networkit/community/IsolatedInterpartitionExpansion.hpp +40 -0
- package/vendor/include/networkit/community/JaccardMeasure.hpp +25 -0
- package/vendor/include/networkit/community/LFM.hpp +49 -0
- package/vendor/include/networkit/community/LPDegreeOrdered.hpp +48 -0
- package/vendor/include/networkit/community/LocalCommunityEvaluation.hpp +100 -0
- package/vendor/include/networkit/community/LocalCoverEvaluation.hpp +31 -0
- package/vendor/include/networkit/community/LocalPartitionEvaluation.hpp +31 -0
- package/vendor/include/networkit/community/LouvainMapEquation.hpp +135 -0
- package/vendor/include/networkit/community/Modularity.hpp +54 -0
- package/vendor/include/networkit/community/NMIDistance.hpp +28 -0
- package/vendor/include/networkit/community/NodeStructuralRandMeasure.hpp +27 -0
- package/vendor/include/networkit/community/OverlappingCommunityDetectionAlgorithm.hpp +51 -0
- package/vendor/include/networkit/community/OverlappingNMIDistance.hpp +175 -0
- package/vendor/include/networkit/community/PLM.hpp +89 -0
- package/vendor/include/networkit/community/PLP.hpp +83 -0
- package/vendor/include/networkit/community/ParallelAgglomerativeClusterer.hpp +37 -0
- package/vendor/include/networkit/community/ParallelLeiden.hpp +96 -0
- package/vendor/include/networkit/community/ParallelLeidenView.hpp +138 -0
- package/vendor/include/networkit/community/PartitionFragmentation.hpp +30 -0
- package/vendor/include/networkit/community/PartitionHubDominance.hpp +37 -0
- package/vendor/include/networkit/community/PartitionIntersection.hpp +25 -0
- package/vendor/include/networkit/community/QualityMeasure.hpp +27 -0
- package/vendor/include/networkit/community/SampledGraphStructuralRandMeasure.hpp +40 -0
- package/vendor/include/networkit/community/SampledNodeStructuralRandMeasure.hpp +40 -0
- package/vendor/include/networkit/community/StablePartitionNodes.hpp +48 -0
- package/vendor/include/networkit/components/BiconnectedComponents.hpp +116 -0
- package/vendor/include/networkit/components/ComponentDecomposition.hpp +72 -0
- package/vendor/include/networkit/components/ConnectedComponents.hpp +55 -0
- package/vendor/include/networkit/components/DynConnectedComponents.hpp +71 -0
- package/vendor/include/networkit/components/DynWeaklyConnectedComponents.hpp +73 -0
- package/vendor/include/networkit/components/ParallelConnectedComponents.hpp +44 -0
- package/vendor/include/networkit/components/RandomSpanningForest.hpp +36 -0
- package/vendor/include/networkit/components/StronglyConnectedComponents.hpp +50 -0
- package/vendor/include/networkit/components/WeaklyConnectedComponents.hpp +59 -0
- package/vendor/include/networkit/correlation/Assortativity.hpp +64 -0
- package/vendor/include/networkit/distance/APSP.hpp +70 -0
- package/vendor/include/networkit/distance/AStar.hpp +68 -0
- package/vendor/include/networkit/distance/AStarGeneral.hpp +110 -0
- package/vendor/include/networkit/distance/AdamicAdarDistance.hpp +52 -0
- package/vendor/include/networkit/distance/AffectedNodes.hpp +130 -0
- package/vendor/include/networkit/distance/AlgebraicDistance.hpp +63 -0
- package/vendor/include/networkit/distance/BFS.hpp +43 -0
- package/vendor/include/networkit/distance/BidirectionalBFS.hpp +51 -0
- package/vendor/include/networkit/distance/BidirectionalDijkstra.hpp +69 -0
- package/vendor/include/networkit/distance/CommuteTimeDistance.hpp +89 -0
- package/vendor/include/networkit/distance/Diameter.hpp +97 -0
- package/vendor/include/networkit/distance/Dijkstra.hpp +50 -0
- package/vendor/include/networkit/distance/DynAPSP.hpp +67 -0
- package/vendor/include/networkit/distance/DynBFS.hpp +56 -0
- package/vendor/include/networkit/distance/DynDijkstra.hpp +57 -0
- package/vendor/include/networkit/distance/DynPrunedLandmarkLabeling.hpp +67 -0
- package/vendor/include/networkit/distance/DynSSSP.hpp +87 -0
- package/vendor/include/networkit/distance/Eccentricity.hpp +32 -0
- package/vendor/include/networkit/distance/EffectiveDiameter.hpp +47 -0
- package/vendor/include/networkit/distance/EffectiveDiameterApproximation.hpp +57 -0
- package/vendor/include/networkit/distance/FloydWarshall.hpp +93 -0
- package/vendor/include/networkit/distance/GraphDistance.hpp +49 -0
- package/vendor/include/networkit/distance/HopPlotApproximation.hpp +62 -0
- package/vendor/include/networkit/distance/IncompleteDijkstra.hpp +66 -0
- package/vendor/include/networkit/distance/IncompleteSSSP.hpp +41 -0
- package/vendor/include/networkit/distance/JaccardDistance.hpp +57 -0
- package/vendor/include/networkit/distance/MultiTargetBFS.hpp +32 -0
- package/vendor/include/networkit/distance/MultiTargetDijkstra.hpp +40 -0
- package/vendor/include/networkit/distance/NeighborhoodFunction.hpp +47 -0
- package/vendor/include/networkit/distance/NeighborhoodFunctionApproximation.hpp +56 -0
- package/vendor/include/networkit/distance/NeighborhoodFunctionHeuristic.hpp +56 -0
- package/vendor/include/networkit/distance/NodeDistance.hpp +54 -0
- package/vendor/include/networkit/distance/PrunedLandmarkLabeling.hpp +76 -0
- package/vendor/include/networkit/distance/ReverseBFS.hpp +46 -0
- package/vendor/include/networkit/distance/SPSP.hpp +143 -0
- package/vendor/include/networkit/distance/SSSP.hpp +216 -0
- package/vendor/include/networkit/distance/STSP.hpp +193 -0
- package/vendor/include/networkit/distance/Volume.hpp +66 -0
- package/vendor/include/networkit/dynamics/DGSStreamParser.hpp +40 -0
- package/vendor/include/networkit/dynamics/DGSWriter.hpp +30 -0
- package/vendor/include/networkit/dynamics/GraphDifference.hpp +110 -0
- package/vendor/include/networkit/dynamics/GraphEvent.hpp +55 -0
- package/vendor/include/networkit/dynamics/GraphEventHandler.hpp +39 -0
- package/vendor/include/networkit/dynamics/GraphEventProxy.hpp +55 -0
- package/vendor/include/networkit/dynamics/GraphUpdater.hpp +38 -0
- package/vendor/include/networkit/edgescores/ChibaNishizekiQuadrangleEdgeScore.hpp +26 -0
- package/vendor/include/networkit/edgescores/ChibaNishizekiTriangleEdgeScore.hpp +33 -0
- package/vendor/include/networkit/edgescores/EdgeScore.hpp +50 -0
- package/vendor/include/networkit/edgescores/EdgeScoreAsWeight.hpp +33 -0
- package/vendor/include/networkit/edgescores/EdgeScoreBlender.hpp +33 -0
- package/vendor/include/networkit/edgescores/EdgeScoreLinearizer.hpp +32 -0
- package/vendor/include/networkit/edgescores/EdgeScoreNormalizer.hpp +35 -0
- package/vendor/include/networkit/edgescores/GeometricMeanScore.hpp +29 -0
- package/vendor/include/networkit/edgescores/PrefixJaccardScore.hpp +23 -0
- package/vendor/include/networkit/edgescores/TriangleEdgeScore.hpp +39 -0
- package/vendor/include/networkit/embedding/Node2Vec.hpp +83 -0
- package/vendor/include/networkit/flow/EdmondsKarp.hpp +112 -0
- package/vendor/include/networkit/generators/BarabasiAlbertGenerator.hpp +87 -0
- package/vendor/include/networkit/generators/ChungLuGenerator.hpp +46 -0
- package/vendor/include/networkit/generators/ChungLuGeneratorAlamEtAl.hpp +63 -0
- package/vendor/include/networkit/generators/ClusteredRandomGraphGenerator.hpp +56 -0
- package/vendor/include/networkit/generators/ConfigurationModel.hpp +36 -0
- package/vendor/include/networkit/generators/DorogovtsevMendesGenerator.hpp +33 -0
- package/vendor/include/networkit/generators/DynamicBarabasiAlbertGenerator.hpp +33 -0
- package/vendor/include/networkit/generators/DynamicDGSParser.hpp +51 -0
- package/vendor/include/networkit/generators/DynamicDorogovtsevMendesGenerator.hpp +34 -0
- package/vendor/include/networkit/generators/DynamicForestFireGenerator.hpp +55 -0
- package/vendor/include/networkit/generators/DynamicGraphGenerator.hpp +40 -0
- package/vendor/include/networkit/generators/DynamicGraphSource.hpp +79 -0
- package/vendor/include/networkit/generators/DynamicHyperbolicGenerator.hpp +143 -0
- package/vendor/include/networkit/generators/DynamicPathGenerator.hpp +26 -0
- package/vendor/include/networkit/generators/DynamicPubWebGenerator.hpp +54 -0
- package/vendor/include/networkit/generators/EdgeSwitchingMarkovChainGenerator.hpp +65 -0
- package/vendor/include/networkit/generators/ErdosRenyiEnumerator.hpp +318 -0
- package/vendor/include/networkit/generators/ErdosRenyiGenerator.hpp +56 -0
- package/vendor/include/networkit/generators/HavelHakimiGenerator.hpp +48 -0
- package/vendor/include/networkit/generators/HyperbolicGenerator.hpp +236 -0
- package/vendor/include/networkit/generators/LFRGenerator.hpp +175 -0
- package/vendor/include/networkit/generators/MocnikGenerator.hpp +147 -0
- package/vendor/include/networkit/generators/MocnikGeneratorBasic.hpp +58 -0
- package/vendor/include/networkit/generators/PowerlawDegreeSequence.hpp +128 -0
- package/vendor/include/networkit/generators/PubWebGenerator.hpp +94 -0
- package/vendor/include/networkit/generators/RegularRingLatticeGenerator.hpp +37 -0
- package/vendor/include/networkit/generators/RmatGenerator.hpp +67 -0
- package/vendor/include/networkit/generators/StaticDegreeSequenceGenerator.hpp +42 -0
- package/vendor/include/networkit/generators/StaticGraphGenerator.hpp +30 -0
- package/vendor/include/networkit/generators/StochasticBlockmodel.hpp +41 -0
- package/vendor/include/networkit/generators/WattsStrogatzGenerator.hpp +43 -0
- package/vendor/include/networkit/generators/quadtree/QuadNode.hpp +857 -0
- package/vendor/include/networkit/generators/quadtree/QuadNodeCartesianEuclid.hpp +587 -0
- package/vendor/include/networkit/generators/quadtree/QuadNodePolarEuclid.hpp +726 -0
- package/vendor/include/networkit/generators/quadtree/Quadtree.hpp +232 -0
- package/vendor/include/networkit/generators/quadtree/QuadtreeCartesianEuclid.hpp +149 -0
- package/vendor/include/networkit/generators/quadtree/QuadtreePolarEuclid.hpp +143 -0
- package/vendor/include/networkit/geometric/HyperbolicSpace.hpp +248 -0
- package/vendor/include/networkit/geometric/Point2DWithIndex.hpp +145 -0
- package/vendor/include/networkit/global/ClusteringCoefficient.hpp +42 -0
- package/vendor/include/networkit/global/GlobalClusteringCoefficient.hpp +24 -0
- package/vendor/include/networkit/graph/Attributes.hpp +568 -0
- package/vendor/include/networkit/graph/BFS.hpp +111 -0
- package/vendor/include/networkit/graph/DFS.hpp +71 -0
- package/vendor/include/networkit/graph/Dijkstra.hpp +83 -0
- package/vendor/include/networkit/graph/EdgeIterators.hpp +171 -0
- package/vendor/include/networkit/graph/Graph.hpp +2083 -0
- package/vendor/include/networkit/graph/GraphBuilder.hpp +289 -0
- package/vendor/include/networkit/graph/GraphR.hpp +133 -0
- package/vendor/include/networkit/graph/GraphTools.hpp +589 -0
- package/vendor/include/networkit/graph/GraphW.hpp +1236 -0
- package/vendor/include/networkit/graph/KruskalMSF.hpp +50 -0
- package/vendor/include/networkit/graph/NeighborIterators.hpp +163 -0
- package/vendor/include/networkit/graph/NodeIterators.hpp +127 -0
- package/vendor/include/networkit/graph/PrimMSF.hpp +66 -0
- package/vendor/include/networkit/graph/RandomMaximumSpanningForest.hpp +133 -0
- package/vendor/include/networkit/graph/SpanningForest.hpp +41 -0
- package/vendor/include/networkit/graph/TopologicalSort.hpp +87 -0
- package/vendor/include/networkit/graph/UnionMaximumSpanningForest.hpp +126 -0
- package/vendor/include/networkit/graph/test/GraphBuilderBenchmark.hpp +68 -0
- package/vendor/include/networkit/independentset/IndependentSetFinder.hpp +44 -0
- package/vendor/include/networkit/independentset/Luby.hpp +27 -0
- package/vendor/include/networkit/io/BinaryEdgeListPartitionReader.hpp +45 -0
- package/vendor/include/networkit/io/BinaryEdgeListPartitionWriter.hpp +47 -0
- package/vendor/include/networkit/io/BinaryPartitionReader.hpp +41 -0
- package/vendor/include/networkit/io/BinaryPartitionWriter.hpp +44 -0
- package/vendor/include/networkit/io/CoverReader.hpp +27 -0
- package/vendor/include/networkit/io/CoverWriter.hpp +21 -0
- package/vendor/include/networkit/io/DGSReader.hpp +39 -0
- package/vendor/include/networkit/io/DibapGraphReader.hpp +43 -0
- package/vendor/include/networkit/io/DotGraphWriter.hpp +39 -0
- package/vendor/include/networkit/io/DotPartitionWriter.hpp +23 -0
- package/vendor/include/networkit/io/DynamicGraphReader.hpp +29 -0
- package/vendor/include/networkit/io/EdgeListCoverReader.hpp +35 -0
- package/vendor/include/networkit/io/EdgeListPartitionReader.hpp +43 -0
- package/vendor/include/networkit/io/EdgeListReader.hpp +61 -0
- package/vendor/include/networkit/io/EdgeListWriter.hpp +48 -0
- package/vendor/include/networkit/io/GMLGraphReader.hpp +33 -0
- package/vendor/include/networkit/io/GMLGraphWriter.hpp +33 -0
- package/vendor/include/networkit/io/GraphIO.hpp +52 -0
- package/vendor/include/networkit/io/GraphReader.hpp +40 -0
- package/vendor/include/networkit/io/GraphToolBinaryReader.hpp +71 -0
- package/vendor/include/networkit/io/GraphToolBinaryWriter.hpp +61 -0
- package/vendor/include/networkit/io/GraphWriter.hpp +27 -0
- package/vendor/include/networkit/io/KONECTGraphReader.hpp +44 -0
- package/vendor/include/networkit/io/LineFileReader.hpp +42 -0
- package/vendor/include/networkit/io/METISGraphReader.hpp +36 -0
- package/vendor/include/networkit/io/METISGraphWriter.hpp +29 -0
- package/vendor/include/networkit/io/METISParser.hpp +63 -0
- package/vendor/include/networkit/io/MTXGraphReader.hpp +31 -0
- package/vendor/include/networkit/io/MTXParser.hpp +87 -0
- package/vendor/include/networkit/io/MatrixMarketReader.hpp +33 -0
- package/vendor/include/networkit/io/MatrixReader.hpp +33 -0
- package/vendor/include/networkit/io/MemoryMappedFile.hpp +80 -0
- package/vendor/include/networkit/io/NetworkitBinaryGraph.hpp +144 -0
- package/vendor/include/networkit/io/NetworkitBinaryReader.hpp +50 -0
- package/vendor/include/networkit/io/NetworkitBinaryWriter.hpp +71 -0
- package/vendor/include/networkit/io/PartitionReader.hpp +34 -0
- package/vendor/include/networkit/io/PartitionWriter.hpp +31 -0
- package/vendor/include/networkit/io/RBGraphReader.hpp +37 -0
- package/vendor/include/networkit/io/RBMatrixReader.hpp +49 -0
- package/vendor/include/networkit/io/RasterReader.hpp +40 -0
- package/vendor/include/networkit/io/SNAPEdgeListPartitionReader.hpp +28 -0
- package/vendor/include/networkit/io/SNAPGraphReader.hpp +53 -0
- package/vendor/include/networkit/io/SNAPGraphWriter.hpp +53 -0
- package/vendor/include/networkit/io/ThrillGraphBinaryReader.hpp +44 -0
- package/vendor/include/networkit/io/ThrillGraphBinaryWriter.hpp +27 -0
- package/vendor/include/networkit/layout/LayoutAlgorithm.hpp +39 -0
- package/vendor/include/networkit/linkprediction/AdamicAdarIndex.hpp +37 -0
- package/vendor/include/networkit/linkprediction/AdjustedRandIndex.hpp +36 -0
- package/vendor/include/networkit/linkprediction/AlgebraicDistanceIndex.hpp +70 -0
- package/vendor/include/networkit/linkprediction/CommonNeighborsIndex.hpp +39 -0
- package/vendor/include/networkit/linkprediction/EvaluationMetric.hpp +135 -0
- package/vendor/include/networkit/linkprediction/JaccardIndex.hpp +44 -0
- package/vendor/include/networkit/linkprediction/KatzIndex.hpp +84 -0
- package/vendor/include/networkit/linkprediction/LinkPredictor.hpp +98 -0
- package/vendor/include/networkit/linkprediction/LinkThresholder.hpp +56 -0
- package/vendor/include/networkit/linkprediction/MissingLinksFinder.hpp +60 -0
- package/vendor/include/networkit/linkprediction/NeighborhoodDistanceIndex.hpp +42 -0
- package/vendor/include/networkit/linkprediction/NeighborhoodUtility.hpp +54 -0
- package/vendor/include/networkit/linkprediction/NeighborsMeasureIndex.hpp +48 -0
- package/vendor/include/networkit/linkprediction/PrecisionRecallMetric.hpp +40 -0
- package/vendor/include/networkit/linkprediction/PredictionsSorter.hpp +66 -0
- package/vendor/include/networkit/linkprediction/PreferentialAttachmentIndex.hpp +37 -0
- package/vendor/include/networkit/linkprediction/ROCMetric.hpp +39 -0
- package/vendor/include/networkit/linkprediction/RandomLinkSampler.hpp +47 -0
- package/vendor/include/networkit/linkprediction/ResourceAllocationIndex.hpp +38 -0
- package/vendor/include/networkit/linkprediction/SameCommunityIndex.hpp +50 -0
- package/vendor/include/networkit/linkprediction/TotalNeighborsIndex.hpp +39 -0
- package/vendor/include/networkit/linkprediction/UDegreeIndex.hpp +35 -0
- package/vendor/include/networkit/linkprediction/VDegreeIndex.hpp +35 -0
- package/vendor/include/networkit/matching/BMatcher.hpp +52 -0
- package/vendor/include/networkit/matching/BMatching.hpp +115 -0
- package/vendor/include/networkit/matching/BSuitorMatcher.hpp +170 -0
- package/vendor/include/networkit/matching/DynamicBSuitorMatcher.hpp +78 -0
- package/vendor/include/networkit/matching/LocalMaxMatcher.hpp +35 -0
- package/vendor/include/networkit/matching/Matcher.hpp +55 -0
- package/vendor/include/networkit/matching/Matching.hpp +111 -0
- package/vendor/include/networkit/matching/PathGrowingMatcher.hpp +46 -0
- package/vendor/include/networkit/matching/SuitorMatcher.hpp +62 -0
- package/vendor/include/networkit/numerics/ConjugateGradient.hpp +163 -0
- package/vendor/include/networkit/numerics/GaussSeidelRelaxation.hpp +99 -0
- package/vendor/include/networkit/numerics/LAMG/LAMGSettings.hpp +70 -0
- package/vendor/include/networkit/numerics/LAMG/Lamg.hpp +460 -0
- package/vendor/include/networkit/numerics/LAMG/Level/EliminationStage.hpp +47 -0
- package/vendor/include/networkit/numerics/LAMG/Level/Level.hpp +56 -0
- package/vendor/include/networkit/numerics/LAMG/Level/LevelAggregation.hpp +52 -0
- package/vendor/include/networkit/numerics/LAMG/Level/LevelElimination.hpp +133 -0
- package/vendor/include/networkit/numerics/LAMG/Level/LevelFinest.hpp +28 -0
- package/vendor/include/networkit/numerics/LAMG/LevelHierarchy.hpp +165 -0
- package/vendor/include/networkit/numerics/LAMG/MultiLevelSetup.hpp +1090 -0
- package/vendor/include/networkit/numerics/LAMG/SolverLamg.hpp +316 -0
- package/vendor/include/networkit/numerics/LinearSolver.hpp +151 -0
- package/vendor/include/networkit/numerics/Preconditioner/DiagonalPreconditioner.hpp +61 -0
- package/vendor/include/networkit/numerics/Preconditioner/IdentityPreconditioner.hpp +36 -0
- package/vendor/include/networkit/numerics/Smoother.hpp +37 -0
- package/vendor/include/networkit/overlap/HashingOverlapper.hpp +28 -0
- package/vendor/include/networkit/overlap/Overlapper.hpp +27 -0
- package/vendor/include/networkit/planarity/LeftRightPlanarityCheck.hpp +113 -0
- package/vendor/include/networkit/randomization/Curveball.hpp +49 -0
- package/vendor/include/networkit/randomization/CurveballGlobalTradeGenerator.hpp +39 -0
- package/vendor/include/networkit/randomization/CurveballUniformTradeGenerator.hpp +39 -0
- package/vendor/include/networkit/randomization/DegreePreservingShuffle.hpp +82 -0
- package/vendor/include/networkit/randomization/EdgeSwitching.hpp +157 -0
- package/vendor/include/networkit/randomization/GlobalCurveball.hpp +69 -0
- package/vendor/include/networkit/randomization/GlobalTradeSequence.hpp +303 -0
- package/vendor/include/networkit/reachability/AllSimplePaths.hpp +122 -0
- package/vendor/include/networkit/reachability/ReachableNodes.hpp +83 -0
- package/vendor/include/networkit/scd/ApproximatePageRank.hpp +51 -0
- package/vendor/include/networkit/scd/CliqueDetect.hpp +55 -0
- package/vendor/include/networkit/scd/CombinedSCD.hpp +51 -0
- package/vendor/include/networkit/scd/GCE.hpp +42 -0
- package/vendor/include/networkit/scd/LFMLocal.hpp +54 -0
- package/vendor/include/networkit/scd/LocalT.hpp +40 -0
- package/vendor/include/networkit/scd/LocalTightnessExpansion.hpp +46 -0
- package/vendor/include/networkit/scd/PageRankNibble.hpp +55 -0
- package/vendor/include/networkit/scd/RandomBFS.hpp +33 -0
- package/vendor/include/networkit/scd/SCDGroundTruthComparison.hpp +121 -0
- package/vendor/include/networkit/scd/SelectiveCommunityDetector.hpp +76 -0
- package/vendor/include/networkit/scd/SetConductance.hpp +47 -0
- package/vendor/include/networkit/scd/TCE.hpp +41 -0
- package/vendor/include/networkit/scd/TwoPhaseL.hpp +40 -0
- package/vendor/include/networkit/scoring/EdgeScoring.hpp +44 -0
- package/vendor/include/networkit/scoring/ModularityScoring.hpp +79 -0
- package/vendor/include/networkit/simulation/EpidemicSimulationSEIR.hpp +59 -0
- package/vendor/include/networkit/sparsification/ChanceCorrectedTriangleScore.hpp +28 -0
- package/vendor/include/networkit/sparsification/ForestFireScore.hpp +34 -0
- package/vendor/include/networkit/sparsification/GlobalThresholdFilter.hpp +40 -0
- package/vendor/include/networkit/sparsification/LocalDegreeScore.hpp +30 -0
- package/vendor/include/networkit/sparsification/LocalFilterScore.hpp +124 -0
- package/vendor/include/networkit/sparsification/LocalSimilarityScore.hpp +63 -0
- package/vendor/include/networkit/sparsification/MultiscaleScore.hpp +38 -0
- package/vendor/include/networkit/sparsification/RandomEdgeScore.hpp +33 -0
- package/vendor/include/networkit/sparsification/RandomNodeEdgeScore.hpp +29 -0
- package/vendor/include/networkit/sparsification/SCANStructuralSimilarityScore.hpp +23 -0
- package/vendor/include/networkit/sparsification/SimmelianOverlapScore.hpp +35 -0
- package/vendor/include/networkit/sparsification/SimmelianScore.hpp +92 -0
- package/vendor/include/networkit/sparsification/Sparsifiers.hpp +166 -0
- package/vendor/include/networkit/structures/Cover.hpp +248 -0
- package/vendor/include/networkit/structures/LocalCommunity.hpp +363 -0
- package/vendor/include/networkit/structures/Partition.hpp +335 -0
- package/vendor/include/networkit/structures/UnionFind.hpp +66 -0
- package/vendor/include/networkit/viz/GraphLayoutAlgorithm.hpp +157 -0
- package/vendor/include/networkit/viz/MaxentStress.hpp +346 -0
- package/vendor/include/networkit/viz/Octree.hpp +428 -0
- package/vendor/include/networkit/viz/PivotMDS.hpp +63 -0
- package/vendor/include/networkit/viz/Point.hpp +415 -0
- package/vendor/include/networkit/viz/PostscriptWriter.hpp +78 -0
- package/vendor/include/tlx/algorithm/exclusive_scan.hpp +56 -0
- package/vendor/include/tlx/algorithm/is_sorted_cmp.hpp +56 -0
- package/vendor/include/tlx/algorithm/merge_advance.hpp +177 -0
- package/vendor/include/tlx/algorithm/merge_combine.hpp +76 -0
- package/vendor/include/tlx/algorithm/multisequence_partition.hpp +346 -0
- package/vendor/include/tlx/algorithm/multisequence_selection.hpp +351 -0
- package/vendor/include/tlx/algorithm/multiway_merge.hpp +1385 -0
- package/vendor/include/tlx/algorithm/multiway_merge_splitting.hpp +257 -0
- package/vendor/include/tlx/algorithm/parallel_multiway_merge.hpp +408 -0
- package/vendor/include/tlx/algorithm/random_bipartition_shuffle.hpp +116 -0
- package/vendor/include/tlx/algorithm.hpp +36 -0
- package/vendor/include/tlx/allocator_base.hpp +100 -0
- package/vendor/include/tlx/backtrace.hpp +54 -0
- package/vendor/include/tlx/cmdline_parser.hpp +498 -0
- package/vendor/include/tlx/container/btree.hpp +3977 -0
- package/vendor/include/tlx/container/btree_map.hpp +634 -0
- package/vendor/include/tlx/container/btree_multimap.hpp +627 -0
- package/vendor/include/tlx/container/btree_multiset.hpp +612 -0
- package/vendor/include/tlx/container/btree_set.hpp +612 -0
- package/vendor/include/tlx/container/d_ary_addressable_int_heap.hpp +416 -0
- package/vendor/include/tlx/container/d_ary_heap.hpp +311 -0
- package/vendor/include/tlx/container/loser_tree.hpp +1009 -0
- package/vendor/include/tlx/container/lru_cache.hpp +319 -0
- package/vendor/include/tlx/container/radix_heap.hpp +735 -0
- package/vendor/include/tlx/container/ring_buffer.hpp +428 -0
- package/vendor/include/tlx/container/simple_vector.hpp +304 -0
- package/vendor/include/tlx/container/splay_tree.hpp +399 -0
- package/vendor/include/tlx/container/string_view.hpp +805 -0
- package/vendor/include/tlx/container.hpp +40 -0
- package/vendor/include/tlx/counting_ptr.hpp +522 -0
- package/vendor/include/tlx/define/attribute_always_inline.hpp +34 -0
- package/vendor/include/tlx/define/attribute_fallthrough.hpp +36 -0
- package/vendor/include/tlx/define/attribute_format_printf.hpp +34 -0
- package/vendor/include/tlx/define/attribute_packed.hpp +34 -0
- package/vendor/include/tlx/define/attribute_warn_unused_result.hpp +34 -0
- package/vendor/include/tlx/define/constexpr.hpp +31 -0
- package/vendor/include/tlx/define/deprecated.hpp +39 -0
- package/vendor/include/tlx/define/endian.hpp +49 -0
- package/vendor/include/tlx/define/likely.hpp +33 -0
- package/vendor/include/tlx/define/visibility_hidden.hpp +34 -0
- package/vendor/include/tlx/define.hpp +36 -0
- package/vendor/include/tlx/delegate.hpp +524 -0
- package/vendor/include/tlx/die/core.hpp +311 -0
- package/vendor/include/tlx/die.hpp +106 -0
- package/vendor/include/tlx/digest/md5.hpp +81 -0
- package/vendor/include/tlx/digest/sha1.hpp +81 -0
- package/vendor/include/tlx/digest/sha256.hpp +81 -0
- package/vendor/include/tlx/digest/sha512.hpp +81 -0
- package/vendor/include/tlx/digest.hpp +30 -0
- package/vendor/include/tlx/logger/all.hpp +33 -0
- package/vendor/include/tlx/logger/array.hpp +43 -0
- package/vendor/include/tlx/logger/core.hpp +287 -0
- package/vendor/include/tlx/logger/deque.hpp +42 -0
- package/vendor/include/tlx/logger/map.hpp +65 -0
- package/vendor/include/tlx/logger/set.hpp +60 -0
- package/vendor/include/tlx/logger/tuple.hpp +66 -0
- package/vendor/include/tlx/logger/unordered_map.hpp +68 -0
- package/vendor/include/tlx/logger/unordered_set.hpp +64 -0
- package/vendor/include/tlx/logger/wrap_unprintable.hpp +75 -0
- package/vendor/include/tlx/logger.hpp +44 -0
- package/vendor/include/tlx/math/abs_diff.hpp +35 -0
- package/vendor/include/tlx/math/aggregate.hpp +231 -0
- package/vendor/include/tlx/math/aggregate_min_max.hpp +116 -0
- package/vendor/include/tlx/math/bswap.hpp +148 -0
- package/vendor/include/tlx/math/bswap_be.hpp +79 -0
- package/vendor/include/tlx/math/bswap_le.hpp +79 -0
- package/vendor/include/tlx/math/clz.hpp +174 -0
- package/vendor/include/tlx/math/ctz.hpp +174 -0
- package/vendor/include/tlx/math/div_ceil.hpp +36 -0
- package/vendor/include/tlx/math/ffs.hpp +123 -0
- package/vendor/include/tlx/math/integer_log2.hpp +189 -0
- package/vendor/include/tlx/math/is_power_of_two.hpp +74 -0
- package/vendor/include/tlx/math/polynomial_regression.hpp +243 -0
- package/vendor/include/tlx/math/popcount.hpp +173 -0
- package/vendor/include/tlx/math/power_to_the.hpp +44 -0
- package/vendor/include/tlx/math/rol.hpp +112 -0
- package/vendor/include/tlx/math/ror.hpp +112 -0
- package/vendor/include/tlx/math/round_to_power_of_two.hpp +121 -0
- package/vendor/include/tlx/math/round_up.hpp +36 -0
- package/vendor/include/tlx/math/sgn.hpp +38 -0
- package/vendor/include/tlx/math.hpp +46 -0
- package/vendor/include/tlx/meta/apply_tuple.hpp +55 -0
- package/vendor/include/tlx/meta/call_for_range.hpp +78 -0
- package/vendor/include/tlx/meta/call_foreach.hpp +60 -0
- package/vendor/include/tlx/meta/call_foreach_tuple.hpp +60 -0
- package/vendor/include/tlx/meta/call_foreach_tuple_with_index.hpp +61 -0
- package/vendor/include/tlx/meta/call_foreach_with_index.hpp +64 -0
- package/vendor/include/tlx/meta/enable_if.hpp +37 -0
- package/vendor/include/tlx/meta/fold_left.hpp +63 -0
- package/vendor/include/tlx/meta/fold_left_tuple.hpp +60 -0
- package/vendor/include/tlx/meta/fold_right.hpp +63 -0
- package/vendor/include/tlx/meta/fold_right_tuple.hpp +60 -0
- package/vendor/include/tlx/meta/function_chain.hpp +197 -0
- package/vendor/include/tlx/meta/function_stack.hpp +189 -0
- package/vendor/include/tlx/meta/has_member.hpp +80 -0
- package/vendor/include/tlx/meta/has_method.hpp +117 -0
- package/vendor/include/tlx/meta/index_sequence.hpp +66 -0
- package/vendor/include/tlx/meta/is_std_array.hpp +40 -0
- package/vendor/include/tlx/meta/is_std_pair.hpp +39 -0
- package/vendor/include/tlx/meta/is_std_tuple.hpp +39 -0
- package/vendor/include/tlx/meta/is_std_vector.hpp +39 -0
- package/vendor/include/tlx/meta/log2.hpp +101 -0
- package/vendor/include/tlx/meta/no_operation.hpp +55 -0
- package/vendor/include/tlx/meta/static_index.hpp +42 -0
- package/vendor/include/tlx/meta/vexpand.hpp +34 -0
- package/vendor/include/tlx/meta/vmap_for_range.hpp +84 -0
- package/vendor/include/tlx/meta/vmap_foreach.hpp +63 -0
- package/vendor/include/tlx/meta/vmap_foreach_tuple.hpp +59 -0
- package/vendor/include/tlx/meta/vmap_foreach_tuple_with_index.hpp +62 -0
- package/vendor/include/tlx/meta/vmap_foreach_with_index.hpp +70 -0
- package/vendor/include/tlx/meta.hpp +55 -0
- package/vendor/include/tlx/multi_timer.hpp +148 -0
- package/vendor/include/tlx/port/setenv.hpp +31 -0
- package/vendor/include/tlx/port.hpp +27 -0
- package/vendor/include/tlx/semaphore.hpp +119 -0
- package/vendor/include/tlx/simple_vector.hpp +20 -0
- package/vendor/include/tlx/siphash.hpp +282 -0
- package/vendor/include/tlx/sort/networks/best.hpp +611 -0
- package/vendor/include/tlx/sort/networks/bose_nelson.hpp +412 -0
- package/vendor/include/tlx/sort/networks/bose_nelson_parameter.hpp +507 -0
- package/vendor/include/tlx/sort/networks/cswap.hpp +60 -0
- package/vendor/include/tlx/sort/parallel_mergesort.hpp +398 -0
- package/vendor/include/tlx/sort/strings/insertion_sort.hpp +232 -0
- package/vendor/include/tlx/sort/strings/multikey_quicksort.hpp +185 -0
- package/vendor/include/tlx/sort/strings/parallel_sample_sort.hpp +1647 -0
- package/vendor/include/tlx/sort/strings/radix_sort.hpp +934 -0
- package/vendor/include/tlx/sort/strings/sample_sort_tools.hpp +756 -0
- package/vendor/include/tlx/sort/strings/string_ptr.hpp +426 -0
- package/vendor/include/tlx/sort/strings/string_set.hpp +800 -0
- package/vendor/include/tlx/sort/strings.hpp +329 -0
- package/vendor/include/tlx/sort/strings_parallel.hpp +325 -0
- package/vendor/include/tlx/sort.hpp +29 -0
- package/vendor/include/tlx/stack_allocator.hpp +226 -0
- package/vendor/include/tlx/string/appendline.hpp +35 -0
- package/vendor/include/tlx/string/base64.hpp +87 -0
- package/vendor/include/tlx/string/bitdump.hpp +139 -0
- package/vendor/include/tlx/string/compare_icase.hpp +42 -0
- package/vendor/include/tlx/string/contains.hpp +36 -0
- package/vendor/include/tlx/string/contains_word.hpp +42 -0
- package/vendor/include/tlx/string/ends_with.hpp +79 -0
- package/vendor/include/tlx/string/equal_icase.hpp +42 -0
- package/vendor/include/tlx/string/erase_all.hpp +70 -0
- package/vendor/include/tlx/string/escape_html.hpp +34 -0
- package/vendor/include/tlx/string/escape_uri.hpp +34 -0
- package/vendor/include/tlx/string/expand_environment_variables.hpp +49 -0
- package/vendor/include/tlx/string/extract_between.hpp +40 -0
- package/vendor/include/tlx/string/format_iec_units.hpp +32 -0
- package/vendor/include/tlx/string/format_si_iec_units.hpp +19 -0
- package/vendor/include/tlx/string/format_si_units.hpp +32 -0
- package/vendor/include/tlx/string/hash_djb2.hpp +87 -0
- package/vendor/include/tlx/string/hash_sdbm.hpp +86 -0
- package/vendor/include/tlx/string/hexdump.hpp +154 -0
- package/vendor/include/tlx/string/index_of.hpp +56 -0
- package/vendor/include/tlx/string/join.hpp +65 -0
- package/vendor/include/tlx/string/join_generic.hpp +89 -0
- package/vendor/include/tlx/string/join_quoted.hpp +46 -0
- package/vendor/include/tlx/string/less_icase.hpp +64 -0
- package/vendor/include/tlx/string/levenshtein.hpp +193 -0
- package/vendor/include/tlx/string/pad.hpp +39 -0
- package/vendor/include/tlx/string/parse_si_iec_units.hpp +46 -0
- package/vendor/include/tlx/string/parse_uri.hpp +66 -0
- package/vendor/include/tlx/string/parse_uri_form_data.hpp +136 -0
- package/vendor/include/tlx/string/replace.hpp +141 -0
- package/vendor/include/tlx/string/split.hpp +170 -0
- package/vendor/include/tlx/string/split_quoted.hpp +49 -0
- package/vendor/include/tlx/string/split_view.hpp +218 -0
- package/vendor/include/tlx/string/split_words.hpp +53 -0
- package/vendor/include/tlx/string/ssprintf.hpp +45 -0
- package/vendor/include/tlx/string/ssprintf_generic.hpp +95 -0
- package/vendor/include/tlx/string/starts_with.hpp +44 -0
- package/vendor/include/tlx/string/to_lower.hpp +47 -0
- package/vendor/include/tlx/string/to_upper.hpp +47 -0
- package/vendor/include/tlx/string/trim.hpp +298 -0
- package/vendor/include/tlx/string/union_words.hpp +33 -0
- package/vendor/include/tlx/string/word_wrap.hpp +35 -0
- package/vendor/include/tlx/string.hpp +68 -0
- package/vendor/include/tlx/thread_barrier_mutex.hpp +109 -0
- package/vendor/include/tlx/thread_barrier_spin.hpp +127 -0
- package/vendor/include/tlx/thread_pool.hpp +151 -0
- package/vendor/include/tlx/timestamp.hpp +23 -0
- package/vendor/include/tlx/unused.hpp +28 -0
- package/vendor/include/tlx/vector_free.hpp +30 -0
- package/vendor/include/tlx/version.hpp +49 -0
- package/vendor/include/ttmath/ttmath.h +2881 -0
- package/vendor/include/ttmath/ttmathbig.h +6111 -0
- package/vendor/include/ttmath/ttmathdec.h +419 -0
- package/vendor/include/ttmath/ttmathint.h +1923 -0
- package/vendor/include/ttmath/ttmathmisc.h +250 -0
- package/vendor/include/ttmath/ttmathobjects.h +812 -0
- package/vendor/include/ttmath/ttmathparser.h +2791 -0
- package/vendor/include/ttmath/ttmaththreads.h +252 -0
- package/vendor/include/ttmath/ttmathtypes.h +707 -0
- package/vendor/include/ttmath/ttmathuint.h +4190 -0
- package/vendor/include/ttmath/ttmathuint_noasm.h +1038 -0
- package/vendor/include/ttmath/ttmathuint_x86.h +1620 -0
- package/vendor/include/ttmath/ttmathuint_x86_64.h +1177 -0
- package/vendor/lib/cmake/tlx/tlx-config.cmake +51 -0
- package/vendor/lib/cmake/tlx/tlx-targets-release.cmake +19 -0
- package/vendor/lib/cmake/tlx/tlx-targets.cmake +106 -0
- package/vendor/lib/cmake/tlx/tlx-version.cmake +11 -0
- package/vendor/lib/libnetworkit.dylib +0 -0
- package/vendor/lib/libtlx.a +0 -0
- package/vendor/lib/pkgconfig/networkit.pc +11 -0
- package/vendor/lib/pkgconfig/tlx.pc +11 -0
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* STSP.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 15.06.2019
|
|
5
|
+
* Author: Eugenio Angriman <angrimae@hu-berlin.de>
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DISTANCE_STSP_HPP_
|
|
9
|
+
#define NETWORKIT_DISTANCE_STSP_HPP_
|
|
10
|
+
|
|
11
|
+
#include <algorithm>
|
|
12
|
+
#include <unordered_map>
|
|
13
|
+
#include <vector>
|
|
14
|
+
|
|
15
|
+
#include <networkit/Globals.hpp>
|
|
16
|
+
#include <networkit/auxiliary/Log.hpp>
|
|
17
|
+
#include <networkit/base/Algorithm.hpp>
|
|
18
|
+
#include <networkit/graph/Graph.hpp>
|
|
19
|
+
|
|
20
|
+
namespace NetworKit {
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* @ingroup distance
|
|
24
|
+
* Abstract base class for source-target shortest path algorithms.
|
|
25
|
+
*/
|
|
26
|
+
class STSP : public Algorithm {
|
|
27
|
+
|
|
28
|
+
public:
|
|
29
|
+
/**
|
|
30
|
+
* Creates the STSP class for a graph @a G, source node @a source, and
|
|
31
|
+
* target node @a target.
|
|
32
|
+
*
|
|
33
|
+
* @param G The graph.
|
|
34
|
+
* @param source The source node.
|
|
35
|
+
* @param target The target node.
|
|
36
|
+
* @param storePred If true, the algorithm will also store the predecessors
|
|
37
|
+
* and reconstruct a shortest path from @a source and @a target.
|
|
38
|
+
*/
|
|
39
|
+
STSP(const Graph &G, node source, node target, bool storePred = true)
|
|
40
|
+
: G(&G), source(source), target(target), storePred(storePred) {
|
|
41
|
+
if (!G.hasNode(source))
|
|
42
|
+
throw std::runtime_error("Error: source node not in the graph!");
|
|
43
|
+
if (!G.hasNode(target))
|
|
44
|
+
throw std::runtime_error("Error: target node not in the graph!");
|
|
45
|
+
if (source == target)
|
|
46
|
+
WARN("Source and target nodes are equal!");
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Creates the STSP class for a graph @a G, source node @a source, and
|
|
51
|
+
* multiple target nodes.
|
|
52
|
+
*
|
|
53
|
+
* @param G The graph.
|
|
54
|
+
* @param source The source node.
|
|
55
|
+
* @param targetsFirst,targetsLast Range of target nodes.
|
|
56
|
+
*/
|
|
57
|
+
template <class InputIt>
|
|
58
|
+
STSP(const Graph &G, node source, InputIt targetsFirst, InputIt targetsLast)
|
|
59
|
+
: G(&G), source(source), targets(targetsFirst, targetsLast), storePred(false) {
|
|
60
|
+
if (!G.hasNode(source))
|
|
61
|
+
throw std::runtime_error("Error: source node not in the graph!");
|
|
62
|
+
if (!std::all_of(targetsFirst, targetsLast, [&G](node u) { return G.hasNode(u); }))
|
|
63
|
+
throw std::runtime_error("Error: target node not in the graph!");
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Returns a shortest path from the source node to the target node (without
|
|
68
|
+
* including them). Note: the shortest path can be constructed only if the
|
|
69
|
+
* algorithm is executed with @a storePred set to true.
|
|
70
|
+
*
|
|
71
|
+
* @return A shortest path from the @a source to @a target.
|
|
72
|
+
*/
|
|
73
|
+
virtual std::vector<node> getPath() const {
|
|
74
|
+
checkStorePredecessors();
|
|
75
|
+
assureFinished();
|
|
76
|
+
return path;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Returns the predecessor nodes from the @a target to the source. Note:
|
|
81
|
+
* predecessors are stored only if the algorithm is executed with @a
|
|
82
|
+
* storePred set to true.
|
|
83
|
+
*
|
|
84
|
+
* @return The list of predecessors from @a target to @a source.
|
|
85
|
+
*/
|
|
86
|
+
const std::vector<node> &getPredecessors() const {
|
|
87
|
+
checkStorePredecessors();
|
|
88
|
+
assureFinished();
|
|
89
|
+
return pred;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/**
|
|
93
|
+
* If the target is a single node: returns the distance from the source node to the target
|
|
94
|
+
* node.
|
|
95
|
+
* @return The distance from source to the target node.
|
|
96
|
+
*/
|
|
97
|
+
edgeweight getDistance() const {
|
|
98
|
+
assureFinished();
|
|
99
|
+
return distance;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* In case of multiple target nodes: returns the distance from the source node to the target
|
|
104
|
+
* nodes.
|
|
105
|
+
* @return Distances from the source to the target nodes.
|
|
106
|
+
*/
|
|
107
|
+
const std::vector<edgeweight> &getDistances() const {
|
|
108
|
+
assureFinished();
|
|
109
|
+
return distances;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* Sets the source node.
|
|
114
|
+
*
|
|
115
|
+
* @param newSource The new source node.
|
|
116
|
+
*/
|
|
117
|
+
void setSource(node newSource) {
|
|
118
|
+
assert(G->hasNode(newSource));
|
|
119
|
+
source = newSource;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Sets the target node.
|
|
124
|
+
*
|
|
125
|
+
* @param newTarget The new target node.
|
|
126
|
+
*/
|
|
127
|
+
void setTarget(node newTarget) {
|
|
128
|
+
assert(G->hasNode(newTarget));
|
|
129
|
+
target = newTarget;
|
|
130
|
+
targets.clear();
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Sets the target nodes.
|
|
135
|
+
*
|
|
136
|
+
* @param targetsFirst,targetsLast Range of target nodes.
|
|
137
|
+
*/
|
|
138
|
+
template <class InputIt>
|
|
139
|
+
void setTargets(InputIt targetsFirst, InputIt targetsLast) {
|
|
140
|
+
assert(std::all_of(targetsFirst, targetsLast, [&](auto u) { return G->hasNode(u); }));
|
|
141
|
+
targets.assign(targetsFirst, targetsLast);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Returns the <node, index> map from target nodes to their index in the vector
|
|
146
|
+
* returned by STSP::getDistances().
|
|
147
|
+
*
|
|
148
|
+
* @return Map from target nodes to their index in the vector returned by STSP::getDistances().
|
|
149
|
+
*/
|
|
150
|
+
const std::unordered_map<node, index> &getTargetIndexMap() const {
|
|
151
|
+
assureFinished();
|
|
152
|
+
return targetIdx;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
protected:
|
|
156
|
+
const Graph *G;
|
|
157
|
+
node source = none, target = none;
|
|
158
|
+
std::vector<node> targets;
|
|
159
|
+
const bool storePred;
|
|
160
|
+
std::vector<node> pred, path;
|
|
161
|
+
|
|
162
|
+
edgeweight distance;
|
|
163
|
+
std::vector<edgeweight> distances;
|
|
164
|
+
std::unordered_map<node, index> targetIdx;
|
|
165
|
+
|
|
166
|
+
// Builds a source-target shortest path using the predecessors
|
|
167
|
+
void buildPath();
|
|
168
|
+
|
|
169
|
+
void checkStorePredecessors() const {
|
|
170
|
+
if (!storePred)
|
|
171
|
+
WARN("Predecessors not stored.");
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
void init() {
|
|
175
|
+
hasRun = false;
|
|
176
|
+
if (storePred)
|
|
177
|
+
pred.resize(G->upperNodeIdBound());
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
|
|
181
|
+
inline void STSP::buildPath() {
|
|
182
|
+
path.clear();
|
|
183
|
+
node t = target;
|
|
184
|
+
while (pred[t] != source) {
|
|
185
|
+
path.push_back(pred[t]);
|
|
186
|
+
t = pred[t];
|
|
187
|
+
}
|
|
188
|
+
std::ranges::reverse(path);
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
} // namespace NetworKit
|
|
192
|
+
|
|
193
|
+
#endif // NETWORKIT_DISTANCE_STSP_HPP_
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Volume.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: July 7, 2018
|
|
5
|
+
* Author: Franz-Benjamin Mocnik <mail@mocnik-science.net>
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DISTANCE_VOLUME_HPP_
|
|
9
|
+
#define NETWORKIT_DISTANCE_VOLUME_HPP_
|
|
10
|
+
|
|
11
|
+
#include <unordered_map>
|
|
12
|
+
|
|
13
|
+
#include <networkit/graph/Graph.hpp>
|
|
14
|
+
|
|
15
|
+
namespace NetworKit {
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @ingroup volume
|
|
19
|
+
*/
|
|
20
|
+
class Volume {
|
|
21
|
+
private:
|
|
22
|
+
/**
|
|
23
|
+
* For a given node n, the nodes within distance r are returned together with
|
|
24
|
+
* their distance to node n.
|
|
25
|
+
*/
|
|
26
|
+
static std::unordered_map<node, double> nodesWithinDistance(const Graph &G, double r, node n);
|
|
27
|
+
|
|
28
|
+
public:
|
|
29
|
+
/**
|
|
30
|
+
* Number of nodes within a given radius; average for many nodes
|
|
31
|
+
*
|
|
32
|
+
* Please find further information about the volume and its meaning in the
|
|
33
|
+
* following publication:
|
|
34
|
+
*
|
|
35
|
+
* Franz-Benjamin Mocnik: "The Polynomial Volume Law of Complex Networks in
|
|
36
|
+
* the Context of Local and Global Optimization", Scientific Reports 8(11274)
|
|
37
|
+
* 2018. doi: 10.1038/s41598-018-29131-0
|
|
38
|
+
*
|
|
39
|
+
* @param G the graph
|
|
40
|
+
* @param r the radius
|
|
41
|
+
* @param samples the number of samples
|
|
42
|
+
*
|
|
43
|
+
**/
|
|
44
|
+
static double volume(const Graph &G, double r, count samples);
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Number of nodes within different given radii; average for many nodes
|
|
48
|
+
*
|
|
49
|
+
* Please find further information about the volume and its meaning in the
|
|
50
|
+
* following publication:
|
|
51
|
+
*
|
|
52
|
+
* Franz-Benjamin Mocnik: "The Polynomial Volume Law of Complex Networks in
|
|
53
|
+
* the Context of Local and Global Optimization", Scientific Reports 8(11274)
|
|
54
|
+
* 2018. doi: 10.1038/s41598-018-29131-0
|
|
55
|
+
*
|
|
56
|
+
* @param G the graph
|
|
57
|
+
* @param rs the radii
|
|
58
|
+
* @param samples the number of samples
|
|
59
|
+
*
|
|
60
|
+
**/
|
|
61
|
+
static std::vector<double> volume(const Graph &G, std::vector<double> rs, count samples);
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
} /* namespace NetworKit */
|
|
65
|
+
|
|
66
|
+
#endif // NETWORKIT_DISTANCE_VOLUME_HPP_
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* DGSStreamParser.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 23.12.2013
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_DGS_STREAM_PARSER_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_DGS_STREAM_PARSER_HPP_
|
|
10
|
+
|
|
11
|
+
#include <fstream>
|
|
12
|
+
#include <map>
|
|
13
|
+
#include <string>
|
|
14
|
+
#include <vector>
|
|
15
|
+
|
|
16
|
+
#include <networkit/dynamics/GraphEvent.hpp>
|
|
17
|
+
|
|
18
|
+
namespace NetworKit {
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @ingroup dynamics
|
|
22
|
+
*/
|
|
23
|
+
class DGSStreamParser final {
|
|
24
|
+
|
|
25
|
+
public:
|
|
26
|
+
DGSStreamParser(std::string_view path, bool mapped = true, node baseIndex = 0);
|
|
27
|
+
|
|
28
|
+
std::vector<GraphEvent> getStream();
|
|
29
|
+
|
|
30
|
+
private:
|
|
31
|
+
std::ifstream dgsFile;
|
|
32
|
+
bool mapped;
|
|
33
|
+
std::map<std::string, node> key2id;
|
|
34
|
+
node baseIndex;
|
|
35
|
+
node nextNode;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
} /* namespace NetworKit */
|
|
39
|
+
|
|
40
|
+
#endif // NETWORKIT_DYNAMICS_DGS_STREAM_PARSER_HPP_
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* DGSWriter.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 14.01.2014
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_DGS_WRITER_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_DGS_WRITER_HPP_
|
|
10
|
+
|
|
11
|
+
#include <string>
|
|
12
|
+
#include <vector>
|
|
13
|
+
|
|
14
|
+
#include <networkit/dynamics/GraphEvent.hpp>
|
|
15
|
+
|
|
16
|
+
namespace NetworKit {
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* @ingroup dynamics
|
|
20
|
+
*/
|
|
21
|
+
class DGSWriter final {
|
|
22
|
+
public:
|
|
23
|
+
DGSWriter() = default;
|
|
24
|
+
|
|
25
|
+
void write(std::vector<GraphEvent> &stream, std::string_view path);
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
} /* namespace NetworKit */
|
|
29
|
+
|
|
30
|
+
#endif // NETWORKIT_DYNAMICS_DGS_WRITER_HPP_
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
#ifndef NETWORKIT_DYNAMICS_GRAPH_DIFFERENCE_HPP_
|
|
2
|
+
#define NETWORKIT_DYNAMICS_GRAPH_DIFFERENCE_HPP_
|
|
3
|
+
|
|
4
|
+
#include <networkit/base/Algorithm.hpp>
|
|
5
|
+
#include <networkit/dynamics/GraphEvent.hpp>
|
|
6
|
+
#include <networkit/graph/Graph.hpp>
|
|
7
|
+
|
|
8
|
+
namespace NetworKit {
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Calculate the edge difference between two graphs.
|
|
12
|
+
*
|
|
13
|
+
* This calculates which graph edge additions or edge removals are
|
|
14
|
+
* necessary to transform one given graph into another given graph.
|
|
15
|
+
*
|
|
16
|
+
* Both graphs need to have the same node set, directed graphs are not
|
|
17
|
+
* supported currently.
|
|
18
|
+
*
|
|
19
|
+
* Note that edge weight differences are not detected but edge
|
|
20
|
+
* addition events set the correct edge weight.
|
|
21
|
+
*/
|
|
22
|
+
class GraphDifference final : public Algorithm {
|
|
23
|
+
public:
|
|
24
|
+
/**
|
|
25
|
+
* Construct the edge edit difference with two graphs to compare.
|
|
26
|
+
*
|
|
27
|
+
* @param G1 The first graph to compare.
|
|
28
|
+
* @param G2 The second graph to compare.
|
|
29
|
+
*/
|
|
30
|
+
GraphDifference(const Graph &G1, const Graph &G2);
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Execute the algorithm and compute the difference.
|
|
34
|
+
*/
|
|
35
|
+
void run() override;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Get the required edits.
|
|
39
|
+
*
|
|
40
|
+
* @return A vector of graph events.
|
|
41
|
+
*/
|
|
42
|
+
const std::vector<GraphEvent> &getEdits() const;
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Get the required number of edits.
|
|
46
|
+
*
|
|
47
|
+
* This is only the number of actual changes.
|
|
48
|
+
* In order to get correct node ids, more edits might be generated.
|
|
49
|
+
*
|
|
50
|
+
* @return The number of edits.
|
|
51
|
+
*/
|
|
52
|
+
count getNumberOfEdits() const;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Get the required number of node additions.
|
|
56
|
+
*
|
|
57
|
+
* @return The number of node additions.
|
|
58
|
+
*/
|
|
59
|
+
count getNumberOfNodeAdditions() const;
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* Get the required number of node removals.
|
|
63
|
+
*
|
|
64
|
+
* @return The number of node removals.
|
|
65
|
+
*/
|
|
66
|
+
count getNumberOfNodeRemovals() const;
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Get the required number of node restorations.
|
|
70
|
+
*
|
|
71
|
+
* @return The number of node restorations.
|
|
72
|
+
*/
|
|
73
|
+
count getNumberOfNodeRestorations() const;
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Get the required number of edge additions.
|
|
77
|
+
*
|
|
78
|
+
* @return The number of edge additions.
|
|
79
|
+
*/
|
|
80
|
+
count getNumberOfEdgeAdditions() const;
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Get the required number of edge removals.
|
|
84
|
+
*
|
|
85
|
+
* @return The number of edge removals.
|
|
86
|
+
*/
|
|
87
|
+
count getNumberOfEdgeRemovals() const;
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Get the required number of edge weight updates.
|
|
91
|
+
*
|
|
92
|
+
* @return The number of edge weight updates.
|
|
93
|
+
*/
|
|
94
|
+
count getNumberOfEdgeWeightUpdates() const;
|
|
95
|
+
|
|
96
|
+
private:
|
|
97
|
+
const Graph *G1, *G2;
|
|
98
|
+
std::vector<GraphEvent> edits;
|
|
99
|
+
count numEdits;
|
|
100
|
+
count numNodeAdditions;
|
|
101
|
+
count numNodeRemovals;
|
|
102
|
+
count numNodeRestorations;
|
|
103
|
+
count numEdgeAdditions;
|
|
104
|
+
count numEdgeRemovals;
|
|
105
|
+
count numWeightUpdates;
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
} // namespace NetworKit
|
|
109
|
+
|
|
110
|
+
#endif // NETWORKIT_DYNAMICS_GRAPH_DIFFERENCE_HPP_
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* GraphEvent.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 02.04.2013
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_GRAPH_EVENT_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_GRAPH_EVENT_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/graph/Graph.hpp>
|
|
12
|
+
|
|
13
|
+
namespace NetworKit {
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @ingroup dynamics
|
|
17
|
+
*/
|
|
18
|
+
class GraphEvent final {
|
|
19
|
+
|
|
20
|
+
public:
|
|
21
|
+
enum Type {
|
|
22
|
+
NODE_ADDITION,
|
|
23
|
+
NODE_REMOVAL,
|
|
24
|
+
NODE_RESTORATION,
|
|
25
|
+
EDGE_ADDITION,
|
|
26
|
+
EDGE_REMOVAL,
|
|
27
|
+
EDGE_WEIGHT_UPDATE,
|
|
28
|
+
EDGE_WEIGHT_INCREMENT,
|
|
29
|
+
TIME_STEP
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
Type type; //!< type of graph event
|
|
33
|
+
node u; //!< first node parameter
|
|
34
|
+
node v; //!< second node parameter
|
|
35
|
+
edgeweight w; //!< edge weight parameter
|
|
36
|
+
|
|
37
|
+
GraphEvent() = default;
|
|
38
|
+
|
|
39
|
+
GraphEvent(Type type, node u = none, node v = none, edgeweight w = defaultEdgeWeight);
|
|
40
|
+
|
|
41
|
+
bool operator==(const GraphEvent &rhs) const noexcept;
|
|
42
|
+
bool operator!=(const GraphEvent &rhs) const noexcept;
|
|
43
|
+
friend bool operator<(const GraphEvent &a, const GraphEvent &b) noexcept;
|
|
44
|
+
friend bool operator>(const GraphEvent &a, const GraphEvent &b) noexcept;
|
|
45
|
+
bool operator<=(const GraphEvent &rhs) const noexcept;
|
|
46
|
+
bool operator>=(const GraphEvent &rhs) const noexcept;
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Return string representation.
|
|
50
|
+
*/
|
|
51
|
+
std::string toString() const;
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
} /* namespace NetworKit */
|
|
55
|
+
#endif // NETWORKIT_DYNAMICS_GRAPH_EVENT_HPP_
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* GraphEventHandler.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 02.04.2013
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_GRAPH_EVENT_HANDLER_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_GRAPH_EVENT_HANDLER_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/graph/Graph.hpp>
|
|
12
|
+
|
|
13
|
+
namespace NetworKit {
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @ingroup dynamics
|
|
17
|
+
*/
|
|
18
|
+
class GraphEventHandler {
|
|
19
|
+
|
|
20
|
+
public:
|
|
21
|
+
virtual void onNodeAddition(node u) = 0;
|
|
22
|
+
|
|
23
|
+
virtual void onNodeRemoval(node u) = 0;
|
|
24
|
+
|
|
25
|
+
virtual void onNodeRestoration(node u) = 0;
|
|
26
|
+
|
|
27
|
+
virtual void onEdgeAddition(node u, node v, edgeweight w = 1.0) = 0;
|
|
28
|
+
|
|
29
|
+
virtual void onEdgeRemoval(node u, node v, edgeweight w = 1.0) = 0;
|
|
30
|
+
|
|
31
|
+
virtual void onWeightUpdate(node u, node v, edgeweight wOld, edgeweight wNew) = 0;
|
|
32
|
+
|
|
33
|
+
virtual void onWeightIncrement(node u, node v, edgeweight wOld, edgeweight delta) = 0;
|
|
34
|
+
|
|
35
|
+
virtual void onTimeStep() = 0;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
} /* namespace NetworKit */
|
|
39
|
+
#endif // NETWORKIT_DYNAMICS_GRAPH_EVENT_HANDLER_HPP_
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* GraphEventProxy.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 03.04.2013
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_GRAPH_EVENT_PROXY_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_GRAPH_EVENT_PROXY_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/dynamics/GraphEventHandler.hpp>
|
|
12
|
+
#include <networkit/graph/Graph.hpp>
|
|
13
|
+
#include <networkit/graph/GraphW.hpp>
|
|
14
|
+
|
|
15
|
+
namespace NetworKit {
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @ingroup dynamics
|
|
19
|
+
* This class enables the observer pattern for dynamic graphs: It has the same modifiers as a Graph
|
|
20
|
+
* object. When these modifiers are called, they are also called on the underlying graphs. Also, all
|
|
21
|
+
* registered observers (type GraphEventHandler) are notified.
|
|
22
|
+
*/
|
|
23
|
+
class GraphEventProxy final {
|
|
24
|
+
|
|
25
|
+
private:
|
|
26
|
+
std::vector<GraphEventHandler *> observers;
|
|
27
|
+
|
|
28
|
+
public:
|
|
29
|
+
GraphW *G;
|
|
30
|
+
|
|
31
|
+
GraphEventProxy(); // nullary constructor needed for python interface
|
|
32
|
+
|
|
33
|
+
GraphEventProxy(GraphW &G);
|
|
34
|
+
|
|
35
|
+
void registerObserver(GraphEventHandler *observer);
|
|
36
|
+
|
|
37
|
+
node addNode();
|
|
38
|
+
|
|
39
|
+
void removeNode(node u);
|
|
40
|
+
|
|
41
|
+
void restoreNode(node u);
|
|
42
|
+
|
|
43
|
+
void addEdge(node u, node v, edgeweight weight = defaultEdgeWeight);
|
|
44
|
+
|
|
45
|
+
void removeEdge(node u, node v);
|
|
46
|
+
|
|
47
|
+
void setWeight(node u, node v, edgeweight w);
|
|
48
|
+
|
|
49
|
+
void incrementWeight(node u, node v, edgeweight delta);
|
|
50
|
+
|
|
51
|
+
void timeStep();
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
} /* namespace NetworKit */
|
|
55
|
+
#endif // NETWORKIT_DYNAMICS_GRAPH_EVENT_PROXY_HPP_
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* GraphUpdater.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 27.12.2013
|
|
5
|
+
* Author: cls
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_DYNAMICS_GRAPH_UPDATER_HPP_
|
|
9
|
+
#define NETWORKIT_DYNAMICS_GRAPH_UPDATER_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/dynamics/GraphEvent.hpp>
|
|
12
|
+
#include <networkit/graph/GraphW.hpp>
|
|
13
|
+
|
|
14
|
+
namespace NetworKit {
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @ingroup dynamics
|
|
18
|
+
*/
|
|
19
|
+
class GraphUpdater final {
|
|
20
|
+
|
|
21
|
+
public:
|
|
22
|
+
GraphUpdater(GraphW &G);
|
|
23
|
+
|
|
24
|
+
void update(const std::vector<GraphEvent> &stream);
|
|
25
|
+
|
|
26
|
+
const std::vector<std::pair<count, count>> &getSizeTimeline() const;
|
|
27
|
+
|
|
28
|
+
static bool compare(GraphEvent a, GraphEvent b);
|
|
29
|
+
static bool equal(GraphEvent a, GraphEvent b);
|
|
30
|
+
|
|
31
|
+
private:
|
|
32
|
+
GraphW *G;
|
|
33
|
+
std::vector<std::pair<count, count>> size;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
} /* namespace NetworKit */
|
|
37
|
+
|
|
38
|
+
#endif // NETWORKIT_DYNAMICS_GRAPH_UPDATER_HPP_
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* ChibaNishizekiQuadrangleEdgeScore.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 18.11.2014
|
|
5
|
+
* Author: Michael Hamann, Gerd Lindner
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_QUADRANGLE_EDGE_SCORE_HPP_
|
|
9
|
+
#define NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_QUADRANGLE_EDGE_SCORE_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/edgescores/EdgeScore.hpp>
|
|
12
|
+
|
|
13
|
+
namespace NetworKit {
|
|
14
|
+
|
|
15
|
+
class ChibaNishizekiQuadrangleEdgeScore final : public EdgeScore<count> {
|
|
16
|
+
|
|
17
|
+
public:
|
|
18
|
+
ChibaNishizekiQuadrangleEdgeScore(const Graph &G);
|
|
19
|
+
count score(edgeid eid) override;
|
|
20
|
+
count score(node u, node v) override;
|
|
21
|
+
void run() override;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
} // namespace NetworKit
|
|
25
|
+
|
|
26
|
+
#endif // NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_QUADRANGLE_EDGE_SCORE_HPP_
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* ChibaNishizekiTriangleEdgeScore.hpp
|
|
3
|
+
*
|
|
4
|
+
* Created on: 22.05.2014
|
|
5
|
+
* Author: Gerd Lindner
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
#ifndef NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_TRIANGLE_EDGE_SCORE_HPP_
|
|
9
|
+
#define NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_TRIANGLE_EDGE_SCORE_HPP_
|
|
10
|
+
|
|
11
|
+
#include <networkit/edgescores/EdgeScore.hpp>
|
|
12
|
+
#include <networkit/graph/Graph.hpp>
|
|
13
|
+
|
|
14
|
+
namespace NetworKit {
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* An implementation of the triangle counting algorithm by Chiba/Nishizeki.
|
|
18
|
+
*
|
|
19
|
+
* @deprecated Use TriangleEdgeScore instead which is parallelized and has a similar performance
|
|
20
|
+
* even in the sequential case.
|
|
21
|
+
*/
|
|
22
|
+
class ChibaNishizekiTriangleEdgeScore final : public EdgeScore<count> {
|
|
23
|
+
|
|
24
|
+
public:
|
|
25
|
+
ChibaNishizekiTriangleEdgeScore(const Graph &G);
|
|
26
|
+
count score(edgeid eid) override;
|
|
27
|
+
count score(node u, node v) override;
|
|
28
|
+
void run() override;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
} /* namespace NetworKit */
|
|
32
|
+
|
|
33
|
+
#endif // NETWORKIT_EDGESCORES_CHIBA_NISHIZEKI_TRIANGLE_EDGE_SCORE_HPP_
|