@ladybugmem/icebug 0.1.0 → 0.1.2
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/binding.gyp +32 -10
- package/lib/index.js +23 -11
- package/package.json +9 -15
- package/prebuilds/darwin-arm64/icebug.node +0 -0
- package/{vendor/lib → prebuilds/darwin-arm64}/libnetworkit.dylib +0 -0
- package/prebuilds/linux-x64/icebug.node +0 -0
- package/prebuilds/linux-x64/libnetworkit.so +0 -0
- package/scripts/download-icebug.sh +92 -0
- package/build/Release/.deps/Release/icebug.node.d +0 -1
- package/build/Release/.deps/Release/obj.target/icebug/src/addon.o.d +0 -291
- package/build/Release/icebug.node +0 -0
- package/build/Release/obj.target/icebug/src/addon.o +0 -0
- package/vendor/include/networkit/GlobalState.hpp +0 -86
- package/vendor/include/networkit/Globals.hpp +0 -41
- package/vendor/include/networkit/algebraic/AlgebraicGlobals.hpp +0 -27
- package/vendor/include/networkit/algebraic/CSRGeneralMatrix.hpp +0 -1292
- package/vendor/include/networkit/algebraic/CSRMatrix.hpp +0 -11
- package/vendor/include/networkit/algebraic/DenseMatrix.hpp +0 -537
- package/vendor/include/networkit/algebraic/DynamicMatrix.hpp +0 -514
- package/vendor/include/networkit/algebraic/GraphBLAS.hpp +0 -323
- package/vendor/include/networkit/algebraic/MatrixTools.hpp +0 -156
- package/vendor/include/networkit/algebraic/Semirings.hpp +0 -171
- package/vendor/include/networkit/algebraic/SparseAccumulator.hpp +0 -111
- package/vendor/include/networkit/algebraic/Vector.hpp +0 -371
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicBFS.hpp +0 -72
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicBellmanFord.hpp +0 -88
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicMatchingCoarsening.hpp +0 -96
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicPageRank.hpp +0 -145
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicSpanningEdgeCentrality.hpp +0 -122
- package/vendor/include/networkit/algebraic/algorithms/AlgebraicTriangleCounting.hpp +0 -76
- package/vendor/include/networkit/auxiliary/AlignedAllocator.hpp +0 -113
- package/vendor/include/networkit/auxiliary/ArrayTools.hpp +0 -85
- package/vendor/include/networkit/auxiliary/BloomFilter.hpp +0 -70
- package/vendor/include/networkit/auxiliary/BucketPQ.hpp +0 -142
- package/vendor/include/networkit/auxiliary/Enforce.hpp +0 -117
- package/vendor/include/networkit/auxiliary/FunctionTraits.hpp +0 -74
- package/vendor/include/networkit/auxiliary/HashUtils.hpp +0 -28
- package/vendor/include/networkit/auxiliary/IncrementalUniformRandomSelector.hpp +0 -52
- package/vendor/include/networkit/auxiliary/Log.hpp +0 -119
- package/vendor/include/networkit/auxiliary/MissingMath.hpp +0 -48
- package/vendor/include/networkit/auxiliary/Multiprecision.hpp +0 -17
- package/vendor/include/networkit/auxiliary/NumberParsing.hpp +0 -307
- package/vendor/include/networkit/auxiliary/NumericTools.hpp +0 -57
- package/vendor/include/networkit/auxiliary/Parallel.hpp +0 -56
- package/vendor/include/networkit/auxiliary/Parallelism.hpp +0 -33
- package/vendor/include/networkit/auxiliary/PrioQueue.hpp +0 -252
- package/vendor/include/networkit/auxiliary/Random.hpp +0 -122
- package/vendor/include/networkit/auxiliary/SetIntersector.hpp +0 -72
- package/vendor/include/networkit/auxiliary/SignalHandling.hpp +0 -39
- package/vendor/include/networkit/auxiliary/SortedList.hpp +0 -128
- package/vendor/include/networkit/auxiliary/SparseVector.hpp +0 -215
- package/vendor/include/networkit/auxiliary/SpinLock.hpp +0 -23
- package/vendor/include/networkit/auxiliary/StringBuilder.hpp +0 -322
- package/vendor/include/networkit/auxiliary/StringTools.hpp +0 -76
- package/vendor/include/networkit/auxiliary/TemplateUtils.hpp +0 -76
- package/vendor/include/networkit/auxiliary/Timer.hpp +0 -145
- package/vendor/include/networkit/auxiliary/VectorComparator.hpp +0 -32
- package/vendor/include/networkit/base/Algorithm.hpp +0 -41
- package/vendor/include/networkit/base/DynAlgorithm.hpp +0 -31
- package/vendor/include/networkit/centrality/ApproxBetweenness.hpp +0 -62
- package/vendor/include/networkit/centrality/ApproxCloseness.hpp +0 -136
- package/vendor/include/networkit/centrality/ApproxElectricalCloseness.hpp +0 -156
- package/vendor/include/networkit/centrality/ApproxGroupBetweenness.hpp +0 -124
- package/vendor/include/networkit/centrality/ApproxSpanningEdge.hpp +0 -84
- package/vendor/include/networkit/centrality/Betweenness.hpp +0 -47
- package/vendor/include/networkit/centrality/Centrality.hpp +0 -98
- package/vendor/include/networkit/centrality/Closeness.hpp +0 -107
- package/vendor/include/networkit/centrality/ComplexPaths.hpp +0 -113
- package/vendor/include/networkit/centrality/CoreDecomposition.hpp +0 -161
- package/vendor/include/networkit/centrality/DegreeCentrality.hpp +0 -55
- package/vendor/include/networkit/centrality/DynApproxBetweenness.hpp +0 -95
- package/vendor/include/networkit/centrality/DynBetweenness.hpp +0 -99
- package/vendor/include/networkit/centrality/DynBetweennessOneNode.hpp +0 -98
- package/vendor/include/networkit/centrality/DynKatzCentrality.hpp +0 -115
- package/vendor/include/networkit/centrality/DynTopHarmonicCloseness.hpp +0 -223
- package/vendor/include/networkit/centrality/EigenvectorCentrality.hpp +0 -41
- package/vendor/include/networkit/centrality/EstimateBetweenness.hpp +0 -51
- package/vendor/include/networkit/centrality/ForestCentrality.hpp +0 -112
- package/vendor/include/networkit/centrality/GedWalk.hpp +0 -225
- package/vendor/include/networkit/centrality/GroupCloseness.hpp +0 -115
- package/vendor/include/networkit/centrality/GroupClosenessGrowShrink.hpp +0 -78
- package/vendor/include/networkit/centrality/GroupClosenessLocalSearch.hpp +0 -77
- package/vendor/include/networkit/centrality/GroupClosenessLocalSwaps.hpp +0 -106
- package/vendor/include/networkit/centrality/GroupDegree.hpp +0 -155
- package/vendor/include/networkit/centrality/GroupHarmonicCloseness.hpp +0 -83
- package/vendor/include/networkit/centrality/HarmonicCloseness.hpp +0 -48
- package/vendor/include/networkit/centrality/KPathCentrality.hpp +0 -52
- package/vendor/include/networkit/centrality/KadabraBetweenness.hpp +0 -242
- package/vendor/include/networkit/centrality/KatzCentrality.hpp +0 -62
- package/vendor/include/networkit/centrality/LaplacianCentrality.hpp +0 -44
- package/vendor/include/networkit/centrality/LocalClusteringCoefficient.hpp +0 -60
- package/vendor/include/networkit/centrality/LocalPartitionCoverage.hpp +0 -43
- package/vendor/include/networkit/centrality/LocalSquareClusteringCoefficient.hpp +0 -42
- package/vendor/include/networkit/centrality/PageRank.hpp +0 -101
- package/vendor/include/networkit/centrality/PermanenceCentrality.hpp +0 -48
- package/vendor/include/networkit/centrality/Sfigality.hpp +0 -45
- package/vendor/include/networkit/centrality/SpanningEdgeCentrality.hpp +0 -86
- package/vendor/include/networkit/centrality/TopCloseness.hpp +0 -136
- package/vendor/include/networkit/centrality/TopHarmonicCloseness.hpp +0 -151
- package/vendor/include/networkit/clique/MaximalCliques.hpp +0 -83
- package/vendor/include/networkit/coarsening/ClusteringProjector.hpp +0 -59
- package/vendor/include/networkit/coarsening/CoarsenedGraphView.hpp +0 -156
- package/vendor/include/networkit/coarsening/GraphCoarsening.hpp +0 -57
- package/vendor/include/networkit/coarsening/MatchingCoarsening.hpp +0 -43
- package/vendor/include/networkit/coarsening/ParallelPartitionCoarsening.hpp +0 -33
- package/vendor/include/networkit/coarsening/ParallelPartitionCoarseningView.hpp +0 -62
- package/vendor/include/networkit/community/AdjustedRandMeasure.hpp +0 -31
- package/vendor/include/networkit/community/ClusteringGenerator.hpp +0 -75
- package/vendor/include/networkit/community/CommunityDetectionAlgorithm.hpp +0 -58
- package/vendor/include/networkit/community/Conductance.hpp +0 -32
- package/vendor/include/networkit/community/CoverF1Similarity.hpp +0 -53
- package/vendor/include/networkit/community/CoverHubDominance.hpp +0 -38
- package/vendor/include/networkit/community/Coverage.hpp +0 -25
- package/vendor/include/networkit/community/CutClustering.hpp +0 -62
- package/vendor/include/networkit/community/DissimilarityMeasure.hpp +0 -31
- package/vendor/include/networkit/community/DynamicNMIDistance.hpp +0 -44
- package/vendor/include/networkit/community/EdgeCut.hpp +0 -24
- package/vendor/include/networkit/community/GraphClusteringTools.hpp +0 -103
- package/vendor/include/networkit/community/GraphStructuralRandMeasure.hpp +0 -28
- package/vendor/include/networkit/community/HubDominance.hpp +0 -46
- package/vendor/include/networkit/community/IntrapartitionDensity.hpp +0 -44
- package/vendor/include/networkit/community/IsolatedInterpartitionConductance.hpp +0 -40
- package/vendor/include/networkit/community/IsolatedInterpartitionExpansion.hpp +0 -40
- package/vendor/include/networkit/community/JaccardMeasure.hpp +0 -25
- package/vendor/include/networkit/community/LFM.hpp +0 -49
- package/vendor/include/networkit/community/LPDegreeOrdered.hpp +0 -48
- package/vendor/include/networkit/community/LocalCommunityEvaluation.hpp +0 -100
- package/vendor/include/networkit/community/LocalCoverEvaluation.hpp +0 -31
- package/vendor/include/networkit/community/LocalPartitionEvaluation.hpp +0 -31
- package/vendor/include/networkit/community/LouvainMapEquation.hpp +0 -135
- package/vendor/include/networkit/community/Modularity.hpp +0 -54
- package/vendor/include/networkit/community/NMIDistance.hpp +0 -28
- package/vendor/include/networkit/community/NodeStructuralRandMeasure.hpp +0 -27
- package/vendor/include/networkit/community/OverlappingCommunityDetectionAlgorithm.hpp +0 -51
- package/vendor/include/networkit/community/OverlappingNMIDistance.hpp +0 -175
- package/vendor/include/networkit/community/PLM.hpp +0 -89
- package/vendor/include/networkit/community/PLP.hpp +0 -83
- package/vendor/include/networkit/community/ParallelAgglomerativeClusterer.hpp +0 -37
- package/vendor/include/networkit/community/ParallelLeiden.hpp +0 -96
- package/vendor/include/networkit/community/ParallelLeidenView.hpp +0 -138
- package/vendor/include/networkit/community/PartitionFragmentation.hpp +0 -30
- package/vendor/include/networkit/community/PartitionHubDominance.hpp +0 -37
- package/vendor/include/networkit/community/PartitionIntersection.hpp +0 -25
- package/vendor/include/networkit/community/QualityMeasure.hpp +0 -27
- package/vendor/include/networkit/community/SampledGraphStructuralRandMeasure.hpp +0 -40
- package/vendor/include/networkit/community/SampledNodeStructuralRandMeasure.hpp +0 -40
- package/vendor/include/networkit/community/StablePartitionNodes.hpp +0 -48
- package/vendor/include/networkit/components/BiconnectedComponents.hpp +0 -116
- package/vendor/include/networkit/components/ComponentDecomposition.hpp +0 -72
- package/vendor/include/networkit/components/ConnectedComponents.hpp +0 -55
- package/vendor/include/networkit/components/DynConnectedComponents.hpp +0 -71
- package/vendor/include/networkit/components/DynWeaklyConnectedComponents.hpp +0 -73
- package/vendor/include/networkit/components/ParallelConnectedComponents.hpp +0 -44
- package/vendor/include/networkit/components/RandomSpanningForest.hpp +0 -36
- package/vendor/include/networkit/components/StronglyConnectedComponents.hpp +0 -50
- package/vendor/include/networkit/components/WeaklyConnectedComponents.hpp +0 -59
- package/vendor/include/networkit/correlation/Assortativity.hpp +0 -64
- package/vendor/include/networkit/distance/APSP.hpp +0 -70
- package/vendor/include/networkit/distance/AStar.hpp +0 -68
- package/vendor/include/networkit/distance/AStarGeneral.hpp +0 -110
- package/vendor/include/networkit/distance/AdamicAdarDistance.hpp +0 -52
- package/vendor/include/networkit/distance/AffectedNodes.hpp +0 -130
- package/vendor/include/networkit/distance/AlgebraicDistance.hpp +0 -63
- package/vendor/include/networkit/distance/BFS.hpp +0 -43
- package/vendor/include/networkit/distance/BidirectionalBFS.hpp +0 -51
- package/vendor/include/networkit/distance/BidirectionalDijkstra.hpp +0 -69
- package/vendor/include/networkit/distance/CommuteTimeDistance.hpp +0 -89
- package/vendor/include/networkit/distance/Diameter.hpp +0 -97
- package/vendor/include/networkit/distance/Dijkstra.hpp +0 -50
- package/vendor/include/networkit/distance/DynAPSP.hpp +0 -67
- package/vendor/include/networkit/distance/DynBFS.hpp +0 -56
- package/vendor/include/networkit/distance/DynDijkstra.hpp +0 -57
- package/vendor/include/networkit/distance/DynPrunedLandmarkLabeling.hpp +0 -67
- package/vendor/include/networkit/distance/DynSSSP.hpp +0 -87
- package/vendor/include/networkit/distance/Eccentricity.hpp +0 -32
- package/vendor/include/networkit/distance/EffectiveDiameter.hpp +0 -47
- package/vendor/include/networkit/distance/EffectiveDiameterApproximation.hpp +0 -57
- package/vendor/include/networkit/distance/FloydWarshall.hpp +0 -93
- package/vendor/include/networkit/distance/GraphDistance.hpp +0 -49
- package/vendor/include/networkit/distance/HopPlotApproximation.hpp +0 -62
- package/vendor/include/networkit/distance/IncompleteDijkstra.hpp +0 -66
- package/vendor/include/networkit/distance/IncompleteSSSP.hpp +0 -41
- package/vendor/include/networkit/distance/JaccardDistance.hpp +0 -57
- package/vendor/include/networkit/distance/MultiTargetBFS.hpp +0 -32
- package/vendor/include/networkit/distance/MultiTargetDijkstra.hpp +0 -40
- package/vendor/include/networkit/distance/NeighborhoodFunction.hpp +0 -47
- package/vendor/include/networkit/distance/NeighborhoodFunctionApproximation.hpp +0 -56
- package/vendor/include/networkit/distance/NeighborhoodFunctionHeuristic.hpp +0 -56
- package/vendor/include/networkit/distance/NodeDistance.hpp +0 -54
- package/vendor/include/networkit/distance/PrunedLandmarkLabeling.hpp +0 -76
- package/vendor/include/networkit/distance/ReverseBFS.hpp +0 -46
- package/vendor/include/networkit/distance/SPSP.hpp +0 -143
- package/vendor/include/networkit/distance/SSSP.hpp +0 -216
- package/vendor/include/networkit/distance/STSP.hpp +0 -193
- package/vendor/include/networkit/distance/Volume.hpp +0 -66
- package/vendor/include/networkit/dynamics/DGSStreamParser.hpp +0 -40
- package/vendor/include/networkit/dynamics/DGSWriter.hpp +0 -30
- package/vendor/include/networkit/dynamics/GraphDifference.hpp +0 -110
- package/vendor/include/networkit/dynamics/GraphEvent.hpp +0 -55
- package/vendor/include/networkit/dynamics/GraphEventHandler.hpp +0 -39
- package/vendor/include/networkit/dynamics/GraphEventProxy.hpp +0 -55
- package/vendor/include/networkit/dynamics/GraphUpdater.hpp +0 -38
- package/vendor/include/networkit/edgescores/ChibaNishizekiQuadrangleEdgeScore.hpp +0 -26
- package/vendor/include/networkit/edgescores/ChibaNishizekiTriangleEdgeScore.hpp +0 -33
- package/vendor/include/networkit/edgescores/EdgeScore.hpp +0 -50
- package/vendor/include/networkit/edgescores/EdgeScoreAsWeight.hpp +0 -33
- package/vendor/include/networkit/edgescores/EdgeScoreBlender.hpp +0 -33
- package/vendor/include/networkit/edgescores/EdgeScoreLinearizer.hpp +0 -32
- package/vendor/include/networkit/edgescores/EdgeScoreNormalizer.hpp +0 -35
- package/vendor/include/networkit/edgescores/GeometricMeanScore.hpp +0 -29
- package/vendor/include/networkit/edgescores/PrefixJaccardScore.hpp +0 -23
- package/vendor/include/networkit/edgescores/TriangleEdgeScore.hpp +0 -39
- package/vendor/include/networkit/embedding/Node2Vec.hpp +0 -83
- package/vendor/include/networkit/flow/EdmondsKarp.hpp +0 -112
- package/vendor/include/networkit/generators/BarabasiAlbertGenerator.hpp +0 -87
- package/vendor/include/networkit/generators/ChungLuGenerator.hpp +0 -46
- package/vendor/include/networkit/generators/ChungLuGeneratorAlamEtAl.hpp +0 -63
- package/vendor/include/networkit/generators/ClusteredRandomGraphGenerator.hpp +0 -56
- package/vendor/include/networkit/generators/ConfigurationModel.hpp +0 -36
- package/vendor/include/networkit/generators/DorogovtsevMendesGenerator.hpp +0 -33
- package/vendor/include/networkit/generators/DynamicBarabasiAlbertGenerator.hpp +0 -33
- package/vendor/include/networkit/generators/DynamicDGSParser.hpp +0 -51
- package/vendor/include/networkit/generators/DynamicDorogovtsevMendesGenerator.hpp +0 -34
- package/vendor/include/networkit/generators/DynamicForestFireGenerator.hpp +0 -55
- package/vendor/include/networkit/generators/DynamicGraphGenerator.hpp +0 -40
- package/vendor/include/networkit/generators/DynamicGraphSource.hpp +0 -79
- package/vendor/include/networkit/generators/DynamicHyperbolicGenerator.hpp +0 -143
- package/vendor/include/networkit/generators/DynamicPathGenerator.hpp +0 -26
- package/vendor/include/networkit/generators/DynamicPubWebGenerator.hpp +0 -54
- package/vendor/include/networkit/generators/EdgeSwitchingMarkovChainGenerator.hpp +0 -65
- package/vendor/include/networkit/generators/ErdosRenyiEnumerator.hpp +0 -318
- package/vendor/include/networkit/generators/ErdosRenyiGenerator.hpp +0 -56
- package/vendor/include/networkit/generators/HavelHakimiGenerator.hpp +0 -48
- package/vendor/include/networkit/generators/HyperbolicGenerator.hpp +0 -236
- package/vendor/include/networkit/generators/LFRGenerator.hpp +0 -175
- package/vendor/include/networkit/generators/MocnikGenerator.hpp +0 -147
- package/vendor/include/networkit/generators/MocnikGeneratorBasic.hpp +0 -58
- package/vendor/include/networkit/generators/PowerlawDegreeSequence.hpp +0 -128
- package/vendor/include/networkit/generators/PubWebGenerator.hpp +0 -94
- package/vendor/include/networkit/generators/RegularRingLatticeGenerator.hpp +0 -37
- package/vendor/include/networkit/generators/RmatGenerator.hpp +0 -67
- package/vendor/include/networkit/generators/StaticDegreeSequenceGenerator.hpp +0 -42
- package/vendor/include/networkit/generators/StaticGraphGenerator.hpp +0 -30
- package/vendor/include/networkit/generators/StochasticBlockmodel.hpp +0 -41
- package/vendor/include/networkit/generators/WattsStrogatzGenerator.hpp +0 -43
- package/vendor/include/networkit/generators/quadtree/QuadNode.hpp +0 -857
- package/vendor/include/networkit/generators/quadtree/QuadNodeCartesianEuclid.hpp +0 -587
- package/vendor/include/networkit/generators/quadtree/QuadNodePolarEuclid.hpp +0 -726
- package/vendor/include/networkit/generators/quadtree/Quadtree.hpp +0 -232
- package/vendor/include/networkit/generators/quadtree/QuadtreeCartesianEuclid.hpp +0 -149
- package/vendor/include/networkit/generators/quadtree/QuadtreePolarEuclid.hpp +0 -143
- package/vendor/include/networkit/geometric/HyperbolicSpace.hpp +0 -248
- package/vendor/include/networkit/geometric/Point2DWithIndex.hpp +0 -145
- package/vendor/include/networkit/global/ClusteringCoefficient.hpp +0 -42
- package/vendor/include/networkit/global/GlobalClusteringCoefficient.hpp +0 -24
- package/vendor/include/networkit/graph/Attributes.hpp +0 -568
- package/vendor/include/networkit/graph/BFS.hpp +0 -111
- package/vendor/include/networkit/graph/DFS.hpp +0 -71
- package/vendor/include/networkit/graph/Dijkstra.hpp +0 -83
- package/vendor/include/networkit/graph/EdgeIterators.hpp +0 -171
- package/vendor/include/networkit/graph/Graph.hpp +0 -2083
- package/vendor/include/networkit/graph/GraphBuilder.hpp +0 -289
- package/vendor/include/networkit/graph/GraphR.hpp +0 -133
- package/vendor/include/networkit/graph/GraphTools.hpp +0 -589
- package/vendor/include/networkit/graph/GraphW.hpp +0 -1236
- package/vendor/include/networkit/graph/KruskalMSF.hpp +0 -50
- package/vendor/include/networkit/graph/NeighborIterators.hpp +0 -163
- package/vendor/include/networkit/graph/NodeIterators.hpp +0 -127
- package/vendor/include/networkit/graph/PrimMSF.hpp +0 -66
- package/vendor/include/networkit/graph/RandomMaximumSpanningForest.hpp +0 -133
- package/vendor/include/networkit/graph/SpanningForest.hpp +0 -41
- package/vendor/include/networkit/graph/TopologicalSort.hpp +0 -87
- package/vendor/include/networkit/graph/UnionMaximumSpanningForest.hpp +0 -126
- package/vendor/include/networkit/graph/test/GraphBuilderBenchmark.hpp +0 -68
- package/vendor/include/networkit/independentset/IndependentSetFinder.hpp +0 -44
- package/vendor/include/networkit/independentset/Luby.hpp +0 -27
- package/vendor/include/networkit/io/BinaryEdgeListPartitionReader.hpp +0 -45
- package/vendor/include/networkit/io/BinaryEdgeListPartitionWriter.hpp +0 -47
- package/vendor/include/networkit/io/BinaryPartitionReader.hpp +0 -41
- package/vendor/include/networkit/io/BinaryPartitionWriter.hpp +0 -44
- package/vendor/include/networkit/io/CoverReader.hpp +0 -27
- package/vendor/include/networkit/io/CoverWriter.hpp +0 -21
- package/vendor/include/networkit/io/DGSReader.hpp +0 -39
- package/vendor/include/networkit/io/DibapGraphReader.hpp +0 -43
- package/vendor/include/networkit/io/DotGraphWriter.hpp +0 -39
- package/vendor/include/networkit/io/DotPartitionWriter.hpp +0 -23
- package/vendor/include/networkit/io/DynamicGraphReader.hpp +0 -29
- package/vendor/include/networkit/io/EdgeListCoverReader.hpp +0 -35
- package/vendor/include/networkit/io/EdgeListPartitionReader.hpp +0 -43
- package/vendor/include/networkit/io/EdgeListReader.hpp +0 -61
- package/vendor/include/networkit/io/EdgeListWriter.hpp +0 -48
- package/vendor/include/networkit/io/GMLGraphReader.hpp +0 -33
- package/vendor/include/networkit/io/GMLGraphWriter.hpp +0 -33
- package/vendor/include/networkit/io/GraphIO.hpp +0 -52
- package/vendor/include/networkit/io/GraphReader.hpp +0 -40
- package/vendor/include/networkit/io/GraphToolBinaryReader.hpp +0 -71
- package/vendor/include/networkit/io/GraphToolBinaryWriter.hpp +0 -61
- package/vendor/include/networkit/io/GraphWriter.hpp +0 -27
- package/vendor/include/networkit/io/KONECTGraphReader.hpp +0 -44
- package/vendor/include/networkit/io/LineFileReader.hpp +0 -42
- package/vendor/include/networkit/io/METISGraphReader.hpp +0 -36
- package/vendor/include/networkit/io/METISGraphWriter.hpp +0 -29
- package/vendor/include/networkit/io/METISParser.hpp +0 -63
- package/vendor/include/networkit/io/MTXGraphReader.hpp +0 -31
- package/vendor/include/networkit/io/MTXParser.hpp +0 -87
- package/vendor/include/networkit/io/MatrixMarketReader.hpp +0 -33
- package/vendor/include/networkit/io/MatrixReader.hpp +0 -33
- package/vendor/include/networkit/io/MemoryMappedFile.hpp +0 -80
- package/vendor/include/networkit/io/NetworkitBinaryGraph.hpp +0 -144
- package/vendor/include/networkit/io/NetworkitBinaryReader.hpp +0 -50
- package/vendor/include/networkit/io/NetworkitBinaryWriter.hpp +0 -71
- package/vendor/include/networkit/io/PartitionReader.hpp +0 -34
- package/vendor/include/networkit/io/PartitionWriter.hpp +0 -31
- package/vendor/include/networkit/io/RBGraphReader.hpp +0 -37
- package/vendor/include/networkit/io/RBMatrixReader.hpp +0 -49
- package/vendor/include/networkit/io/RasterReader.hpp +0 -40
- package/vendor/include/networkit/io/SNAPEdgeListPartitionReader.hpp +0 -28
- package/vendor/include/networkit/io/SNAPGraphReader.hpp +0 -53
- package/vendor/include/networkit/io/SNAPGraphWriter.hpp +0 -53
- package/vendor/include/networkit/io/ThrillGraphBinaryReader.hpp +0 -44
- package/vendor/include/networkit/io/ThrillGraphBinaryWriter.hpp +0 -27
- package/vendor/include/networkit/layout/LayoutAlgorithm.hpp +0 -39
- package/vendor/include/networkit/linkprediction/AdamicAdarIndex.hpp +0 -37
- package/vendor/include/networkit/linkprediction/AdjustedRandIndex.hpp +0 -36
- package/vendor/include/networkit/linkprediction/AlgebraicDistanceIndex.hpp +0 -70
- package/vendor/include/networkit/linkprediction/CommonNeighborsIndex.hpp +0 -39
- package/vendor/include/networkit/linkprediction/EvaluationMetric.hpp +0 -135
- package/vendor/include/networkit/linkprediction/JaccardIndex.hpp +0 -44
- package/vendor/include/networkit/linkprediction/KatzIndex.hpp +0 -84
- package/vendor/include/networkit/linkprediction/LinkPredictor.hpp +0 -98
- package/vendor/include/networkit/linkprediction/LinkThresholder.hpp +0 -56
- package/vendor/include/networkit/linkprediction/MissingLinksFinder.hpp +0 -60
- package/vendor/include/networkit/linkprediction/NeighborhoodDistanceIndex.hpp +0 -42
- package/vendor/include/networkit/linkprediction/NeighborhoodUtility.hpp +0 -54
- package/vendor/include/networkit/linkprediction/NeighborsMeasureIndex.hpp +0 -48
- package/vendor/include/networkit/linkprediction/PrecisionRecallMetric.hpp +0 -40
- package/vendor/include/networkit/linkprediction/PredictionsSorter.hpp +0 -66
- package/vendor/include/networkit/linkprediction/PreferentialAttachmentIndex.hpp +0 -37
- package/vendor/include/networkit/linkprediction/ROCMetric.hpp +0 -39
- package/vendor/include/networkit/linkprediction/RandomLinkSampler.hpp +0 -47
- package/vendor/include/networkit/linkprediction/ResourceAllocationIndex.hpp +0 -38
- package/vendor/include/networkit/linkprediction/SameCommunityIndex.hpp +0 -50
- package/vendor/include/networkit/linkprediction/TotalNeighborsIndex.hpp +0 -39
- package/vendor/include/networkit/linkprediction/UDegreeIndex.hpp +0 -35
- package/vendor/include/networkit/linkprediction/VDegreeIndex.hpp +0 -35
- package/vendor/include/networkit/matching/BMatcher.hpp +0 -52
- package/vendor/include/networkit/matching/BMatching.hpp +0 -115
- package/vendor/include/networkit/matching/BSuitorMatcher.hpp +0 -170
- package/vendor/include/networkit/matching/DynamicBSuitorMatcher.hpp +0 -78
- package/vendor/include/networkit/matching/LocalMaxMatcher.hpp +0 -35
- package/vendor/include/networkit/matching/Matcher.hpp +0 -55
- package/vendor/include/networkit/matching/Matching.hpp +0 -111
- package/vendor/include/networkit/matching/PathGrowingMatcher.hpp +0 -46
- package/vendor/include/networkit/matching/SuitorMatcher.hpp +0 -62
- package/vendor/include/networkit/numerics/ConjugateGradient.hpp +0 -163
- package/vendor/include/networkit/numerics/GaussSeidelRelaxation.hpp +0 -99
- package/vendor/include/networkit/numerics/LAMG/LAMGSettings.hpp +0 -70
- package/vendor/include/networkit/numerics/LAMG/Lamg.hpp +0 -460
- package/vendor/include/networkit/numerics/LAMG/Level/EliminationStage.hpp +0 -47
- package/vendor/include/networkit/numerics/LAMG/Level/Level.hpp +0 -56
- package/vendor/include/networkit/numerics/LAMG/Level/LevelAggregation.hpp +0 -52
- package/vendor/include/networkit/numerics/LAMG/Level/LevelElimination.hpp +0 -133
- package/vendor/include/networkit/numerics/LAMG/Level/LevelFinest.hpp +0 -28
- package/vendor/include/networkit/numerics/LAMG/LevelHierarchy.hpp +0 -165
- package/vendor/include/networkit/numerics/LAMG/MultiLevelSetup.hpp +0 -1090
- package/vendor/include/networkit/numerics/LAMG/SolverLamg.hpp +0 -316
- package/vendor/include/networkit/numerics/LinearSolver.hpp +0 -151
- package/vendor/include/networkit/numerics/Preconditioner/DiagonalPreconditioner.hpp +0 -61
- package/vendor/include/networkit/numerics/Preconditioner/IdentityPreconditioner.hpp +0 -36
- package/vendor/include/networkit/numerics/Smoother.hpp +0 -37
- package/vendor/include/networkit/overlap/HashingOverlapper.hpp +0 -28
- package/vendor/include/networkit/overlap/Overlapper.hpp +0 -27
- package/vendor/include/networkit/planarity/LeftRightPlanarityCheck.hpp +0 -113
- package/vendor/include/networkit/randomization/Curveball.hpp +0 -49
- package/vendor/include/networkit/randomization/CurveballGlobalTradeGenerator.hpp +0 -39
- package/vendor/include/networkit/randomization/CurveballUniformTradeGenerator.hpp +0 -39
- package/vendor/include/networkit/randomization/DegreePreservingShuffle.hpp +0 -82
- package/vendor/include/networkit/randomization/EdgeSwitching.hpp +0 -157
- package/vendor/include/networkit/randomization/GlobalCurveball.hpp +0 -69
- package/vendor/include/networkit/randomization/GlobalTradeSequence.hpp +0 -303
- package/vendor/include/networkit/reachability/AllSimplePaths.hpp +0 -122
- package/vendor/include/networkit/reachability/ReachableNodes.hpp +0 -83
- package/vendor/include/networkit/scd/ApproximatePageRank.hpp +0 -51
- package/vendor/include/networkit/scd/CliqueDetect.hpp +0 -55
- package/vendor/include/networkit/scd/CombinedSCD.hpp +0 -51
- package/vendor/include/networkit/scd/GCE.hpp +0 -42
- package/vendor/include/networkit/scd/LFMLocal.hpp +0 -54
- package/vendor/include/networkit/scd/LocalT.hpp +0 -40
- package/vendor/include/networkit/scd/LocalTightnessExpansion.hpp +0 -46
- package/vendor/include/networkit/scd/PageRankNibble.hpp +0 -55
- package/vendor/include/networkit/scd/RandomBFS.hpp +0 -33
- package/vendor/include/networkit/scd/SCDGroundTruthComparison.hpp +0 -121
- package/vendor/include/networkit/scd/SelectiveCommunityDetector.hpp +0 -76
- package/vendor/include/networkit/scd/SetConductance.hpp +0 -47
- package/vendor/include/networkit/scd/TCE.hpp +0 -41
- package/vendor/include/networkit/scd/TwoPhaseL.hpp +0 -40
- package/vendor/include/networkit/scoring/EdgeScoring.hpp +0 -44
- package/vendor/include/networkit/scoring/ModularityScoring.hpp +0 -79
- package/vendor/include/networkit/simulation/EpidemicSimulationSEIR.hpp +0 -59
- package/vendor/include/networkit/sparsification/ChanceCorrectedTriangleScore.hpp +0 -28
- package/vendor/include/networkit/sparsification/ForestFireScore.hpp +0 -34
- package/vendor/include/networkit/sparsification/GlobalThresholdFilter.hpp +0 -40
- package/vendor/include/networkit/sparsification/LocalDegreeScore.hpp +0 -30
- package/vendor/include/networkit/sparsification/LocalFilterScore.hpp +0 -124
- package/vendor/include/networkit/sparsification/LocalSimilarityScore.hpp +0 -63
- package/vendor/include/networkit/sparsification/MultiscaleScore.hpp +0 -38
- package/vendor/include/networkit/sparsification/RandomEdgeScore.hpp +0 -33
- package/vendor/include/networkit/sparsification/RandomNodeEdgeScore.hpp +0 -29
- package/vendor/include/networkit/sparsification/SCANStructuralSimilarityScore.hpp +0 -23
- package/vendor/include/networkit/sparsification/SimmelianOverlapScore.hpp +0 -35
- package/vendor/include/networkit/sparsification/SimmelianScore.hpp +0 -92
- package/vendor/include/networkit/sparsification/Sparsifiers.hpp +0 -166
- package/vendor/include/networkit/structures/Cover.hpp +0 -248
- package/vendor/include/networkit/structures/LocalCommunity.hpp +0 -363
- package/vendor/include/networkit/structures/Partition.hpp +0 -335
- package/vendor/include/networkit/structures/UnionFind.hpp +0 -66
- package/vendor/include/networkit/viz/GraphLayoutAlgorithm.hpp +0 -157
- package/vendor/include/networkit/viz/MaxentStress.hpp +0 -346
- package/vendor/include/networkit/viz/Octree.hpp +0 -428
- package/vendor/include/networkit/viz/PivotMDS.hpp +0 -63
- package/vendor/include/networkit/viz/Point.hpp +0 -415
- package/vendor/include/networkit/viz/PostscriptWriter.hpp +0 -78
- package/vendor/include/tlx/algorithm/exclusive_scan.hpp +0 -56
- package/vendor/include/tlx/algorithm/is_sorted_cmp.hpp +0 -56
- package/vendor/include/tlx/algorithm/merge_advance.hpp +0 -177
- package/vendor/include/tlx/algorithm/merge_combine.hpp +0 -76
- package/vendor/include/tlx/algorithm/multisequence_partition.hpp +0 -346
- package/vendor/include/tlx/algorithm/multisequence_selection.hpp +0 -351
- package/vendor/include/tlx/algorithm/multiway_merge.hpp +0 -1385
- package/vendor/include/tlx/algorithm/multiway_merge_splitting.hpp +0 -257
- package/vendor/include/tlx/algorithm/parallel_multiway_merge.hpp +0 -408
- package/vendor/include/tlx/algorithm/random_bipartition_shuffle.hpp +0 -116
- package/vendor/include/tlx/algorithm.hpp +0 -36
- package/vendor/include/tlx/allocator_base.hpp +0 -100
- package/vendor/include/tlx/backtrace.hpp +0 -54
- package/vendor/include/tlx/cmdline_parser.hpp +0 -498
- package/vendor/include/tlx/container/btree.hpp +0 -3977
- package/vendor/include/tlx/container/btree_map.hpp +0 -634
- package/vendor/include/tlx/container/btree_multimap.hpp +0 -627
- package/vendor/include/tlx/container/btree_multiset.hpp +0 -612
- package/vendor/include/tlx/container/btree_set.hpp +0 -612
- package/vendor/include/tlx/container/d_ary_addressable_int_heap.hpp +0 -416
- package/vendor/include/tlx/container/d_ary_heap.hpp +0 -311
- package/vendor/include/tlx/container/loser_tree.hpp +0 -1009
- package/vendor/include/tlx/container/lru_cache.hpp +0 -319
- package/vendor/include/tlx/container/radix_heap.hpp +0 -735
- package/vendor/include/tlx/container/ring_buffer.hpp +0 -428
- package/vendor/include/tlx/container/simple_vector.hpp +0 -304
- package/vendor/include/tlx/container/splay_tree.hpp +0 -399
- package/vendor/include/tlx/container/string_view.hpp +0 -805
- package/vendor/include/tlx/container.hpp +0 -40
- package/vendor/include/tlx/counting_ptr.hpp +0 -522
- package/vendor/include/tlx/define/attribute_always_inline.hpp +0 -34
- package/vendor/include/tlx/define/attribute_fallthrough.hpp +0 -36
- package/vendor/include/tlx/define/attribute_format_printf.hpp +0 -34
- package/vendor/include/tlx/define/attribute_packed.hpp +0 -34
- package/vendor/include/tlx/define/attribute_warn_unused_result.hpp +0 -34
- package/vendor/include/tlx/define/constexpr.hpp +0 -31
- package/vendor/include/tlx/define/deprecated.hpp +0 -39
- package/vendor/include/tlx/define/endian.hpp +0 -49
- package/vendor/include/tlx/define/likely.hpp +0 -33
- package/vendor/include/tlx/define/visibility_hidden.hpp +0 -34
- package/vendor/include/tlx/define.hpp +0 -36
- package/vendor/include/tlx/delegate.hpp +0 -524
- package/vendor/include/tlx/die/core.hpp +0 -311
- package/vendor/include/tlx/die.hpp +0 -106
- package/vendor/include/tlx/digest/md5.hpp +0 -81
- package/vendor/include/tlx/digest/sha1.hpp +0 -81
- package/vendor/include/tlx/digest/sha256.hpp +0 -81
- package/vendor/include/tlx/digest/sha512.hpp +0 -81
- package/vendor/include/tlx/digest.hpp +0 -30
- package/vendor/include/tlx/logger/all.hpp +0 -33
- package/vendor/include/tlx/logger/array.hpp +0 -43
- package/vendor/include/tlx/logger/core.hpp +0 -287
- package/vendor/include/tlx/logger/deque.hpp +0 -42
- package/vendor/include/tlx/logger/map.hpp +0 -65
- package/vendor/include/tlx/logger/set.hpp +0 -60
- package/vendor/include/tlx/logger/tuple.hpp +0 -66
- package/vendor/include/tlx/logger/unordered_map.hpp +0 -68
- package/vendor/include/tlx/logger/unordered_set.hpp +0 -64
- package/vendor/include/tlx/logger/wrap_unprintable.hpp +0 -75
- package/vendor/include/tlx/logger.hpp +0 -44
- package/vendor/include/tlx/math/abs_diff.hpp +0 -35
- package/vendor/include/tlx/math/aggregate.hpp +0 -231
- package/vendor/include/tlx/math/aggregate_min_max.hpp +0 -116
- package/vendor/include/tlx/math/bswap.hpp +0 -148
- package/vendor/include/tlx/math/bswap_be.hpp +0 -79
- package/vendor/include/tlx/math/bswap_le.hpp +0 -79
- package/vendor/include/tlx/math/clz.hpp +0 -174
- package/vendor/include/tlx/math/ctz.hpp +0 -174
- package/vendor/include/tlx/math/div_ceil.hpp +0 -36
- package/vendor/include/tlx/math/ffs.hpp +0 -123
- package/vendor/include/tlx/math/integer_log2.hpp +0 -189
- package/vendor/include/tlx/math/is_power_of_two.hpp +0 -74
- package/vendor/include/tlx/math/polynomial_regression.hpp +0 -243
- package/vendor/include/tlx/math/popcount.hpp +0 -173
- package/vendor/include/tlx/math/power_to_the.hpp +0 -44
- package/vendor/include/tlx/math/rol.hpp +0 -112
- package/vendor/include/tlx/math/ror.hpp +0 -112
- package/vendor/include/tlx/math/round_to_power_of_two.hpp +0 -121
- package/vendor/include/tlx/math/round_up.hpp +0 -36
- package/vendor/include/tlx/math/sgn.hpp +0 -38
- package/vendor/include/tlx/math.hpp +0 -46
- package/vendor/include/tlx/meta/apply_tuple.hpp +0 -55
- package/vendor/include/tlx/meta/call_for_range.hpp +0 -78
- package/vendor/include/tlx/meta/call_foreach.hpp +0 -60
- package/vendor/include/tlx/meta/call_foreach_tuple.hpp +0 -60
- package/vendor/include/tlx/meta/call_foreach_tuple_with_index.hpp +0 -61
- package/vendor/include/tlx/meta/call_foreach_with_index.hpp +0 -64
- package/vendor/include/tlx/meta/enable_if.hpp +0 -37
- package/vendor/include/tlx/meta/fold_left.hpp +0 -63
- package/vendor/include/tlx/meta/fold_left_tuple.hpp +0 -60
- package/vendor/include/tlx/meta/fold_right.hpp +0 -63
- package/vendor/include/tlx/meta/fold_right_tuple.hpp +0 -60
- package/vendor/include/tlx/meta/function_chain.hpp +0 -197
- package/vendor/include/tlx/meta/function_stack.hpp +0 -189
- package/vendor/include/tlx/meta/has_member.hpp +0 -80
- package/vendor/include/tlx/meta/has_method.hpp +0 -117
- package/vendor/include/tlx/meta/index_sequence.hpp +0 -66
- package/vendor/include/tlx/meta/is_std_array.hpp +0 -40
- package/vendor/include/tlx/meta/is_std_pair.hpp +0 -39
- package/vendor/include/tlx/meta/is_std_tuple.hpp +0 -39
- package/vendor/include/tlx/meta/is_std_vector.hpp +0 -39
- package/vendor/include/tlx/meta/log2.hpp +0 -101
- package/vendor/include/tlx/meta/no_operation.hpp +0 -55
- package/vendor/include/tlx/meta/static_index.hpp +0 -42
- package/vendor/include/tlx/meta/vexpand.hpp +0 -34
- package/vendor/include/tlx/meta/vmap_for_range.hpp +0 -84
- package/vendor/include/tlx/meta/vmap_foreach.hpp +0 -63
- package/vendor/include/tlx/meta/vmap_foreach_tuple.hpp +0 -59
- package/vendor/include/tlx/meta/vmap_foreach_tuple_with_index.hpp +0 -62
- package/vendor/include/tlx/meta/vmap_foreach_with_index.hpp +0 -70
- package/vendor/include/tlx/meta.hpp +0 -55
- package/vendor/include/tlx/multi_timer.hpp +0 -148
- package/vendor/include/tlx/port/setenv.hpp +0 -31
- package/vendor/include/tlx/port.hpp +0 -27
- package/vendor/include/tlx/semaphore.hpp +0 -119
- package/vendor/include/tlx/simple_vector.hpp +0 -20
- package/vendor/include/tlx/siphash.hpp +0 -282
- package/vendor/include/tlx/sort/networks/best.hpp +0 -611
- package/vendor/include/tlx/sort/networks/bose_nelson.hpp +0 -412
- package/vendor/include/tlx/sort/networks/bose_nelson_parameter.hpp +0 -507
- package/vendor/include/tlx/sort/networks/cswap.hpp +0 -60
- package/vendor/include/tlx/sort/parallel_mergesort.hpp +0 -398
- package/vendor/include/tlx/sort/strings/insertion_sort.hpp +0 -232
- package/vendor/include/tlx/sort/strings/multikey_quicksort.hpp +0 -185
- package/vendor/include/tlx/sort/strings/parallel_sample_sort.hpp +0 -1647
- package/vendor/include/tlx/sort/strings/radix_sort.hpp +0 -934
- package/vendor/include/tlx/sort/strings/sample_sort_tools.hpp +0 -756
- package/vendor/include/tlx/sort/strings/string_ptr.hpp +0 -426
- package/vendor/include/tlx/sort/strings/string_set.hpp +0 -800
- package/vendor/include/tlx/sort/strings.hpp +0 -329
- package/vendor/include/tlx/sort/strings_parallel.hpp +0 -325
- package/vendor/include/tlx/sort.hpp +0 -29
- package/vendor/include/tlx/stack_allocator.hpp +0 -226
- package/vendor/include/tlx/string/appendline.hpp +0 -35
- package/vendor/include/tlx/string/base64.hpp +0 -87
- package/vendor/include/tlx/string/bitdump.hpp +0 -139
- package/vendor/include/tlx/string/compare_icase.hpp +0 -42
- package/vendor/include/tlx/string/contains.hpp +0 -36
- package/vendor/include/tlx/string/contains_word.hpp +0 -42
- package/vendor/include/tlx/string/ends_with.hpp +0 -79
- package/vendor/include/tlx/string/equal_icase.hpp +0 -42
- package/vendor/include/tlx/string/erase_all.hpp +0 -70
- package/vendor/include/tlx/string/escape_html.hpp +0 -34
- package/vendor/include/tlx/string/escape_uri.hpp +0 -34
- package/vendor/include/tlx/string/expand_environment_variables.hpp +0 -49
- package/vendor/include/tlx/string/extract_between.hpp +0 -40
- package/vendor/include/tlx/string/format_iec_units.hpp +0 -32
- package/vendor/include/tlx/string/format_si_iec_units.hpp +0 -19
- package/vendor/include/tlx/string/format_si_units.hpp +0 -32
- package/vendor/include/tlx/string/hash_djb2.hpp +0 -87
- package/vendor/include/tlx/string/hash_sdbm.hpp +0 -86
- package/vendor/include/tlx/string/hexdump.hpp +0 -154
- package/vendor/include/tlx/string/index_of.hpp +0 -56
- package/vendor/include/tlx/string/join.hpp +0 -65
- package/vendor/include/tlx/string/join_generic.hpp +0 -89
- package/vendor/include/tlx/string/join_quoted.hpp +0 -46
- package/vendor/include/tlx/string/less_icase.hpp +0 -64
- package/vendor/include/tlx/string/levenshtein.hpp +0 -193
- package/vendor/include/tlx/string/pad.hpp +0 -39
- package/vendor/include/tlx/string/parse_si_iec_units.hpp +0 -46
- package/vendor/include/tlx/string/parse_uri.hpp +0 -66
- package/vendor/include/tlx/string/parse_uri_form_data.hpp +0 -136
- package/vendor/include/tlx/string/replace.hpp +0 -141
- package/vendor/include/tlx/string/split.hpp +0 -170
- package/vendor/include/tlx/string/split_quoted.hpp +0 -49
- package/vendor/include/tlx/string/split_view.hpp +0 -218
- package/vendor/include/tlx/string/split_words.hpp +0 -53
- package/vendor/include/tlx/string/ssprintf.hpp +0 -45
- package/vendor/include/tlx/string/ssprintf_generic.hpp +0 -95
- package/vendor/include/tlx/string/starts_with.hpp +0 -44
- package/vendor/include/tlx/string/to_lower.hpp +0 -47
- package/vendor/include/tlx/string/to_upper.hpp +0 -47
- package/vendor/include/tlx/string/trim.hpp +0 -298
- package/vendor/include/tlx/string/union_words.hpp +0 -33
- package/vendor/include/tlx/string/word_wrap.hpp +0 -35
- package/vendor/include/tlx/string.hpp +0 -68
- package/vendor/include/tlx/thread_barrier_mutex.hpp +0 -109
- package/vendor/include/tlx/thread_barrier_spin.hpp +0 -127
- package/vendor/include/tlx/thread_pool.hpp +0 -151
- package/vendor/include/tlx/timestamp.hpp +0 -23
- package/vendor/include/tlx/unused.hpp +0 -28
- package/vendor/include/tlx/vector_free.hpp +0 -30
- package/vendor/include/tlx/version.hpp +0 -49
- package/vendor/include/ttmath/ttmath.h +0 -2881
- package/vendor/include/ttmath/ttmathbig.h +0 -6111
- package/vendor/include/ttmath/ttmathdec.h +0 -419
- package/vendor/include/ttmath/ttmathint.h +0 -1923
- package/vendor/include/ttmath/ttmathmisc.h +0 -250
- package/vendor/include/ttmath/ttmathobjects.h +0 -812
- package/vendor/include/ttmath/ttmathparser.h +0 -2791
- package/vendor/include/ttmath/ttmaththreads.h +0 -252
- package/vendor/include/ttmath/ttmathtypes.h +0 -707
- package/vendor/include/ttmath/ttmathuint.h +0 -4190
- package/vendor/include/ttmath/ttmathuint_noasm.h +0 -1038
- package/vendor/include/ttmath/ttmathuint_x86.h +0 -1620
- package/vendor/include/ttmath/ttmathuint_x86_64.h +0 -1177
- package/vendor/lib/cmake/tlx/tlx-config.cmake +0 -51
- package/vendor/lib/cmake/tlx/tlx-targets-release.cmake +0 -19
- package/vendor/lib/cmake/tlx/tlx-targets.cmake +0 -106
- package/vendor/lib/cmake/tlx/tlx-version.cmake +0 -11
- package/vendor/lib/libtlx.a +0 -0
- package/vendor/lib/pkgconfig/networkit.pc +0 -11
- package/vendor/lib/pkgconfig/tlx.pc +0 -11
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* AlgebraicMatchingCoarsening.hpp
|
|
3
|
-
*
|
|
4
|
-
* Created on: Jul 12, 2016
|
|
5
|
-
* Author: Michael Wegner (michael.wegner@student.kit.edu)
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
#ifndef NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_MATCHING_COARSENING_HPP_
|
|
9
|
-
#define NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_MATCHING_COARSENING_HPP_
|
|
10
|
-
|
|
11
|
-
#include <networkit/algebraic/AlgebraicGlobals.hpp>
|
|
12
|
-
#include <networkit/coarsening/GraphCoarsening.hpp>
|
|
13
|
-
#include <networkit/matching/Matching.hpp>
|
|
14
|
-
|
|
15
|
-
namespace NetworKit {
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* @ingroup algebraic
|
|
19
|
-
* Implements an algebraic version of the MatchingCoarsening algorithm by computing a projection
|
|
20
|
-
* matrix from fine to coarse.
|
|
21
|
-
*/
|
|
22
|
-
template <class Matrix>
|
|
23
|
-
class AlgebraicMatchingCoarsening final : public GraphCoarsening {
|
|
24
|
-
public:
|
|
25
|
-
/**
|
|
26
|
-
* Constructs an instance of AlgebraicMatchingCoarsening for the given Graph @a graph and the
|
|
27
|
-
* corresponding Matching @a matching. If @a noSelfLoops is set to true (false by default), no
|
|
28
|
-
* self-loops are created during the coarsening.
|
|
29
|
-
* @param graph
|
|
30
|
-
* @param matching
|
|
31
|
-
* @param noSelfLoops
|
|
32
|
-
*/
|
|
33
|
-
AlgebraicMatchingCoarsening(const Graph &graph, const Matching &matching,
|
|
34
|
-
bool noSelfLoops = false);
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Computes the coarsening for the graph using the given matching.
|
|
38
|
-
*/
|
|
39
|
-
void run() override;
|
|
40
|
-
|
|
41
|
-
private:
|
|
42
|
-
Matrix A; // adjacency matrix of the graph
|
|
43
|
-
Matrix P; // projection matrix
|
|
44
|
-
bool noSelfLoops;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
template <class Matrix>
|
|
48
|
-
AlgebraicMatchingCoarsening<Matrix>::AlgebraicMatchingCoarsening(const Graph &graph,
|
|
49
|
-
const Matching &matching,
|
|
50
|
-
bool noSelfLoops)
|
|
51
|
-
: GraphCoarsening(graph), A(Matrix::adjacencyMatrix(graph)), noSelfLoops(noSelfLoops) {
|
|
52
|
-
if (G->isDirected())
|
|
53
|
-
throw std::runtime_error("Only defined for undirected graphs.");
|
|
54
|
-
nodeMapping.resize(graph.numberOfNodes());
|
|
55
|
-
std::vector<Triplet> triplets(graph.numberOfNodes());
|
|
56
|
-
|
|
57
|
-
count numCoarse = graph.numberOfNodes() - matching.size(graph);
|
|
58
|
-
index idx = 0;
|
|
59
|
-
graph.forNodes([&](node u) {
|
|
60
|
-
index mate = matching.mate(u);
|
|
61
|
-
if ((mate == none) || (u < mate)) {
|
|
62
|
-
// vertex u is carried over to the new level
|
|
63
|
-
nodeMapping[u] = idx;
|
|
64
|
-
++idx;
|
|
65
|
-
} else {
|
|
66
|
-
// vertex u is not carried over, receives ID of mate
|
|
67
|
-
nodeMapping[u] = nodeMapping[mate];
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
triplets[u] = {u, nodeMapping[u], 1};
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
P = Matrix(graph.numberOfNodes(), numCoarse, triplets); // dimensions: fine x coarse
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
template <class Matrix>
|
|
77
|
-
void AlgebraicMatchingCoarsening<Matrix>::run() {
|
|
78
|
-
Matrix coarseAdj =
|
|
79
|
-
P.transpose() * A
|
|
80
|
-
* P; // Matrix::mTmMultiply performs worse due to high sparsity of P (nnz = n)
|
|
81
|
-
|
|
82
|
-
Gcoarsened = GraphW(coarseAdj.numberOfRows(), true);
|
|
83
|
-
coarseAdj.forNonZeroElementsInRowOrder([&](node u, node v, edgeweight weight) {
|
|
84
|
-
if (u == v && !noSelfLoops) {
|
|
85
|
-
Gcoarsened.addEdge(u, v, weight / 2.0);
|
|
86
|
-
} else if (u < v) {
|
|
87
|
-
Gcoarsened.addEdge(u, v, weight);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
hasRun = true;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
} /* namespace NetworKit */
|
|
95
|
-
|
|
96
|
-
#endif // NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_MATCHING_COARSENING_HPP_
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* AlgebraicPageRank.hpp
|
|
3
|
-
*
|
|
4
|
-
* Created on: Jun 20, 2016
|
|
5
|
-
* Author: Michael Wegner (michael.wegner@student.kit.edu)
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
#ifndef NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_PAGE_RANK_HPP_
|
|
9
|
-
#define NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_PAGE_RANK_HPP_
|
|
10
|
-
|
|
11
|
-
#include <networkit/auxiliary/Parallel.hpp>
|
|
12
|
-
#include <networkit/centrality/Centrality.hpp>
|
|
13
|
-
|
|
14
|
-
#include <networkit/algebraic/GraphBLAS.hpp>
|
|
15
|
-
#include <networkit/algebraic/Vector.hpp>
|
|
16
|
-
#include <networkit/graph/Graph.hpp>
|
|
17
|
-
|
|
18
|
-
namespace NetworKit {
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* @ingroup algebraic
|
|
22
|
-
* Implementation of PageRank using the GraphBLAS interface.
|
|
23
|
-
*/
|
|
24
|
-
template <class Matrix>
|
|
25
|
-
class AlgebraicPageRank final : public Centrality {
|
|
26
|
-
public:
|
|
27
|
-
/**
|
|
28
|
-
* Constructs an instance of AlgebraicPageRank for the given @a graph. Page rank uses the
|
|
29
|
-
* damping factor @a damp and the tolerance @a tol.
|
|
30
|
-
* @param graph
|
|
31
|
-
* @param damp
|
|
32
|
-
* @param tol
|
|
33
|
-
*/
|
|
34
|
-
AlgebraicPageRank(const Graph &graph, const double damp = 0.85, const double tol = 1e-8)
|
|
35
|
-
: Centrality(graph), damp(damp), tol(tol) {
|
|
36
|
-
Matrix A = Matrix::adjacencyMatrix(graph);
|
|
37
|
-
// normalize At by out-degree
|
|
38
|
-
Vector invOutDeg = GraphBLAS::rowReduce(A);
|
|
39
|
-
#pragma omp parallel for
|
|
40
|
-
for (omp_index i = 0; i < static_cast<omp_index>(invOutDeg.getDimension()); ++i) {
|
|
41
|
-
invOutDeg[i] = 1.0 / invOutDeg[i];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
std::vector<Triplet> mTriplets(A.nnz());
|
|
45
|
-
index idx = 0;
|
|
46
|
-
A.forNonZeroElementsInRowOrder([&](index i, index j, double value) {
|
|
47
|
-
mTriplets[idx++] = {j, i, damp * value * invOutDeg[i]};
|
|
48
|
-
});
|
|
49
|
-
M = std::move(Matrix(A.numberOfRows(), mTriplets));
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
void run() override;
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Get a vector containing the betweenness score for each node in the graph.
|
|
56
|
-
*
|
|
57
|
-
* @return The betweenness scores calculated by @ref run().
|
|
58
|
-
*/
|
|
59
|
-
const std::vector<double> &scores() const override;
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Get a vector of pairs sorted into descending order. Each pair contains a node and the
|
|
63
|
-
* corresponding score calculated by @ref run().
|
|
64
|
-
* @return A vector of pairs.
|
|
65
|
-
*/
|
|
66
|
-
std::vector<std::pair<node, double>> ranking() override;
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Get the betweenness score of node @a v calculated by @ref run().
|
|
70
|
-
*
|
|
71
|
-
* @param v A node.
|
|
72
|
-
* @return The betweenness score of node @a v.
|
|
73
|
-
*/
|
|
74
|
-
double score(node v) override;
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Get the theoretical maximum of centrality score in the given graph.
|
|
78
|
-
*
|
|
79
|
-
* @return The maximum centrality score.
|
|
80
|
-
*/
|
|
81
|
-
double maximum() override { return 1.0; }
|
|
82
|
-
|
|
83
|
-
private:
|
|
84
|
-
Matrix M;
|
|
85
|
-
|
|
86
|
-
const double damp;
|
|
87
|
-
const double tol;
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
template <class Matrix>
|
|
91
|
-
void AlgebraicPageRank<Matrix>::run() {
|
|
92
|
-
count n = M.numberOfRows();
|
|
93
|
-
double teleportProb = (1.0 - damp) / (double)n;
|
|
94
|
-
Vector rank(n, 1.0 / (double)n);
|
|
95
|
-
Vector lastRank;
|
|
96
|
-
|
|
97
|
-
do {
|
|
98
|
-
lastRank = rank;
|
|
99
|
-
rank = M * rank;
|
|
100
|
-
rank.apply([&](double value) { return value += teleportProb; });
|
|
101
|
-
} while ((rank - lastRank).length() > tol);
|
|
102
|
-
|
|
103
|
-
double sum = 0.0;
|
|
104
|
-
#pragma omp parallel for reduction(+ : sum)
|
|
105
|
-
for (omp_index i = 0; i < static_cast<omp_index>(rank.getDimension()); ++i) {
|
|
106
|
-
sum += rank[i];
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
scoreData.resize(n, 0);
|
|
110
|
-
#pragma omp parallel for
|
|
111
|
-
for (omp_index i = 0; i < static_cast<omp_index>(rank.getDimension()); ++i) {
|
|
112
|
-
scoreData[i] = rank[i] / sum;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
hasRun = true;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
template <class Matrix>
|
|
119
|
-
const std::vector<double> &AlgebraicPageRank<Matrix>::scores() const {
|
|
120
|
-
assureFinished();
|
|
121
|
-
return scoreData;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
template <class Matrix>
|
|
125
|
-
std::vector<std::pair<node, double>> AlgebraicPageRank<Matrix>::ranking() {
|
|
126
|
-
assureFinished();
|
|
127
|
-
std::vector<std::pair<node, double>> ranking;
|
|
128
|
-
for (index i = 0; i < scoreData.size(); ++i) {
|
|
129
|
-
ranking.push_back({i, scoreData[i]});
|
|
130
|
-
}
|
|
131
|
-
Aux::Parallel::sort(
|
|
132
|
-
ranking.begin(), ranking.end(),
|
|
133
|
-
[](std::pair<node, double> x, std::pair<node, double> y) { return x.second > y.second; });
|
|
134
|
-
return ranking;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
template <class Matrix>
|
|
138
|
-
double AlgebraicPageRank<Matrix>::score(node v) {
|
|
139
|
-
assureFinished();
|
|
140
|
-
return scoreData.at(v);
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
} /* namespace NetworKit */
|
|
144
|
-
|
|
145
|
-
#endif // NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_PAGE_RANK_HPP_
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* AlgebraicSpanningEdgeCentrality.hpp
|
|
3
|
-
*
|
|
4
|
-
* Created on: Jul 12, 2016
|
|
5
|
-
* Author: Michael Wegner (michael.wegner@student.kit.edu)
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
#ifndef NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_SPANNING_EDGE_CENTRALITY_HPP_
|
|
9
|
-
#define NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_SPANNING_EDGE_CENTRALITY_HPP_
|
|
10
|
-
|
|
11
|
-
#include <atomic>
|
|
12
|
-
#include <cmath>
|
|
13
|
-
|
|
14
|
-
#include <networkit/centrality/Centrality.hpp>
|
|
15
|
-
#include <networkit/numerics/LAMG/Lamg.hpp>
|
|
16
|
-
|
|
17
|
-
namespace NetworKit {
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* @ingroup algebraic
|
|
21
|
-
* Implementation of Spanning edge centrality with algebraic notation.
|
|
22
|
-
*/
|
|
23
|
-
template <class Matrix>
|
|
24
|
-
class AlgebraicSpanningEdgeCentrality : public Centrality {
|
|
25
|
-
public:
|
|
26
|
-
/**
|
|
27
|
-
* Constructs an instance of the AlgebraicSpanningEdgeCentrality algorithm for the given Graph
|
|
28
|
-
* @a graph. The tolerance @a tol is used to control the approximation error when approximating
|
|
29
|
-
* the spanning edge centrality for @a graph.
|
|
30
|
-
* @param graph
|
|
31
|
-
* @param tol
|
|
32
|
-
*/
|
|
33
|
-
AlgebraicSpanningEdgeCentrality(const Graph &graph, double tol = 0.1)
|
|
34
|
-
: Centrality(graph), tol(tol) {}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* Compute spanning edge centrality exactly.
|
|
38
|
-
*/
|
|
39
|
-
void run() override;
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Approximate spanning edge centrality scores with the Johnson-Lindenstrauss transform.
|
|
43
|
-
*/
|
|
44
|
-
void runApproximation();
|
|
45
|
-
|
|
46
|
-
private:
|
|
47
|
-
double tol;
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
template <class Matrix>
|
|
51
|
-
void AlgebraicSpanningEdgeCentrality<Matrix>::run() {
|
|
52
|
-
const count n = G.numberOfNodes();
|
|
53
|
-
const count m = G.numberOfEdges();
|
|
54
|
-
scoreData.clear();
|
|
55
|
-
scoreData.resize(m, 0.0);
|
|
56
|
-
|
|
57
|
-
std::vector<Vector> rhs(m, Vector(n));
|
|
58
|
-
this->G.parallelForEdges([&](node u, node v, edgeid e) {
|
|
59
|
-
rhs[e][u] = +1;
|
|
60
|
-
rhs[e][v] = -1;
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
std::vector<Vector> solutions(m, Vector(n));
|
|
64
|
-
|
|
65
|
-
Lamg<Matrix> lamg(1e-5);
|
|
66
|
-
lamg.setupConnected(Matrix::laplacianMatrix(this->G));
|
|
67
|
-
lamg.parallelSolve(rhs, solutions);
|
|
68
|
-
|
|
69
|
-
this->G.parallelForEdges([&](node u, node v, edgeid e) {
|
|
70
|
-
double diff = solutions[e][u] - solutions[e][v];
|
|
71
|
-
scoreData[e] = std::fabs(diff);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
hasRun = true;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
template <class Matrix>
|
|
78
|
-
void AlgebraicSpanningEdgeCentrality<Matrix>::runApproximation() {
|
|
79
|
-
const count n = G.numberOfNodes();
|
|
80
|
-
const count m = G.numberOfEdges();
|
|
81
|
-
scoreData.clear();
|
|
82
|
-
scoreData.resize(m, 0.0);
|
|
83
|
-
double epsilon2 = tol * tol;
|
|
84
|
-
const count k = std::ceil(std::log2(n)) / epsilon2;
|
|
85
|
-
double randTab[2] = {1.0 / std::sqrt(k), -1.0 / std::sqrt(k)};
|
|
86
|
-
|
|
87
|
-
const auto rhsLoader = [&](count, Vector &yRow) -> Vector & {
|
|
88
|
-
yRow.fill(0);
|
|
89
|
-
G.forEdges([&](node u, node v, edgeweight w, index) {
|
|
90
|
-
double rand = randTab[Aux::Random::integer(1)];
|
|
91
|
-
yRow[u] += w * rand;
|
|
92
|
-
yRow[v] -= w * rand;
|
|
93
|
-
});
|
|
94
|
-
return yRow;
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
std::vector<std::atomic<double>> scoreDataAtom(m);
|
|
98
|
-
const auto resultProcessor = [&](count, const Vector &zRow) {
|
|
99
|
-
G.forEdges([&](node u, node v, edgeid e) {
|
|
100
|
-
double diff = (zRow[u] - zRow[v]);
|
|
101
|
-
diff *= diff;
|
|
102
|
-
for (double old = scoreDataAtom[e].load(); !scoreDataAtom[e].compare_exchange_strong(
|
|
103
|
-
old, old + diff, std::memory_order_relaxed);)
|
|
104
|
-
;
|
|
105
|
-
});
|
|
106
|
-
};
|
|
107
|
-
|
|
108
|
-
Lamg<Matrix> lamg(1e-5);
|
|
109
|
-
lamg.setupConnected(Matrix::laplacianMatrix(this->G));
|
|
110
|
-
lamg.parallelSolve(rhsLoader, resultProcessor, std::make_pair(k, n));
|
|
111
|
-
|
|
112
|
-
#pragma omp parallel for
|
|
113
|
-
for (omp_index i = 0; i < static_cast<omp_index>(m); ++i) {
|
|
114
|
-
scoreData[i] = scoreDataAtom[i].load(std::memory_order_relaxed);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
hasRun = true;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
} /* namespace NetworKit */
|
|
121
|
-
|
|
122
|
-
#endif // NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_SPANNING_EDGE_CENTRALITY_HPP_
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* AlgebraicTriangleCounting.hpp
|
|
3
|
-
*
|
|
4
|
-
* Created on: Jul 12, 2016
|
|
5
|
-
* Author: Michael Wegner (michael.wegner@student.kit.edu)
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
#ifndef NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_TRIANGLE_COUNTING_HPP_
|
|
9
|
-
#define NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_TRIANGLE_COUNTING_HPP_
|
|
10
|
-
|
|
11
|
-
#include <networkit/base/Algorithm.hpp>
|
|
12
|
-
|
|
13
|
-
namespace NetworKit {
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* @ingroup algebraic
|
|
17
|
-
* Implements a triangle counting algorithm for nodes based on algebraic methods.
|
|
18
|
-
*/
|
|
19
|
-
template <class Matrix>
|
|
20
|
-
class AlgebraicTriangleCounting : public Algorithm {
|
|
21
|
-
public:
|
|
22
|
-
/**
|
|
23
|
-
* Creates an instance of AlgebraicTriangleCounting for the given Graph @a graph.
|
|
24
|
-
* @param graph
|
|
25
|
-
*/
|
|
26
|
-
AlgebraicTriangleCounting(const Graph &graph)
|
|
27
|
-
: A(Matrix::adjacencyMatrix(graph)), directed(graph.isDirected()) {}
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Computes the number of triangles each node is part of. A triangle is considered as a set of
|
|
31
|
-
* nodes (i.e. if there is a triangle (u,v,w) it only counts as one triangle at each node).
|
|
32
|
-
*/
|
|
33
|
-
void run() override;
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* Returns the score of node @a u.
|
|
37
|
-
* @param u
|
|
38
|
-
*/
|
|
39
|
-
count score(node u) const {
|
|
40
|
-
assureFinished();
|
|
41
|
-
assert(u < A.numberOfRows());
|
|
42
|
-
return nodeScores[u];
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Returns the scores for all nodes of the graph.
|
|
47
|
-
*/
|
|
48
|
-
const std::vector<count> &getScores() const {
|
|
49
|
-
assureFinished();
|
|
50
|
-
return nodeScores;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
private:
|
|
54
|
-
Matrix A;
|
|
55
|
-
bool directed;
|
|
56
|
-
std::vector<count> nodeScores;
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
template <class Matrix>
|
|
60
|
-
void AlgebraicTriangleCounting<Matrix>::run() {
|
|
61
|
-
Matrix powA = A * A * A;
|
|
62
|
-
|
|
63
|
-
nodeScores.clear();
|
|
64
|
-
nodeScores.resize(A.numberOfRows(), 0);
|
|
65
|
-
|
|
66
|
-
#pragma omp parallel for
|
|
67
|
-
for (omp_index i = 0; i < static_cast<omp_index>(powA.numberOfRows()); ++i) {
|
|
68
|
-
nodeScores[i] = directed ? powA(i, i) : powA(i, i) / 2.0;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
hasRun = true;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
} /* namespace NetworKit */
|
|
75
|
-
|
|
76
|
-
#endif // NETWORKIT_ALGEBRAIC_ALGORITHMS_ALGEBRAIC_TRIANGLE_COUNTING_HPP_
|
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
#ifndef NETWORKIT_AUXILIARY_ALIGNED_ALLOCATOR_HPP_
|
|
3
|
-
#define NETWORKIT_AUXILIARY_ALIGNED_ALLOCATOR_HPP_
|
|
4
|
-
|
|
5
|
-
#include <stdexcept>
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Allocator for aligned data.
|
|
9
|
-
*
|
|
10
|
-
* Modified from the Mallocator from Stephan T. Lavavej.
|
|
11
|
-
* <http://blogs.msdn.com/b/vcblog/archive/2008/08/28/the-mallocator.aspx>
|
|
12
|
-
*/
|
|
13
|
-
template <typename T, size_t Alignment>
|
|
14
|
-
class AlignedAllocator {
|
|
15
|
-
public:
|
|
16
|
-
// The following will be the same for virtually all allocators.
|
|
17
|
-
typedef T *pointer;
|
|
18
|
-
typedef const T *const_pointer;
|
|
19
|
-
typedef T &reference;
|
|
20
|
-
typedef const T &const_reference;
|
|
21
|
-
typedef T value_type;
|
|
22
|
-
typedef size_t size_type;
|
|
23
|
-
typedef ptrdiff_t difference_type;
|
|
24
|
-
|
|
25
|
-
T *address(T &r) const { return &r; }
|
|
26
|
-
|
|
27
|
-
const T *address(const T &s) const { return &s; }
|
|
28
|
-
|
|
29
|
-
size_t max_size() const {
|
|
30
|
-
// The following has been carefully written to be independent of
|
|
31
|
-
// the definition of size_t and to avoid signed/unsigned warnings.
|
|
32
|
-
return (static_cast<size_t>(0) - static_cast<size_t>(1)) / sizeof(T);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
// The following must be the same for all allocators.
|
|
36
|
-
template <typename U>
|
|
37
|
-
struct rebind {
|
|
38
|
-
typedef AlignedAllocator<U, Alignment> other;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
bool operator!=(const AlignedAllocator &other) const { return !(*this == other); }
|
|
42
|
-
|
|
43
|
-
void construct(T *const p, const T &t) const {
|
|
44
|
-
void *const pv = static_cast<void *>(p);
|
|
45
|
-
|
|
46
|
-
new (pv) T(t);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
void destroy(T *const p) const { p->~T(); }
|
|
50
|
-
|
|
51
|
-
// Returns true if and only if storage allocated from *this
|
|
52
|
-
// can be deallocated from other, and vice versa.
|
|
53
|
-
// Always returns true for stateless allocators.
|
|
54
|
-
bool operator==(const AlignedAllocator &) const { return true; }
|
|
55
|
-
|
|
56
|
-
// Default constructor, copy constructor, rebinding constructor, and destructor.
|
|
57
|
-
// Empty for stateless allocators.
|
|
58
|
-
AlignedAllocator() {}
|
|
59
|
-
|
|
60
|
-
AlignedAllocator(const AlignedAllocator &) {}
|
|
61
|
-
|
|
62
|
-
template <typename U>
|
|
63
|
-
AlignedAllocator(const AlignedAllocator<U, Alignment> &) {}
|
|
64
|
-
|
|
65
|
-
~AlignedAllocator() {}
|
|
66
|
-
|
|
67
|
-
// The following will be different for each allocator.
|
|
68
|
-
T *allocate(size_t n) const {
|
|
69
|
-
// The return value of allocate(0) is unspecified.
|
|
70
|
-
// Mallocator returns NULL in order to avoid depending
|
|
71
|
-
// on malloc(0)'s implementation-defined behavior
|
|
72
|
-
// (the implementation can define malloc(0) to return NULL,
|
|
73
|
-
// in which case the bad_alloc check below would fire).
|
|
74
|
-
// All allocators can return NULL in this case.
|
|
75
|
-
if (n == 0)
|
|
76
|
-
return NULL;
|
|
77
|
-
|
|
78
|
-
// All allocators should contain an integer overflow check.
|
|
79
|
-
// The Standardization Committee recommends that std::length_error
|
|
80
|
-
// be thrown in the case of integer overflow.
|
|
81
|
-
if (n > max_size())
|
|
82
|
-
throw std::length_error("AlignedAllocator<T>::allocate() - Integer overflow.");
|
|
83
|
-
|
|
84
|
-
// Mallocator wraps malloc().
|
|
85
|
-
void *const pv = _mm_malloc(n * sizeof(T), Alignment);
|
|
86
|
-
|
|
87
|
-
// Allocators should throw std::bad_alloc in the case of memory allocation failure.
|
|
88
|
-
if (pv == NULL)
|
|
89
|
-
throw std::bad_alloc();
|
|
90
|
-
|
|
91
|
-
return static_cast<T *>(pv);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
void deallocate(T *const p, size_t) const { _mm_free(p); }
|
|
95
|
-
|
|
96
|
-
// The following will be the same for all allocators that ignore hints.
|
|
97
|
-
template <typename U>
|
|
98
|
-
T *allocate(size_t n, const U * /* const hint */) const {
|
|
99
|
-
return allocate(n);
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
// Allocators are not required to be assignable, so
|
|
103
|
-
// all allocators should have a private unimplemented
|
|
104
|
-
// assignment operator. Note that this will trigger the
|
|
105
|
-
// off-by-default (enabled under /Wall) warning C4626
|
|
106
|
-
// "assignment operator could not be generated because a
|
|
107
|
-
// base class assignment operator is inaccessible" within
|
|
108
|
-
// the STL headers, but that warning is useless.
|
|
109
|
-
private:
|
|
110
|
-
AlignedAllocator &operator=(const AlignedAllocator &);
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
#endif // NETWORKIT_AUXILIARY_ALIGNED_ALLOCATOR_HPP_
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
#ifndef NETWORKIT_AUXILIARY_ARRAY_TOOLS_HPP_
|
|
2
|
-
#define NETWORKIT_AUXILIARY_ARRAY_TOOLS_HPP_
|
|
3
|
-
|
|
4
|
-
#include <cmath>
|
|
5
|
-
#include <utility>
|
|
6
|
-
#include <vector>
|
|
7
|
-
|
|
8
|
-
#include <networkit/Globals.hpp>
|
|
9
|
-
|
|
10
|
-
#include <tlx/math/integer_log2.hpp>
|
|
11
|
-
|
|
12
|
-
namespace Aux {
|
|
13
|
-
namespace ArrayTools {
|
|
14
|
-
|
|
15
|
-
template <class ArrayIt, class PermIt>
|
|
16
|
-
void applyPermutation(ArrayIt first, ArrayIt last, PermIt permFirst) {
|
|
17
|
-
|
|
18
|
-
using PermType = typename std::iterator_traits<PermIt>::value_type;
|
|
19
|
-
static_assert(std::is_integral<PermType>::value, "Elements of permutation must be integral.");
|
|
20
|
-
|
|
21
|
-
const size_t arraySize =
|
|
22
|
-
static_cast<typename std::iterator_traits<ArrayIt>::difference_type>(last - first);
|
|
23
|
-
|
|
24
|
-
const size_t usedBitsInPerm = tlx::integer_log2_ceil(arraySize);
|
|
25
|
-
// Avoid to use the sign bit if signed integral
|
|
26
|
-
const size_t bitsInPerm = sizeof(PermType) * 8 - (std::is_signed<PermType>::value ? 1 : 0);
|
|
27
|
-
|
|
28
|
-
if (bitsInPerm == usedBitsInPerm) {
|
|
29
|
-
// All bits in permutation are needed, we mark swapped elements with a bool vector
|
|
30
|
-
std::vector<bool> swapped(arraySize);
|
|
31
|
-
for (size_t i = 0; i < arraySize; ++i) {
|
|
32
|
-
if (swapped[i])
|
|
33
|
-
continue;
|
|
34
|
-
|
|
35
|
-
size_t cur = i;
|
|
36
|
-
swapped[cur] = true;
|
|
37
|
-
auto tmp = std::move(first[cur]);
|
|
38
|
-
|
|
39
|
-
while (static_cast<size_t>(permFirst[cur]) != i) {
|
|
40
|
-
first[cur] = std::move(first[permFirst[cur]]);
|
|
41
|
-
cur = permFirst[cur];
|
|
42
|
-
swapped[cur] = true;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
first[cur] = std::move(tmp);
|
|
46
|
-
}
|
|
47
|
-
} else {
|
|
48
|
-
// Not all bits in the permutation are needed, we use the last (or, if signed integral,
|
|
49
|
-
// second to last) bit in the permutation to mark swapped elements
|
|
50
|
-
const auto mask = PermType{1} << (bitsInPerm - (std::is_signed<PermType>::value ? 2 : 1));
|
|
51
|
-
|
|
52
|
-
const auto swapped = [&permFirst, mask = mask](size_t i) -> bool {
|
|
53
|
-
return (permFirst[i] & mask) != 0;
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
const auto markSwapped = [&permFirst, mask = mask](size_t i) -> void {
|
|
57
|
-
permFirst[i] |= mask;
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
for (size_t i = 0; i < arraySize; ++i) {
|
|
61
|
-
if (swapped(i))
|
|
62
|
-
continue;
|
|
63
|
-
|
|
64
|
-
size_t cur = i;
|
|
65
|
-
markSwapped(cur);
|
|
66
|
-
auto tmp = std::move(first[cur]);
|
|
67
|
-
|
|
68
|
-
while (static_cast<size_t>(permFirst[cur] & ~mask) != i) {
|
|
69
|
-
first[cur] = std::move(first[permFirst[cur] & ~mask]);
|
|
70
|
-
cur = permFirst[cur] & ~mask;
|
|
71
|
-
markSwapped(cur);
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
first[cur] = std::move(tmp);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
for (size_t i = 0; i < arraySize; ++i)
|
|
78
|
-
permFirst[i] &= ~mask;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
} // namespace ArrayTools
|
|
83
|
-
} // namespace Aux
|
|
84
|
-
|
|
85
|
-
#endif // NETWORKIT_AUXILIARY_ARRAY_TOOLS_HPP_
|