Title: | Enable downstream analysis of Visium capture areas stitched together with Fiji |
---|---|
Description: | This package provides helper functions for working with multiple Visium capture areas that overlap each other. This package was developed along with the companion example use case data available from https://github.com/LieberInstitute/visiumStitched_brain. visiumStitched prepares SpaceRanger (10x Genomics) output files so you can stitch the images from groups of capture areas together with Fiji. Then visiumStitched builds a SpatialExperiment object with the stitched data and makes an artificial hexogonal grid enabling the seamless use of spatial clustering methods that rely on such grid to identify neighboring spots, such as PRECAST and BayesSpace. The SpatialExperiment objects created by visiumStitched are compatible with spatialLIBD, which can be used to build interactive websites for stitched SpatialExperiment objects. visiumStitched also enables casting SpatialExperiment objects as Seurat objects. |
Authors: | Nicholas J. Eagles [aut, cre] , Leonardo Collado-Torres [ctb] |
Maintainer: | Nicholas J. Eagles <[email protected]> |
License: | Artistic-2.0 |
Version: | 0.99.15 |
Built: | 2025-01-13 03:55:01 UTC |
Source: | https://github.com/bioc/visiumStitched |
SpatialExperiment
Given a SpatialExperiment-class, sample information, and coordinates produced from the refinement workflow, add array and pixel coordinates appropriate for the linearly transformed capture areas making up each group present in the SpatialExperiment-class.
add_array_coords(spe, sample_info, coords_dir, calc_error_metrics = FALSE)
add_array_coords(spe, sample_info, coords_dir, calc_error_metrics = FALSE)
spe |
A SpatialExperiment-class object. |
sample_info |
A |
coords_dir |
A |
calc_error_metrics |
A |
Array coordinates are determined via an algorithm that fits each spot to
the nearest spot on a new, imaginary, Visium-like capture area. The imaginary
capture area differs from a real capture area only in its extent; array
coordinates still start at 0 but may extend arbitrarily beyond the normal
maximum indices of 77 and 127 to fit every capture area in each group
defined in the SpatialExperiment-class.
The goal is to return well-defined
array coordinates in a consistent spatial orientation for each group, such
that downstream applications, such as clustering with BayesSpace
, can
process each group as if it really were one capture area in the first place.
See
https://research.libd.org/visiumStitched/articles/visiumStitched.html#defining-array-coordinates
for more details.
A SpatialExperiment-class
object with additional colData
columns pxl_row_in_fullres_[suffix]
and pxl_col_in_fullres_[suffix]
with [suffix]
values original
and rounded
;
array_row_original
and array_col_original
columns; and
modified colData()
columns array_row
and
array_col
and spatialCoords()
with their transformed values.
Nicholas J. Eagles
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } ######################################################################## # Prepare sample_info ######################################################################## sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) ## Preparing Fiji coordinates and images for build_SpatialExperiment() spe_input_dir <- tempdir() prep_fiji_coords(sample_info, out_dir = spe_input_dir) prep_fiji_image(sample_info, out_dir = spe_input_dir) ######################################################################## # Add array coordinates ######################################################################## spe_new <- add_array_coords(spe, sample_info, tempdir()) # Several columns related to spatial coordinates were added added_cols_regex <- "^(array|pxl)_(row|col)(_in_fullres)?_(original|rounded)$" colnames(SummarizedExperiment::colData(spe_new))[ grep(added_cols_regex, colnames(SummarizedExperiment::colData(spe_new))) ] # 'array_row', 'array_col', and spatialCoords() were overwritten with # their transformed values head(spe$array_row) head(spe$array_col) head(SpatialExperiment::spatialCoords(spe_new))
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } ######################################################################## # Prepare sample_info ######################################################################## sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) ## Preparing Fiji coordinates and images for build_SpatialExperiment() spe_input_dir <- tempdir() prep_fiji_coords(sample_info, out_dir = spe_input_dir) prep_fiji_image(sample_info, out_dir = spe_input_dir) ######################################################################## # Add array coordinates ######################################################################## spe_new <- add_array_coords(spe, sample_info, tempdir()) # Several columns related to spatial coordinates were added added_cols_regex <- "^(array|pxl)_(row|col)(_in_fullres)?_(original|rounded)$" colnames(SummarizedExperiment::colData(spe_new))[ grep(added_cols_regex, colnames(SummarizedExperiment::colData(spe_new))) ] # 'array_row', 'array_col', and spatialCoords() were overwritten with # their transformed values head(spe$array_row) head(spe$array_col) head(SpatialExperiment::spatialCoords(spe_new))
Given a SpatialExperiment-class
and column name in its colData
,
return a modified copy of the SpatialExperiment
with additional colData
columns: spe$exclude_overlapping
and spe$overlap_key
.
add_overlap_info(spe, metric_name)
add_overlap_info(spe, metric_name)
spe |
A SpatialExperiment-class
with |
metric_name |
|
spe$exclude_overlapping
is TRUE
for spots with a higher-quality
overlapping capture area and FALSE
otherwise.
vis_clus onlydisplays FALSE
spots to
prevent overplotting in regions of overlap. spe$overlap_key
gives
comma-separated strings containing the keys of any overlapping spots, and is
the empty string otherwise.
A SpatialExperiment
object with additional colData
columns spe$exclude_overlapping
and spe$overlap_key
.
Nicholas J. Eagles
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } # Find the mean of the 'sum_umi' metric by capture area to understand # which capture areas will be excluded in regions of overlap SummarizedExperiment::colData(spe) |> dplyr::as_tibble() |> dplyr::group_by(capture_area) |> dplyr::summarize(mean_sum_umi = mean(sum_umi)) spe <- add_overlap_info(spe, "sum_umi") # See how many spots were excluded by capture area table(spe$exclude_overlapping, spe$capture_area) # Examine how data about overlapping spots is stored (for the first # few spots with overlap) head(spe$overlap_key[spe$overlap_key != ""])
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } # Find the mean of the 'sum_umi' metric by capture area to understand # which capture areas will be excluded in regions of overlap SummarizedExperiment::colData(spe) |> dplyr::as_tibble() |> dplyr::group_by(capture_area) |> dplyr::summarize(mean_sum_umi = mean(sum_umi)) spe <- add_overlap_info(spe, "sum_umi") # See how many spots were excluded by capture area table(spe$exclude_overlapping, spe$capture_area) # Examine how data about overlapping spots is stored (for the first # few spots with overlap) head(spe$overlap_key[spe$overlap_key != ""])
SpatialExperiment
object to a Seurat
objectGiven a SpatialExperiment-class
object, first as.Seurat()
is run, which operates on
SingleCellExperiment-class
objects. The remaining components (images, spatial coordinates) are added
manually. The actual appearance of images are buggy for now.
as.Seurat( spe, spatial_cols = c(tissue = "in_tissue", row = "array_row", col = "array_col", imagerow = "pxl_row_in_fullres", imagecol = "pxl_col_in_fullres"), verbose = TRUE )
as.Seurat( spe, spatial_cols = c(tissue = "in_tissue", row = "array_row", col = "array_col", imagerow = "pxl_row_in_fullres", imagecol = "pxl_col_in_fullres"), verbose = TRUE )
spe |
A
SpatialExperiment-class with
|
spatial_cols |
A |
verbose |
A |
Note that only the lowres
images from imgData(spe)
will be used.
A Seurat
object.
Nicholas J. Eagles
## Download some example data spe_unstitched <- spatialLIBD::fetch_data( type = "spatialDLPFC_Visium_example_subset" )[seq(100), seq(100)] ## Make the column names unique colnames(spe_unstitched) <- spatialLIBD::add_key(spe_unstitched)$key ## Convert from a SpatialExperiment to a Seurat object seur <- as.Seurat(spe_unstitched) seur ## Example with an stitched SPE object if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } seur_stitched <- as.Seurat(spe[seq(100), seq(100)]) ## Let's look at our resulting Seurat object seur_stitched
## Download some example data spe_unstitched <- spatialLIBD::fetch_data( type = "spatialDLPFC_Visium_example_subset" )[seq(100), seq(100)] ## Make the column names unique colnames(spe_unstitched) <- spatialLIBD::add_key(spe_unstitched)$key ## Convert from a SpatialExperiment to a Seurat object seur <- as.Seurat(spe_unstitched) seur ## Example with an stitched SPE object if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } seur_stitched <- as.Seurat(spe[seq(100), seq(100)]) ## Let's look at our resulting Seurat object seur_stitched
SpatialExperiment
First, read in capture-area-level SpaceRanger
https://www.10xgenomics.com/support/software/space-ranger/latest/analysis/running-pipelines/space-ranger-count
outputs. Then, overwrite
spatial coordinates and images to represent group-level samples using
sample_info$group
(though keep original coordinates in
colData
columns ending with the suffix "_original"
). Next, add info
about overlaps (via spe$exclude_overlapping
and
spe$overlap_key
).
Ultimately, return a
SpatialExperiment-class ready
for visualization or downstream analysis.
build_SpatialExperiment( sample_info, coords_dir, count_type = "sparse", reference_gtf = NULL, gtf_cols = c("source", "type", "gene_id", "gene_version", "gene_name", "gene_type"), calc_error_metrics = FALSE )
build_SpatialExperiment( sample_info, coords_dir, count_type = "sparse", reference_gtf = NULL, gtf_cols = c("source", "type", "gene_id", "gene_version", "gene_name", "gene_type"), calc_error_metrics = FALSE )
sample_info |
A |
coords_dir |
A |
count_type |
A |
reference_gtf |
Passed to |
gtf_cols |
Passed to |
calc_error_metrics |
A |
A SpatialExperiment-class
object with one sample per group specified in sample_info
using
transformed pixel and array coordinates (including in the
spatialCoords()
).
Nicholas J. Eagles
######################################################################## # Prepare sample_info ######################################################################## sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) ## Preparing Fiji coordinates and images for build_SpatialExperiment() spe_input_dir <- tempdir() prep_fiji_coords(sample_info, out_dir = spe_input_dir) prep_fiji_image(sample_info, out_dir = spe_input_dir) ######################################################################## # Build the SpatialExperiment ######################################################################## # Since we don't have access to the original GTF used to run SpaceRanger, # we must explicitly supply our own GTF to build_SpatialExperiment(). We use # GENCODE release 32, intended to be quite close to the actual GTF used, # which is available from: # https://cf.10xgenomics.com/supp/cell-exp/refdata-gex-GRCh38-2024-A.tar.gz bfc <- BiocFileCache::BiocFileCache() gtf_cache <- BiocFileCache::bfcrpath( bfc, paste0( "ftp://ftp.ebi.ac.uk/pub/databases/gencode/Gencode_human/", "release_32/gencode.v32.annotation.gtf.gz" ) ) ## Now we can build the stitched SpatialExperiment object spe <- build_SpatialExperiment( sample_info, coords_dir = spe_input_dir, reference_gtf = gtf_cache ) ## Let's explore the stitched SpatialExperiment object spe
######################################################################## # Prepare sample_info ######################################################################## sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) ## Preparing Fiji coordinates and images for build_SpatialExperiment() spe_input_dir <- tempdir() prep_fiji_coords(sample_info, out_dir = spe_input_dir) prep_fiji_image(sample_info, out_dir = spe_input_dir) ######################################################################## # Build the SpatialExperiment ######################################################################## # Since we don't have access to the original GTF used to run SpaceRanger, # we must explicitly supply our own GTF to build_SpatialExperiment(). We use # GENCODE release 32, intended to be quite close to the actual GTF used, # which is available from: # https://cf.10xgenomics.com/supp/cell-exp/refdata-gex-GRCh38-2024-A.tar.gz bfc <- BiocFileCache::BiocFileCache() gtf_cache <- BiocFileCache::bfcrpath( bfc, paste0( "ftp://ftp.ebi.ac.uk/pub/databases/gencode/Gencode_human/", "release_32/gencode.v32.annotation.gtf.gz" ) ) ## Now we can build the stitched SpatialExperiment object spe <- build_SpatialExperiment( sample_info, coords_dir = spe_input_dir, reference_gtf = gtf_cache ) ## Let's explore the stitched SpatialExperiment object spe
Given a stitched SpatialExperiment-class,
merge overlapping (same array coordinates) spots by adding
expression (i.e. from assays(spe)$counts
), returning a
SpatialExperiment
with at most one spot per array location.
merge_overlapping(spe)
merge_overlapping(spe)
spe |
A SpatialExperiment-class
with |
colData(spe)
and spatialCoords(spe)
of the merged spots are
taken from the spots whose exclude_overlapping
values are TRUE
.
A SpatialExperiment with at most one spot per array location
Nicholas J. Eagles
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } # Group colData by group and array coordinates grouped_coldata <- colData(spe) |> dplyr::as_tibble() |> dplyr::group_by(group, array_row, array_col) # Find the first 100 keys that overlap other spots and don't, respectively overlapping_keys <- grouped_coldata |> dplyr::filter(dplyr::n() > 1) |> dplyr::slice_head(n = 2) |> dplyr::ungroup() |> dplyr::slice_head(n = 100) |> dplyr::pull(key) nonoverlapping_keys <- grouped_coldata |> dplyr::filter(dplyr::n() == 1) |> dplyr::ungroup() |> dplyr::slice_head(n = 100) |> dplyr::pull(key) # Built a small SPE containing some overlaps and some non-overlapping spots small_spe <- spe[, c(overlapping_keys, nonoverlapping_keys)] # Merge overlapping spots small_spe_merged <- merge_overlapping(small_spe) # All array coordinates have just one unique spot after merging colData(small_spe_merged) |> dplyr::as_tibble() |> dplyr::group_by(group, array_row, array_col) |> dplyr::summarize(n = dplyr::n()) |> dplyr::pull(n) |> table()
if (!exists("spe")) { spe <- spatialLIBD::fetch_data(type = "visiumStitched_brain_spe") } # Group colData by group and array coordinates grouped_coldata <- colData(spe) |> dplyr::as_tibble() |> dplyr::group_by(group, array_row, array_col) # Find the first 100 keys that overlap other spots and don't, respectively overlapping_keys <- grouped_coldata |> dplyr::filter(dplyr::n() > 1) |> dplyr::slice_head(n = 2) |> dplyr::ungroup() |> dplyr::slice_head(n = 100) |> dplyr::pull(key) nonoverlapping_keys <- grouped_coldata |> dplyr::filter(dplyr::n() == 1) |> dplyr::ungroup() |> dplyr::slice_head(n = 100) |> dplyr::pull(key) # Built a small SPE containing some overlaps and some non-overlapping spots small_spe <- spe[, c(overlapping_keys, nonoverlapping_keys)] # Merge overlapping spots small_spe_merged <- merge_overlapping(small_spe) # All array coordinates have just one unique spot after merging colData(small_spe_merged) |> dplyr::as_tibble() |> dplyr::group_by(group, array_row, array_col) |> dplyr::summarize(n = dplyr::n()) |> dplyr::pull(n) |> table()
Together, prep_fiji_image()
and prep_fiji_coords()
process Fiji outputs
and generate one directory per group resembling Spaceranger's
spatial outputs;
in particular, tissue_positions.csv
, tissue_lowres_image.png
, and
scalefactors_json.json
files are created. These functions are necessary to
run in preparation for build_SpatialExperiment()
.
prep_fiji_image(sample_info, out_dir, lowres_max_size = 1200) prep_fiji_coords(sample_info, out_dir)
prep_fiji_image(sample_info, out_dir, lowres_max_size = 1200) prep_fiji_coords(sample_info, out_dir)
sample_info |
A |
out_dir |
A |
lowres_max_size |
An |
Given a data.frame()
of sample information (sample_info
) with
columns capture_area
, group
, and fiji_xml_path
,
expected to have one unique path to Fiji XML output per group, prep_fiji_coords
reads in the pixel coordinates from each capture area's tissue_positions.csv
file from SpaceRanger, and transform using the rotation matrix specified
by Fiji https://imagej.net/software/fiji/. It writes one new tissue_positions.csv
file per group.
After stitching all groups in sample_info
with Fiji, images of
various resolutions (pixel dimensions) are left. prep_fiji_image()
creates copies
of each image whose largest dimension is lowres_max_size
pixels. It
also creates a corresponding scalefactors_json.json
file much like
SpaceRanger's.
This function returns a character()
with the file paths to the
files it created. For prep_fiji_coords()
, these are the tissue_positions.csv
files; for prep_fiji_image()
, these are the tissue_lowres_image.png
and
scalefactors_json.json
files.
prep_fiji_image()
: Create low-res images and scale factors from high-res
Fiji output images
prep_fiji_coords()
: Apply transform info from Fiji XML output
Nicholas J. Eagles
sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) spe_input_dir <- tempdir() out_paths_image <- prep_fiji_image( sample_info, out_dir = spe_input_dir, lowres_max_size = 1000 ) out_path_coords <- prep_fiji_coords(sample_info, out_dir = spe_input_dir) # A "low resolution" stitched image was produced, which has 1000 # pixels in its largest dimension this_image <- imager::load.image( file.path(spe_input_dir, "Br2719", "tissue_lowres_image.png") ) dim(this_image) library("imager") plot(this_image) # 'prep_fiji_image' produced an image and scalefactors out_paths_image # 'prep_fiji_coords' produced a file of spatial coordinates for the # stitched Br2719 readr::read_csv(out_path_coords)
sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info sample_info <- rescale_fiji_inputs(sample_info, out_dir = tempdir()) spe_input_dir <- tempdir() out_paths_image <- prep_fiji_image( sample_info, out_dir = spe_input_dir, lowres_max_size = 1000 ) out_path_coords <- prep_fiji_coords(sample_info, out_dir = spe_input_dir) # A "low resolution" stitched image was produced, which has 1000 # pixels in its largest dimension this_image <- imager::load.image( file.path(spe_input_dir, "Br2719", "tissue_lowres_image.png") ) dim(this_image) library("imager") plot(this_image) # 'prep_fiji_image' produced an image and scalefactors out_paths_image # 'prep_fiji_coords' produced a file of spatial coordinates for the # stitched Br2719 readr::read_csv(out_path_coords)
Given a data.frame()
of sample information (sample_info
)
with
columns capture_area
, group
, and spaceranger_dir
,
Write new high-resolution images for use as input to Fiji
https://imagej.net/software/fiji/. Particularly
when capture areas come from different slides, there is a risk of significant
scale differences among SpaceRanger's tissue_hires_image.png
images;
that is, the physical distance represented by a pixel from each capture area
may differ nontrivially, leading to a distance-distorted output image, and
inconsistent scaling when later transforming pixel coordinates. This function
writes approximately high-res images whose pixels are of equal physical size
within each group
, then adds intra_group_scalar
and
group_hires_scalef
columns to sample_info
. intra_group_scalar
gives the scalar by a which a given capture area's
tissue_hires_image.png
image and pixel
coordinates must be multiplied to match the scale of other group
members; group_hires_scalef
gives the new tissue_hires_scalef
(as from SpaceRanger's scalefactors_json.json
file) appropriate for
every capture area from the group.
rescale_fiji_inputs(sample_info, out_dir)
rescale_fiji_inputs(sample_info, out_dir)
sample_info |
A |
out_dir |
A |
A tibble: a copy of sample_info
with
additional columns
intra_group_scalar
and group_hires_scalef
.
Nicholas J. Eagles
# Define sample information for the example human brain data sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info out_dir <- tempdir() sample_info_new <- rescale_fiji_inputs(sample_info, out_dir = out_dir) # Scale factors are computed that are necessary downstream (i.e. with # prep_fiji_*() functions) sample_info_new[, setdiff(colnames(sample_info_new), colnames(sample_info))] # Image are produced that are ready for alignment in Fiji list.files(out_dir)
# Define sample information for the example human brain data sample_info <- dplyr::tibble( group = "Br2719", capture_area = c("V13B23-283_A1", "V13B23-283_C1", "V13B23-283_D1") ) # Add 'spaceranger_dir' column sr_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_spaceranger"), exdir = sr_dir ) sample_info$spaceranger_dir <- file.path( sr_dir, sample_info$capture_area, "outs", "spatial" ) # Add Fiji-output-related columns fiji_dir <- tempdir() temp <- unzip( spatialLIBD::fetch_data("visiumStitched_brain_Fiji_out"), exdir = fiji_dir ) sample_info$fiji_xml_path <- temp[grep("xml$", temp)] sample_info$fiji_image_path <- temp[grep("png$", temp)] ## Re-size images and add more information to the sample_info out_dir <- tempdir() sample_info_new <- rescale_fiji_inputs(sample_info, out_dir = out_dir) # Scale factors are computed that are necessary downstream (i.e. with # prep_fiji_*() functions) sample_info_new[, setdiff(colnames(sample_info_new), colnames(sample_info))] # Image are produced that are ready for alignment in Fiji list.files(out_dir)