source: trunk/MESOSCALE/LMDZ.MARS/libf_gcm/aeronomars/intrplf.F @ 3557

Last change on this file since 3557 was 57, checked in by aslmd, 14 years ago

mineur LMD_MM_MARS: ajout du GCM ancienne physique, systeme maintenant complet sur SVN (ne manque que la base de donnees d'etats initiaux)

File size: 1.1 KB
Line 
1c******************************************************
2      SUBROUTINE intrplf(x,y,xd,yd,nd)
3c interpolation, give y = f(x) with array xd,yd known, size nd
4 
5c  Version with CONSTANT values outside limits
6c**********************************************************
7 
8c Variable declaration
9c --------------------
10c  Arguments :
11      real x,y
12      real xd(nd),yd(nd)
13      integer nd
14c  internal
15      integer i,j
16      real y_undefined
17 
18c run
19c ---
20      y_undefined=1.e20
21 
22      y=0.
23      if ((x.le.xd(1)).and.(x.le.xd(nd))) then
24        if (xd(1).lt.xd(nd)) y = yd(1) ! yd(1)
25        if (xd(1).ge.xd(nd)) y = yd(nd) ! yd(1)
26      else if ((x.ge.xd(1)).and.(x.ge.xd(nd))) then
27        if (xd(1).lt.xd(nd)) y = yd(nd) ! yd(1)
28        if (xd(1).ge.xd(nd)) y = yd(1) ! yd(1)
29c        y = yd (nd)
30      else
31        do i=1,nd-1
32         if ( ( (x.ge.xd(i)).and.(x.lt.xd(i+1)) )
33     &     .or. ( (x.le.xd(i)).and.(x.gt.xd(i+1)) ) ) then
34           y=yd(i)+(x-xd(i))*(yd(i+1)-yd(i))/(xd(i+1)-xd(i))
35           goto 99
36         end if
37        end do
38      end if
39 
40 99   continue
41      return
42      end                   
Note: See TracBrowser for help on using the repository browser.