Title: | preciseTAD: A machine learning framework for precise TAD boundary prediction |
---|---|
Description: | preciseTAD provides functions to predict the location of boundaries of topologically associated domains (TADs) and chromatin loops at base-level resolution. As an input, it takes BED-formatted genomic coordinates of domain boundaries detected from low-resolution Hi-C data, and coordinates of high-resolution genomic annotations from ENCODE or other consortia. preciseTAD employs several feature engineering strategies and resampling techniques to address class imbalance, and trains an optimized random forest model for predicting low-resolution domain boundaries. Translated on a base-level, preciseTAD predicts the probability for each base to be a boundary. Density-based clustering and scalable partitioning techniques are used to detect precise boundary regions and summit points. Compared with low-resolution boundaries, preciseTAD boundaries are highly enriched for CTCF, RAD21, SMC3, and ZNF143 signal and more conserved across cell lines. The pre-trained model can accurately predict boundaries in another cell line using CTCF, RAD21, SMC3, and ZNF143 annotation data for this cell line. |
Authors: | Spiro Stilianoudakis [aut], Mikhail Dozmorov [aut, cre] |
Maintainer: | Mikhail Dozmorov <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.17.0 |
Built: | 2025-01-01 06:23:55 UTC |
Source: | https://github.com/bioc/preciseTAD |
A data frame with 3 columns and 8409 rows
The chromosome number
The start coordinate of the TAD
The end coordinate of the TAD
arrowhead_gm12878_5kb
arrowhead_gm12878_5kb
An object of class data.frame
with 8409 rows and 3 columns.
A data.frame
Data from Rao SS, Huntley MH, Durand NC, Stamenova EK et al. A 3D map of the human genome at kilobase resolution reveals principles of chromatin looping. Cell 2014 Dec 18;159(7):1665-80. PMID: 25497547. Available at https://www.ncbi.nlm.nih.gov/geo/query/acc.cgi?acc=GSE63525
Function to create a GRangesList object from functional genomic annotation data in the form of BED files
bedToGRangesList( filepath, bedList = NULL, bedNames = NULL, pattern = "*.bed", signal = NULL )
bedToGRangesList( filepath, bedList = NULL, bedNames = NULL, pattern = "*.bed", signal = NULL )
filepath |
Character describing the path to the folder containing the BED files of functional genomic annotations. This is ignored if bedList is specified. |
bedList |
A list object containing the bed data as data frames to be converted into a GRangesList. The data frames must include at least chromosome, start, and end coordinates as the first 3 columns. Default is NULL. |
bedNames |
A character vector to provide names to the GRangesList, should be in the order of bedList. Default is NULL. |
pattern |
Character describing the pattern of the files for the functional genomic annotations. Default is "*.bed". |
signal |
The column number in the BED files that denotes coverage strength. Must be the same for all files. Default is NULL indicating to no coverage value is to be used. |
A GRangesList
object where each entry is a GRanges
object specific to each BED file in the path provided
#set path path <- system.file("extdata", package = "preciseTAD") #contains 2 BED files representing YY1 and NFYA #transcription factor binding sites for GM12878 tfbsList <- bedToGRangesList(filepath = path, bedList=NULL, bedNames=NULL, pattern = "*.bed", signal=NULL)
#set path path <- system.file("extdata", package = "preciseTAD") #contains 2 BED files representing YY1 and NFYA #transcription factor binding sites for GM12878 tfbsList <- bedToGRangesList(filepath = path, bedList=NULL, bedNames=NULL, pattern = "*.bed", signal=NULL)
Helper function used to create binary overlap type feature space
binary_func(binned_data_gr, annot_data_gr)
binary_func(binned_data_gr, annot_data_gr)
binned_data_gr |
A GRanges object |
annot_data_gr |
A Granges object |
An indicator vector for whether or not an overlap occured
Helper function used to create count overlap type feature space
count_func(binned_data_gr, annot_data_gr)
count_func(binned_data_gr, annot_data_gr)
binned_data_gr |
A GRanges object |
annot_data_gr |
A Granges object |
A vector of counts enumerating the number of overlaps
Function to create a data matrix used for building a predictive model to classify boundary regions from functional genomic elements
createTADdata( bounds.GR, resolution, genomicElements.GR, featureType = "distance", resampling, trainCHR, predictCHR = NULL, genome = "hg19" )
createTADdata( bounds.GR, resolution, genomicElements.GR, featureType = "distance", resampling, trainCHR, predictCHR = NULL, genome = "hg19" )
bounds.GR |
a GRanges object with chromosomal coordinates of TAD
boundaries used to identify positive cases (can be obtained using
|
resolution |
Numeric, the width to bin the genome at, should match the resolution that TADs were called at. Required. |
genomicElements.GR |
a GRangesList object containing GRanges objects
for each ChIP-seq data to leverage in the random forest model (can be
obtained using the |
featureType |
Character, controls how the feature space is constructed (one of either "binary" (overlap yes/no), "oc" (overlap counts, the number of overlaps), "op" (overlap percent, the percent of bin width covered by the genomic annotation), or "distance" (log2-transformed distance from the center of the nearest genomic annotation to the center of the bin); default is "distance"). Required. |
resampling |
Character, controls if and how the data should be resampled to create balanced classes of boundary vs. nonboundary regions (one of either "none" - no re-sampling, "ros" - Random Over-Sampling, "rus" - Random Under-Sampling. Required. |
trainCHR |
Character vector of chromosomes to use to build the binned data matrix for training. Required. |
predictCHR |
Character vector of chromosomes to use to build the binned data matrix for testing. Default in NULL, indicating no test data is created. If trainCHR=predictCHR then a 7:3 split is created. |
genome |
version of the human genome assembly. Used to filter out bases overlapping centromeric regions. Accepted values - hg19 (default) or hg38. |
A list object containing two data.frames: 1) the training data, 2) the test data (only if predictCHR is not NULL, otherwise it is NA). "y" is an indicator whether the corresponding bin is a TAD boundary, and the subsequent columns have the association measures between bins and the genomic annotations
# Create training data for CHR21 and testing data for CHR22 with # 5 kb binning, oc-type predictors from 26 different transcription factor # binding sites from the GM12878 cell line, and random under-sampling # Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) #Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "oc", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22")
# Create training data for CHR21 and testing data for CHR22 with # 5 kb binning, oc-type predictors from 26 different transcription factor # binding sites from the GM12878 cell line, and random under-sampling # Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) #Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "oc", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22")
Helper function used to create (log2) distance type feature space
distance_func(binned_data_center_gr, annot_data_center_gr)
distance_func(binned_data_center_gr, annot_data_center_gr)
binned_data_center_gr |
A GRanges object of width 1 |
annot_data_center_gr |
A GRanges object of width 1 |
A vector of log2 distances to the nearest overlap
Function to extract boundaries from domain data.
extractBoundaries(domains.mat, filter = FALSE, CHR, resolution)
extractBoundaries(domains.mat, filter = FALSE, CHR, resolution)
domains.mat |
either a |
filter |
logical, indicating whether or not domains exceeding 2mb in width or smaller than 2*(the specified resolution) should be filtered out (default is FALSE, all boundaries will be used). Required. |
CHR |
character vector, specifying which chromosome(s) to extract domain boundaries on (ex: "chr22", case ignored). Unused seqnames are dropped. Required. |
resolution |
numeric, the Hi-C data resolution that domains were called at. Ignored if filter is FALSE, required otherwise. |
A GRanges
object
#Read in domain data from ARROWHEAD at 5 kb for GM12878 data("arrowhead_gm12878_5kb") #Extract unique boundaries for CHRs 1-8 and 10-22 bounds.GR <- extractBoundaries(domains.mat=arrowhead_gm12878_5kb, filter=FALSE, CHR=paste0("CHR",c(1:8,10:22)), resolution=5000)
#Read in domain data from ARROWHEAD at 5 kb for GM12878 data("arrowhead_gm12878_5kb") #Extract unique boundaries for CHRs 1-8 and 10-22 bounds.GR <- extractBoundaries(domains.mat=arrowhead_gm12878_5kb, filter=FALSE, CHR=paste0("CHR",c(1:8,10:22)), resolution=5000)
Helper function for transforming a GRanges object into matrix form to be saved as .txt or .BED file and imported into juicer
juicer_func(grdat)
juicer_func(grdat)
grdat |
A GRanges object representing boundary coordinates |
A dataframe that can be saved as a BED file to import into juicer
Helper function used to create percent overlap type feature space
percent_func(binned_data_gr, annot_data_gr)
percent_func(binned_data_gr, annot_data_gr)
binned_data_gr |
A GRanges object |
annot_data_gr |
A Granges object |
A vector of proportions indicating the percentage of overlap
Precise TAD boundary prediction at base-level resolution using density-based spatial clustering and partitioning techniques
preciseTAD( genomicElements.GR, featureType = "distance", CHR, chromCoords = NULL, tadModel, threshold = 1, verbose = TRUE, parallel = NULL, DBSCAN_params = list(30000, 100), slope = 5000, genome = "hg19", BaseProbs = FALSE, savetobed = FALSE )
preciseTAD( genomicElements.GR, featureType = "distance", CHR, chromCoords = NULL, tadModel, threshold = 1, verbose = TRUE, parallel = NULL, DBSCAN_params = list(30000, 100), slope = 5000, genome = "hg19", BaseProbs = FALSE, savetobed = FALSE )
genomicElements.GR |
|
featureType |
Controls how the feature space is constructed (one of either "binary", "oc", "op", "signal, or "distance" (log2- transformed). Default and recommended: "distance". |
CHR |
Controls which chromosome to predict boundaries on at base-level resolution, e.g., CHR22. Required. |
chromCoords |
List containing the starting bp coordinate and ending bp coordinate that defines the region of the linear genome to make predictions on. If chromCoords is not specified, then predictions will be made on the entire chromosome. Default is NULL. |
tadModel |
Model object used to obtain predicted probabilities at
base-level resolution (examples include |
threshold |
Bases with predicted probabilities that are greater than or equal to this value are labeled as potential TAD boundaries. Values in the range of .95-1.0 are suggested. Default is 1. To explore how selection of the 'threshold' parameter affects the results, it is recommended to rerun the function with a different threshold, e.g., 0.99, and compare the results of Normalized Enrichment test (see 'DBSCAN_params' and the 'preciseTADparams' slot). |
verbose |
Option to print progress. Default is TRUE. |
parallel |
Option to parallelise the process for obtaining predicted probabilities. Must be number to indicate the number of cores to use in parallel. Default is NULL. |
DBSCAN_params |
Parameters passed to |
slope |
Controls how much to flank the predicted TAD boundary points for calculating normalized enrichment. Default: 5000 bases. Required. |
genome |
version of the human genome assembly. Used to filter out bases overlapping centromeric regions. Accepted values - hg19 or hg38. Default: hg19 |
BaseProbs |
Option to include the vector of probabilities for each base-level coordinate. Recommended to be used only when chromCoords is specified. Default: FALSE |
savetobed |
If true, preciseTAD regions (PTBRs) and preciseTAD points (PTBPs) will be saved as BED-like files into the current folder (as.data.frame(GRanges)). File name convention: <PTBRs/PTBPs>_<threshold>_<MinPts>_<eps>.bed, e.g., PTBR_1_3_30000.bed. If multiple DBSCAN_params are specified, each result will be saved in its own file. Default: FALSE |
A list containing 4 elements including: 1) data frame with average (and standard deviation) normalized enrichment (NE) values for each combination of t and eps (only if multiple values are provided for at least paramenter; all subsequent summaries are applied to optimal combination of (t, eps)), 2) the genomic coordinates spanning each preciseTAD predicted region (PTBR), 3) the genomic coordinates of preciseTAD predicted boundaries points (PTBP), 4) a named list including summary statistics of the following: PTBRWidth - PTBR width, PTBRCoverage - the proportion of bases within a PTBR with probabilities that equal to or exceed the threshold (t=1 by default), DistanceBetweenPTBR - the genomic distance between the end of the previous PTBR and the start of the subsequent PTBR, NumSubRegions - the number of the subregions in each PTBR cluster, SubRegionWidth - the width of the subregion forming each PTBR, DistBetweenSubRegions - the genomic distance between the end of the previous PTBR-specific subregion and the start of the subsequent PTBR-specific subregion, NormilizedEnrichment - the normalized enrichment of the genomic annotations used in the model around flanked PTBPs, and BaseProbs - a numeric vector of probabilities for each corresponding base coordinate.
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) # Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS and filter to include only CTCF, RAD21, #SMC3, and ZNF143 data(tfbsList) tfbsList_filt <- tfbsList[which(names(tfbsList) %in% c("Gm12878-Ctcf-Broad", "Gm12878-Rad21-Haib", "Gm12878-Smc3-Sydh", "Gm12878-Znf143-Sydh"))] # Create the binned data matrix for CHR1 (training) and CHR22 (testing) # using 5 kb binning, distance-type predictors from 4 TFBS from # the GM12878 cell line, and random under-sampling set.seed(123) tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList_filt, featureType = "distance", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22") # Perform random forest using TADrandomForest by tuning mtry over 10 values # using 3-fold CV set.seed(123) tadModel <- TADrandomForest(trainData = tadData[[1]], testData = tadData[[2]], tuneParams = list(mtry = 2, ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = TRUE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = TRUE) # Apply preciseTAD on a specific 2mb section of CHR22:17000000-18000000 set.seed(123) pt <- preciseTAD(genomicElements.GR = tfbsList_filt, featureType = "distance", CHR = "CHR22", chromCoords = list(17000000, 18000000), tadModel = tadModel[[1]], threshold = 1.0, verbose = TRUE, parallel = NULL, DBSCAN_params = list(c(1000, 10000, 30000), c(10, 100, 1000)), slope = 5000, genome = "hg19", BaseProbs = FALSE, savetobed = FALSE)
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) # Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS and filter to include only CTCF, RAD21, #SMC3, and ZNF143 data(tfbsList) tfbsList_filt <- tfbsList[which(names(tfbsList) %in% c("Gm12878-Ctcf-Broad", "Gm12878-Rad21-Haib", "Gm12878-Smc3-Sydh", "Gm12878-Znf143-Sydh"))] # Create the binned data matrix for CHR1 (training) and CHR22 (testing) # using 5 kb binning, distance-type predictors from 4 TFBS from # the GM12878 cell line, and random under-sampling set.seed(123) tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList_filt, featureType = "distance", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22") # Perform random forest using TADrandomForest by tuning mtry over 10 values # using 3-fold CV set.seed(123) tadModel <- TADrandomForest(trainData = tadData[[1]], testData = tadData[[2]], tuneParams = list(mtry = 2, ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = TRUE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = TRUE) # Apply preciseTAD on a specific 2mb section of CHR22:17000000-18000000 set.seed(123) pt <- preciseTAD(genomicElements.GR = tfbsList_filt, featureType = "distance", CHR = "CHR22", chromCoords = list(17000000, 18000000), tadModel = tadModel[[1]], threshold = 1.0, verbose = TRUE, parallel = NULL, DBSCAN_params = list(c(1000, 10000, 30000), c(10, 100, 1000)), slope = 5000, genome = "hg19", BaseProbs = FALSE, savetobed = FALSE)
Helper function used to create signal type feature space
signal_func(binned_data_gr, annot_data_gr)
signal_func(binned_data_gr, annot_data_gr)
binned_data_gr |
A GRanges object |
annot_data_gr |
A GRanges object |
A vector of intensities indicating the signal strength within each overlap
caret::train
to apply a random forest
classification algorithm built and tested on user-defined binned domain
data from createTADdata
.A wrapper function passed to caret::train
to apply a random forest
classification algorithm built and tested on user-defined binned domain
data from createTADdata
.
TADrandomForest( trainData, testData = NULL, tuneParams = list(mtry = ceiling(sqrt(ncol(trainData) - 1)), ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = FALSE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = FALSE )
TADrandomForest( trainData, testData = NULL, tuneParams = list(mtry = ceiling(sqrt(ncol(trainData) - 1)), ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = FALSE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = FALSE )
trainData |
Data frame, the binned data matrix to built a random forest
classifiers (can be obtained using |
testData |
Data frame, the binned data matrix to test random forest
classifiers (can be obtained using |
tuneParams |
List, providing |
cvFolds |
Numeric, number of k-fold cross-validation to perform in order to tune the hyperparameters. Required. |
cvMetric |
Character, performance metric to use to choose optimal tuning parameters (one of either "Kappa", "Accuracy", "MCC", "ROC", "Sens", "Spec", "Pos Pred Value", "Neg Pred Value"). Default is "Accuracy". |
verbose |
Logical, controls whether or not details regarding modeling should be printed out. Default is TRUE. |
model |
Logical, whether to keep the model object. Default is TRUE. |
importances |
Logical, whether to extract variable importances. Default is TRUE. |
impMeasure |
Character, indicates the variable importance measure to use (one of either "MDA" (mean decrease in accuracy) or "MDG" (mean decrease in gini)). Ignored if importances = FALSE. |
performances |
Logical, indicates whether various performance metrics should be extracted when validating the model on the test data. Ignored if testData = NULL. |
A list containing: 1) a train object from caret
with model
information, 2) a data.frame of variable importance for each feature
included in the model, and 3) a data.frame of various performance metrics
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) # Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) # Create the binned data matrix for CHR1 (training) and CHR22 (testing) # using 5 kb binning, distance-type predictors from 26 different TFBS from # the GM12878 cell line, and random under-sampling tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "distance", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22") # Perform random forest using TADrandomForest by tuning mtry over 10 values # using 3-fold CV tadModel <- TADrandomForest(trainData = tadData[[1]], testData = tadData[[2]], tuneParams = list(mtry = c(2,5,8,10,13,16,18,21,24,26), ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = TRUE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = TRUE)
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) # Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = c("CHR21", "CHR22"), resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) # Create the binned data matrix for CHR1 (training) and CHR22 (testing) # using 5 kb binning, distance-type predictors from 26 different TFBS from # the GM12878 cell line, and random under-sampling tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "distance", resampling = "rus", trainCHR = "CHR21", predictCHR = "CHR22") # Perform random forest using TADrandomForest by tuning mtry over 10 values # using 3-fold CV tadModel <- TADrandomForest(trainData = tadData[[1]], testData = tadData[[2]], tuneParams = list(mtry = c(2,5,8,10,13,16,18,21,24,26), ntree = 500, nodesize = 1), cvFolds = 3, cvMetric = "Accuracy", verbose = TRUE, model = TRUE, importances = TRUE, impMeasure = "MDA", performances = TRUE)
caret::rfe
to apply recursive feature
elimination (RFE) on binned domain data as a feature reduction technique for
random forests. Backward elimination is performed from p down to 2, by
powers of 2, where p is the number of features in the data.A wrapper function passed to caret::rfe
to apply recursive feature
elimination (RFE) on binned domain data as a feature reduction technique for
random forests. Backward elimination is performed from p down to 2, by
powers of 2, where p is the number of features in the data.
TADrfe( trainData, tuneParams = list(ntree = 500, nodesize = 1), cvFolds = 5, cvMetric = "Accuracy", verbose = FALSE )
TADrfe( trainData, tuneParams = list(ntree = 500, nodesize = 1), cvFolds = 5, cvMetric = "Accuracy", verbose = FALSE )
trainData |
Data frame, the binned data matrix to built a random forest
classifiers (can be obtained using |
tuneParams |
List, providing |
cvFolds |
Numeric, number of k-fold cross-validation to perform. Required. |
cvMetric |
Character, performance metric to use to choose optimal tuning parameters (one of either "Kappa", "Accuracy", "MCC","ROC","Sens", "Spec", "Pos Pred Value", "Neg Pred Value"). Default is "Accuracy". |
verbose |
Logical, controls whether or not details regarding modeling should be printed out. Default is TRUE. |
A list containing: 1) the performances extracted at each of the k folds and, 2) Variable importances among the top features at each step of RFE. For 1) 'Variables' - the best subset of features to consider at each iteration, 'MCC' (Matthews Correlation Coefficient), 'ROC' (Area under the receiver operating characteristic curve), 'Sens' (Sensitivity), 'Spec' (Specificity), 'Pos Pred Value' (Positive predictive value), 'Neg Pred Value' (Negative predictive value), 'Accuracy', and the corresponding standard deviations across the cross-folds. For 2) 'Overall' - the variable importance, 'var' - the feature name, 'Variables' - the number of features that were considered at each cross-fold, and 'Resample' - the cross-fold
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) #Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = "CHR22", resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) # Create the binned data matrix for CHR22 using: # 5 kb binning, # oc-type predictors from 26 different TFBS from the GM12878 cell line, and # random under-sampling tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "oc", resampling = "rus", trainCHR = "CHR22", predictCHR = NULL) # Perform RFE for fully grown random forests with 100 trees using 5-fold CV # Evaluate performances using accuracy rfe_res <- TADrfe(trainData = tadData[[1]], tuneParams = list(ntree = 100, nodesize = 1), cvFolds = 5, cvMetric = "Accuracy", verbose = TRUE)
# Read in ARROWHEAD-called TADs at 5kb data(arrowhead_gm12878_5kb) #Extract unique boundaries bounds.GR <- extractBoundaries(domains.mat = arrowhead_gm12878_5kb, filter = FALSE, CHR = "CHR22", resolution = 5000) # Read in GRangesList of 26 TFBS data(tfbsList) # Create the binned data matrix for CHR22 using: # 5 kb binning, # oc-type predictors from 26 different TFBS from the GM12878 cell line, and # random under-sampling tadData <- createTADdata(bounds.GR = bounds.GR, resolution = 5000, genomicElements.GR = tfbsList, featureType = "oc", resampling = "rus", trainCHR = "CHR22", predictCHR = NULL) # Perform RFE for fully grown random forests with 100 trees using 5-fold CV # Evaluate performances using accuracy rfe_res <- TADrfe(trainData = tadData[[1]], tuneParams = list(ntree = 100, nodesize = 1), cvFolds = 5, cvMetric = "Accuracy", verbose = TRUE)
A GRangesList containing 26 GRanges objects each with the following elements
The chromosome number
IRanges object with start and end coordinates for each TFBS
empty column
a metadata column with peak strength values at each site
tfbsList
tfbsList
An object of class CompressedGRangesList
of length 26.
A GrangeList
Data obtained from ENCODE. ENCODE integrative analysis (PMID: 22955616; PMCID: PMC3439153) ENCODE portal (PMID: 29126249; PMCID: PMC5753278) Available at https://www.encodeproject.org/