FORTRAN Generation
(/./ftp/cats/J/A_AS/143/391)

Conversion of standardized ReadMe file for file /./ftp/cats/J/A_AS/143/391 into FORTRAN code for loading all data files into arrays.

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 2024-Apr-19
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/A+AS/143/391      ROSAT HRI catalogue of LMC X-ray sources    (Sasaki+, 2000)
*================================================================================
*ROSAT HRI catalogue of X-ray sources in the LMC region
*    Sasaki M., Haberl F., Pietsch W.
*   <Astron. Astrophys. Suppl. Ser. 143, 391 (2000)>
*   =2000A&AS..143..391S
C=============================================================================

C  Internal variables

      integer*4 i__

c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 

C  Declarations for 'table1.dat'	! Variable sources

      integer*4 nr__
      parameter (nr__=26)	! Number of records
      character*97 ar__   	! Full-size record

      integer*4     HRI        (nr__) ! HRI source number
      real*4        Hrate      (nr__) ! (ct/s) HRI count rate
      real*4        Prate      (nr__) ! (ct/s) ? PSPC count rate
      real*8        Fquo       (nr__) ! Fmax/Fmin
      real*8        redChi     (nr__) ! reduced Chi square
      integer*4     dof        (nr__) ! degrees of freedom
      integer*4     PNo        (nr__) ! ? PSPC source number, see Note (G1)
      character*55  Remarks    (nr__) ! Source ID, see Note (1)
*Note (1): < > for new classification.
*          References between [] are defined in refs.dat file

c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 

C  Declarations for 'table2.dat'	! Identified sources

      integer*4 nr__1
      parameter (nr__1=97)	! Number of records
      character*146 ar__1  	! Full-size record

C  J2000 position composed of: RAh RAm RAs DE- DEd DEm DEs
      real*8        RAdeg      (nr__1) ! (deg) Right Ascension J2000
      real*8        DEdeg      (nr__1) ! (deg)     Declination J2000
C  ---------------------------------- ! (position vector(s) in degrees)

      integer*4     HRI_1      (nr__1) ! HRI source number
      integer*4     RAh        (nr__1) ! (h) Right ascension J2000
      integer*4     RAm        (nr__1) ! (min) Right ascension J2000
      real*4        RAs        (nr__1) ! (s) Right ascension J2000
      character*1   DE_        (nr__1) ! Declination sign J2000
      integer*4     DEd        (nr__1) ! (deg) Declination J2000
      integer*4     DEm        (nr__1) ! (arcmin) Declination J2000
      integer*4     DEs        (nr__1) ! (arcsec) Declination J2000
      real*4        PosErr     (nr__1) ! (arcsec) Positional error
      real*8        MLexi      (nr__1) ! Existence Likelihood
      real*4        Rate       (nr__1) ! (ct/s) Count rate
      real*4        e_Rate     (nr__1) ! (ct/s) Count rate error
      real*4        Extent     (nr__1) ! (arcsec) Source extent
      real*4        e_Extent   (nr__1) ! (arcsec) Extent error
      real*4        MLext      (nr__1) ! Extent Likelihood
      integer*4     PNo_1      (nr__1) ! ? PSPC source number, see Note (G1)
      real*4        PHR1       (nr__1) ! ? Hardness ratio 1 of the PSPC source
      real*4        e_PHR1     (nr__1) ! ? Error of hardness ratio 1
      character*1   n_PHR1     (nr__1) ! [*] * when no uncertainty for PHR1 value
      real*4        PHR2       (nr__1) ! ? Hardness ratio 2 of the PSPC source
      real*4        e_PHR2     (nr__1) ! ? Error of hardness ratio 2
      character*1   n_PHR2     (nr__1) ! [*] * when no uncertainty for PHR2 value
      character*44  Remarks_1  (nr__1) ! Source classification, see Note (1)
*Note (1): fg = foreground
*     Candidates from literature are marked with '?' behind the source class
*     References between [] are defined in refs.dat file

c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 

C  Declarations for 'table3.dat'	! Classified sources

      integer*4 nr__2
      parameter (nr__2=21)	! Number of records
      character*132 ar__2  	! Full-size record

C  J2000 position composed of: RAh RAm RAs DE- DEd DEm DEs
      real*8        RAdeg_1    (nr__2) ! (deg) Right Ascension J2000
      real*8        DEdeg_1    (nr__2) ! (deg)     Declination J2000
C  ---------------------------------- ! (position vector(s) in degrees)

      integer*4     HRI_2      (nr__2) ! HRI source number
      integer*4     RAh_1      (nr__2) ! (h) Right ascension J2000
      integer*4     RAm_1      (nr__2) ! (min) Right ascension J2000
      real*4        RAs_1      (nr__2) ! (s) Right ascension J2000
      character*1   DE__1      (nr__2) ! Declination sign J2000
      integer*4     DEd_1      (nr__2) ! (deg) Declination J2000
      integer*4     DEm_1      (nr__2) ! (arcmin) Declination J2000
      integer*4     DEs_1      (nr__2) ! (arcsec) Declination J2000
      real*4        PosErr_1   (nr__2) ! (arcsec) Positional error
      real*4        MLexi_1    (nr__2) ! Existence Likelihood
      real*4        Rate_1     (nr__2) ! (ct/s) Count rate
      real*4        e_Rate_1   (nr__2) ! (ct/s) Count rate error
      real*4        Extent_1   (nr__2) ! (arcsec) Source extent
      real*4        e_Extent_1 (nr__2) ! (arcsec) Extent error
      real*4        MLext_1    (nr__2) ! Extent Likelihood
      real*4        log_Fx_Fopt(nr__2) ! log(Fx/Fopt)
      integer*4     PNo_2      (nr__2) ! ? PSPC source number, see Note (G1)
      real*4        PHR1_1     (nr__2) ! ? Hardness ratio 1 of the PSPC source
      real*4        e_PHR1_1   (nr__2) ! ? Error of hardness ratio 1
      real*4        PHR2_1     (nr__2) ! ? Hardness ratio 2 of the PSPC source
      real*4        e_PHR2_1   (nr__2) ! ? Error of hardness ratio 2
      character*30  Remarks_2  (nr__2) ! Source classification (1)
*Note (1): References between [] are defined in refs.dat file

c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 

C  Declarations for 'table4.dat'	! ROSAT HRI LMC catalogue

      integer*4 nr__3
      parameter (nr__3=397)	! Number of records
      character*182 ar__3  	! Full-size record

C  J2000 position composed of: RAh RAm RAs DE- DEd DEm DEs
      real*8        RAdeg_2    (nr__3) ! (deg) Right Ascension J2000
      real*8        DEdeg_2    (nr__3) ! (deg)     Declination J2000
C  ---------------------------------- ! (position vector(s) in degrees)

      integer*4     HRI_3      (nr__3) ! HRI source number
      integer*4     RAh_2      (nr__3) ! (h) Right ascension J2000
      integer*4     RAm_2      (nr__3) ! (min) Right ascension J2000
      real*4        RAs_2      (nr__3) ! (s) Right ascension J2000
      character*1   DE__2      (nr__3) ! Declination sign J2000
      integer*4     DEd_2      (nr__3) ! (deg) Declination J2000
      integer*4     DEm_2      (nr__3) ! (arcmin) Declination J2000
      integer*4     DEs_2      (nr__3) ! (arcsec) Declination J2000
      real*4        PosErr_2   (nr__3) ! (arcsec) Positional error
      real*8        MLexi_2    (nr__3) ! Existence Likelihood
      real*4        Rate_2     (nr__3) ! (ct/s) Count rate
      real*4        e_Rate_2   (nr__3) ! (ct/s) Count rate error
      real*4        Extent_2   (nr__3) ! (arcsec) Source extent
      real*4        e_Extent_2 (nr__3) ! (arcsec) Extent error
      real*4        MLext_2    (nr__3) ! Extent Likelihood
      character*1   l_PRate    (nr__3) ! see Note (1)
      real*4        PRate_1    (nr__3) ! (ct/s) ? PSPC count rate, see Note (1)
      integer*4     PNo_3      (nr__3) ! ? PSPC source number, see Note (G1)
      real*4        PHR1_2     (nr__3) ! ? Hardness ratio 1 of the PSPC source
      real*4        e_PHR1_2   (nr__3) ! ? Error of hardness ratio 1
      character*1   n_PHR1_1   (nr__3) ! [*] * when no uncertainty for PHR1 value
      real*4        PHR2_2     (nr__3) ! ? Hardness ratio 2 of the PSPC source
      real*4        e_PHR2_2   (nr__3) ! ? Error of hardness ratio 2
      character*1   n_PHR2_1   (nr__3) ! [*] * when no uncertainty for PHR2 value
      character*70  Remarks_3  (nr__3) ! Source classification, see Note (2)
*Note (1): For sources which are listed in the ROSAT PSPC catalogue
*    (Haberl & Pietsch, 1999, Cat. <J/A+AS/139/277>) PSPC count rates are
*    taken from the catalogue. Otherwise PSPC count rate is the 2 sigma
*    upper limit from maximum likelihood algorithm ('<' in column Uplim).
*Note (2): fg: foreground
*    Candidates from literature are marked with '?' behind the source class
*    New classifications are put in < >
*    References between [] are defined in refs.dat file

c - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 

C  Declarations for 'refs.dat'	! References

      integer*4 nr__4
      parameter (nr__4=18)	! Number of records
      character*209 ar__4  	! Full-size record

      character*8   Ref        (nr__4) ! Reference code
      character*19  BibCode    (nr__4) ! BibCode
      character*54  Aut        (nr__4) ! Author names
      character*126 Com        (nr__4) ! Comments

C=============================================================================

C  Loading file 'table1.dat'	! Variable sources

C  Format for file interpretation

    1 format(I3,1X,E6.1,1X,E6.1,1X,F7.1,1X,F7.1,1X,I2,1X,I4,1X,A55)

C  Effective file loading

      open(unit=1,status='old',file=
     +'table1.dat')
      write(6,*) '....Loading file: table1.dat'
      do i__=1,26
        read(1,'(A97)')ar__
        read(ar__,1)
     +  HRI(i__),Hrate(i__),Prate(i__),Fquo(i__),redChi(i__),dof(i__),
     +  PNo(i__),Remarks(i__)
        if(ar__(12:17) .EQ. '') Prate(i__) = rNULL__
        if(ar__(38:41) .EQ. '') PNo(i__) = iNULL__
c    ..............Just test output...........
        write(6,1)
     +  HRI(i__),Hrate(i__),Prate(i__),Fquo(i__),redChi(i__),dof(i__),
     +  PNo(i__),Remarks(i__)
c    .......End.of.Just test output...........
      end do
      close(1)

C=============================================================================

C  Loading file 'table2.dat'	! Identified sources

C  Format for file interpretation

    2 format(
     +  I3,1X,I2,1X,I2,1X,F4.1,1X,A1,I2,1X,I2,1X,I2,1X,F4.1,1X,F7.1,
     +  1X,E8.2,1X,E8.2,1X,F4.1,1X,F3.1,1X,F6.1,1X,I4,1X,F5.2,1X,F4.2,
     +  A1,1X,F5.2,1X,F4.2,A1,1X,A44)

C  Effective file loading

      open(unit=1,status='old',file=
     +'table2.dat')
      write(6,*) '....Loading file: table2.dat'
      do i__=1,97
        read(1,'(A146)')ar__1
        read(ar__1,2)
     +  HRI_1(i__),RAh(i__),RAm(i__),RAs(i__),DE_(i__),DEd(i__),
     +  DEm(i__),DEs(i__),PosErr(i__),MLexi(i__),Rate(i__),
     +  e_Rate(i__),Extent(i__),e_Extent(i__),MLext(i__),PNo_1(i__),
     +  PHR1(i__),e_PHR1(i__),n_PHR1(i__),PHR2(i__),e_PHR2(i__),
     +  n_PHR2(i__),Remarks_1(i__)
        if(ar__1(73:76) .EQ. '') PNo_1(i__) = iNULL__
        if(ar__1(78:82) .EQ. '') PHR1(i__) = rNULL__
        if(ar__1(84:87) .EQ. '') e_PHR1(i__) = rNULL__
        if(ar__1(90:94) .EQ. '') PHR2(i__) = rNULL__
        if(ar__1(96:99) .EQ. '') e_PHR2(i__) = rNULL__
        RAdeg(i__) = rNULL__
        DEdeg(i__) = rNULL__
c  Derive coordinates RAdeg and DEdeg from input data
c  (RAdeg and DEdeg are set to rNULL__ when unknown)
        if(RAh(i__) .GT. -180) RAdeg(i__)=RAh(i__)*15.
        if(RAm(i__) .GT. -180) RAdeg(i__)=RAdeg(i__)+RAm(i__)/4.
        if(RAs(i__) .GT. -180) RAdeg(i__)=RAdeg(i__)+RAs(i__)/240.
        if(DEd(i__) .GE. 0) DEdeg(i__)=DEd(i__)
        if(DEm(i__) .GE. 0) DEdeg(i__)=DEdeg(i__)+DEm(i__)/60.
        if(DEs(i__) .GE. 0) DEdeg(i__)=DEdeg(i__)+DEs(i__)/3600.
        if(DE_(i__).EQ.'-'.AND.DEdeg(i__).GE.0) DEdeg(i__)=-DEdeg(i__)
