Conversion of standardized ReadMe file for
file /./ftp/cats/J/AZh/82/420 into FORTRAN code for reading data files line by line.
Note that special values are assigned to unknown or unspecified
numbers (also called NULL numbers);
when necessary, the coordinate components making up the right ascension
and declination are converted into floating-point numbers
representing these angles in degrees.
program load_ReadMe
C=============================================================================
C F77-compliant program generated by readme2f_1.81 (2015-09-23), on 2026-Jun-08
C=============================================================================
* This code was generated from the ReadMe file documenting a catalogue
* according to the "Standard for Documentation of Astronomical Catalogues"
* currently in use by the Astronomical Data Centers (CDS, ADC, A&A)
* (see full documentation at URL http://vizier.u-strasbg.fr/doc/catstd.htx)
* Please report problems or questions to
C=============================================================================
implicit none
* Unspecified or NULL values, generally corresponding to blank columns,
* are assigned one of the following special values:
* rNULL__ for unknown or NULL floating-point values
* iNULL__ for unknown or NULL integer values
real*4 rNULL__
integer*4 iNULL__
parameter (rNULL__=--2147483648.) ! NULL real number
parameter (iNULL__=(-2147483647-1)) ! NULL int number
integer idig ! testing NULL number
C=============================================================================
Cat. J/AZh/82/420 Spectral study of 19 radio sources (Afanasiev+, 2005)
*================================================================================
*Spectral studies with the Special Astrophysical Observatory 6m and
*RATAN-600 Telescopes.
* Afanasiev V.L., Dodonov S.N., Moiseev A.V., Gorshkov A.G., Konnikova V.K.,
* Mingaliev M.G.
* <Astron. Zh. 82, 420 (2005)>
* =2005AZh....82..420A
* =2005ARep...49..374A
C=============================================================================
C Internal variables
integer*4 i__
c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C Declarations for 'table1.dat' ! Coordinates of the objects
integer*4 nr__
parameter (nr__=19) ! Number of records
character*69 ar__ ! Full-size record
C J2000 position composed of: RAh RAm RAs DE- DEd DEm DEs
real*8 RAdeg ! (deg) Right Ascension J2000
real*8 DEdeg ! (deg) Declination J2000
C ---------------------------------- ! (position vector(s) in degrees)
character*10 Name ! Object name
integer*4 RAh ! (h) Right ascension (J2000)
integer*4 RAm ! (min) Right ascension (J2000)
real*4 RAs ! (s) Right ascension (J2000)
character*1 DE_ ! Declination sign (J2000)
integer*4 DEd ! (deg) Declination (J2000)
integer*4 DEm ! (arcmin) Declination (J2000)
real*4 DEs ! (arcsec) Declination (J2000)
real*4 oRA ! (arcsec) Offset between optical and radio position in RA
real*4 oDE ! (arcsec) Offset between optical and radio position in DE
real*4 Rmag ! (mag) USNO R magnitude
real*4 Bmag ! (mag) ? USNO B magnitude
character*5 r_Pos ! Reference for coordinates (1)
*Note (1): References for coordinates are as follows:
* JVAS = Jordell Bank-VLA Astrometric Survey at 8.4GHz (1998, Cat. <VIII/60>)
* NVSS = NRAS VLA Sky Survey at 1.4GHz (1998, Cat. <VIII/65>)
* TEXAS = TEXAS survey at 0.365GHz (1996, Cat. <VII/42>)
c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C Declarations for 'table2.dat' ! Optical data
integer*4 nr__1
parameter (nr__1=65) ! Number of records
character*64 ar__1 ! Full-size record
character*10 Name_1 ! Object name
character*9 Line ! Observed spectral line
character*1 n_Line ! [*] * for line observed in absorption,
* others in emission
character*9 Lambda ! (0.1nm) ? Wavelength of the rest/observed wavelength
real*4 z ! ? Redshift
character*5 Type ! Type of source
character*10 Date ! ("DD/MM/YYYY") Observation date
real*4 ExpTime ! (min) ? Exposure time
c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
C Declarations for 'table3.dat' ! Radio data
integer*4 nr__2
parameter (nr__2=35) ! Number of records
character*78 ar__2 ! Full-size record
character*10 Name_2 ! Object name
integer*4 F0_97GHz ! (mJy) ? Flux density in 0.97GHz
integer*4 e_F0_97GHz ! (mJy) ? rms error at 0.97GHz
integer*4 F2_3GHz ! (mJy) Flux density in 2.3GHz
integer*4 e_F2_3GHz ! (mJy) rms error at 2.3GHz
integer*4 F3_9GHz ! (mJy) ? Flux density in 3.9GHz
integer*4 e_F3_9GHz ! (mJy) ? rms error at 3.9GHz
integer*4 F7_7GHz ! (mJy) ? Flux density in 7.7GHz
integer*4 e_F7_7GHz ! (mJy) ? rms error at 7.7GHz
integer*4 F11_1GHz ! (mJy) ? Flux density in 11.1GHz
integer*4 e_F11_1GHz ! (mJy) ? rms error at 11.1GHz
integer*4 F21_7GHz ! (mJy) ? Flux density in 21.7GHz
integer*4 e_F21_7GHz ! (mJy) ? rms error at 21.7GHz
character*10 Epoch ! ("DD/MM/YYYY") Epoch of observation
C=============================================================================
C Loading file 'table1.dat' ! Coordinates of the objects
C Format for file interpretation
1 format(
+ A10,1X,I2,1X,I2,1X,F6.3,1X,A1,I2,1X,I2,1X,F5.2,2X,F6.3,1X,
+ F6.3,F5.2,1X,F5.2,2X,A5)
C Effective file loading
open(unit=1,status='old',file=
+'table1.dat')
write(6,*) '....Loading file: table1.dat'
do i__=1,19
read(1,'(A69)')ar__
read(ar__,1)
+ Name,RAh,RAm,RAs,DE_,DEd,DEm,DEs,oRA,oDE,Rmag,Bmag,r_Pos
if(ar__(58:62) .EQ. '') Bmag = rNULL__
RAdeg = rNULL__
DEdeg = rNULL__
c Derive coordinates RAdeg and DEdeg from input data
c (RAdeg and DEdeg are set to rNULL__ when unknown)
if(RAh .GT. -180) RAdeg=RAh*15.
if(RAm .GT. -180) RAdeg=RAdeg+RAm/4.
if(RAs .GT. -180) RAdeg=RAdeg+RAs/240.
if(DEd .GE. 0) DEdeg=DEd
if(DEm .GE. 0) DEdeg=DEdeg+DEm/60.
if(DEs .GE. 0) DEdeg=DEdeg+DEs/3600.
if(DE_.EQ.'-'.AND.DEdeg.GE.0) DEdeg=-DEdeg
c ..............Just test output...........
write(6,1)
+ Name,RAh,RAm,RAs,DE_,DEd,DEm,DEs,oRA,oDE,Rmag,Bmag,r_Pos
write(6,'(6H Pos: 2F8.4)') RAdeg,DEdeg
c .......End.of.Just test output...........
end do
close(1)
C=============================================================================
C Loading file 'table2.dat' ! Optical data
C Format for file interpretation
2 format(A10,4X,A9,A1,1X,A9,2X,F5.3,2X,A5,1X,A10,1X,F4.1)
C Effective file loading
open(unit=1,status='old',file=
+'table2.dat')
write(6,*) '....Loading file: table2.dat'
do i__=1,65
read(1,'(A64)')ar__1
read(ar__1,2)Name_1,Line,n_Line,Lambda,z,Type,Date,ExpTime
if(ar__1(37:41) .EQ. '') z = rNULL__
if(ar__1(61:64) .EQ. '') ExpTime = rNULL__
c ..............Just test output...........
write(6,2)Name_1,Line,n_Line,Lambda,z,Type,Date,ExpTime
c .......End.of.Just test output...........
end do
close(1)
C=============================================================================
C Loading file 'table3.dat' ! Radio data
C Format for file interpretation
3 format(
+ A10,2X,I4,2X,I2,2X,I4,2X,I2,2X,I4,1X,I2,2X,I4,1X,I2,2X,I4,1X,
+ I2,2X,I4,1X,I2,2X,A10)
C Effective file loading
open(unit=1,status='old',file=
+'table3.dat')
write(6,*) '....Loading file: table3.dat'
do i__=1,35
read(1,'(A78)')ar__2
read(ar__2,3)
+ Name_2,F0_97GHz,e_F0_97GHz,F2_3GHz,e_F2_3GHz,F3_9GHz,
+ e_F3_9GHz,F7_7GHz,e_F7_7GHz,F11_1GHz,e_F11_1GHz,F21_7GHz,
+ e_F21_7GHz,Epoch
if(ar__2(13:16) .EQ. '') F0_97GHz = iNULL__
if(ar__2(19:20) .EQ. '') e_F0_97GHz = iNULL__
if(ar__2(33:36) .EQ. '') F3_9GHz = iNULL__
if(ar__2(38:39) .EQ. '') e_F3_9GHz = iNULL__
if(ar__2(42:45) .EQ. '') F7_7GHz = iNULL__
if(ar__2(47:48) .EQ. '') e_F7_7GHz = iNULL__
if(ar__2(51:54) .EQ. '') F11_1GHz = iNULL__
if(ar__2(56:57) .EQ. '') e_F11_1GHz = iNULL__
if(ar__2(60:63) .EQ. '') F21_7GHz = iNULL__
if(ar__2(65:66) .EQ. '') e_F21_7GHz = iNULL__
c ..............Just test output...........
write(6,3)
+ Name_2,F0_97GHz,e_F0_97GHz,F2_3GHz,e_F2_3GHz,F3_9GHz,
+ e_F3_9GHz,F7_7GHz,e_F7_7GHz,F11_1GHz,e_F11_1GHz,F21_7GHz,
+ e_F21_7GHz,Epoch
c .......End.of.Just test output...........
end do
close(1)
C=============================================================================
stop
end