-
Notifications
You must be signed in to change notification settings - Fork 22
Home
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).
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:
- Download an archive of a release from the releases page.
- 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
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:
- 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).
- 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.
- 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).
Please direct questions to Andy Pohl.