~ubuntu-branches/debian/jessie/eso-midas/jessie

« back to all changes in this revision

Viewing changes to applic/fit/libsrc/funct2i.for

  • Committer: Package Import Robot
  • Author(s): Ole Streicher
  • Date: 2014-04-22 14:44:58 UTC
  • Revision ID: package-import@ubuntu.com-20140422144458-okiwi1assxkkiz39
Tags: upstream-13.09pl1.2+dfsg
ImportĀ upstreamĀ versionĀ 13.09pl1.2+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
C @(#)funct2i.for       19.1 (ES0-DMD) 02/25/03 13:17:38
 
2
C===========================================================================
 
3
C Copyright (C) 1995 European Southern Observatory (ESO)
 
4
C
 
5
C This program is free software; you can redistribute it and/or 
 
6
C modify it under the terms of the GNU General Public License as 
 
7
C published by the Free Software Foundation; either version 2 of 
 
8
C the License, or (at your option) any later version.
 
9
C
 
10
C This program is distributed in the hope that it will be useful,
 
11
C but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
C MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
C GNU General Public License for more details.
 
14
C
 
15
C You should have received a copy of the GNU General Public 
 
16
C License along with this program; if not, write to the Free 
 
17
C Software Foundation, Inc., 675 Massachusetss Ave, Cambridge, 
 
18
C MA 02139, USA.
 
19
C
 
20
C Corresponding concerning ESO-MIDAS should be addressed as follows:
 
21
C       Internet e-mail: midas@eso.org
 
22
C       Postal address: European Southern Observatory
 
23
C                       Data Management Division 
 
24
C                       Karl-Schwarzschild-Strasse 2
 
25
C                       D 85748 Garching bei Muenchen 
 
26
C                       GERMANY
 
27
C===========================================================================
 
28
C
 
29
      SUBROUTINE FUNC2I(NRPRM,PRM,FCT,GRD,PIXEL,WEIGHT,IDIM1,IDIM2,           
 
30
     +                    IDIM3)                                                
 
31
C+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++        
 
32
C                                                                               
 
33
C.MODULE                                                                        
 
34
C       FIT                                                                     
 
35
C                                                                               
 
36
C.NAME                                                                          
 
37
C       FUNCT2_I                                                                
 
38
C                                                                               
 
39
C.PURPOSE                                                                       
 
40
C       Function to compute the sum of residuals and the gradient.              
 
41
C       for FIT/IMAGE                                                           
 
42
C                                                                               
 
43
C.KEYWORDS                                                                      
 
44
C       Approximating Function.                                                 
 
45
C                                                                               
 
46
C.DESCRIPTION                                                                   
 
47
C       Trivial                                                                 
 
48
C                                                                               
 
49
C.LANGUAGE                                                                      
 
50
C       FORTRAN                                                                 
 
51
C                                                                               
 
52
C.CALLING SEQUENCE                                                              
 
53
C      CALL LSFUN2(NRPRM,PRM,FCT,GRD                                            
 
54
C    +                     PIXEL,WEIGHT,IDIM1,IDIM2,IDIM3)                      
 
55
C                                                                               
 
56
C.INPUT PARAMETERS                                                              
 
57
C       NRPRM               INTEGER  Number of parameters                       
 
58
C       PRM (NRPRM)         DOUBLE   Parameters                                 
 
59
C       PIXEL (IDIM_)       REAL     pixel values of the image                  
 
60
C       WEIGHT (IDIM_)      REAL     weighting factors                          
 
61
C       IDIM_               INTEGER  dimension of the 3-dim image.              
 
62
C                                                                               
 
63
C.MODIFIED PARAMETERS                                                           
 
64
C       none                                                                    
 
65
C                                                                               
 
66
C.OUTPUT PARAMETERS                                                             
 
67
C       FCT                 DOUBLE   Sum of residuals                           
 
68
C       GRD (NRPRM)         DOUBLE   Gradient                                   
 
69
C                                                                               
 
70
C.FILES                                                                         
 
71
C       FIT_NAG.INC/NOLIST                                                      
 
72
C                                                                               
 
73
C.MODULES CALLED                                                                
 
74
C       FTFUNC                                                                  
 
75
C                                                                               
 
76
C.AUTHOR                                                                        
 
77
C       Ph. DEFERT,      Feb 1986                                               
 
78
C                                                                               
 
79
C.MODIFICATIONS                                                                 
 
80
C                                                                               
 
81
C                                                                               
 
82
C-----------------------------------------------------------------------        
 
83
C      IMPLICIT NONE                                                            
 
84
C     ..                                                                        
 
85
C     .. Scalar Arguments ..                                                    
 
86
      INTEGER NRPRM,IDIM1,IDIM2,IDIM3                                           
 
87
      DOUBLE PRECISION FCT                                                      
 
88
C     ..                                                                        
 
89
C     .. Array Arguments ..                                                     
 
90
      DOUBLE PRECISION PRM(NRPRM),GRD(NRPRM)                                    
 
91
      REAL PIXEL(IDIM1,IDIM2,IDIM3),WEIGHT(IDIM1,IDIM2,IDIM3)                   
 
92
C     ..                                                                        
 
93
C     .. Scalars in Common ..                                                   
 
94
      INTEGER NRCOL,ISTAR                                                       
 
95
      CHARACTER WGTTYP*1                                                        
 
96
C     ..                                                                        
 
97
C     .. Arrays in Common ..                                                    
 
98
      INTEGER ICOL(10)                                                          
 
99
C     ..                                                                        
 
100
C     .. Local Scalars ..                                                       
 
101
      DOUBLE PRECISION W,Y,Y1,YOUT,YY                                           
 
102
      INTEGER IFUN,K,BEGFCT,I1,I2,I3,IP                   
 
103
C     ..                                                                        
 
104
C     .. Local Arrays ..                                                        
 
105
      REAL X(10)                                                       
 
106
C     ..                                                                        
 
107
C     .. Common blocks ..                                                       
 
108
C     ..                                                                        
 
109
C     .. External Files ..                                                      
 
110
       INCLUDE 'MID_INCLUDE:FITNAGI.INC/NOLIST'                                 
 
111
      DOUBLE PRECISION PARDER(MAXPAR)                                 
 
112
       INCLUDE 'MID_INCLUDE:FITNAGC.INC/NOLIST'                                 
 
113
      COMMON /LSQFUN/ICOL,NRCOL,ISTAR,WGTTYP                                    
 
114
C     ..                                                                        
 
115
C     .. Executable Statements ..                                               
 
116
C                                                                               
 
117
C  Deal with simple linear constraints                                          
 
118
C                                                                               
 
119
      DO 10 K = 1,NRPRM                                                         
 
120
          IP     = FIXPAR(K)                                                    
 
121
          IF (IP.GT.0) THEN                                                     
 
122
              PRM(K) = PRM(IP)*PRPFAC(K)                                        
 
123
              PARAM(K) = PRM(K)                                                 
 
124
          END IF                                                                
 
125
                                                                                
 
126
          GRD(K) = 0.                                                           
 
127
   10 CONTINUE                                                                  
 
128
C                                                                               
 
129
C  Go through the image                                                         
 
130
C                                                                               
 
131
      X(1)   = START(1)                                                         
 
132
      X(2)   = START(2)                                                         
 
133
      X(3)   = START(3)                                                         
 
134
      FCT    = 0.                                                               
 
135
      DO 60 I3 = 1,IDIM3                                                        
 
136
          DO 50 I2 = 1,IDIM2                                                    
 
137
              DO 40 I1 = 1,IDIM1                                                
 
138
C                                                                               
 
139
C   compute weights                                                             
 
140
C                                                                               
 
141
                  Y      = PIXEL(I1,I2,I3)                                      
 
142
                  IF (WGTTYP(1:1).EQ.'C') THEN                                  
 
143
                      W      = 1.                                               
 
144
                                                                                
 
145
                  ELSE IF (WGTTYP(1:1).EQ.'W') THEN                             
 
146
                      W      = WEIGHT(I1,I2,I3)                                 
 
147
                                                                                
 
148
                  ELSE IF (WGTTYP(1:1).EQ.'S') THEN                             
 
149
                      YY     = ABS(Y)                                           
 
150
                      IF (YY.LT.1.E-12) THEN                                    
 
151
                          W      = 1.                                           
 
152
                                                                                
 
153
                      ELSE                                                      
 
154
                          W      = 1./YY                                        
 
155
                      END IF                                                    
 
156
                                                                                
 
157
                  ELSE IF (WGTTYP(1:1).EQ.'I') THEN                             
 
158
                      W      = 1./WEIGHT(I1,I2,I3)**2                           
 
159
                  END IF                                                        
 
160
C                                                                               
 
161
C  Compute fitting values                                                       
 
162
C                                                                               
 
163
                  Y1     = 0.D0                                                 
 
164
                  BEGFCT = 1                                                    
 
165
                  DO 20 IFUN = 1,NRFUN                                          
 
166
                      CALL FTFUNC(FCTCOD(IFUN),NRIND,X,ACTPAR(IFUN),            
 
167
     +                            PRM(BEGFCT),YOUT,PARDER(BEGFCT))              
 
168
                      Y1     = Y1 + YOUT                                        
 
169
                      BEGFCT = BEGFCT + ACTPAR(IFUN)                            
 
170
   20             CONTINUE                                                      
 
171
                  FCT    = FCT + W* (Y1-Y)**2                                   
 
172
                  DO 30 K = 1,NRPRM                                             
 
173
                      IP     = FIXPAR(K)                                        
 
174
                      IF (IP.LE.0) THEN                                         
 
175
                          GRD(K) = GRD(K) + 2.D0*W*PARDER(K)* (Y1-Y)            
 
176
                                                                                
 
177
                      ELSE                                                      
 
178
                          GRD(IP) = GRD(IP) + 2.D0*W*PARDER(K)* (Y1-Y)/         
 
179
     +                              PRPFAC(K)                                   
 
180
                      END IF                                                    
 
181
                                                                                
 
182
   30             CONTINUE                                                      
 
183
                  X(1)   = X(1) + STEP(1)                                       
 
184
   40         CONTINUE                                                          
 
185
              X(2)   = X(2) + STEP(2)                                           
 
186
   50     CONTINUE                                                              
 
187
          X(3)   = X(3) + STEP(3)                                               
 
188
   60 CONTINUE                                                                  
 
189
      RETURN                                                                    
 
190
                                                                                
 
191
      END