R/tang.conc.R

Defines functions tang.conc

Documented in tang.conc

################################
#### ANOVA for cicular data (Tangential approach for equality of concentration parameters)
#### Tsagris Michail 1/2015
#### mtsagris@yahoo.gr
#### References: Mardia Kanti V. and Jupp Peter E. (2000)
#### Directional statistics, page 141
################################
tang.conc <- function(u, ina, rads = FALSE) {
  ## u contains all the circular data in radians or degrees
  ## ina is an indicator variable of each sample
  n <- length(u)  ## sample size
  ina <- as.numeric(ina)
  ni <- tabulate(ina)
  g <- max(ina)  ## how many groups are there
  ## if the data are in degrees we transform them into radians
  if ( !rads )   u <- u * pi/180
  d2 <- dmi <- numeric(g)
  x1 <- cos(u)
  x2 <- sin(u)
  C <- rowsum(x1, ina)
  S <- rowsum(x2, ina)
  mi <- atan(S/C) + pi * as.numeric(C<0)
  d <- NULL  ## will store the absolute sinus centred data here
  for (i in 1:g) {
    b <- abs( sin( u[ ina == i ] - mi[i] ) )
    d <- c(d, b)
  }
  dmi <- Rfast::group(d, ina, method = "mean")
  d2 <- Rfast::group(d, ina, method = "var") * (ni - 1)
  mdm <- mean(d)

  Ft <- (n - g) * sum(ni * (dmi - mdm)^2) / ( (g - 1) * sum(d2) )
  p.value <- pf(Ft, g - 1, n - g, lower.tail = FALSE)
  parameter <- c(g - 1, n - g)     ;   names(parameter) <- c("df1", "df2")
  statistic <- Ft  ;   names(statistic) <- "F-test statistic"
  alternative <- "At least one concentration parameter differs"
  method <- "ANOVA for cicular data (Tangential approach for equality of concentration parameters)"
  data.name <- c("data")
  result <- list( statistic = statistic, parameter = parameter, p.value = p.value,
                  alternative = alternative, method = method, data.name = data.name )
  class(result) <- "htest"
}

Try the Directional package in your browser

Any scripts or data that you put into this service are public.

Directional documentation built on Oct. 30, 2024, 9:15 a.m.