Skip to content

Commit

Permalink
Merge pull request #324 from taoliu/feat_py3
Browse files Browse the repository at this point in the history
Migrate MACS2 to Python3
  • Loading branch information
taoliu committed Oct 2, 2019
2 parents 85920ca + af91e93 commit 2b0ee05
Show file tree
Hide file tree
Showing 153 changed files with 7,163,292 additions and 1,252 deletions.
54 changes: 0 additions & 54 deletions .github/workflows/macs2.yml

This file was deleted.

12 changes: 2 additions & 10 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -14,20 +14,12 @@ test/subcommandstest_run_*
test/__pycache__

.DS_Store

MACS2/IO/cParser.h

MACS2/IO/numpy.pxd

MACS2/mnumpy.pxd

MACS2/numpy.pxd
.cache

test/NOSPMR.ppois.bdg_ppois.bdg
test/*_run_*

MACS2.egg-info
MACS2/IO/*.c
MACS2/*.c

.pytest_cache
.cache
9 changes: 6 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,16 @@
language: python
python:
- '2.7'
- "3.7"
- "3.6"
- "3.5"
install:
- pip install -r requirements.txt
- pip install --upgrade pip
- pip install --upgrade -r requirements.txt
- python setup.py install
script:
- pytest
- cd test
- ./test.sh subcommandstest
- ./test.sh smalldatatest
- cd ..
deploy:
provider: pypi
Expand Down
21 changes: 20 additions & 1 deletion ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,22 @@
2019-10-01 Tao Liu <vladimir.liu@gmail.com>
MACS version 2.2.4 (Python3)

* Features added

1) First Python3 version MACS2 released.

2) Version number 2.2.X will be used for MACS2 in Python3, in
parallel to 2.1.X.

3) More comprehensive test.sh script to check consistency of
results from Python2 version and Python3 version.

4) Simplify setup.py script since the newest version transparently
supports cython. And when cython is not installed by user,
setup.py can still compile using only C codes.

5) Fix Signal.pyx to use np.array instead of np.mat.

2019-09-30 Tao Liu <vladimir.liu@gmail.com>
MACS version 2.1.4

Expand Down Expand Up @@ -96,7 +115,7 @@
2016-03-09 Tao Liu <vladimir.liu@gmail.com>
MACS version 2.1.1 20160309

* Retire the tag:rc.
* Retire the tag:rc.

* Fixed spelling. Merged pull request #120. Thank @mr-c!

Expand Down
2 changes: 1 addition & 1 deletion DOCKER/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# Use an official Python runtime as a parent image
FROM python:2.7.15
FROM python:3.7

# install numpy and MACS2
RUN git clone https://github.com/taoliu/MACS.git /MACS
Expand Down
6 changes: 3 additions & 3 deletions DOCKER/Dockerfile-slim
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
# Use an official Python runtime as a parent image
FROM python:2.7 AS build
FROM python:3.7 AS build

# install numpy and MACS2
RUN git clone https://github.com/taoliu/MACS.git /MACS
RUN pip install --trusted-host pypi.python.org --upgrade pip && pip install --trusted-host pypi.python.org -r /MACS/requirements.txt
RUN cd /MACS && python setup.py install

FROM python:2.7-slim
FROM python:3.7-slim

# copy compiled files over to python-slim
COPY --from=build /usr/local/bin/macs2 /usr/local/bin/
COPY --from=build /usr/local/lib/python2.7/site-packages/ /usr/local/lib/python2.7/site-packages/
COPY --from=build /usr/local/lib/python3.7/site-packages/ /usr/local/lib/python3.7/site-packages/

# Define environment variable
ENTRYPOINT ["macs2"]
8 changes: 4 additions & 4 deletions DOCKER/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,13 @@ MACS2 is a bioinformatics algorithm to analyze ChIP-seq datasets.

## Pull the image

Currently, there are two types of MACS2 images, one based on official Python2.7 docker image, and the other based on official Python2.7-slim docker image. Only if space is a concern, and you keep using Python2.7-slim docker for all the Python 2.7 applications, pull the slim one.
Currently, there are two types of MACS2 images, one based on official Python3.7 docker image, and the other based on official Python3.7-slim docker image. Only if space is a concern, and you keep using Python3.7-slim docker for all the Python 3.7 applications, pull the slim one.

To pull the regular MACS2 image:

```docker pull fooliu/macs2```

To pull the MACS2 image based on Python2.7-slim
To pull the MACS2 image based on Python3.7-slim

```docker pull fooliu/macs2:py27-slim```

Expand All @@ -28,8 +28,8 @@ The first part ```-v $PWD:/data/``` will mount the CURRENT directory ```$PWD```

# Built with

* Python2.7 docker image 2.7.15
* pip install numpy version 1.16, cython 0.29, and pytest 4.6
* Python3.7 docker image 3.7
* pip install numpy version 1.17, cython 0.29, and pytest 4.6
* git clone MACS codes from github master branch then run ```setup.py```

# Author
Expand Down
97 changes: 69 additions & 28 deletions INSTALL.md
Original file line number Diff line number Diff line change
@@ -1,54 +1,86 @@
# INSTALL Guide For MACS
Time-stamp: <2019-09-30 14:47:45 taoliu>
Time-stamp: <2019-10-02 12:06:33 taoliu>

Please check the following instructions to complete your installation.

## Prerequisites

Python version must be equal to *2.7* to run MACS.
MACS v2.2.x requires Python3. We have tested MACS in Python3.5, 3.6
and 3.7. MACS runs slower under Python3.5, so Python3.6 or Python3.7
is recommanded.

[Numpy](http://www.scipy.org/Download) (>=1.16) are required to run MACS v2.
MACS also requires [Numpy](http://www.scipy.org/Download) (>=1.17).

GCC is required to compile `.c` codes in MACS v2 package, and python
header files are needed. If you are using Mac OSX, I recommend you
install Xcode; if you are using Linux, you need to make sure
`python-dev` is installed.
`python-dev` package is installed -- the actual package name depends
on the Linux OS distribution you are using.

[Cython](http://cython.org/) (>=0.29) is required to generate `.c`
files from `.pyx` files using `setup.py` script.
[Cython](http://cython.org/) is **NOT** required although most of
MACS codes are written in Cython. But if you plan to generate `.c`
files from `.pyx` by your own, you can install Cython (>=0.29), then
use `setup.py` script.

## Easy installation through PyPI
## Prepare a virtual Python environment

The easiest way to install MACS2 is through PyPI system. Get pip_ if
it's not available in your system. *Note* if you have already
installed numpy and scipy system-wide, you can use `virtualenv
--system-site-packages` to let your virtual Python environment have
access to system-wide numpy and scipy libraries so that you don't need
to install them again.
I strongly recommend to install your MACS program in a virtual
environment, so that you have full control of your installation and
won't mess up with your system libraries. To learn about virtual
environment, read
[this article](https://docs.python.org/3/library/venv.html). A simple
way to create a virtual environment of Python3 is

Then under command line, type `pip install MACS2`. PyPI will
install Numpy and Cython automatically if they are absent.
`$ python3 -m venv MyPythonEnv/`

To upgrade MACS2, type `pip install --upgrade MACS2`. It will check
Then active it by

`$ source MyPythonEnv/bin/active`

## Install through PyPI

The easiest way to install MACS is through PyPI system. Get `pip` if
it's not available in your system. If you create a virtual environment
as described before, your `pip` command will install everything under
the folder you specified previously through `python3 -m env` command.

Then under the command line, type `pip install macs2`. PyPI will
install Numpy automatically if it is absent.

To upgrade MACS2, type `pip install --upgrade macs2`. It will check
currently installed MACS2, compare the version with the one on PyPI
repository, download and install newer version while necessary.

## Install through Conda

Please check [MACS2 page on
bioconda](https://anaconda.org/bioconda/macs2) for instructions.

## Install through Debian APT

MACS is included in Debian Stretch/Buster/Unstable blessed by some
kind of Supper Cow Powers.

## Install from source

MACS uses Python's distutils tools for source installations. To
install a source distribution of MACS, unpack the distribution tarball
and open up a command terminal. Go to the directory where you unpacked
MACS, and simply run the install script:
MACS uses Python's [setuptools](https://setuptools.readthedocs.io) for
source code installations. To install a source distribution of MACS,
unpack the distribution tarball, or clone Git repository with `git
clone git@github.com:taoliu/MACS.git`. Go to the directory where you
unpacked MACS, and simply run the install script:

`$ python setup.py install`

By default, the script will install python library and executable
codes globally, which means you need to be root or administrator of
the machine so as to complete the installation. Please contact the
administrator of that machine if you want their help. If you need to
provide a nonstandard install prefix, or any other nonstandard
options, you can provide many command line options to the install
script. Use the –help option to see a brief list of available options:
codes according to the environment. When you run the command under
virtualenv, the script will install to the virtual environment
instead. When you run it without virtual environment, you may need to
be root or administrator of the machine so as to complete the
installation. Please contact the system administrator if you want
their help. If you need to provide a nonstandard install prefix, or
any other nonstandard options, you can provide many command line
options to the install script. Use the `--help` option to see a brief
list of available options:

`$ python setup.py --help`

Expand All @@ -57,9 +89,18 @@ directory, use this command:

`$ python setup.py install --prefix /home/taoliu/`

As mentioned in *Prerequisites*, you don't need to install Cython in
order to install MACS. When Cython is available, this setup script
will regenerate C codes from Pyx codes when necessary. When Cython is
not available, this setup script will just use the C codes included in
release package (or your Github clone) for installation.

## Configure enviroment variables

*Note*, if you are using virtual environment, you should skip this
section since all the corresponding environment variables have been
correctly set while you `activate` the environment.

After running the setup script, you might need to add the install
location to your `PYTHONPATH` and `PATH` environment variables. The
process for doing this varies on each platform, but the general
Expand All @@ -70,7 +111,7 @@ concept is the same across platforms.
To set up your `PYTHONPATH` environment variable, you'll need to add the
value `PREFIX/lib/pythonX.Y/site-packages` to your existing
`PYTHONPATH`. In this value, X.Y stands for the major–minor version of
Python you are using (such as 2.7 ; you can find this with
Python you are using (such as 3.7 ; you can find this with
`sys.version[:3]` from a Python command line). `PREFIX` is the install
prefix where you installed MACS. If you did not specify a prefix on
the command line, MACS will be installed using Python's sys.prefix
Expand All @@ -79,7 +120,7 @@ value.
On Linux, using bash, I include the new value in my `PYTHONPATH` by
adding this line to my `~/.bashrc`::

`$ export PYTHONPATH=/home/taoliu/lib/python2.7/site-packages:$PYTHONPATH`
`$ export PYTHONPATH=/home/taoliu/lib/python3.7/site-packages:$PYTHONPATH`

Using Windows, you need to open up the system properties dialog, and
locate the tab labeled Environment. Add your value to the `PYTHONPATH`
Expand Down
2 changes: 1 addition & 1 deletion MACS2/Constants.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
MACS_VERSION = "2.1.4"
MACS_VERSION = "2.2.4"
#MACSDIFF_VERSION = "1.0.4 20110212 (tag:alpha)"
FILTERDUP_VERSION = "1.0.0 20140616"
RANDSAMPLE_VERSION = "1.0.0 20120703"
Expand Down

0 comments on commit 2b0ee05

Please sign in to comment.