Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

icoder211/BallMapperOptimisation

Open more actions menu

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ball Mapper Optimisation

This repository contains an optimised version of the Ball Mapper Algorithm To know more about the Ball Mapper Algorithm visit: CRAN package of Ball Mapper Algorithm. The relevant files are also included in this repp in R folder for easy reference.

In this repo, the ball.cpp file contains the optimised code The optimisations are:

  • The quadratic procedure of finding and removing duplicate edges has been optimised to $O(nlogn)$. This refers to this block
  • The code has been deployed in C++, speeding up the runtime by 100 times

How to use

  • Run ball.cpp with input file name and epsilon as command line arguments
  • The results are stored in files in the root folder
  • To use the results in the R file (for visualisations etc) use readBallMapperGraphFromFile with FILENAME (in ball.cpp) as argument

Results

The Boston property dataset (/R/data) was modified to create datasets of different sizes and here are the runtimes of the CRAN implementation and our C++ code: Optimised algo performance

As can be seen, there is a consistent 100x improvement in runtime.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published
Morty Proxy This is a proxified and sanitized view of the page, visit original site.