-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HDF5-based Fastq container #8
Comments
cc @antgonza @wasade |
What are the groups @tanaes I can't find the picture we had from before. This seems reasonably in sync from what I remember except that I thought we organized at the top level with a group per sample. This would necessitate per-sample groups in the trimmed results as well. One beneficial tweak on the above: qual can safely be represented as Jagged arrays are not allowed so If the fwd trims are consistent, ie always X nt, then storing as column order may be better. If the trim is variable, then row order makes sense. If we want to eek out a little more storage though, storing as column order will allow for better compression as there will be long stretches of nulls for sequences that aren't of length |
We were thinking that it would be nice to have a base structure that worked for a single fastq, but which could be combined hierarchically to represent multi-sample (or multiple sequence files per sample) structures. Regarding array size and Forward trims are likely to not be consistent, or not enough to depend on. |
Oh, I see. Would it be possible to get a use case description for representing multiple sequence files per sample within this structure? Good point re: Looking back at the format description, you may want to partition the trim information into individual datasets, or store them in column order, as I suspect the access pattern would be to bulk fetch indices in some defined buffer size, then bulk fetch the corresponding offsets, then bulk fetch the sequence. |
I am less familiar with the use-cases of FASTQ files beyond 16S. The structure above makes sense. From searching around, seems like PacBio maintains a format to store FASTQ data in HDF5, not sure if it's entirely applicable, definitely under-documented: Side note, I was reminded of this article from a consortium of image processing experts. Different problem, different domain, but some of their "lessons learned" are good! |
Notes from Qiita meeting: File / sample architecture:Daniel thinks that having per-sample files is good idea. Jon agrees, notes that much bioinformatics software operates on this assumption. Jose notes that there are some advantages to storing multiple samples together. per-lane:Question of whether samples run on multiple lanes, which come from same molecules but end up with different originating fastq files, should exist in separate original files or DownloadingIf storing all fastqs as hdf5 need to figure out mechanisms for downloading. Need to either have some way of serializing -> gzipping on the fly for downloading, or have some sort of staging to generate (and wait) before download. Yoshiki: how often are people downloading? Could check logs to see how frequent this is likely to come up. OtherPerhaps we can get something bare bones put together for next Wednesay!! |
Problem:
Shotgun metagenomic analysis create a large number of partially-redundant Fastq files which occupy a lot of disk space.
As an example, a typical workflow looks something like this, per sample:
So for a typical workflow, the initial data is likely to be ~triplicated on disk. Any additional comparison of parameter values, for example different trimming operations, would require additional duplication of data.
Compounding the problem, different programs use different 'flavors' of Fastq format.
Trimmomatic outputs (up to) four files per trimming run:
Other trimming programs will output interleaved forward/reverse pairs, either discarding pairs where one mate was filtered or inserting empty sequence.
Analysis programs also sometimes require either interleaved format or non-interleaved format. Additionally, some programs can and some cannot accept gzipped input files. In a given analysis, it might be necessary to take a single trimmed, host-filtered Fastq file and reprocess it several different ways on disk to satisfy different downstream programs.
Proposed solution:
An HDF5-based Fastq container format that can read multiple flavors of Fastq sequence file, store them in a compressed but accessible structure, and efficiently write temporary Fastq sequences files of various flavors for use by downstream tools.
Desired characteristics
I'll address each of these briefly.
1. Compressed data structure
We should get this for free with HDF5
2. Simple, fast methods for writing Fastq
Because these would be a purely intermediate format, we're trading compute time necessary to generate the appropriate Fastq type for storage. Thus we'll likely have to write a complete Fastq file every time we want to interact with the object: generating a new file should be fast as possible.
3. Efficient read-name indexing
If the unique read names can be indexed in an accessible way, it will allow selective retrieval of data subsets in cases where you only want to look at a portion of the reads.
4. Compact, additive trimming info
Rather than storing entirely new Fastq files for new trimming steps, it would be great to just store a lightweight mask of the trimmed positions -- this mask could be added to the original sequence container to produce the intermediate, trimmed Fastq for analysis.
It might also be useful if these could be additive -- for example, I might want to trim a Fastq for adapters before host filtering, but then be able to propagate the host trimming information back with reference to the original sequences.
Because trimming programs don't necessarily yield rich per-sequence information about trimming outcomes, there will need to be some simple aligner (or similar) that can calculate the trim positions by comparing the original and trimmed sequence.
5. Container scaling
Frequently, a single biological sample will get sequenced on multiple lanes, generating several starting Fastq files. It would be nice to be able to treat these as a single file while maintaining the run information.
Proposed HDF5 file structure
A basic representation would store a single Fastq file, with each read set off the instrument stored as an N x M array (number of reads by read length) for fast streaming writes. The different datasets (fwd, rev, i1 and i2) will be in the same order. That is, row 1 belongs to the same "read".
Trimming results could be stored as a separate HDF5 referencing the original data structure:
Optionally, the trimming results could also be added to the original HDF5 file as a new group to store all the information in a single file, which will simplify data sharing.
The text was updated successfully, but these errors were encountered: