He medido dos parámetros (carbono orgánico disuelto DOC = y, y descarga = x). Cuando estas dos variables se trazan una contra la otra, obtenemos un ciclo de histéresis (vea el ejemplo de código y la imagen).
Ahora, para un análisis más detallado, me gustaría determinar el área de este circuito histérico. Descubrí que esto se puede hacer usando el método de lanzamiento de Monte Carlo. Este método dice que el área de un área desconocida es proporcional al área de un rectángulo conocido multiplicado por los golpes en el campo interior (el bucle).
Mi problema ahora es cómo resolver el problema interno / externo con R. ¿Cómo puedo dibujar un rectángulo con un área conocida y cómo puedo sobresalir los golpes aleatorios dentro y fuera del circuito histérico?
Tenga en cuenta que estoy abierto a cualquier otro método ...
Busqué en Google y busqué en varios sitios estadísticos, pero no pude encontrar una respuesta. Cualquier ayuda directa o enlace a otros sitios web / publicaciones es muy apreciada.
Data <- read.table("http://dl.dropbox.com/u/2108381/DOC_Q_hystersis.txt", sep = ";",
header = T)
head(Data)
plot(Data$Q, Data$DOC, type = "o", xlab = "Discharge (m3 s-1)", ylab = "DOC (mg C l-1)",
main = "Hystersis loop of the C/Q relationship")
fuente
Una posibilidad sería esta: me parece que el ciclo de histéresis debería ser convexo, ¿verdad? Por lo tanto, se podrían generar puntos y probar para cada punto si es parte del casco convexo de la unión de su conjunto de datos y el punto aleatorio; en caso afirmativo, se encuentra fuera del conjunto de datos original. Para acelerar las cosas, podemos trabajar con un subconjunto del conjunto de datos original, es decir, los puntos que comprenden su propio casco convexo.
Por supuesto, la forma R de hacer las cosas no usaría mi
for
ciclo, pero esto es fácil de entender y no demasiado lento. Obtengo un área estimada de 0.703.EDITAR: por supuesto, esto se basa en la supuesta convexidad de la relación. Por ejemplo, parece haber una parte no convexa en la esquina inferior derecha. En principio, podríamos estimar Montecarlo el área de tal área de la misma manera y restar esto de la estimación del área original.
fuente