Method of Lines PDE Analysis in Biomedical Science and Engineering
()
About this ebook
Presents the methodology and applications of ODE and PDE models within biomedical science and engineering
With an emphasis on the method of lines (MOL) for partial differential equation (PDE) numerical integration, Method of Lines PDE Analysis in Biomedical Science and Engineering demonstrates the use of numerical methods for the computer solution of PDEs as applied to biomedical science and engineering (BMSE). Written by a well-known researcher in the field, the book provides an introduction to basic numerical methods for initial/boundary value PDEs before moving on to specific BMSE applications of PDEs.
Featuring a straightforward approach, the book’s chapters follow a consistent and comprehensive format. First, each chapter begins by presenting the model as an ordinary differential equation (ODE)/PDE system, including the initial and boundary conditions. Next, the programming of the model equations is introduced through a series of R routines that primarily implement MOL for PDEs. Subsequently, the resulting numerical and graphical solution is discussed and interpreted with respect to the model equations. Finally, each chapter concludes with a review of the numerical algorithm performance, general observations and results, and possible extensions of the model. Method of Lines PDE Analysis in Biomedical Science and Engineering also includes:
- Examples of MOL analysis of PDEs, including BMSE applications in wave front resolution in chromatography, VEGF angiogenesis, thermographic tumor location, blood-tissue transport, two fluid and membrane mass transfer, artificial liver support system, cross diffusion epidemiology, oncolytic virotherapy, tumor cell density in glioblastomas, and variable grids
- Discussions on the use of R software, which facilitates immediate solutions to differential equation problems without having to first learn the basic concepts of numerical analysis for PDEs and the programming of PDE algorithms
- A companion website that provides source code for the R routines
William E. Schiesser
Dr. William E. Schiesser is Emeritus McCann Professor of Chemical and Biomolecular Engineering, and Professor of Mathematics at Lehigh University. He holds a PhD from Princeton University and a ScD (hon) from the University of Mons, Belgium. His research is directed toward numerical methods and associated software for ordinary, differential-algebraic and partial differential equations (ODE/DAE/PDEs), and the development of mathematical models based on ODE/DAE/PDEs. He is the author or coauthor of more than 16 books, and his ODE/DAE/PDE computer routines have been accessed by some 5,000 colleges and universities, corporations, and government agencies.
Read more from William E. Schiesser
Differential Equation Analysis in Biomedical Science and Engineering: Ordinary Differential Equation Applications with R Rating: 0 out of 5 stars0 ratingsSpline Collocation Methods for Partial Differential Equations: With Applications in R Rating: 0 out of 5 stars0 ratingsDifferential Equation Analysis in Biomedical Science and Engineering: Partial Differential Equation Applications with R Rating: 0 out of 5 stars0 ratings
Related to Method of Lines PDE Analysis in Biomedical Science and Engineering
Related ebooks
Modelling Optimization and Control of Biomedical Systems Rating: 0 out of 5 stars0 ratingsOptimal Modified Continuous Galerkin CFD Rating: 4 out of 5 stars4/5Biomedical Engineering Challenges: A Chemical Engineering Insight Rating: 0 out of 5 stars0 ratingsIntroduction to Statistical Analysis of Laboratory Data Rating: 0 out of 5 stars0 ratingsMulti-modality Cardiac Imaging: Processing and Analysis Rating: 0 out of 5 stars0 ratingsArtificial Neural Network Applications for Software Reliability Prediction Rating: 0 out of 5 stars0 ratingsChemical Reaction Kinetics: Concepts, Methods and Case Studies Rating: 0 out of 5 stars0 ratingsDynamic Models in Biology Rating: 3 out of 5 stars3/5An Introduction to Envelopes: Dimension Reduction for Efficient Estimation in Multivariate Statistics Rating: 0 out of 5 stars0 ratingsModel Identification and Data Analysis Rating: 0 out of 5 stars0 ratingsFundamental Statistical Inference: A Computational Approach Rating: 0 out of 5 stars0 ratingsComputational Acoustics: Theory and Implementation Rating: 0 out of 5 stars0 ratingsAdvanced Analysis of Variance Rating: 0 out of 5 stars0 ratingsHybridization, Diagnostic and Prognostic of PEM Fuel Cells: Durability and Reliability Rating: 0 out of 5 stars0 ratingsRandomization in Clinical Trials: Theory and Practice Rating: 0 out of 5 stars0 ratingsOptimization Techniques and Applications with Examples Rating: 0 out of 5 stars0 ratingsAdvanced Numerical and Semi-Analytical Methods for Differential Equations Rating: 0 out of 5 stars0 ratingsTransitions from Digital Communications to Quantum Communications: Concepts and Prospects Rating: 0 out of 5 stars0 ratingsPower Electronic Converters: Dynamics and Control in Conventional and Renewable Energy Applications Rating: 0 out of 5 stars0 ratingsNanomaterial Characterization: An Introduction Rating: 0 out of 5 stars0 ratingsPreparative Chromatography for Separation of Proteins Rating: 0 out of 5 stars0 ratingsRobust Statistics: Theory and Methods (with R) Rating: 0 out of 5 stars0 ratingsPractical Applications of Bayesian Reliability Rating: 0 out of 5 stars0 ratingsStatistical Signal Processing in Engineering Rating: 0 out of 5 stars0 ratingsIntroduction to Population Pharmacokinetic / Pharmacodynamic Analysis with Nonlinear Mixed Effects Models Rating: 0 out of 5 stars0 ratingsNumerical Methods for Inverse Problems Rating: 0 out of 5 stars0 ratingsNetwork Meta-Analysis for Decision-Making Rating: 0 out of 5 stars0 ratingsDiscrete Fourier Analysis and Wavelets: Applications to Signal and Image Processing Rating: 0 out of 5 stars0 ratingsPractical Inductively Coupled Plasma Spectrometry Rating: 0 out of 5 stars0 ratingsTurbulent Fluid Flow Rating: 0 out of 5 stars0 ratings
Mathematics For You
What If?: Serious Scientific Answers to Absurd Hypothetical Questions Rating: 5 out of 5 stars5/5Algebra I Workbook For Dummies Rating: 3 out of 5 stars3/5Calculus Made Easy Rating: 4 out of 5 stars4/5My Best Mathematical and Logic Puzzles Rating: 4 out of 5 stars4/5Standard Deviations: Flawed Assumptions, Tortured Data, and Other Ways to Lie with Statistics Rating: 4 out of 5 stars4/5Basic Math & Pre-Algebra Workbook For Dummies with Online Practice Rating: 4 out of 5 stars4/5Quantum Physics for Beginners Rating: 4 out of 5 stars4/5Math Magic: How To Master Everyday Math Problems Rating: 3 out of 5 stars3/5Basic Math & Pre-Algebra For Dummies Rating: 4 out of 5 stars4/5The Little Book of Mathematical Principles, Theories & Things Rating: 3 out of 5 stars3/5The Everything Guide to Algebra: A Step-by-Step Guide to the Basics of Algebra - in Plain English! Rating: 4 out of 5 stars4/5Mental Math Secrets - How To Be a Human Calculator Rating: 5 out of 5 stars5/5Real Estate by the Numbers: A Complete Reference Guide to Deal Analysis Rating: 0 out of 5 stars0 ratingsAlgebra - The Very Basics Rating: 5 out of 5 stars5/5Alan Turing: The Enigma: The Book That Inspired the Film The Imitation Game - Updated Edition Rating: 4 out of 5 stars4/5Intermediate Algebra Rating: 0 out of 5 stars0 ratingsRelativity: The special and the general theory Rating: 5 out of 5 stars5/5Algebra II For Dummies Rating: 3 out of 5 stars3/5Calculus For Dummies Rating: 4 out of 5 stars4/5Pre-Calculus For Dummies Rating: 5 out of 5 stars5/5Mental Math: Tricks To Become A Human Calculator Rating: 3 out of 5 stars3/5Flatland Rating: 4 out of 5 stars4/5How to Solve It: A New Aspect of Mathematical Method Rating: 4 out of 5 stars4/5ACT Math & Science Prep: Includes 500+ Practice Questions Rating: 3 out of 5 stars3/5The Moscow Puzzles: 359 Mathematical Recreations Rating: 5 out of 5 stars5/5Must Know High School Algebra Rating: 5 out of 5 stars5/5Basic Math and Pre-Algebra: 1,001 Practice Problems For Dummies (+ Free Online Practice) Rating: 3 out of 5 stars3/5Game Theory: A Simple Introduction Rating: 4 out of 5 stars4/5
Reviews for Method of Lines PDE Analysis in Biomedical Science and Engineering
0 ratings0 reviews
Book preview
Method of Lines PDE Analysis in Biomedical Science and Engineering - William E. Schiesser
Preface
The reporting of differential equation models in biomedical science and engineering (BMSE) continues at a remarkable pace. In this book, recently reported models based on initial-boundary-value ordinary and partial differential equations (ODE/PDEs) are described in chapters that have the following general format:
1. The model is stated as an ODE/PDE system, including the required initial conditions (ICs) and boundary conditions (BCs). The origin of PDEs based on mass conservation is discussed in Appendix A.
2. The coding (programming) of the model equations is presented as a series of routines in R, which primarily implements the method of lines (MOL) for PDEs. Briefly, in the MOL,
The partial derivatives in the spatial (boundary value) independent variables are replaced by approximations such as finite differences, finite elements, finite volumes, or spectral representations. In the present discussion, finite differences (FDs) are used, although alternatives are easily included.¹
Derivatives with respect to an initial-value variable remain, which are expressed through a system of ODEs. An ODE solver (integrator) is then used to compute a numerical solution to the ODE/PDE system.²
3. The resulting numerical and graphical (plotted) solution is discussed and interpreted with respect to the model equations.
4. The chapter concludes with a review of the numerical (MOL) algorithmperformance, general observations and results from the model, and possible extensions of the model.
The source of each model is included as one or more references. Generally, these are recent papers from the scientific and mathematics literature. Typically, a paper consists of some background discussion of the model, a statement of the model ODE/PDE system, presentation of a numerical solution of the model equations, and conclusions concerning the model and features of the solution.
What is missing in this format are the details of the numerical algorithms used to compute the reported solutions and the coding of the model equations. Also, the statement of the model is frequently incomplete such as missing equations, parameters, ICs, and BCs, so that reproduction of the solution with reasonable effort is virtually impossible.
We have attempted to address this situation by providing the source code of the routines, with a detailed explanation of the code, a few lines at a time. This approach includes a complete statement of the model (the computer will ensure this) and an explanation of how the numerical solutions are computed in enough detail that the reader can understand the numerical methods and coding and reproduce the solutions by executing the R routines (provided in a download).
In this way, we think that the formulation and use of the ODE/PDE models will be clear, including all of the mathematical details, so that readers can execute, then possibly experiment and extend, the models with reasonable effort. Finally, the intent of the detailed discussion is to explain the MOL formulation and methodology so that the reader can develop new ODE/PDE models and applications without becoming deeply involved in mathematics and computer programming.
In summary, the presentation is not as formal mathematics, for example, theorems and proofs. Rather, the presentation is by examples of recently reported ODE/PDE BMSE models including the details for computing numerical solutions, particularly documented source code. The author would welcome comments and suggestions for improvements ([email protected]).
William E. Schiesser
Bethlehem, PA, USA
May 1, 2016
¹ Representative routines for the approximation of PDE spatial derivatives are listed in Appendix B.
² Additional ODEs, which might, for example, be BCs for PDEs, can naturally be included in the model MOL solution. The solution of a mixed ODE/PDE system is demonstrated in some of the BMSE applications. Also, differential algebraic equations (DAEs) can easily be included in a MOL solution through the use of a modified ODE solver or a DAE solver.
About the Companion Website
This book is accompanied by a companion website:
www.wiley.com/go/Schiesser/PDE_Analysis
The website includes:
• Related R Routines
Chapter 1
An Introduction to MOL Analysis of PDEs: Wave Front Resolution in Chromatography
This first chapter introduces a partial differential equation (PDE) model for chromatography which is a basic analytical method in biomedical science and engineering (BSME). For example, chromatography can be used to analyze a stream of various proteins through selective adsorption. Thus, the model can also be applied to adsorption as a basic procedure for separating biochemical species such as proteins. The computer implementation (programming, coding) of the model is in R¹.
The intent of this chapter is to
Derive a basic chromatography PDE model, including the required initial conditions (ICs) and boundary conditions (BCs).
Illustrate the coding of the model within the method of lines (MOL) through a series of R routines, including the use of library routines for integration of the PDE derivatives in time and space.
Present the computed model solution in numerical and graphical (plotted) format.
Discuss the features of the numerical solution and the performance of the algorithms used to compute the solution.
Consider extensions of the model and the numerical algorithms.
1.1 1D 2-PDE model
The configuration of a chromatography column is illustrated in Fig. 1.1.
c01f001Figure 1.1 Diagram of a chromatographic column
We can note the following details about the column represented in Fig. 1.1:
The column is one dimensional (1D) with distance along the column, c01-math-0001 , as the spatial (boundary value) independent variable. Time c01-math-0002 is an initial value independent variable. A solid adsorbent is represented as spherical particles that fill the column. A fluid stream flows through the column in the interstices (voids) between the adsorbent particles. The flowing stream enters the base of the column at c01-math-0003 , and exits the top at c01-math-0004 .
The two PDE dependent variables are:
– c01-math-0005 : concentration of the adsorbate (the chemical component to be processed) in the fluid stream.
– c01-math-0006 : adsorbate concentration on the adsorbent.
c01-math-0007 and c01-math-0008 are the PDE dependent variables. The PDEs that define these dependent variables are derived subsequently².
The adsorbate enters the column at c01-math-0013 with a prescribed (entering) concentration c01-math-0014 that serves as a boundary condition (BC) for the c01-math-0015 PDE³. Note that the boundary value can be a function of c01-math-0018 .
The exiting stream at c01-math-0019 has the concentration c01-math-0020 which is a function of c01-math-0021 . The c01-math-0022 variation of this exiting stream is of primary interest when using the model. A plot of c01-math-0023 against c01-math-0024 is termed a breakthrough curve.
An overall objective in formulating the model and computing numerical solutions is to determine c01-math-0025 , and in particular, how effective the chromatographic column is in altering the entering stream with concentration c01-math-0026 .
In summary, the numerical solution of the PDE model will give the dependent variables c01-math-0027 and c01-math-0028 as a function of c01-math-0029 . c01-math-0030 is a primary output from the model, that is, the outflow adsorbate concentration as a function of time.
A mass balance on the adsorbate stream⁴ gives
1.1a
equationwhere
Eq. (1.1a) is a mass conservation balance for the flowing adsorbate with the terms explained further in the following comments.
LHS-1: c01-math-0043 - accumulation of adsorbate in the incremental volume c01-math-0044 . The CGS units of this term are c01-math-0045 , that is, the accumulation of adsorbate per second within the incremental volume c01-math-0046 . If the derivative c01-math-0047 is negative, the adsorbate is depleted (reduced). Also, some elaboration of the units of length is possible.
c01-math-0048 : c01-math-0049 (so that the void fraction is not dimensionless)
c01-math-0050 : c01-math-0051
c01-math-0052 : c01-math-0053
c01-math-0054 : c01-math-0055
Thus, more detailed units of the LHS c01-math-0056 derivative of eq. (1.1a) are:
equationThe distinction between c01-math-0058 and c01-math-0059 (and later, c01-math-0060 ) will not generally be retained in the subsequent discussion (only cm will be used), but this distinction should be kept in mind when analyzing units in the model.
RHS-1: c01-math-0061 - flow (by convection) of absorbate into the incremental volume at c01-math-0062 . The units of this term are c01-math-0063 , that is, the flow of adsorbate per second into the incremental volume. Note that c01-math-0064 has the units c01-math-0065 This is generally termed a superficial or linear velocity and is assumed constant across the chromatographic column (any wall effects are neglected).
RHS-2: c01-math-0066 - flow (by convection) of absorbate out of the incremental volume at c01-math-0067 . Again, the units of this term are c01-math-0068 , that is, the flow of adsorbate per second out of the incremental volume.
RHS-3: c01-math-0069 - volumetric rate of adsorption (when this term is negative, adsorbate moves from the fluid to the adsorbent) or desorption (when this term is positive). The units of this term are c01-math-0070 , that is, the transfer of adsorbate per second within the incremental volume.
Three additional points about this term can be observed.
c01-math-0071 and c01-math-0072 are volumetric (not surface) adsorbent concentrations with the units c01-math-0073 . c01-math-0074 has the units c01-math-0075 and c01-math-0076 has the units 1/s (explained next). By definition,
equationand
equationThen the units of the term c01-math-0079 are:
equationThe forward rate of adsorption, c01-math-0081 , is usually termed a logistic rate. Note that it is nonlinear from the product of the two dependent variables, c01-math-0082 , which means that an analytical solution to the PDE model is probably precluded, but a numerical solution can be easily programmed and calculated. Also, for c01-math-0083 this forward rate is positive giving adsorption from this term in eq. (1.1a) , and for c01-math-0084 this term reflects desorption (when the adsorbate concentration c01-math-0085 exceeds the equilibrium adsorbent concentration, c01-math-0086 ).
When c01-math-0087 , adsorption takes place (with a reduction in c01-math-0088 from eq. (1.1a) since this term is multiplied by a minus). Conversely, when c01-math-0089 , this term reflects desorption (and an increase in c01-math-0090 from eq. (1.1a)).
If eq. (1.1a) is divided by c01-math-0091 ,
equationor for c01-math-0093 ,
1.1b
equationEq. (1.1b) is the PDE for the calculation of c01-math-0095 . For the subsequent analysis and programming, we will take c01-math-0096 as independent of c01-math-0097 so it can be taken outside the derivative in c01-math-0098 (even though the transfer of adsorbate could affect c01-math-0099 , but this will not be considered). c01-math-0100 as a function of c01-math-0101 is an interesting case that could be investigated through the use of eq. (1.1b). Note also that the column cross sectional area, c01-math-0102 , canceled in going from eq. (1.1a) to eq. (1.1b) , that is, we come to the somewhat unexpected conclusion that c01-math-0103 does not appear in eq. (1.1b).
Also, in eq. (1.1b),
equationas expected for consistent units in eq. (1.1b) , that is, the units in the various terms in eq. (1.1b) are c01-math-0105 since eq. (1.1b) is a mass balance on the fluid.
A PDE for c01-math-0106 follows from an analogous mass balance for the adsorbent. The starting point is
1.2a
equationDivision by c01-math-0108 gives
1.2b equation
Note that the adsorption terms in eqs. (1.1b) and (1.2b) are opposite in sign which indicates that the rate absorbate leaves (or enters) the fluid stream equals the rate adsorbate is transferred to (or leaves) the adsorbent. Also, the LHS and RHS terms in eq. (1.2b) have the units c01-math-0110 , since eq. (1.2b) is a mass balance on the adsorbent in an incremental volume c01-math-0111 . Again, c01-math-0112 cancels in going from eq. (1.2a) to eq. (1.2b).
Eqs. (1.1b) and (1.2b) are a c01-math-0113 (two equations in two unknowns) for the concentrations c01-math-0114 . One other variable, c01-math-0115 , appears in the adsorption rate in these two PDEs. This adsorbent equilibrium concentration might be assumed to be a constant, for example, corresponding to a monolayer of the adsorbate on the adsorbent. Or c01-math-0116 can be considered a variable from an equilibrium relation such as, for example, a Langmuir isotherm of the form
1.3 equation
where c01-math-0118 are constants typically measured experimentally.
Eq. (1.1b) is first order in c01-math-0119 and c01-math-0120 (and is termed a first-order, hyperbolic PDE). Therefore, it requires one initial condition (IC)⁵ and one boundary condition (BC).⁶,⁷
The IC is taken as
1.4a equation
The BC is taken as
1.4b equation
where c01-math-0140 and c01-math-0141 are prescibed functions of c01-math-0142 and c01-math-0143 , respectively.
Eq. (1.2b) is first order in c01-math-0144 so it requires one IC
1.4c equation
Eq. (1.4b) is a Dirichlet BC since the dependent variable c01-math-0146 is specified at the boundary c01-math-0147 . Other types of BCs are discussed in subsequent chapters.
Eqs. (1.1) to (1.4) constitute the PDE model for the chromatographic column. We next consider the programming of these equations within the MOL framework.
1.2 MOL routines
The discussion of the routines for eqs. (1.1) to (1.4) starts with the main program.
1.2.1 Main program
The listing of the main program follows.
Listing 1.1 Main program pde_1_main for eqs. (1.1) to (1.4)
#
# Delete previous workspaces
rm(list=ls(all=TRUE))
#
# 1D, one component, chromatography model
#
# The ODE/PDE system is
#
# u1_t = -v*u1_z - (1 - eps)/eps*rate (1.1b)
#
# u2_t = rate (1.2b)
#
# rate = kf*u1*(u2eq - u2) - kr*u2
#
# u2eq = c1*u1/(1 + c2*u1) (1.3)
#
# Boundary condition
#
# u1(z=0,t) = step(t) (1.4b)
#
# Initial conditions
#
# u1(z,t=0) = 0 (1.4a)
#
# u2(z,t=0) = 0 (1.4c)
#
# The method of lines (MOL) solution for eqs. (1.1) to
# (1.4) is coded below. Specifically, the spatial
# derivative in the fluid balance, u1_z in eq. (1.1b),
# is replaced by one of four approximations as selected
# by the variable ifd.
#
# Access ODE integrator
library(deSolve
);
#
# Access
files
setwd(g:/chap1
);
source(pde_1.R
) ;source(step.R
) ;
source(dss004.R
);source(dss012.R
);
source(dss020.R
);source(vanl.R
) ;
source(max3.R
) ;
#
# Step through cases
for(ncase in 1:2){
#
# Model parameters
v=1; eps=0.4; u10=0; u20=0;
c1=1; c2=1; zL=50; n=41;
if(ncase==1){ kf=0; kr=0; }
if(ncase==2){ kf=1; kr=1; }
#
# Select an approximation for the convective derivative u1z
#
# ifd = 1: Two point upwind approximation
#
# ifd = 2: Centered approximation
#
# ifd = 3: Five point, biased upwind approximation
#
# ifd = 4: van Leer flux limiter
#
ifd=1;
#
# Level of output
#
# Detailed output - ip = 1
#
# Brief (IC) output - ip = 2
#
ip=1;
#
# Initial condition
u0=rep(0,2*n);
for(i in 1:n){
u0[i]=u10;
u0[i+n]=u20;
}
t0=0;tf=150;nout=51;
tout=seq(from=t0,to=tf,by=(tf-t0)/(nout-1));
ncall=0;
#
# ODE
integration
out=ode(func=pde_1,times=tout,y=u0);
#
# Store solution
u1=matrix(0,nrow=nout,ncol=n);
u2=matrix(0,nrow=nout,ncol=n);
t=rep(0,nout);
for(it in 1:nout){
for(iz in 1:n){
u1[it,iz]=out[it,iz+1];
u2[it,iz]=out[it,iz+1+n];
}
t[it]=out[it,1];
}
#
# Display ifd, ncase
cat(sprintf(\n ifd = %2d ncase = %2d
,ifd,ncase));
#
# Display numerical solution
if(ip==1){
cat(sprintf(
\n\n t u1(z=zL,t) rate(z=zL,t)\n
));
u2eq=rep(0,nout);rate=rep(0,nout);
for(it in 1:nout){
u2eq[it]=c1*u1[it,n]/(1+c2*u1[it,n]);
rate[it]=kf*u1[it,n]*(u2eq[it]-u2[it,n])-kr*u2[it,n];
cat(sprintf(
%7.2f%12.4f%12.4f\n
,t[it],u1[it,n],rate[it]));
}
}
#
# Store solution for plotting
u1plot=rep(0,nout);tplot=rep(0,nout);
for(it in 1:nout){
u1plot[it]=u1[it,n];
tplot[it]=t[it];
}
#
# Calls to ODE routine
cat(sprintf(\n ncall = %4d\n
,ncall));
#
# Plot for u1(z=zL,t)
# ncase = 1
if(ncase==1){
par(mfrow=c(1,1))
plot(tplot,u1plot,xlab=t
,ylab=u1(z=zL,t)
,
lwd=2,main="u1(z=zL,t) vs t, ncase=1\n
line - anal, o - num,type=
l",
xlim=c(0,tplot[nout]));#,ylim=c(0,1));
points(tplot,u1plot, pch=o
,lwd=2);
}
#
# Analytical
solution, ncase=1
if(ncase==1){
u1expl=rep(0,nout);
for(it in 1:nout){
u1expl[it]=step(tplot[it],zL,v);
}
lines(tplot,u1expl,lwd=2,type=l
);
}
#
# ncase = 2
if(ncase==2){
par(mfrow=c(1,1))
plot(tplot,u1plot,xlab=t
,ylab=u1(z=zL,t)
,
lwd=2,main=u1(z=zL,t) vs t, ncase=2
,
type=l
,xlim=c(0,tplot[nout]));#,ylim=c(0,1));
points(tplot,u1plot, pch=o
,lwd=2);
}
#
# Next case
}
We can note the following details about pde_1_main.
Previous files are cleared and a series of documentation comments for the ODE/PDE system is included that restates eqs. (1.1) to (1.4) in the text.
#
# Delete previous workspaces
rm(list=ls(all=TRUE))
#
# 1D, one component, chromatography model
#
# The ODE/PDE system is
#
# u1_t = -v*u1_z - (1 - eps)/eps*rate (1.1b)
#
# u2_t = rate (1.2b)
#
# rate = kf*u1*(u2eq - u2) - kr*u2
#
# u2eq = c1*u1/(1 + c2*u1) (1.3)
#
# Boundary
condition
#
# u1(z=0,t) = step(t) (1.4b)
#
# Initial conditions
#
# u1(z,t=0) = 0 (1.4a)
#
# u2(z,t=0) = 0 (1.4c)
#
# The method of lines (MOL) solution for eqs. (1.1) to
# (1.4) is coded below. Specifically, the spatial
# derivative in the fluid balance, u1_z in eq. (1.1b),
# is replaced by one of four approximations as selected
# by the variable ifd.
The IC and BC functions of eqs. (1.4), c01-math-0148 , are explained subsequently ( c01-math-0149 is the unit step function or Heaviside function).
The R ODE integrator library deSolve and a series of routine discussed subsequently are accessed.
#
# Access ODE integrator
library(deSolve
);
#
# Access files
setwd(g:/chap1
);
source(pde_1.R
) ;source(step.R
) ;
source(dss004.R
);source(dss012.R
);
source(dss020.R
);source(vanl.R
) ;
source(max3.R
) ;
The set working directory, setwd, will have to be edited for the local computer. Note the forward slash, /, rather than the usual backslash, c01-math-0150 . The source utility is used to select individual files that make up the complete code for the model of eqs. (1.1) to (1.4). These files are explained subsequently.
A for is used to step through a series of (two) cases, ncase=1,2.
#
# Step through cases
for(ncase in 1:2){
#
# Model parameters
v=1; eps=0.4; u10=0; u20=0;
c1=1; c2=1; zL=50; n=41;
if(ncase==1){ kf=0; kr=0; }
if(ncase==2){ kf=1; kr=1; }
The parameters in eqs. (1.1) to (1.4) for each case are defined numerically. In particular, for ncase=1, no adsorption takes place so that the fluid with adsorbate concentration c01-math-0151 merely flows through the column and there is no up take of adsorbate with concentration c01-math-0152 onto the adsorbent. This special condition is used to check the coding of the model as discussed subsequently. For ncase=2, the effect of adsorbate transfer to the adsorbent can be observed in the fluid outlet with concentration c01-math-0153 .
An approximation for the spatial derivative c01-math-0154 in eq. (1.1b) ( c01-math-0155 constant and therefore outside of the derivative) is selected with index ifd. The performance of the four approximations is discussed subsequently.
#
# Select an approximation for the convective derivative u1z
#
# ifd = 1: Two point upwind approximation
#
# ifd = 2: Centered approximation
#
# ifd = 3: Five point, biased upwind approximation
#
# ifd = 4: van Leer flux limiter
#
ifd=1;
A level of numerical output is selected with ip. Initially, ip=1 is used to give detailed numerical output along with graphical (plotted) output. ip=2 can be used to give only graphical output (when experimenting with the model).
#
# Level of output
#
# Detailed output - ip = 1
#
# Brief (IC) output - ip = 2
#
ip=1;
ICs (1.4a) and (1.4c) are programmed as zero (homogeneous) ICs (since u10 = u20 = 0). Note that these ICs are placed in a single vector or 1D array u0 as required by the ODE integrator ode discussed next. This vector is first declared (allocated, sized) with the utility rep (2*n = 2*41 = 82 zero elements).
#
# Initial condition
u0=rep(0,2*n);
for(i in 1:n){
u0[i]=u10;
u0[i+n]=u20;
}
t0=0;tf=150;nout=51;
tout=seq(from=t0,to=tf,by=(tf-t0)/(nout-1));
ncall=0;
The time scale is defined as c01-math-0156 with nout=51 points in c01-math-0157 for the numerical solution. The utility seq is used to define the 51 values c01-math-0158 . Finally, the counter for the calls to the ODE routine pde_1 is initialized. The use of this counter is discussed later.
The 2*n = 82 ODEs are integrated numerically with the library integrator ode (part of the deSolve library specified previously).
#
# ODE integration
out=ode(func=pde_1,times=tout,y=u0);
The input arguments for ode require some explanation.
–The routine for the MOL/ODEs that approximate PDEs (1.1b) , (1.2b) , pde_1, is declared for the parameter func (which is a reserved argument name). func does not have to be the first input argument, but by convention, it usually is when calling one of the R integrators (ode in this case).
–The vector of output values of c01-math-0159 , tout, (defined previously) is assigned to the input argument times. Again, times is a reserved name and can be placed anywhere in the input argument list.
–The IC vector, u0, is assigned to the parameter y. The length of this IC vector tells ode how many ODEs are to be integrated, in this case 2*n = 82. Note that the number of ODEs is not specified explicitly in the input argument list.
Numerical solutions to eqs. (1.1) to (1.4) are returned by ode in the 2D array out. The content of this solution array is explained next. The various ODE integrators in deSolve generally follow this format.
The numerical solution is placed in matrices and a vector. These arrays are first declared with the utilities matrix (for c01-math-0160 of eqs. (1.1b) , (1.2b)) and rep (for c01-math-0161 of eqs. (1.1b) and (1.2b)).
#
# Store solution
u1=matrix(0,nrow=nout,ncol=n);
u2=matrix(0,nrow=nout,ncol=n);
t=rep(0,nout);
for(it in 1:nout){
for(iz in 1:n){
u1[it,iz]=out[it,iz+1];
u2[it,iz]=out[it,iz+1+n];
}
t[it]=out[it,1];
}
A pair of nested fors is used to place the numerical solutions in u1,u2. The outer for with index it steps through c01-math-0162 for c01-math-0163 . The inner for with index iz steps through c01-math-0164 for c01-math-0165 with c01-math-0166 (defined previously) and a spatial increment c01-math-0167 , that is, c01-math-0168 (based on n=41 points in c01-math-0169 ).
The solution array out has the dimensions out(nout,2*n+1) = out(51,82+1), that is, 82 ODEs at nout=51 points in c01-math-0170 (including c01-math-0171 ). The offset of 1 in iz+1,iz+1+n,2*n+1,82+1 reflects the additional space for c01-math-0172 , so that out[it,1] contains the 51 values of c01-math-0173 . This ordering of the output array out is a unique feature of the ODE integrators in deSolve, including ode.
Figure 1.2 Comparison of the numerical and analytical solutions of eqs. (1.1b) , (1.2b)
c01f002The index for the spatial differentiator, ifd, and the value of ncase are displayed.
#
# Display ifd, ncase
cat(sprintf(\n ifd = %2d ncase = %2d
,ifd,ncase));
For ip=1, the numerical solution is displayed as (1) c01-math-0174 , (2) c01-math-0175 , and (3)
c01-math-0176(note the use of n for c01-math-0177 ). Vectors are first defined with the utility rep.
#
# Display numerical solution
if(ip==1){
cat(sprintf(
\n\n t u1(z=zL,t) rate(z=zL,t)\n
));
u2eq=rep(0,nout);rate=rep(0,nout);
for(it in 1:nout){
u2eq[it]=c1*u1[it,n]/(1+c2*u1[it,n]);
rate[it]=kf*u1[it,n]*(u2eq[it]-u2[it,n])-kr*u2[it,n];
cat(sprintf(
%7.2f%12.4f%12.4f\n
,t[it],u1[it,n],rate[it]));
}
}
c01-math-0178 = u2eq is computed from the isotherm of eq. (1.3).
c01-math-0179 , c01-math-0180 are stored for subsequent plotting.
#
# Store solution for plotting
u1plot=rep(0,nout);tplot=rep(0,nout);
for(it in 1:nout){
u1plot[it]=u1[it,n];
tplot[it]=t[it];
}
At the end of the solution (after the call to ode), the number of calls to the MOL/ODE routine pde_1 is displayed (this routine is discussed next).
#
# Calls to ODE routine
cat(sprintf(\n ncall = %4d\n
,ncall));
c01-math-0181 is plotted against c01-math-0182 for ncase=1 (no adsorption). For this case, an analytical solution is available that is plotted as a solid line while the numerical solution is plotted as points on a solid line (this is clear in Fig. 1.2).
#
# Plot for u1(z=zL,t)
# ncase = 1
if(ncase==1){
par(mfrow=c(1,1))
plot(tplot,u1plot,xlab=t
,ylab=u1(z=zL,t)
,
lwd=2,main="u1(z=zL,t) vs t, ncase=1\n
line - anal, o - num,type=
l",
xlim=c(0,tplot[nout]));#,ylim=c(0,1));
points(tplot,u1plot, pch=o
,lwd=2);
{
The scaling of the y axis is deactivated as a comment, #,ylim=c(0,1)); so that oscillations in the solution outside c01-math-0183 can be accommodated with the default scaling for the y axis (the oscillations are a numerical artifact that is an incorrect part of the numerical solution as discussed subsequently).
For ncase=1 (no adsorption), the analytical solution to eq. (1.1b) is computed by a call to step (as explained subsequently). The resulting plot of the analytical solution is superimposed on the preceding plot of c01-math-0184 (see Fig. 1.2).
#
# Analytical solution, ncase=1
if(ncase==1){
u1expl=rep(0,nout);
for(it in 1:nout){
u1expl[it]=step(tplot[it],zL,v);
}
lines(tplot,u1expl,lwd=2,type=l
);
}
For ncase=2 (with adsorption), the numerical solution c01-math-0185 is plotted against c01-math-0186 as points on a solid line.
#
# ncase = 2
if(ncase==2){
par(mfrow=c(1,1))
plot(tplot,u1plot,xlab=t
,ylab=u1(z=zL,t)
,
lwd=2,main=u1(z=zL,t) vs t, ncase=2
,
type=l
,xlim=c(0,tplot[nout]));#,ylim=c(0,1));
points(tplot,u1plot, pch=o
,lwd=2);
}
#
# Next case
}
The final } concludes the for in ncase. The ODE routine pde_1 called by ode (Listing 1.1) is considered next.
1.2.2 MOL/ODE routine
The ODE routine pde_1 called by ode (Listing 1.1) is in Listing 1.2.
Listing 1.2 ODE routine pde_1 for eqs. (1.1) to (1.4)
pde_1=function(t,u,parms){
#
# Function pde_1 computes the t derivative vector of the u vector
#
#