java -jar picard.jar CollectInsertSizeMetrics I=aln_sorted.bam O=out.metrics HISTOGRAM_FILE=chartoutput.pdf VALIDATION_STRINGENCY=LENIENT

Similar documents
Clustering using WGCNA

Supplemental Data. Cañas et al. Plant Cell (2017) /tpc

Tutorial for the WGCNA package for R II. Consensus network analysis of liver expression data, female and male mice

Reads Alignment and Variant Calling

Exome sequencing. Jong Kyoung Kim

Exercise 1 Review. --outfiltermismatchnmax : max number of mismatch (Default 10) --outreadsunmapped fastx: output unmapped reads

Exercise 1. RNA-seq alignment and quantification. Part 1. Prepare the working directory. Part 2. Examine qualities of the RNA-seq data files

RPGC Manual. You will also need python 2.7 or above to run our home-brew python scripts.

Simulation studies of module preservation: Simulation study of weak module preservation

Tutorial for the WGCNA package for R II. Consensus network analysis of liver expression data, female and male mice. 1. Data input and cleaning

REPRODUCIBLE NGS WORKFLOWS WITH NEXTFLOW. Paolo Di Tommaso NGS'17 - Workshop, 5 April 2017

Benchmarking of RNA-seq aligners

Tutorial for the WGCNA package for R: III. Using simulated data to evaluate different module detection methods and gene screening approaches

Our data for today is a small subset of Saimaa ringed seal RNA sequencing data (RNA_seq_reads.fasta). Let s first see how many reads are there:

Cyverse tutorial 1 Logging in to Cyverse and data management. Open an Internet browser window and navigate to the Cyverse discovery environment:

RNA-Seq Analysis With the Tuxedo Suite

Reference guided RNA-seq data analysis using BioHPC Lab computers

Goal: Learn how to use various tool to extract information from RNAseq reads. 4.1 Mapping RNAseq Reads to a Genome Assembly

High-throughout sequencing and using short-read aligners. Simon Anders

Identification of consensus modules in Adenocarcinoma data

Next Generation Sequence Alignment on the BRC Cluster. Steve Newhouse 22 July 2010

Tumor-Specific NeoAntigen Detector (TSNAD) v2.0 User s Manual

Sequence Analysis Pipeline

Clustering. Dick de Ridder 6/10/2018

CORE Year 1 Whole Genome Sequencing Final Data Format Requirements

Sentieon DNA Pipeline for Variant Detection Software-only solution, over 20 faster than GATK 3.3 with identical results

The QoRTs Analysis Pipeline Example Walkthrough

WM2 Bioinformatics. ExomeSeq data analysis part 1. Dietmar Rieder

A Tutorial: Genome- based RNA- Seq Analysis Using the TUXEDO Package

Sentieon DNA pipeline for variant detection - Software-only solution, over 20 faster than GATK 3.3 with identical results

SNP Calling. Tuesday 4/21/15

RNASeq2017 Course Salerno, September 27-29, 2017

Analysing re-sequencing samples. Malin Larsson WABI / SciLifeLab

Falcon Accelerated Genomics Data Analysis Solutions. User Guide

Evaluate NimbleGen SeqCap RNA Target Enrichment Data

Analysing re-sequencing samples. Anna Johansson WABI / SciLifeLab

Data: ftp://ftp.broad.mit.edu/pub/users/bhaas/rnaseq_workshop/rnaseq_workshop_dat a.tgz. Software:

Testing for Differential Expression

srap: Simplified RNA-Seq Analysis Pipeline

Standard output. Some of the output files can be redirected into the standard output, which may facilitate in creating the pipelines:

From the Schnable Lab:

SweGen: A whole-genome data resource of genetic variability in a cross-section of the Swedish population

halvade Documentation

Variation among genomes

Bash for SLURM. Author: Wesley Schaal Pharmaceutical Bioinformatics, Uppsala University

323 lines (286 sloc) 15.7 KB. 7d7a6fb

Understanding and Pre-processing Raw Illumina Data

Goal: Learn how to use various tool to extract information from RNAseq reads.

all M 2M_gt_15 2M_8_15 2M_1_7 gt_2m TopHat2

RNAseq analysis: SNP calling. BTI bioinformatics course, spring 2013

