Skip to content

Commit

Permalink
implement ignore argument for setting feature names and spatial coord…
Browse files Browse the repository at this point in the history
…inate names
  • Loading branch information
Artur-man committed Dec 23, 2024
1 parent fc3e721 commit 30f7720
Show file tree
Hide file tree
Showing 17 changed files with 127 additions and 172 deletions.
15 changes: 12 additions & 3 deletions R/assay.R
Original file line number Diff line number Diff line change
Expand Up @@ -553,22 +553,31 @@ vrMainFeatureType.vrAssayV2 <- function(object){
#' @export
vrMainFeatureType.vrAssay <- vrMainFeatureType.vrAssayV2

#' @param ignore ignore if some assays dont have the feature set name
#'
#' @rdname vrMainFeatureType
#' @order 5
#' @export
"vrMainFeatureType<-.vrAssayV2" <- function(object, ignore = FALSE, value){
if(value %in% names(object@data)){
object@main_featureset <- value
} else if(!ignore){
stop("the feature type '", value, "' is not found in the assay!")
} else {
if(ignore){
warning("The feature type '", value, "' is not found in '", vrAssayNames(object),"'. Main feature type is still set to '", vrMainFeatureType(object), "'")
} else {
stop("The feature type '", value, "' is not found in '", vrAssayNames(object),"'. Use ignore = TRUE for ignoring this message")
}
}

return(object)
}

#' @param ignore ignore if some assays dont have the feature set name
#'
#' @rdname vrMainFeatureType
#' @order 5
#' @export
"vrMainFeatureType<-.vrAssay" <- function(object, value){
"vrMainFeatureType<-.vrAssay" <- function(object, ignore = FALSE, value){
stop("vrAssay V1 objects do not have multiple feature types!")
}

Expand Down
3 changes: 2 additions & 1 deletion R/clustering.R
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,8 @@ knn_annoy <- function(data, query = data, k = 10, n_trees = 50, search_k = -1) {
#' Get clustering of the VoltRon object
#'
#' @param object a VoltRon object
#' @param resolution the resolution parameter for leiden clustering
#' @param resolution the resolution parameter for leiden clustering.
#' @param nclus The number of cluster centers for K-means clustering.
#' @param assay assay name (exp: Assay1) or assay class (exp: Visium, Xenium), see \link{SampleMetadata}.
#' if NULL, the default assay will be used, see \link{vrMainAssay}.
#' @param method The method of clustering. Use 'leiden' to perform graph clustering and 'kmeans' for K-means based clustering
Expand Down
4 changes: 2 additions & 2 deletions R/generics.R
Original file line number Diff line number Diff line change
Expand Up @@ -526,7 +526,7 @@ vrMainSpatial <- function(object, assay = NULL) {
#' @rdname vrMainImage
#' @export vrMainImage<-
#' @noRd
"vrMainImage<-" <- function(object, assay = NULL, value) {
"vrMainImage<-" <- function(object, assay = NULL, ignore = FALSE, value) {
UseMethod(generic = 'vrMainImage<-', object = object)
}

Expand All @@ -539,7 +539,7 @@ vrMainSpatial <- function(object, assay = NULL) {
#' @rdname vrMainSpatial
#' @export vrMainSpatial<-
#' @noRd
"vrMainSpatial<-" <- function(object, assay = NULL, value) {
"vrMainSpatial<-" <- function(object, assay = NULL, ignore = FALSE, value) {
UseMethod(generic = 'vrMainSpatial<-', object = object)
}

Expand Down
176 changes: 54 additions & 122 deletions R/image.R
Original file line number Diff line number Diff line change
Expand Up @@ -571,11 +571,9 @@ vrMainImage.VoltRon <- function(object, assay = NULL){
}

# get assay types
# image_names <- unlist(lapply(assay_names, function(x) vrMainImage(object[[x]])))
spatial_names <- unlist(lapply(assay_names, function(x) vrMainSpatial(object[[x]])))

# return data
# image_data <- data.frame(Assay = assay_names, Image = image_names)
spatial_data <- data.frame(Assay = assay_names, Spatial = spatial_names)

# return
Expand All @@ -598,16 +596,20 @@ vrMainSpatial.VoltRon <- function(object, assay = NULL){
#' @order 4
#' @export
"vrMainImage<-.VoltRon" <- function(object, assay = NULL, value){

if(!is.null(assay)){
if(length(assay) == 1){
# vrMainImage(object[[assay]]) <- value
vrMainSpatial(object[[assay]]) <- value
} else {
stop("You can only set the main image of a single assay")
}

# get assay names
assay_names <- vrAssayNames(object, assay = assay)

# get spatial metadata
sample.metadata <- SampleMetadata(object)
assayclass <- unique(sample.metadata[assay_names,"Assay"])

# check for assay number
if(length(assayclass) == 1){
for(assy in assay_names)
vrMainSpatial(object[[assy]], ignore = TRUE) <- value
} else {
stop("You should define the assay whose main image you wanna set, by using 'Assay = <assay name>'")
stop("You can only set the main spatial system of a single assay")
}

return(object)
Expand All @@ -623,9 +625,14 @@ vrMainSpatial.VoltRon <- function(object, assay = NULL){
# get assay names
assay_names <- vrAssayNames(object, assay = assay)

# get spatial metadata
sample.metadata <- SampleMetadata(object)
assayclass <- unique(sample.metadata[assay_names,"Assay"])

# check for assay number
if(length(assay_names) == 1){
vrMainSpatial(object[[assay_names]]) <- value
if(length(assayclass) == 1){
for(assy in assay_names)
vrMainSpatial(object[[assy]], ignore = TRUE) <- value
} else {
stop("You can only set the main spatial system of a single assay")
}
Expand Down Expand Up @@ -657,12 +664,10 @@ vrMainSpatial.vrAssay <- function(object){
#' @export
vrMainSpatial.vrAssayV2 <- vrMainSpatial.vrAssay

#' @rdname vrMainImage
#' @order 5
#' @export
"vrMainImage<-.vrAssay" <- function(object, value){

if(length(value) > 0){
#' @noRd
.replaceMainSpatial <- function(object, ignore = FALSE, value){

if(length(value) %in% c(1,2)){

# get channel name if exists in the value
if(length(value) == 2){
Expand All @@ -675,122 +680,56 @@ vrMainSpatial.vrAssayV2 <- vrMainSpatial.vrAssay
# set main spatial/image
if(value %in% vrSpatialNames(object)){
object@main_image <- value

# set channel
if(!is.null(channel))
vrMainChannel(object@image[[value]]) <- channel

} else {
stop("'",value,"' is not a spatial coordinate system")
if(ignore){
warning("'",value,"' is not a spatial coordinate system in '", vrAssayNames(object),"'. Main system is still set to '", vrMainSpatial(object), "'")
} else {
stop("'",value,"' is not a spatial coordinate system in '", vrAssayNames(object),"'. Use ignore = TRUE for ignoring this message")
}
}

# set channel
if(!is.null(channel))
vrMainChannel(object@image[[value]]) <- channel

} else {
stop("The Main image is set by either: \n vrMainImage(object) <- c('image name', 'channel name')\n or vrMainImage(object) <- 'image name'")
stop("The Main image is set by either: \n vrMainSpatial(object) <- c('<spatial name>', '<channel name>')\n or vrMainSpatial(object) <- '<spatial name>'")
}

return(object)
}

#' @param ignore if TRUE, the non-existing spatial coordinate system will be ignored.
#'
#' @rdname vrMainImage
#' @order 5
#' @export
"vrMainImage<-.vrAssayV2" <- function(object, value){

if(length(value) > 0){

# get channel name if exists in the value
if(length(value) == 2){
channel <- value[2]
value <- value[1]
} else {
channel <- NULL
}

# set main spatial/image
if(value %in% vrSpatialNames(object)){
object@main_image <- value
} else {
stop("'",value,"' is not a spatial coordinate system")
}

# set channel
if(!is.null(channel))
vrMainChannel(object@image[[value]]) <- channel

} else {
stop("The Main image is set by either: \n vrMainImage(object) <- c('image name', 'channel name')\n or vrMainImage(object) <- 'image name'")
}

return(object)
}
"vrMainImage<-.vrAssay" <- .replaceMainSpatial

#' @param ignore if TRUE, the non-existing spatial coordinate system will be ignored.
#'
#' @rdname vrMainImage
#' @order 5
#' @export
"vrMainImage<-.vrAssayV2" <- .replaceMainSpatial

#' @param ignore if TRUE, the non-existing spatial coordinate system will be ignored.
#'
#' @rdname vrMainSpatial
#' @order 5
#' @export
"vrMainSpatial<-.vrAssay" <- function(object, value){

if(length(value) > 0){

# get channel name if exists in the value
if(length(value) == 2){
channel <- value[2]
value <- value[1]
} else {
channel <- NULL
}

# set main spatial/image
if(value %in% vrSpatialNames(object)){
object@main_image <- value
} else {
stop("'",value,"' is not a spatial coordinate system")
}

# set channel
if(!is.null(channel))
vrMainChannel(object@image[[value]]) <- channel

} else {
stop("The Main image is set by either: \n vrMainImage(object) <- c('image name', 'channel name')\n or vrMainImage(object) <- 'image name'")
}

return(object)
}
"vrMainSpatial<-.vrAssay" <- .replaceMainSpatial

#' @param ignore if TRUE, the non-existing spatial coordinate system will be ignored.
#'
#' @rdname vrMainSpatial
#' @order 5
#' @export
"vrMainSpatial<-.vrAssayV2" <- function(object, value){

if(length(value) > 0){

# get channel name if exists in the value
if(length(value) == 2){
channel <- value[2]
value <- value[1]
} else {
channel <- NULL
}

# set main spatial/image
if(value %in% vrSpatialNames(object)){
object@main_image <- value
} else {
stop("'",value,"' is not a spatial coordinate system")
}

# set channel
if(!is.null(channel))
vrMainChannel(object@image[[value]]) <- channel

} else {
stop("The Main image is set by either: \n vrMainImage(object) <- c('image name', 'channel name')\n or vrMainImage(object) <- 'image name'")
}

return(object)
}
"vrMainSpatial<-.vrAssayV2" <- .replaceMainSpatial

#' @param assay assay name (exp: Assay1) or assay class (exp: Visium, Xenium), see \link{SampleMetadata}.
#' If NULL, the default assay will be used, see \link{vrMainAssay}. If given as "all", then provides a summary of spatial systems across all assays
#' If NULL, the default assay will be used, see \link{vrMainAssay}. If equals to "all", then provides a summary of spatial systems across all assays
#'
#' @rdname vrImageNames
#'
Expand All @@ -810,14 +749,14 @@ vrImageNames.VoltRon <- function(object, assay = NULL){
}
}

# image_names <- unique(unlist(lapply(assay_names, function(x) vrImageNames(object[[x]]))))
# unique names
spatial_names <- unique(unlist(lapply(assay_names, function(x) vrSpatialNames(object[[x]]))))

return(spatial_names)
}

#' @param assay assay name (exp: Assay1) or assay class (exp: Visium, Xenium), see \link{SampleMetadata}.
#' if NULL, the default assay will be used, see \link{vrMainAssay}.
#' if NULL, the default assay will be used, see \link{vrMainAssay}. If equals to "all", then provides a summary of spatial systems across all assays
#'
#' @rdname vrSpatialNames
#'
Expand Down Expand Up @@ -963,7 +902,6 @@ vrImageChannelNames.VoltRon <- function(object, assay = NULL){
}

# get image names
# image_names <- unlist(lapply(assay_names, function(x) vrMainImage(object[[x]])))
spatial_names <- unlist(lapply(assay_names, function(x) vrMainSpatial(object[[x]])))

# get channel names
Expand Down Expand Up @@ -1500,12 +1438,6 @@ vrCoordinates.vrSpatial <- function(object) {
} else {
stop("Please make sure that the coordinates matrix have only two or three columns: for x and y coordinates")
}

# if(ncol(value) != 2) {
# stop("Please make sure that the coordinates matrix have only two columns: for x and y coordinates")
# } else {
# colnames(value) <- c("x", "y")
# }

methods::slot(object = object, name = 'coords') <- value
return(object)
Expand Down
5 changes: 2 additions & 3 deletions R/objects.R
Original file line number Diff line number Diff line change
Expand Up @@ -1403,13 +1403,12 @@ vrMainFeatureType.VoltRon <- function(object, assay = NULL){
}
}

#' @param ignore ignore if some assays dont have the feature set name
#' @param value the name of main feature set
#'
#' @rdname vrMainFeatureType
#' @order 4
#' @export
"vrMainFeatureType<-.VoltRon" <- function(object, assay = NULL, ignore = FALSE, value){
"vrMainFeatureType<-.VoltRon" <- function(object, assay = NULL, value){

# sample metadata
sample_metadata <- SampleMetadata(object)
Expand All @@ -1421,7 +1420,7 @@ vrMainFeatureType.VoltRon <- function(object, assay = NULL){
stop("You can only set the main feature type of a single assay type")
} else {
for(assy in assay_names){
vrMainFeatureType(object[[assy]], ignore = ignore) <- value
vrMainFeatureType(object[[assy]], ignore = TRUE) <- value
}
}

Expand Down
2 changes: 1 addition & 1 deletion docs/registration.Rmd
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ VRBlock <- transferData(VRBlock, from = "Assay2", to = "Assay1")
We now set the main feature set of the Xenium assays.

```{r class.source="watch-out", eval = FALSE}
vrMainFeatureType(VRBlock, assay = "Xenium", ignore = TRUE) <- "RNA_pseudo"
vrMainFeatureType(VRBlock, assay = "Xenium") <- "RNA_pseudo"
vrMainFeatureType(VRBlock, assay = "all")
```

Expand Down
2 changes: 1 addition & 1 deletion docs/registration.html
Original file line number Diff line number Diff line change
Expand Up @@ -717,7 +717,7 @@ <h4>Data Transfer (Spots-&gt;Cells)</h4>
<pre class="r watch-out"><code>vrMainFeatureType(VRBlock, assay = &quot;Visium&quot;) &lt;- &quot;RNA&quot;
VRBlock &lt;- transferData(VRBlock, from = &quot;Assay2&quot;, to = &quot;Assay1&quot;)</code></pre>
<p>We now set the main feature set of the Xenium assays.</p>
<pre class="r watch-out"><code>vrMainFeatureType(VRBlock, assay = &quot;Xenium&quot;, ignore = TRUE) &lt;- &quot;RNA_pseudo&quot;
<pre class="r watch-out"><code>vrMainFeatureType(VRBlock, assay = &quot;Xenium&quot;) &lt;- &quot;RNA_pseudo&quot;
vrMainFeatureType(VRBlock, assay = &quot;all&quot;)</code></pre>
<pre><code> Assay Feature
1 Assay1 RNA_pseudo
Expand Down
Loading

0 comments on commit 30f7720

Please sign in to comment.