c    ..............Just test output...........
        write(6,2)
     +  HRI_1(i__),RAh(i__),RAm(i__),RAs(i__),DE_(i__),DEd(i__),
     +  DEm(i__),DEs(i__),PosErr(i__),MLexi(i__),Rate(i__),
     +  e_Rate(i__),Extent(i__),e_Extent(i__),MLext(i__),PNo_1(i__),
     +  PHR1(i__),e_PHR1(i__),n_PHR1(i__),PHR2(i__),e_PHR2(i__),
     +  n_PHR2(i__),Remarks_1(i__)
        write(6,'(6H Pos: 2F8.4)') RAdeg(i__),DEdeg(i__)
c    .......End.of.Just test output...........
      end do
      close(1)

C=============================================================================

C  Loading file 'table3.dat'	! Classified sources

C  Format for file interpretation

    3 format(
     +  I3,1X,I2,1X,I2,1X,F4.1,1X,A1,I2,1X,I2,1X,I2,1X,F4.1,1X,F6.1,
     +  1X,E8.2,1X,E8.2,1X,F4.1,1X,F4.1,1X,F5.1,1X,F5.2,1X,I4,1X,F4.2,
     +  1X,F4.2,1X,F4.2,1X,F4.2,1X,A30)

C  Effective file loading

      open(unit=1,status='old',file=
     +'table3.dat')
      write(6,*) '....Loading file: table3.dat'
      do i__=1,21
        read(1,'(A132)')ar__2
        read(ar__2,3)
     +  HRI_2(i__),RAh_1(i__),RAm_1(i__),RAs_1(i__),DE__1(i__),
     +  DEd_1(i__),DEm_1(i__),DEs_1(i__),PosErr_1(i__),MLexi_1(i__),
     +  Rate_1(i__),e_Rate_1(i__),Extent_1(i__),e_Extent_1(i__),
     +  MLext_1(i__),log_Fx_Fopt(i__),PNo_2(i__),PHR1_1(i__),
     +  e_PHR1_1(i__),PHR2_1(i__),e_PHR2_1(i__),Remarks_2(i__)
        if(ar__2(78:81) .EQ. '') PNo_2(i__) = iNULL__
        if(ar__2(83:86) .EQ. '') PHR1_1(i__) = rNULL__
        if(ar__2(88:91) .EQ. '') e_PHR1_1(i__) = rNULL__
        if(ar__2(93:96) .EQ. '') PHR2_1(i__) = rNULL__
        if(ar__2(98:101) .EQ. '') e_PHR2_1(i__) = rNULL__
        RAdeg_1(i__) = rNULL__
        DEdeg_1(i__) = rNULL__
c  Derive coordinates RAdeg_1 and DEdeg_1 from input data
c  (RAdeg_1 and DEdeg_1 are set to rNULL__ when unknown)
        if(RAh_1(i__) .GT. -180) RAdeg_1(i__)=RAh_1(i__)*15.
        if(RAm_1(i__) .GT. -180) RAdeg_1(i__)=RAdeg_1(i__)+RAm_1(i__)/4.
        if(RAs_1(i__) .GT. -180) RAdeg_1(i__)=RAdeg_1(i__)+RAs_1(i__)/240.
        if(DEd_1(i__) .GE. 0) DEdeg_1(i__)=DEd_1(i__)
        if(DEm_1(i__) .GE. 0) DEdeg_1(i__)=DEdeg_1(i__)+DEm_1(i__)/60.
        if(DEs_1(i__) .GE. 0) DEdeg_1(i__)=DEdeg_1(i__)+DEs_1(i__)/3600.
        if(DE__1(i__).EQ.'-'.AND.DEdeg_1(i__).GE.0) DEdeg_1(i__)=-DEdeg_1(i__)
c    ..............Just test output...........
        write(6,3)
     +  HRI_2(i__),RAh_1(i__),RAm_1(i__),RAs_1(i__),DE__1(i__),
     +  DEd_1(i__),DEm_1(i__),DEs_1(i__),PosErr_1(i__),MLexi_1(i__),
     +  Rate_1(i__),e_Rate_1(i__),Extent_1(i__),e_Extent_1(i__),
     +  MLext_1(i__),log_Fx_Fopt(i__),PNo_2(i__),PHR1_1(i__),
     +  e_PHR1_1(i__),PHR2_1(i__),e_PHR2_1(i__),Remarks_2(i__)
        write(6,'(6H Pos: 2F8.4)') RAdeg_1(i__),DEdeg_1(i__)
c    .......End.of.Just test output...........
      end do
      close(1)

C=============================================================================

C  Loading file 'table4.dat'	! ROSAT HRI LMC catalogue