Input files: Trim reads: Create bwa index: Align trimmed reads: Convert sam to bam: Sort bam: Remove duplicates: Index sorted, no-duplicates bam:

RNA-seq. Manpreet S. Katari

Maize genome sequence in FASTA format. Gene annotation file in gff format

Statistical analysis of RNA-Seq data

Differential gene expression analysis

11/8/2017 Trinity De novo Transcriptome Assembly Workshop trinityrnaseq/rnaseq_trinity_tuxedo_workshop Wiki GitHub

version /1/2011 Source code Linux x86_64 binary Mac OS X x86_64 binary

TopHat, Cufflinks, Cuffdiff

1. Quality control software FASTQC:

By Ludovic Duvaux (27 November 2013)

Centre (CNIO). 3rd Melchor Fernández Almagro St , Madrid, Spain. s/n, Universidad de Vigo, Ourense, Spain.

Galaxy workshop at the Winter School Igor Makunin

Short Read Sequencing Analysis Workshop

Short tutorial on studying module preservation: Preservation of female mouse liver modules in male data

Decrypting your genome data privately in the cloud

Gene Expression Data Analysis. Qin Ma, Ph.D. December 10, 2017

Differential Expression

Halvade: scalable sequence analysis with MapReduce

RNA-Seq. Joshua Ainsley, PhD Postdoctoral Researcher Lab of Leon Reijmers Neuroscience Department Tufts University

Meta-analysis of aging methylation data sets Validation success of various meta-analysis methods in selecting genes

Galaxy Platform For NGS Data Analyses

Package ArrayExpressHTS

Colorado State University Bioinformatics Algorithms Assignment 6: Analysis of High- Throughput Biological Data Hamidreza Chitsaz, Ali Sharifi- Zarchi

Package dynamictreecut

New High Performance Computing Cluster For Large Scale Multi-omics Data Analysis. 28 February 2018 (Wed) 2:30pm 3:30pm Seminar Room 1A, G/F

Expander 7.2 Online Documentation

Package ssizerna. January 9, 2017

Ensembl RNASeq Practical. Overview

EpiGnome Methyl Seq Bioinformatics User Guide Rev. 0.1

Sentieon Documentation

Package dynamictreecut

RNA sequence practical

Services Performed. The following checklist confirms the steps of the RNA-Seq Service that were performed on your samples.

NGS Sequence data. Jason Stajich. UC Riverside. jason.stajich[at]ucr.edu. twitter:hyphaltip stajichlab

Hinri Kerstens. NGS pipeline using Broad's Cromwell

Automated Bioinformatics Analysis System on Chip ABASOC. version 1.1

m6aviewer Version Documentation

Evaluate NimbleGen SeqCap Epi Target Enrichment Data

General instructions:

Preservation of protein-protein interaction networks Simple simulated example

Calling variants in diploid or multiploid genomes

Introduction to Read Alignment. UCD Genome Center Bioinformatics Core Tuesday 15 September 2015

Visualization using CummeRbund 2014 Overview

Differential Expression with DESeq2

Our typical RNA quantification pipeline

AgroMarker Finder manual (1.1)

Mapping NGS reads for genomics studies

High-throughput sequencing: Alignment and related topic. Simon Anders EMBL Heidelberg

Functional Genomics Research Stream. Computational Meeting: March 29, 2012 RNA-seq Analysis Pipeline

Clustering. RNA-seq: What is it good for? Finding Similarly Expressed Genes. Data... And Lots of It!

Transcription:

