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

« back to all changes in this revision

Viewing changes to applic/fit/libsrc/funct1i.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 @(#)funct1i.for       19.1 (ES0-DMD) 02/25/03 13:17:37
 
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 FUNC1I(NRPRM,PRM,FCT,PIXEL,WEIGHT,IDIM1,IDIM2,IDIM3)         
 
30
C+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++        
 
31
C                                                                               
 
32
C.MODULE                                                                        
 
33
C       FIT                                                                     
 
34
C                                                                               
 
35
C.NAME                                                                          
 
36
C       FUNCT1_I                                                                
 
37
C                                                                               
 
38
C.PURPOSE                                                                       
 
39
C       Function to compute the sum of residuals                                
 
40
C       for FIT/IMAG                                                            
 
41
C                                                                               
 
42
C.KEYWORDS                                                                      
 
43
C       Approximating Function.                                                 
 
44
C                                                                               
 
45
C.DESCRIPTION                                                                   
 
46
C       Read the TABLE row by row, and compute the fitting function by          
 
47
C       calling MIDAS functions                                                 
 
48
C                                                                               
 
49
C.LANGUAGE                                                                      
 
50
C       FORTRAN                                                                 
 
51
C                                                                               
 
52
C.CALLING SEQUENCE                                                              
 
53
C      CALL FUNC1I(NRPRM,PRM,FCT,PIXEL,WEIGHT,IDIM1,IDIM2,IDIM3)              
 
54
C                                                                               
 
55
C.INPUT PARAMETERS                                                              
 
56
C       NRPRM               INTEGER  Number of parameters                       
 
57
C       PRM (NRPRM)         DOUBLE   Parameters                                 
 
58
C       PIXEL (IDIM_)       REAL     pixel values of the image                  
 
59
C       WEIGHT (IDIM_)      REAL     weighting factors                          
 
60
C       IDIM_               INTEGER  dimension of the 3-dim image.              
 
61
C                                                                               
 
62
C.MODIFIED PARAMETERS                                                           
 
63
C       none                                                                    
 
64
C                                                                               
 
65
C.OUTPUT PARAMETERS                                                             
 
66
C       FCT                 DOUBLE   Sum of residuals                           
 
67
C                                                                               
 
68
C.FILES                                                                         
 
69
C       FIT_NAG.INC/NOLIST                                                      
 
70
C                                                                               
 
71
C.MODULES CALLED                                                                
 
72
C       FTFUNC                                                                  
 
73
C                                                                               
 
74
C.AUTHOR                                                                        
 
75
C       Ph. DEFERT,      Feb 1986                                               
 
76
C                                                                               
 
77
C.MODIFICATIONS                                                                 
 
78
C                                                                               
 
79
C                                                                               
 
80
C-----------------------------------------------------------------------        
 
81
C      IMPLICIT NONE                                                            
 
82
C     ..                                                                        
 
83
C     .. Scalar Arguments ..                                                    
 
84
      INTEGER NRPRM,IDIM1,IDIM2,IDIM3                                           
 
85
      DOUBLE PRECISION FCT                                                      
 
86
C     ..                                                                        
 
87
C     .. Array Arguments ..                                                     
 
88
      DOUBLE PRECISION PRM(NRPRM)                                               
 
89
      REAL PIXEL(IDIM1,IDIM2,IDIM3),WEIGHT(IDIM1,IDIM2,IDIM3)                   
 
90
C     ..                                                                        
 
91
C     .. Scalars in Common ..                                                   
 
92
      INTEGER NRCOL,ISTAR                                                       
 
93
      CHARACTER WGTTYP*1                                                        
 
94
C     ..                                                                        
 
95
C     .. Arrays in Common ..                                                    
 
96
      INTEGER ICOL(10)                                                          
 
97
C     ..                                                                        
 
98
C     .. Local Scalars ..                                                       
 
99
      DOUBLE PRECISION W,Y,Y1,YOUT,YY                                           
 
100
      INTEGER IFUN,K,BEGFCT,I1,I2,I3,IP              
 
101
C     ..                                                                        
 
102
C     .. Local Arrays ..                                                        
 
103
      DOUBLE PRECISION DUMMY(10)                                                
 
104
      REAL X(10)                                                       
 
105
C     ..                                                                        
 
106
C     .. External Files ..                                                      
 
107
       INCLUDE 'MID_INCLUDE:FITNAGI.INC/NOLIST'                                 
 
108
       INCLUDE 'MID_INCLUDE:FITNAGC.INC/NOLIST'                                 
 
109
C     ..                                                                        
 
110
C     .. Common blocks ..                                                       
 
111
      COMMON /LSQFUN/ICOL,NRCOL,ISTAR,WGTTYP                                    
 
112
C     ..                                                                        
 
113
C     .. Executable Statements ..                                               
 
114
C                                                                               
 
115
C  deal with linear simple constraints                                          
 
116
C                                                                               
 
117
      DO 10 K = 1,NRPRM                                                         
 
118
          IP     = FIXPAR(K)                                                    
 
119
          IF (IP.GT.0) THEN                                                     
 
120
              PRM(K) = PRM(IP)*PRPFAC(K)                                        
 
121
              PARAM(K) = PRM(K)                                                 
 
122
          END IF                                                                
 
123
                                                                                
 
124
   10 CONTINUE                                                                  
 
125
C                                                                               
 
126
C  Go through the image                                                         
 
127
C                                                                               
 
128
      X(1)   = START(1)                                                         
 
129
      X(2)   = START(2)                                                         
 
130
      X(3)   = START(3)                                                         
 
131
      FCT    = 0.D0                                                             
 
132
      DO 50 I3 = 1,IDIM3                                                        
 
133
          DO 40 I2 = 1,IDIM2                                                    
 
134
              DO 30 I1 = 1,IDIM1                                                
 
135
C                                                                               
 
136
C   compute weights                                                             
 
137
C                                                                               
 
138
                  Y      = PIXEL(I1,I2,I3)                                      
 
139
                  IF (WGTTYP(1:1).EQ.'C') THEN                                  
 
140
                      W      = 1.                                               
 
141
                                                                                
 
142
                  ELSE IF (WGTTYP(1:1).EQ.'W') THEN                             
 
143
                      W      = WEIGHT(I1,I2,I3)                                 
 
144
                                                                                
 
145
                  ELSE IF (WGTTYP(1:1).EQ.'S') THEN                             
 
146
                      YY     = ABS(Y)                                           
 
147
                      IF (YY.LT.1.E-12) THEN                                    
 
148
                          W      = 1.                                           
 
149
                                                                                
 
150
                      ELSE                                                      
 
151
                          W      = 1./YY                                        
 
152
                      END IF                                                    
 
153
                                                                                
 
154
                  ELSE IF (WGTTYP(1:1).EQ.'I') THEN                             
 
155
                      W      = 1./WEIGHT(I1,I2,I3)**2                           
 
156
                  END IF                                                        
 
157
C                                                                               
 
158
C   Compute fitting values                                                      
 
159
C                                                                               
 
160
                  Y1     = 0.D0                                                 
 
161
                  BEGFCT = 1                                                    
 
162
                  DO 20 IFUN = 1,NRFUN                                          
 
163
                      CALL FTFUNC(FCTCOD(IFUN),NRIND,X,ACTPAR(IFUN),            
 
164
     +                            PRM(BEGFCT),YOUT,DUMMY)                       
 
165
                      Y1     = Y1 + YOUT                                        
 
166
                      BEGFCT = BEGFCT + ACTPAR(IFUN)                            
 
167
   20             CONTINUE                                                      
 
168
                  FCT    = FCT + W* (Y1-Y)**2                                   
 
169
                  X(1)   = X(1) + STEP(1)                                       
 
170
   30         CONTINUE                                                          
 
171
              X(2)   = X(2) + STEP(2)                                           
 
172
   40     CONTINUE                                                              
 
173
          X(3)   = X(3) + STEP(3)                                               
 
174
   50 CONTINUE                                                                  
 
175
      RETURN                                                                    
 
176
                                                                                
 
177
      END