Skip to content
Andy Pohl edited this page Nov 5, 2013 · 42 revisions
**bwtool** is a command-line utility for bigWig files. bigWigs are an indexed and compressed form of wig file, a somewhat standard format for storing genome-wide real-valued signal data. Much of the ENCODE processed data is in this form, and it is appearing more often in GEO as well. The purpose of bwtool is to make these files more useful by providing some convenient functions.

Programs

bwtool's functionality is subdivided into subprograms that roughly fall into three categories: data extraction, analysis, and data modification, although e.g. in the case of the matrix program or the sax program, the boundary between data extraction and analysis isn't very strong. The data modification programs all have the behavior that a bigWig is inputted and a new bigWig is outputted.

Data Extraction Analysis Data modification
extract aggregate fill
matrix chromgraph lift
paste distribution remove
random* find shift
sax summary
window

* available when linking to the GNU Scientific Library (GSL).

Installation

Installing bwtool should just be a matter of a few commands, hopefully. Required are libpng, libm, and zlib, all of which are included in modern linux distributions or Macs with the XCode command-line utilities installed.

To install bwtool, there are two options for obtaining the source code:

  1. Download an archive of a release from the releases page.
  2. Use git to directly clone the repository locally i.e. $ git clone https://github.com/andypohl/bwtool.git

Once the source archive is obtained, unpack/unzip it and do the following:

$ cd bwtool/
$ ./configure
$ make
$ sudo make install

If GSL is not detected in the configuration, it may be possible to install GSL in a home directory first by downloading the package from this site, unpacking the source archive, then compiling with $ ./configure --prefix=$HOME; make; make install. Once GSL is installed, it's possible then to compile with bwtool by configuring first with LDFLAGS and CFLAGS variables set:

$ ./configure --prefix=$HOME LDFLAGS=-L$HOME CFLAGS=-I$HOME

FAQ

Q: The program crashed with a "Segmentation fault" or "Abort" at some stage while it was running. Why?

A: I try my best to test the programs thoroughly, but ultimately some bugs will always be there. Here are some common reasons:

  1. Malformed input. Be very sure that your input conforms to expected formats. I'm especially talking about bed files here... bigWigs are typically solid because they won't be created unless they're in the correct format).
  2. Unforeseen issues. A good example was when someone tried giving as input a file that didn't exist. I try to anticipate as much as I can, because it's always more helpful to provide a nice error message that mentions the mistake than to just have the program crash silently.
  3. Logical errors. These are the most sinister because it indicates the program failed while doing computation. These are the main types of bugs I'm most zealous about seeking and destroying and I will catch most of them before they're public. Nevertheless they're still likely to be found sometimes... and when they are, hopefully I can fix it quickly after I'm made aware (or we... this is open-source now I suppose).

Contact

Please direct questions to Andy Pohl.

Clone this wiki locally