Supplementary Note 1 Pre-Processing and Alignment Commands Trimmomatic Command java -jar trimmomatic-0.32.jar PE -threads 15 -phred33 /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/First_Six_Samples_Raw_Data/Ra w_seq_files/als1_1_sequence.txt.gz /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/First_Six_Samples_Raw_Data/Ra w_seq_files/als1_2_sequence.txt.gz Spinal_Samples/ALS1/ALS1_forward_paired.fq Spinal_Samples/ALS1/ALS1_forward_unpaired.fq Spinal_Samples/ALS1/ALS1_reverse_paired.fq Spinal_Samples/ALS1/ALS1_reverse_unpaired.fq ILLUMINACLIP:TruSeq3-PE- 2.fa:2:30:10:8:true TRAILING:20 MINLEN:50 BWA Commands head -5000000 ALS1_forward_paired.fq > 1.txt head -5000000 ALS1_reverse_paired.fq > 2.txt bwa aln hg19tr.fa 1.txt > 1.sai bwa aln hg19tr.fa 2.txt > 2.sai bwa sampe hg19tr.fa 1.sai 2.sai 1.txt 2.txt > aln.sam samtools view -Sb aln.sam > aln.bam samtools sort aln.bam aln_sorted java -jar picard.jar CollectInsertSizeMetrics I=aln_sorted.bam O=out.metrics HISTOGRAM_FILE=chartoutput.pdf VALIDATION_STRINGENCY=LENIENT # This command will generate a file called out.metrics in the picard folder containing mean_insert size and standard deviation values # Subtract the total length of your reads (in our case 2X150, so 300 total) from the mean_insert size i.e 198-300 = -102 for the Tophat r value. Tophat Command tophat -p 2 -o /Volumes/Drobo_Storage/Tophat_Output/ALS1_150_ARemoved_AllReads -G hg19/annotation/genes/genes.gtf --library-type fr-firststrand -r -102 --mate-std-dev 49 -- transcriptome-index=hg19.transcriptome/hg19tr genome Spinal_Samples/ALS1/ALS1_forward_paired.fq Spinal_Samples/ALS1/ALS1_reverse_paired.fq

Collect RNA-Seq Metrics Command java -jar picard.jar CollectRnaSeqMetrics REF_FLAT=/Volumes/Drobo_Storage/Homo_sapiens_UCSC_hg19/Homo_sapiens/UCSC/hg19/ Annotation/Genes/refFlat.txt.gz RIBOSOMAL_INTERVALS= intervallist.txt STRAND_SPECIFICITY=SECOND_READ_TRANSCRIPTION_STRAND INPUT=accepted_hits.bam OUTPUT=Stats GATK Point Mutation Analysis Commands STAR --runmode genomegenerate --genomedir /Volumes/Drobo_Storage/STARgenome -- genomefastafiles wtie2index/genome.fa --runthreadn 10 STAR --genomedir /Volumes/Drobo_Storage/STARgenome/ --readfilesin /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/Processed_Samples/ALS1/150Bp _AllReads_Adaptors_Removed/ALS1_forward_paired.fq /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/Processed_Samples/ALS1/150Bp _AllReads_Adaptors_Removed/ALS1_reverse_paired.fq --runthreadn 15 STAR --runmode genomegenerate --genomedir /Volumes/Drobo_Storage/STARgenome_2ndpass/ --genomefastafiles wtie2index/genome.fa --sjdbfilechrstartend /Volumes/Drobo_Storage/STAR_Alignments/PAT_ALS1/SJ.out.tab --sjdboverhang 75 -- runthreadn 15 STAR --genomedir /Volumes/Drobo_Storage/STARgenome_2ndpass/ --readfilesin /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/Processed_Samples/ALS1/150Bp _AllReads_Adaptors_Removed/ALS1_forward_paired.fq /Volumes/Drobo_Storage/Raw_Data_and_Trimmomatic_Files/Processed_Samples/ALS1/150Bp _AllReads_Adaptors_Removed/ALS1_reverse_paired.fq --runthreadn 15 java -jar picard.jar AddOrReplaceReadGroups I=Aligned.out.sam O=rg_added_sorted.bam SO=coordinate RGID=ALS1 RGLB=ALS1 RGPL=ILLUMINA RGPU=NextSeq500 RGSM=ALS1 java -Xmx50g -jar picard.jar MarkDuplicates I=rg_added_sorted.bam O=deduped.bam CREATE_INDEX=true VALIDATION_STRINGENCY=SILENT M=output.metrics java -jar GenomeAnalysisTK.jar -T SplitNCigarReads -R wtie2index/genome.fa -I deduped.bam -o split.bam -rf ReassignOneMappingQuality -RMQF 255 - RMQT 60 -U ALLOW_N_CIGAR_READS java -jar GenomeAnalysisTK.jar -T BaseRecalibrator -R wtie2index/genome.fa -I split.bam -knownsites /Volumes/Drobo_Storage/Homo_sapiens_UCSC_hg19/Homo_sapiens/UCSC/hg19/Annotation/E verything_else/variation/dbsnp_138.hg19.vcf -nct 14 -o recal_data.table java -jar GenomeAnalysisTK.jar -T BaseRecalibrator -R

