Skip to content
forked from SheffieldML/GPy

Gaussian processes framework in python

License

Notifications You must be signed in to change notification settings

ertandemiral/GPy

 
 

Repository files navigation

GPy

A Gaussian processes framework in Python.

Continuous integration status: CI status

Python 3 Compatibility

Work is underway to make GPy run on Python 3.

  • All tests in the testsuite now run on Python3.

To see this for yourself, in Ubuntu 14.04, you can do

git clone https://github.com/mikecroucher/GPy.git
cd GPy
git checkout devel
python3 setup.py build_ext --inplace
nosetests3 GPy/testing

nosetests3 is Ubuntu's way of reffering to the Python 3 version of nosetests. You install it with

sudo apt-get install python3-nose

The command python3 setup.py build_ext --inplace builds the Cython extensions. IF it doesn't work, you may need to install this:

sudo apt-get install python3-dev
  • Test coverage is less than 100% so it is expected that there is still more work to be done. We need more tests and examples to try out.
  • All weave functions not covered by the test suite are simply commented out. Can add equivalents later as test functions become available
  • A set of benchmarks would be useful!

Citation

@Misc{gpy2014,
  author =   {The GPy authors},
  title =    {{GPy}: A Gaussian process framework in python},
  howpublished = {\url{http://github.com/SheffieldML/GPy}},
  year = {2012--2014}
}

Pronounciation

We like to pronounce it 'Gee-pie'.

Getting started: installing with pip

The simplest way to install GPy is using pip. Ubuntu users can do:

sudo apt-get install python-pip
pip install gpy

On windows, we recommend the anaconda python distribution. We've also had luck with enthought.

On a fresh install of windows 8.1, we downloaded the Anaconda python distribution, started the anaconda command prompt and typed

pip install GPy

Everything seems to work: from here you can type ipython and then import GPy; GPy.tests(). Working as of 21/11/14

If you'd like to install from source, or want to contribute to the project (e.g. by sending pull requests via github), read on.

Ubuntu hackers

For the most part, the developers are using ubuntu. To install the required packages:

sudo apt-get install python-numpy python-scipy python-matplotlib

clone this git repository and add it to your path:

git clone [email protected]:SheffieldML/GPy.git ~/SheffieldML
echo 'PYTHONPATH=$PYTHONPATH:~/SheffieldML' >> ~/.bashrc

OSX

Everything appears to work out-of-the box using enthought on osx Mavericks. Download/clone GPy, and then add GPy to your PYTHONPATH

git clone [email protected]:SheffieldML/GPy.git ~/SheffieldML
echo 'PYTHONPATH=$PYTHONPATH:~/SheffieldML' >> ~/.profile

Compiling documentation:

The documentation is stored in doc/ and is compiled with the Sphinx Python documentation generator, and is written in the reStructuredText format.

The Sphinx documentation is available here: http://sphinx-doc.org/latest/contents.html

Installing dependencies:

To compile the documentation, first ensure that Sphinx is installed. On Debian-based systems, this can be achieved as follows:

sudo apt-get install python-pip
sudo pip install sphinx

A LaTeX distribution is also required to compile the equations. Note that the extra packages are necessary to install the unicode packages. To compile the equations to PNG format for use in HTML pages, the package dvipng must be installed. IPython is also required. On Debian-based systems, this can be achieved as follows:

sudo apt-get install texlive texlive-latex-extra texlive-base texlive-recommended
sudo apt-get install dvipng
sudo apt-get install ipython

Compiling documentation:

The documentation can be compiled as follows:

cd doc
make html

The HTML files are then stored in doc/_build/

Running unit tests:

Ensure nose is installed via pip:

pip install nose

Run nosetests from the root directory of the repository:

nosetests -v GPy/testing

or from within IPython

import GPy; GPy.tests()

Funding Acknowledgements

Current support for the GPy software is coming through the following projects.

Previous support for the GPy software came from the following projects:

  • BBSRC Project No BB/H018123/2 "An iterative pipeline of computational modelling and experimental design for uncovering gene regulatory networks in vertebrates"
  • Erasysbio "SYNERGY: Systems approach to gene regulation biology through nuclear receptors"

About

Gaussian processes framework in python

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 99.8%
  • Other 0.2%