-
Notifications
You must be signed in to change notification settings - Fork 11
File format specifications
File formats in bioinformatics are notoriously hard to standardize. We hope that this documentation provides the user with a clear idea of what is need as input into Swan.
In Swan, transcript models are loaded from GTFs. To work with Swan, GTFs must adhere to the following specifications:
- transcript and exon entries in column 3 - this is a dependency we would like to remove in the future but for now this is the way it works
- gene_id, gene_name, and transcript_id attributes (for transcripts and exons) in column 9
- any non-data header lines must begin with #
- gene_ids, gene_names, and transcript_ids must be the same across datasets for proper dataset merging
Here is an example of what the first few lines of a GTF should look like:
##description: evidence-based annotation of the human genome (GRCh38), version 29 (Ensembl 94)
##provider: GENCODE
##contact: gencode-help@ebi.ac.uk
##format: gtf
##date: 2018-08-30
chr1 HAVANA gene 11869 14409 . + . gene_id "ENSG00000223972.5"; gene_type "transcribed_unprocessed_pseudogene"; gene_name "DDX11L1"; level 2; havana_gene "OTTHUMG00000000961.2";
chr1 HAVANA transcript 11869 14409 . + . gene_id "ENSG00000223972.5"; transcript_id "ENST00000456328.2"; gene_type "transcribed_unprocessed_pseudogene"; gene_name "DDX11L1"; transcript_type "processed_transcript"; transcript_name "DDX11L1-202"; level 2; transcript_support_level "1"; tag "basic"; havana_gene "OTTHUMG00000000961.2"; havana_transcript "OTTHUMT00000362751.1";
chr1 HAVANA exon 11869 12227 . + . gene_id "ENSG00000223972.5"; transcript_id "ENST00000456328.2"; gene_type "transcribed_unprocessed_pseudogene"; gene_name "DDX11L1"; transcript_type "processed_transcript"; transcript_name "DDX11L1-202"; exon_number 1; exon_id "ENSE00002234944.1"; level 2; transcript_support_level "1"; tag "basic"; havana_gene "OTTHUMG00000000961.2"; havana_transcript "OTTHUMT00000362751.1";
If you are having trouble with your GTF, Swan includes a quick GTF validator which can tell you if your file seems to have an unconventional header or lacks entries needed to run Swan. It cannot tell you if your gene/transcript names/ids match across datasets, however. The validator can be run as follows:
import swan_vis as swan
swan.validate_gtf('test.gtf')
Swan can load abundance information for more meaningful analysis and visualizations. To work with Swan, abundance matrices must:
- Be tab-separated
- Have a column containing transcript ids that are the same as those loaded via GTF or TALON db
- Have a column containing counts of each transcript for a given dataset column name
Luckily, the names of the column names to obtain transcript ids and counts from are flexible. If you were to add abundance to your SwanGraph with the following line, for instance
sg = swan.SwanGraph('swan.p')
sg.add_abundance('counts_file.tsv', \
count_cols='counts_dataset', \
dataset_name='sg_dataset', \
tid_col='transcript_id')
The corresponding abundance file should look something like this:
transcript_id counts_dataset
ENST00000623083.4 1
ENST00000416931.1 0
ENST00000457540.1 0
ENST00000414273.1 0
ENST00000621981.1 0
ENST00000514057.1 0
ENST00000411249.1 0
ENST00000445118.6 1
ENST00000441765.5 0
Swan currently works with TALON databases created with TALON v5.0+