wtie2index/genome.fa -I split.bam -knownsites /Volumes/Drobo_Storage/Homo_sapiens_UCSC_hg19/Homo_sapiens/UCSC/hg19/Annotation/E verything_else/variation/dbsnp_138.hg19.vcf -BQSR recal_data.table -nct 14 -o Final_recal_data.table java -jar GenomeAnalysisTK.jar -T PrintReads -R wtie2index/genome.fa -I split.bam -BQSR Final_recal_data.table -o Recal_split.bam java -jar GenomeAnalysisTK.jar -T HaplotypeCaller -D /Volumes/Drobo_Storage/Homo_sapiens_UCSC_hg19/Homo_sapiens/UCSC/hg19/Annotation/E verything_else/variation/dbsnp_138.hg19.vcf -R wtie2index/genome.fa -I Recal_split.bam -dontusesoftclippedbases -stand_call_conf 20.0 - stand_emit_conf 20.0 -o output.vcf java -jar GenomeAnalysisTK.jar -T VariantFiltration -R wtie2index/genome.fa -V output.vcf -window 35 -cluster 3 -filtername FS -filter "FS >30.0" - filtername QD -filter "QD <2.0" -o final_output.vcf HTSeq Count Command # From within a Tophat Output Folder # samtools sort -n accepted_hits.bam accepted_hits.sorted samtools view accepted_hits.sorted.bam htseq-count -s reverse - /Volumes/Drobo_Storage/Homo_sapiens_UCSC_hg19/Homo_sapiens/UCSC/hg19/Annotation/G enes/genes.gtf > PAT_ALS1_Count.txt Cufflinks, Cuffmerge, and Cuffdiff Commands Cufflinks Command cufflinks -o /Volumes/Drobo_Storage/Cufflinks_Cuffdiff_Output/Postmortem_Spinals_Cufflinks_Output_No_ M/PAT_ALS1_no_novel_highdata1 --library-type fr-firststrand -p 1 -G hg19/annotation/genes/genes.gtf -b hg19/sequence/bowtie2index/genome.fa -M hg19/sequence/bowtie2index/rrna.trna.mt.gtf -u --compatible-hits-norm --max-bundle-frags 999999999 /Volumes/Drobo_Storage/Tophat_Output/Postmortem_Spinal_Samples/PAT_ALS1_150_ARemo ved_allreads/accepted_hits.bam Cuffmerge Command cuffmerge -p 14 -o CTLvPAT_M -g hg19/annotation/genes/genes.gtf -s

