FATMEN maintains three types of monitoring information:
The monitoring information that is stored in the FATMEN catalogued consists of the file size, the date and time of last access and the number of file accesses.
This information is stored per entry at the offsets MFSZFA, MLATFA and MUSCFA. See page [more info] for a description of the bank offsets.
This information can be histogrammed with the example program FATPLOT, included in the FATMEN source file in patch EXAMPLE, deck FATPLOT and reproduced below.
Histogramming monitoring information
*======================================================================= * * Example of using HBOOK to plot various FATMEN catalogue values. * This program histograms the file size, number of days since last * access, medium type etc. *======================================================================= PARAMETER (LURCOR=200000) COMMON/CRZT/IXSTOR,IXDIV,IFENCE(2),LEV,LEVIN,BLVECT(LURCOR) DIMENSION LQ(999),IQ(999),Q(999) EQUIVALENCE (IQ(1),Q(1),LQ(9)),(LQ(1),LEV) * COMMON /USRLNK/LUSRK1,LUSRBK,LUSRLS * COMMON /QUEST/IQUEST(100) CHARACTER*8 THRONG +CDE,FATPARA. +CDE,FATBUG. EXTERNAL UROUT * * * Initialise ZEBRA * CALL MZEBRA(-3) CALL MZSTOR(IXSTOR,'/CRZT/','Q',IFENCE,LEV,BLVECT(1),BLVECT(1), + BLVECT(5000),BLVECT(LURCOR)) CALL MZLOGL(IXSTOR,-3) * * *** Define user division and link area like: * CALL MZDIV (IXSTOR, IXDIV, 'USERS', 50000, LURCOR, 'L') CALL MZLINK (IXSTOR, '/USRLNK/', LUSRK1, LUSRLS, LUSRK1) * * Units for FATMEN RZ/FZ files * LUNRZ = 1 LUNFZ = 2 CALL GETENVF('THRONG',THRONG) LTH = LENOCC(THRONG) * * Initialise FATMEN * CALL FMINIT(IXSTOR,LUNRZ,LUNFZ,'//CERN/'//THRONG(1:LTH),IRC) CALL FMLOGL(0) * * Initialise HBOOK * CALL HLIMIT(-20000) * * Book histograms * CALL HBOOK1(1,'File Size (MB)',50,0.,200.,0.) CALL HBOOK1(2,'Number of accesses',50,0.,50.,0.) CALL HBOOK1(3,'Number days since last access',50,0.,300.,0.) CALL HBOOK1(4,'Number days since catalogued',50,0.,300.,0.) CALL HBOOK1(5,'Number days since created',50,0.,300.,0.) CALL HBOOK1(6,'Medium',5,0.,5.,0.) CALL HIDOPT(0,'BLAC') * * Loop over all files * CALL FMLOOP('//CERN/*/*',-1,UROUT,IRC) * * Print and store the histograms * CALL HPRINT(0) CALL HRPUT(0,'FATTUPLE.'//THRONG(1:LTH),'N') * * Terminate cleanly * CALL FMEND(IRC) END SUBROUTINE UROUT(PATH,KEYS,IRC) +CDE,FATPARA. PARAMETER (LURCOR=200000) COMMON/CRZT/IXSTOR,IXDIV,IFENCE(2),LEV,LEVIN,BLVECT(LURCOR) DIMENSION LQ(999),IQ(999),Q(999) EQUIVALENCE (IQ(1),Q(1),LQ(9)),(LQ(1),LEV) CHARACTER*(*) PATH PARAMETER (LKEYFA=10) DIMENSION KEYS(LKEYFA) DIMENSION NDAYS(3) COMMON/QUEST/IQUEST(100) IRC = 0 LBANK = 0 LP = LENOCC(PATH) CALL FMGETK(PATH(1:LP),LBANK,KEYS,IRC) * * Fill histograms * IF(IQ(LBANK+MFSZFA).NE.0) +CALL HFILL(1,FLOAT(IQ(LBANK+MFSZFA)),0.,1.) IF(IQ(LBANK+MUSCFA).NE.0) +CALL HFILL(2,FLOAT(IQ(LBANK+MUSCFA)),0.,1.) CALL FMDAYS(PATH(1:LP),LBANK,KEYS,NDAYS,' ',IRC) CALL HFILL(3,FLOAT(NDAYS(3)),0.,1.) CALL HFILL(4,FLOAT(NDAYS(2)),0.,1.) CALL HFILL(5,FLOAT(NDAYS(1)),0.,1.) CALL HFILL(6,FLOAT(IQ(LBANK+MMTPFA)),0.,1.) CALL MZDROP(IXSTOR,LBANK,' ') END