C  Format for file interpretation

    4 format(
     +  I3,1X,I2,1X,I2,1X,F4.1,1X,A1,I2,1X,I2,1X,I2,1X,F4.1,1X,F7.1,
     +  1X,E8.2,1X,E8.2,1X,F4.1,1X,F4.1,1X,F6.1,1X,A1,E8.2,1X,I4,1X,
     +  F5.2,1X,F4.2,A1,1X,F5.2,1X,F4.2,A1,1X,A70)

C  Effective file loading

      open(unit=1,status='old',file=
     +'table4.dat')
      write(6,*) '....Loading file: table4.dat'
      do i__=1,397
        read(1,'(A182)')ar__3
        read(ar__3,4)
     +  HRI_3(i__),RAh_2(i__),RAm_2(i__),RAs_2(i__),DE__2(i__),
     +  DEd_2(i__),DEm_2(i__),DEs_2(i__),PosErr_2(i__),MLexi_2(i__),
     +  Rate_2(i__),e_Rate_2(i__),Extent_2(i__),e_Extent_2(i__),
     +  MLext_2(i__),l_PRate(i__),PRate_1(i__),PNo_3(i__),PHR1_2(i__),
     +  e_PHR1_2(i__),n_PHR1_1(i__),PHR2_2(i__),e_PHR2_2(i__),
     +  n_PHR2_1(i__),Remarks_3(i__)
        if(ar__3(75:82) .EQ. '') PRate_1(i__) = rNULL__
        if(ar__3(84:87) .EQ. '') PNo_3(i__) = iNULL__
        if(ar__3(89:93) .EQ. '') PHR1_2(i__) = rNULL__
        if(ar__3(95:98) .EQ. '') e_PHR1_2(i__) = rNULL__
        if(ar__3(101:105) .EQ. '') PHR2_2(i__) = rNULL__
        if(ar__3(107:110) .EQ. '') e_PHR2_2(i__) = rNULL__
        RAdeg_2(i__) = rNULL__
        DEdeg_2(i__) = rNULL__
c  Derive coordinates RAdeg_2 and DEdeg_2 from input data
c  (RAdeg_2 and DEdeg_2 are set to rNULL__ when unknown)
        if(RAh_2(i__) .GT. -180) RAdeg_2(i__)=RAh_2(i__)*15.
        if(RAm_2(i__) .GT. -180) RAdeg_2(i__)=RAdeg_2(i__)+RAm_2(i__)/4.
        if(RAs_2(i__) .GT. -180) RAdeg_2(i__)=RAdeg_2(i__)+RAs_2(i__)/240.
        if(DEd_2(i__) .GE. 0) DEdeg_2(i__)=DEd_2(i__)
        if(DEm_2(i__) .GE. 0) DEdeg_2(i__)=DEdeg_2(i__)+DEm_2(i__)/60.
        if(DEs_2(i__) .GE. 0) DEdeg_2(i__)=DEdeg_2(i__)+DEs_2(i__)/3600.
        if(DE__2(i__).EQ.'-'.AND.DEdeg_2(i__).GE.0) DEdeg_2(i__)=-DEdeg_2(i__)
c    ..............Just test output...........
        write(6,4)
     +  HRI_3(i__),RAh_2(i__),RAm_2(i__),RAs_2(i__),DE__2(i__),
     +  DEd_2(i__),DEm_2(i__),DEs_2(i__),PosErr_2(i__),MLexi_2(i__),
     +  Rate_2(i__),e_Rate_2(i__),Extent_2(i__),e_Extent_2(i__),
     +  MLext_2(i__),l_PRate(i__),PRate_1(i__),PNo_3(i__),PHR1_2(i__),
     +  e_PHR1_2(i__),n_PHR1_1(i__),PHR2_2(i__),e_PHR2_2(i__),
     +  n_PHR2_1(i__),Remarks_3(i__)
        write(6,'(6H Pos: 2F8.4)') RAdeg_2(i__),DEdeg_2(i__)
c    .......End.of.Just test output...........
      end do
      close(1)

C=============================================================================

C  Loading file 'refs.dat'	! References

C  Format for file interpretation

    5 format(A8,1X,A19,1X,A54,A126)

C  Effective file loading

      open(unit=1,status='old',file=
     +'refs.dat')
      write(6,*) '....Loading file: refs.dat'
      do i__=1,18
        read(1,'(A209)')ar__4
        read(ar__4,5)Ref(i__),BibCode(i__),Aut(i__),Com(i__)
c    ..............Just test output...........
        write(6,5)Ref(i__),BibCode(i__),Aut(i__),Com(i__)
c    .......End.of.Just test output...........
      end do
      close(1)

C=============================================================================
      stop
      end