hg19/sequence/wholegenomefasta/genome.fa assemblies.txt Cuffdiff2 Command cuffdiff --library-type fr-firststrand -o /Volumes/Drobo_Storage/PATvCTL_No_M_compared -p 14 - b hg19/sequence/bowtie2index/genome.fa -u -L CTL,PAT -M hg19/sequence/bowtie2index/rrna.trna.mt.gtf -max-bundle-frags 999999999 -v /Volumes/Drobo_Storage/CTLvPAT_No_M/merged.gtf /Volumes/Drobo_Storage/Tophat_Output/CTL_ALS6_150_ARemoved_AllReads/accepted_hits.b am,/volumes/drobo_storage/tophat_output/ctl_als8_150_aremoved_allreads/accepted_hi ts.bam,/volumes/drobo_storage/tophat_output/ctl_als16_150_aremoved_allreads/accept ed_hits.bam,/volumes/drobo_storage/tophat_output/ctl_als22_150_aremoved_allreads/a ccepted_hits.bam,/volumes/drobo_storage/tophat_output/ctl_als23_150_aremoved_allre ads/accepted_hits.bam,/volumes/drobo_storage/tophat_output/ctl_als24_150_aremoved_ AllReads/accepted_hits.bam,/Volumes/Drobo_Storage/Tophat_Output/CTL_ALS25_150_ARemo ved_allreads/accepted_hits.bam,/volumes/drobo_storage/tophat_output/ctl_als27_150_ar emoved_allreads/accepted_hits.bam /Volumes/Drobo_Storage/Tophat_Output/PAT_ALS1_150_ARemoved_AllReads/accepted_hits.b am,/volumes/drobo_storage/tophat_output/pat_als2_150_aremoved_allreads/accepted_hi ts.bam,/volumes/drobo_storage/tophat_output/pat_als3_150_aremoved_allreads/accepte d_hits.bam,/volumes/drobo_storage/tophat_output/pat_als4_150_aremoved_allreads/acc epted_hits.bam,/volumes/drobo_storage/tophat_output/pat_als9_150_aremoved_allreads/ accepted_hits.bam,/volumes/drobo_storage/tophat_output/pat_als10_150_aremoved_allr eads/accepted_hits.bam,/volumes/drobo_storage/tophat_output/pat_als14_150_aremoved _AllReads/accepted_hits.bam Calculating p-values using Benjamini-Hochberg correction #Copy the p-value column in gene_exp.diff output file. Paste them into first column of Excel file, and save as All_P.csv. Open R, then # Data <- read.csv(file="all_p.csv",header=true,stringsasfactors=false) FDR <- p.adjust(data[,1],method="bh") write.csv(fdr, file="fdr.csv") #Paste these values back into the gene_exp.diff file. These are FDR corrected p values. DeSeq2 Commands source("http://bioconductor.org/bioclite.r") bioclite("deseq2") bioclite("pasilla") library(deseq2) library(pasilla) library(biobase) setwd("/users/bennett_lab/desktop/deseq2/individual_count_files_postmortem") getwd() directory = "/Users/Bennett_Lab/Desktop/DESeq2/Individual_Count_Files_Postmortem/" samplefiles <- grep("pat",list.files(directory),value=true)

samplecondition <- sub("(.*pat).*","\\1",samplefiles) sampletable <- data.frame(samplename = samplefiles, filename = samplefiles, condition = samplecondition) ddshtseq <- DESeqDataSetFromHTSeqCount(sampleTable = sampletable, directory = directory, design = ~ condition) dds <- DESeq(ddsHTSeq) res <- results(dds) write.csv(res, file="res.csv") edger Commands setwd("/users/bennett_lab/desktop/edger/postmortem Spinal Samples/") source("http://bioconductor.org/bioclite.r") bioclite("edger") library(edger) x <- read.delim("edger.txt",row.names="symbol") group <- factor(c(2,2,2,2,2,2,2,1,1,1,1,1,1,1,1)) y <- DGEList(counts=x,group=group) keep <- rowsums(cpm(y)>1) >= 7 y <- y[keep,] y$samples$lib.size <- colsums(y$counts) y$samples y <- calcnormfactors(y) y <- estimatecommondisp(y) y <- estimatetagwisedisp(y) et <- exacttest(y) toptags(et) et$table write.csv(et$table, "DEGList.csv") #Copy the Pvalue column in the DEGList.csv output file. Paste them into first column of Excel file, and save as All_P.csv. Open R, then # Data <- read.csv(file="all_p.csv",header=true,stringsasfactors=false) FDR <- p.adjust(data[,1],method="bh") write.csv(fdr, file="fdr.csv") #Paste these adjusted p values back into the DEGList.csv file. These are FDR corrected p values. WGCNA Commands setwd("/users/bennett_lab/desktop/wgcna") getwd() source("http://bioconductor.org/bioclite.r") bioclite("impute") install.packages("wgcna") library(wgcna); options(stringsasfactors = FALSE) ALLOW_WGCNA_THREADS=6

