Skip to content

Commit

Permalink
Merge pull request #193 from zargham-ahmad/issue_120
Browse files Browse the repository at this point in the history
Refactored find.match function
  • Loading branch information
hechth authored Apr 15, 2023
2 parents 12522b2 + 4fd428f commit e84061c
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 39 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
## [dev] - unreleased
### Added
### Changed
- refactored find.match [#193](https://github.com/RECETOX/recetox-aplcms/pull/193)
### Removed

## [0.10.3] - 2023-03-27
Expand Down
66 changes: 33 additions & 33 deletions R/find.match.R
Original file line number Diff line number Diff line change
@@ -1,38 +1,38 @@
find_min_position <- function(distances) {
position <- which.min(distances)[1]
position_x <- position %% nrow(distances)
position_x <- ifelse(position_x == 0, nrow(distances), position_x)
position_y <- ceiling(position / nrow(distances))
return(c(position_x, position_y))
}

#' Internal function: finding the best match between a set of detected features and a set of known features.
#'
#'
#' Given a small matrix of distances, find the best column-row pairing that minimize the sum of distances of the matched pairs.
#'
#' @param a A matrix of distances.
#' @param unacceptable A distance larger than which cannot be accepted as pairs.
#' @return A matrix the same dimension as the input matrix, with matched position taking value 1, and all other positions taking value 0.
find.match <- function(a, unacceptable) {
find.min.pos<-function(d)
{
pos<-which(d==min(d))[1]
pos.x<-pos %% nrow(d)
if(pos.x == 0) pos.x<-nrow(d)
pos.y<-floor((pos-1)/nrow(d)+1)
pos<-c(pos.x, pos.y)
return(pos)
}

b<-a*0
if(ncol(a) == 1)
{
sel<-which(a[,1]==min(a[,1]))[1]
if(a[sel,1] <= unacceptable) b[sel,1]<-1
}else if(nrow(a)==1){
sel<-which(a[1,]==min(a[1,]))[1]
if(a[1,sel] <= unacceptable) b[1,sel]<-1
}else{
p<-find.min.pos(a)
while(a[p[1],p[2]] <= unacceptable)
{
b[p[1],p[2]]<-1
a[p[1],]<-1e10
a[,p[2]]<-1e10
p<-find.min.pos(a)
#'
#' @param distances A matrix of distances.
#' @param max_distance A distance larger than which cannot be accepted as pairs.
#' @return A binary matrix the same size as the input matrix, with matched position taking value 1, and all other positions taking value 0.
find.match <- function(distances, max_distance) {
matches <- matrix(0, nrow(distances), ncol(distances))

if (ncol(distances) == 1) {
sel <- which.min(distances[, 1])[1]
matches[sel, 1] <- as.numeric(distances[sel, 1] <= max_distance)
} else if (nrow(distances) == 1) {
sel <- which(distances[1, ] == min(distances[1, ]))[1]
matches[1, sel] <- as.numeric(distances[1, sel] <= max_distance)
} else {
while (TRUE) {
min_position <- find_min_position(distances)
if (distances[min_position[1], min_position[2]] > max_distance) {
break
}
matches[min_position[1], min_position[2]] <- 1
distances[min_position[1], ] <- 1e10
distances[, min_position[2]] <- 1e10
}
}
return(b)

return(matches)
}
4 changes: 2 additions & 2 deletions R/semi.sup.R
Original file line number Diff line number Diff line change
Expand Up @@ -324,7 +324,7 @@ semi.sup <- function(


time.matched[is.na(time.matched)]<-aligned$rt_tol_relative/2
both.matched<-find.match(time.matched, unacceptable=aligned$rt_tol_relative/2)
both.matched<-find.match(time.matched, aligned$rt_tol_relative/2)

for(m in 1:length(sel.new))
{
Expand Down Expand Up @@ -543,7 +543,7 @@ semi.sup <- function(


time.matched[is.na(time.matched)]<-aligned$rt_tol_relative/2-0.0000001
both.matched<-find.match(time.matched, unacceptable=aligned$rt_tol_relative/2)
both.matched<-find.match(time.matched, aligned$rt_tol_relative/2)

for(m in 1:length(sel.new))
{
Expand Down
8 changes: 4 additions & 4 deletions man/find.match.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit e84061c

Please sign in to comment.