English 中文(简体)
解决2个相互关联的差异方程式系统,利用离散状态
原标题:solving 2 connected system of differential equation using desolve in r
  • 时间:2023-12-29 10:51:39
  •  标签:
  • r
  • desolve

我正试图利用离散状态解决两个相互关联的差异方程式系统。

我的第一个模式是:

library(package = "deSolve")

growth <- function(t, state, parms) {
   with(as.list(c(state, parms)), {
   dx1 <- a*x - b*x*x - c*x*y
   dy2 <- d*y - e*y*x - f*y*y
   return(list(c(dx1, dy2)))   
   })
}

parameters <- c(a = 0.5, b = 10, c = 0.7, d = 0.1, e = 1.2, f = 0.5)
init <- c(x = 0.1, y = 0.2)

model1 <- ode(y = init, func = growth, times = seq(from = 0, to = 10, by = 0.1), parms = parameters)

and then i want to use the values of dx1 and dy1 at a time t to modify the values of model2 at time t.

growth2 <- function(t, state, parms) {
   with(as.list(c(state, parms)), {
   dx2 <- a*x - b*x*x - c*x*y*dx1 
   dy2 <- d*y - e*y*x - f*y*y*dy1
   return(list(c(dx2, dy2)))   
   })
}

parameters <- c(a = 0.5, b = 10, c = 0.7, d = 0.1, e = 1.2, f = 0.5)
init <- c(x = 0.1, y = 0.2)

model2 <- ode(y = init, func = growth2, times = seq(from = 0, to = 10, by = 0.1), parms = parameters)

如何在t时使用dx1的数值,在t时解决模型2。

现在,即解决模式2问题,为此,它分了1个步骤,然后利用循环改变公式的价值。 它花费了大量时间。 由于我的模式非常大,希望缩短模拟时间。

你们会就如何提高其效率提出建议。

问题回答

我以同样的方式在评论中解释你的问题。 我认为,你希望把这一模式作为单一系统。 在这方面,我如何使第二个“模型”取决于第一个“模型”。

library(package = "deSolve")

growth <- function(t, state, parms) {
  with(as.list(c(state, parms)), {
    dx1 <- a*x1 - b*x1*x1 - c*x1*y1
    dy1 <- d*y1 - e*y1*x1 - f*y1*y1
    dx2 <- a*x2 - b*x2*x2 - c*x2*y2*dx1 
    dy2 <- d*y2 - e*y2*x2 - f*y2*y2*dy1
    return(list(c(dx1, dy1, dx2, dy2)))   
  })
}

parameters <- c(a = 0.5, b = 10, c = 0.7, d = 0.1, e = 1.2, f = 0.5)
init <- c(x1 = 0.1, y1 = 0.2, x2 = 0.1, y2 = 0.1)

model1 <- ode(y = init, func = growth, times = seq(from = 0, to = 10, by = 0.1), parms = parameters)

If you are looking for something different, can you clarify your question?





相关问题
How to plot fitted model over observed time series

This is a really really simple question to which I seem to be entirely unable to get a solution. I would like to do a scatter plot of an observed time series in R, and over this I want to plot the ...

REvolution for R

since the latest Ubuntu release (karmic koala), I noticed that the internal R package advertises on start-up the REvolution package. It seems to be a library collection for high-performance matrix ...

R - capturing elements of R output into text files

I am trying to run an analysis by invoking R through the command line as follows: R --no-save < SampleProgram.R > SampleProgram.opt For example, consider the simple R program below: mydata =...

R statistical package: wrapping GOFrame objects

I m trying to generate GOFrame objects to generate a gene ontology mapping in R for unsupported organisms (see http://www.bioconductor.org/packages/release/bioc/vignettes/GOstats/inst/doc/...

Changing the order of dodged bars in ggplot2 barplot

I have a dataframe df.all and I m plotting it in a bar plot with ggplot2 using the code below. I d like to make it so that the order of the dodged bars is flipped. That is, so that the bars labeled "...

Strange error when using sparse matrices and glmnet

I m getting a weird error when training a glmnet regression. invalid class "dgCMatrix" object: length(Dimnames[[2]]) must match Dim[2] It only happens occasionally, and perhaps only under larger ...

Generating non-duplicate combination pairs in R

Sorry for the non-descriptive title but I don t know whether there s a word for what I m trying to achieve. Let s assume that I have a list of names of different classes like c( 1 , 2 , 3 , 4 ) ...

Per panel smoothing in ggplot2

I m plotting a group of curves, using facet in ggplot2. I d like to have a smoother applied to plots where there are enough points to smooth, but not on plots with very few points. In particular I d ...

热门标签