lnames=load(file="allsubjects-data.input.rdata") # This loads the variables datexpr (including information from All_Sample_Data.csv ) and dattraits (including information from dattraits.csv). #### powers = c(c(1:10), seq(from = 12, to=24, by=2)) datexpr[, c(1:13301)] <- sapply(datexpr[, c(1:13301)], as.numeric) sft= picksoftthreshold(datexpr, powervector = powers, verbose = 5, networktype ="signed", corfnc= "bicor", coroptions=list(maxpoutliers=0.1)) sizegrwindow(9, 5) par(mfrow = c(1,2)); cex1 = 0.9; plot(sft$fitindices[,1], -sign(sft$fitindices[,3])*sft$fitindices[,2], xlab="soft Threshold (power)",ylab="scale Free Topology Model Fit,signed R^2",type="n", main = paste("scale independence")); text(sft$fitindices[,1], -sign(sft$fitindices[,3])*sft$fitindices[,2], labels=powers,cex=cex1,col="red"); abline(h=0.80,col="red") plot(sft$fitindices[,1], sft$fitindices[,5], xlab="soft Threshold (power)",ylab="mean Connectivity", type="n", main = paste("mean connectivity")) text(sft$fitindices[,1], sft$fitindices[,5], labels=powers, cex=cex1,col="red") adjacency = adjacency(datexpr, power=24, corfnc="bicor", type="signed", coroptions = "use = 'p', maxpoutliers = 0.1") TOM= TOMsimilarity(adjacency) disstom = 1-TOM genetree = hclust(as.dist(disstom), method = "average"); sizegrwindow(12,9) plot(genetree, xlab="", sub="", main = "Gene clustering on TOM-based dissimilarity", labels = FALSE, hang = 0.04); minmodulesize = 30; dynamicmods = cutreedynamic(dendro = genetree, distm = disstom, deepsplit = 2, pamrespectsdendro = FALSE, minclustersize = minmodulesize); table(dynamicmods) dynamiccolors = labels2colors(dynamicmods) table(dynamiccolors) sizegrwindow(8,6) plotdendroandcolors(genetree, dynamiccolors, "Dynamic Tree Cut", dendrolabels = FALSE, hang = 0.03, addguide = TRUE, guidehang = 0.05, main = "Gene dendrogram and module colors") MEList = moduleeigengenes(datexpr, colors = dynamiccolors) MEs = MEList$eigengenes MEDiss = 1-cor(MEs); METree = hclust(as.dist(mediss), method = "average");

sizegrwindow(7, 6) plot(metree, main = "Clustering of module eigengenes", xlab = "", sub = "") MEDissThres = 0.25 abline(h=medissthres, col = "red") merge = mergeclosemodules(datexpr, dynamiccolors, cutheight = MEDissThres, verbose = 3) mergedcolors = merge$colors; mergedmes = merge$newmes; plotdendroandcolors(genetree, cbind(dynamiccolors, mergedcolors), c("dynamic Tree Cut", "Merged dynamic"), dendrolabels = FALSE, hang = 0.03, addguide = TRUE, guidehang = 0.05) modulecolors = mergedcolors colororder = c("grey", standardcolors(50)); modulelabels = match(modulecolors, colororder)-1; MEs = mergedmes; ngenes = ncol(datexpr); nsamples = nrow(datexpr); MEs0 = moduleeigengenes(datexpr, modulecolors)$eigengenes MEs = ordermes(mes0) moduletraitcor = cor(mes, dattraits, use = "p"); moduletraitpvalue = corpvaluestudent(moduletraitcor, nsamples); sizegrwindow(10,6) textmatrix = paste(signif(moduletraitcor, 2), "\n(", signif(moduletraitpvalue, 1), ")", sep = ""); dim(textmatrix) = dim(moduletraitcor) par(mar = c(6, 8.5, 3, 3)); labeledheatmap(matrix = moduletraitcor, xlabels = names(dattraits), ylabels = names(mes), ysymbols = names(mes), colorlabels = FALSE, colors = greenwhitered(50), textmatrix = textmatrix, setstdmargins = FALSE, cex.text = 0.5, zlim = c(-1,1), main = paste("module-trait relationships")) ##### This is for modular membership scores ##### datkme = signedkme(datexpr, MEs, outputcolumnname = "kme") write.csv(datkme, file="datkme.csv") ##### This is for gene significance scores ##### Disease = as.data.frame(dattraits$disease.status) GS.Disease = as.numeric(cor(datexpr, Disease, use = "p")) write.csv(gs.disease, file="gs.disease.csv") ##### This is for intramodular connectivity scores #####

IMConnectivity = intramodularconnectivity(adjacency, modulecolors, scalebymax = FALSE) write.csv(imconnectivity, file="imconnectivity.csv") To retrieve module genes for IPA Core Analyses: module = "black" probes = names(datexpr) inmodule = (modulecolors==module); modprobes = probes[inmodule];