1
C @(#)ftsval.for 19.1 (ES0-DMD) 02/25/03 13:17:36
2
C===========================================================================
3
C Copyright (C) 1995 European Southern Observatory (ESO)
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.
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.
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,
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
27
C===========================================================================
29
SUBROUTINE FTSVAL(NAME,LEN,FLAG,GUESS,ERROR,FACTOR,ISTAT)
30
C++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
31
C.COPYRIGHT: Copyright (c) 1987 European Southern Observatory,
34
C.VERSION: 1.0 ESO-FORTRAN Conversion, AA 17:25 - 13 JAN 1988
36
C.LANGUAGE: F77+ESOext
42
C FITLIB.FOR VERSION 1.0 27 MAR 1984
46
C INTERFACE ROUTINES FOR THE FITTING STRUCTURES
47
C SEARCH INITIAL VALUES OF THE PARAMETER
51
C USE MIDAS I/O INTERFACES TO FRAMES AND TABLES
58
C----------------------------------------------------------------
62
C NAME CHAR PARAMETER NAME
63
C LEN INTG NUMBER OF BYTES IN NAME
66
C FLAG INTG CONSTRAIN FLAG AS
69
C >0 POINTER TO THE PROPORTIONAL PARAMETER
71
C ERROR REAL OPTIONAL ERROR WEIGHT
72
C FACTOR REAL OPTIONAL FACTOR FOR PROPORTIONAL PARAMETERS
73
C ISTAT INTG STATUS RETURN
76
INTEGER FLAG,LEN,ISTAT,LEN1,I,II,II1,II2,ICASE
77
INTEGER IAC,L2,J,IB,L1
78
REAL ERROR,FACTOR,VALUE
79
DOUBLE PRECISION DB,GUESS
80
CHARACTER*20 TOKEN1,TOKEN2,TEST1,TEST2
81
CHARACTER LINE*80,LINE1*80,C*1,NAME1*10
82
INCLUDE 'MID_INCLUDE:FITI.INC/NOLIST'
83
INCLUDE 'MID_INCLUDE:FITC.INC/NOLIST'
85
C ITERATION ON THE FUNCTION SPECIFICATION
88
NAME1 = NAME(1:LEN)//'='
91
II = INDEX(LINE,NAME1(1:LEN1))
95
C PARAMETER NOT INITIALIZED
103
C DECODE THE PARAMETER VALUE OR CONSTRAIN
109
IF (C.EQ.' ') GO TO 40
113
C CHECK ONE OF THE FOLLOWING RULES
114
C LINE1(1:II) = value
121
IF (LINE1(II:II).EQ.'@') THEN
122
TOKEN1 = LINE1(1:II-1)
126
II1 = INDEX(LINE1(1:II),'*') ! value*param or param*value
128
TOKEN1 = LINE1(1:II1-1)
130
TOKEN2 = LINE1(II1+1:II)
134
II2 = INDEX(LINE1(1:II),'/') ! param/value
136
TOKEN1 = LINE1(1:II2-1)
138
TOKEN2 = LINE1(II2+1:II)
142
II1 = INDEX('-+.0123456789',LINE1(1:1)) ! param
155
CALL GENCNV(TOKEN1(1:L1),2,1,IB,VALUE,DB,IAC)
157
IF (IAC.LT.0) GO TO 60
161
IF (ICASE.EQ.1) FLAG = 0
163
II = INDEX('+-1234567890.',TOKEN1(1:1)) ! TOKEN1 is parameter
166
. CALL GENCNV(TOKEN2(1:L2),2,1,IB,VALUE,DB,IAC)
167
IF (IAC.LT.0) GO TO 60
169
IF (ICASE.EQ.3 .OR. ICASE.EQ.5) THEN
172
IF (VALUE.EQ.0.) GO TO 60
175
ELSE ! value/param not supported
176
IF (ICASE.EQ.4) GO TO 60
177
CALL GENCNV(TOKEN1(1:L1),2,1,IB,VALUE,DB,IAC)
178
IF (IAC.LT.0) GO TO 60
184
C SEARCH FOR PARAMETER TOKEN1
187
CALL FORUPC(TEST1, TEST1)
190
CALL FORUPC(TEST2, TEST2)
191
IF (TEST2(1:FZPLEN(J)).EQ.TEST1(1:L1)) THEN
192
IF (FZFIXED(J).GT.0) GO TO 60