Diversity index: Difference between revisions

From Opasnet
Jump to navigation Jump to search
Line 17: Line 17:
####### qD calculates true diversity for abundance pi with exponent q.
####### qD calculates true diversity for abundance pi with exponent q.


### THIS FUNCTION WOULD BE SIMPLER IF DIFFERENT q's WERE PUT UNDERNEATH INSTEAD OF TO DIFFERENT COLUMNS.
qD <- function(pi, q = q.wiki){ # q.wiki is the q given by the user.
qD <- function(pi, q = q.wiki){ # q.wiki is the q used by the diversity function.
q <- rep(q, times = length(pi))
pi <- pi/sum(pi)
pi <- pi/sum(pi)
out <- rep(NA, length(q))
out <- ifelse(q == 1,
for(i in 1:length(q)){
exp(-sum(pi * log(pi))),
if(q[i] == 1)
ifelse(q == 999,
{out[i] <- exp(-sum(pi * log(pi)))} else
1/max(pi),
if( q[i] == 999){
sum(pi^q)^(1 / (1 - q))))
out[i] <- 1/max(pi)} else
{out[i] <- (sum(pi^q[i]))^(1 / (1 - q[i]))
}
}
return(out)
return(out)
}
}
Line 35: Line 31:


qDa <- function(divj, wj = 1, q = q.wiki){
qDa <- function(divj, wj = 1, q = q.wiki){
q. <- rep(q, each = length(wj))
q. <- rep(q, times = length(wj))
minqDj <- 1/tapply(divj, q., min) # Should this be the inverse?
wj <- rep(wj, each = length(q))
minqDj <- tapply(divj, q., min) # Should this be the inverse?
out <- ifelse(q. == 1, wj * log(divj), wj * divj^(1-q.))
out <- ifelse(q. == 1, wj * log(divj), wj * divj^(1-q.))
out <- tapply(out, q., sum)
out <- tapply(out, q., sum)
out <- ifelse(q == 1, exp(out), out^(1/(1-q)))
out <- ifelse(q == 1, exp(out), out^(1/(1-q)))
out[q == 999] <- minqDj[q == 999]
out[q == 999] <- minqDj[q == 999]
### PREVIOUS CODE THAT DID NOT WORK
# out <- ifelse(q. == 1, exp(sum(wj * log(divj))), (sum(wj * divj^(1-q.)))^(1/(1 - q.)))
# minqDj <- tapply(out, q., min)
# out <- tapply(out, q., sum)^(1-q)
# out[q == 999] <- minqDj[q == 999]
return(out)
return(out)
}
}
Line 74: Line 66:
out <- tapply(out$pij, out$Transect, qD)
out <- tapply(out$pij, out$Transect, qD)


qDj <- rep(NA, nrow(wj)*length(q))
qDj <- NULL


for(i in 1:nrow(wj)){
for(i in 1:nrow(wj)){
for(j in 1:length(q)){
qDj <- c(qDj, out[[i]])
qDj[i + (j - 1) * nrow(wj)] <- out[[i]][j]
}
}
}


Line 111: Line 101:
">
">
library(xtable)
library(xtable)
q.wiki = 1
if(is.null(data)) {data <- c(1,4,6,9,3,4,5,6,5,4,3,3,5,5,7,5,5,4,3,4,5,6,8,9,5,4,5,4,3,3,4,9,6,6,4,5,3,2,1,1,2,3,4,3,2,3,4,5,6,7,7)}
if(is.null(data)) {data <- c(1,4,6,9,3,4,5,6,5,4,3,3,5,5,7,5,5,4,3,4,5,6,8,9,5,4,5,4,3,3,4,9,6,6,4,5,3,2,1,1,2,3,4,3,2,3,4,5,6,7,7)}
data
data
diversity(data)
diversity(data)
if(individual==TRUE) out <- diversity(species = data, q = 1) else out <- diversity(amount = data, q = 1)
if(individual==TRUE) out <- diversity(species = data, q = q.wiki) else out <- diversity(amount = data, q = q.wiki)
print(xtable(out), type = 'html')
print(xtable(out), type = 'html')
</rcode>
</rcode>
Line 135: Line 126:
out <- diversity(amount = amount, species = species, transect = transect, q = q.wiki)
out <- diversity(amount = amount, species = species, transect = transect, q = q.wiki)
print(xtable(out), type = 'html')
print(xtable(out), type = 'html')
diversity(amount=1:20, species = 1:20, transect = c(rep(1, 10), rep(2, 10)), q = c(0, 1, 2))


</rcode>
</rcode>

Revision as of 04:27, 10 January 2012



Question

How to calculate diversity indices?

Answer

Upload your data to Opasnet Base. Use the function diversity to calculate the most common indices.

Actual function diversity

+ Show code

Examples

Example 1 to use function

Give your data in R format or leave empty for example data:

Is your data individual data or group abundancies?:

+ Show code

Example 2

Select your data:

Which q values you want to calculate.:
0
1
2
3

+ Show code

----#: . Mikä ihme tässä koodissa on vikana? q.diviä ei muka löydy mutten ymmärrä miksei. Ongelma on diversity-funktiossa, joka on määritelty sivun ensimmäisessä rcodessa. --Jouni 00:36, 9 January 2012 (EET) to Teemu Rintala (type: truth; paradigms: science: comment)

----#: . Ilmeisesti funktioparametrien defaulteiksi ei saa laittaa ennalta määrittelemättömiä muuttujia. Vaihdoin defaultiksi "q = 0", "q = q.div" sijaan. --Teemu R 16:23, 9 January 2012 (EET) (type: truth; paradigms: science: comment)
←--#: . OK. Luulin, että funktion sisältä kutsuttava funktio voi saada toisen funktion sisällä olevia oletusarvoja, muttei näin välttämättä ole. Oletusarvot ovat kuitenkin tärkeitä, koska qD-funktiota käytetään tapplyssa, jossa voi antaa vain yhden parametrin ja loput tulevat oletusarvoista. Toteutin tämän niin, että käytetään q.wikiä, joka yleensä kysytään käyttäjärajapinnassa tai muuten. --Jouni 20:15, 9 January 2012 (EET) (type: truth; paradigms: science: defence)

The data should be given in R format as a list of values in parenthesis, beginning with c:

c(3,5,3,5,2,1,3,3,4,2) or equivalently c(0.1,0.2,0.4,0.1,0.2)

where the values are either

  • identifiers of the species 1,2,3... in which the individuals belong (one entry per individual), or
  • abundancies of species, i.e. proportions of individuals belonging to each species among the whole population (one entry per species).

Rationale

Diversity indices are thoroughly described in Wikipedia.

See also

References


Related files

<mfanonymousfilelist></mfanonymousfilelist>