Giter Club home page Giter Club logo

bctpy's Introduction

Brain Connectivity Toolbox for Python version 0.5.2

Author: Roan LaPlante [email protected]

Tested against python 2.7 and 3.5+.

Copyright information

This program strictly observes the tenets of fundamentalist Theravada Mahasi style Buddhism. Any use of this program in violation of these aforementioned tenets or in violation of the principles described in the Visuddhimagga Sutta is strictly prohibited and punishable by extensive Mahayana style practice. By being or not being mindful of the immediate present moment sensations involved in the use of this program, you confer your acceptance of these terms and conditions.

Note that the observation of the tenets of fundamentalist Theravada Mahasi style Buddhism and the Visuddhimagga Sutta is optional as long as the terms and conditions of the GNU GPLv3+ are upheld.

Packages used

BCTPY is written in pure python and requires only scipy and numpy. scipy is required for a couple of functions for its statistical and linear algebra packages which have some features not available in numpy alone. If you don't have scipy, most functions that do not need scipy functionality will still work.

Note that graphs must be passed in as numpy.array rather than numpy.matrix. Other constraints/edge cases of the adjacency matrices (e.g. self-loops, negative weights) behave similarly to the matlab functions.

A small number of functions also depend on networkx. This notably includes Network-Based Statistic, a nonparametric test for differences in undirected weighted graphs from different populations. Ideally this dependency should be removed in the future.

Nosetests is used for the test suite. The test suite is not complete.

About bctpy and other authors

BCT is a matlab toolbox with many graph theoretical measures off of which bctpy is based. I did not write BCT (apart from small bugfixes I have submitted) and a quality of life improvements that I have taken liberties to add. With few exceptions, bctpy is a direct translation of matlab code to python.

bctpy should be considered beta software, with BCT being the gold standard by comparison. I did my best to test all functionality in bctpy, but much of it is arcane math that flies over the head of this humble programmer. There are bugs lurking in bctpy, the question is not whether but how many. If you locate bugs, please consider submitting pull requests.

Many thanks to Stefan Fuertinger for his assistance tracking down a number of bugs. Stefan Fuertinger has a similar software package dealing with brain network functionality at http://research.mssm.edu/simonyanlab/analytical-tools/

Many thanks to Chris Barnes for his assistance in documenting a number of issues and facilitating a number of test cases.

Credit for writing BCT (the matlab version) goes to the following list of authors, especially Olaf Sporns and Mika Rubinov.

  • Olaf Sporns
  • Mikail Rubinov
  • Yusuke Adachi
  • Andrea Avena
  • Danielle Bassett
  • Richard Betzel
  • Joaquin Goni
  • Alexandros Goulas
  • Patric Hagmann
  • Christopher Honey
  • Martijn van den Heuvel
  • Rolf Kotter
  • Jonathan Power
  • Murray Shanahan
  • Andrew Zalesky

In order to be a bit more compact I have removed the accreditations from the docstrings each functions. This does not in any way mean that I wish to take credit from the individual contributions. I have moved these accreditations to the credits file.

bctpy's People

Contributors

aestrivex avatar aksimhal avatar ariekahn avatar clbarnes avatar hippocampusgirl avatar i-zaak avatar jdkent avatar muriloschaefer avatar pedroconst avatar poldrack avatar pulkit-khandelwal avatar rmarkello avatar rudimeier avatar sviter avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.