source: palm/trunk/UTIL/chemistry/gasphase_preproc/kpp/util/dFun_dRcoeff.f @ 3606

Last change on this file since 3606 was 2696, checked in by kanani, 7 years ago

Merge of branch palm4u into trunk

File size: 1.9 KB
Line 
1C ------------------------------------------------------------------------------
2C Subroutine for the derivative of Fun with respect to rate coefficients
3C -----------------------------------------------------------------------------
4
5      SUBROUTINE  dFun_dRcoeff( V, F, NCOEFF, JCOEFF, DFDR )
6       
7      IMPLICIT NONE
8      INCLUDE 'KPP_ROOT_Parameters.h'
9      INCLUDE 'KPP_ROOT_Sparse.h'
10
11C V - Concentrations of variable/radical/fixed species           
12      KPP_REAL V(NVAR), F(NFIX)
13C NCOEFF - the number of rate coefficients with respect to which we differentiate
14      INTEGER NCOEFF       
15C JCOEFF - a vector of integers containing the indices of reactions (rate
16C          coefficients) with respect to which we differentiate
17      INTEGER JCOEFF(NCOEFF)       
18C DFDR  - a matrix containg derivative values; specifically, 
19C         column j contains d Fun(1:NVAR) / d RCT( JCOEFF(j) )
20C         for each 1 <= j <= NCOEFF
21C         This matrix is stored in a column-wise linearized format
22      KPP_REAL DFDR(NVAR*NCOEFF)
23
24C Local vector with reactant products
25      KPP_REAL A_RPROD(NREACT)
26      KPP_REAL aj
27      INTEGER i,j,k
28     
29C Compute the reactant products of all reactions     
30      CALL ReactantProd ( V, F, A_RPROD )
31
32C Compute the derivatives by multiplying column JCOEFF(j) of the stoichiometric matrix with A_RPROD       
33      DO j=1,NCOEFF
34C                  Initialize the j-th column of derivative matrix to zero       
35         DO i=1,NVAR
36           DFDR(i+NVAR*(j-1)) = 0.0D0
37         END DO
38C                  Column JCOEFF(j) in the stoichiometric matrix times the
39C                  reactant product  of the JCOEFF(j)-th reaction     
40C                  give the j-th column of the derivative matrix   
41         aj = A_RPROD(JCOEFF(j))
42         DO k=CCOL_STOICM(JCOEFF(j)),CCOL_STOICM(JCOEFF(j)+1)-1
43           DFDR(IROW_STOICM(k)+NVAR*(j-1)) = STOICM(k)*aj
44         END DO
45      END DO
46     
47      RETURN
48      END
Note: See TracBrowser for help on using the repository browser.