Skip to content

Beam Status, Shutter, accelerator and moderator information

Freddie Akeroyd edited this page Dec 5, 2020 · 20 revisions

Wiki > Accelerator Information

Information about the beam current and instrument shutter status is stored in the main accelerator control computer system, though a shutter is local to an instrument it is part of a safety system and we do not have direct access to it ourselves. Also the accelerator computer system can only read main shutter status - opening/closing a main shutter can only be performed using a physical button in the cabin.

This information is fed from an IOC running on a machine on the accelerator network (merckx.isis.rl.ac.uk). This is a Open VMS machine with the EPICS distribution from here. The IOC is set to run on boot time and is auto-restarted if it is not present, it will also auto-restart if it receives too many errors, but some failures can cause it to hang.

You can log onto this machine using details on usual access page (you will need to use ssh via something like PuTTY)

The most likely cause of a problem is that the local database has stopped updating, thus giving an unchanging value. You can can check the server log file with:

cd beamlogdir
type isisbeam.log

And see if there are errors about parameters not updating. Probably easiest thing to do is to kill the service and let it restart, then see if errors continue in the log. First type:

pipe sh sys | sea sys$input isisbeam

you will see a line like

26E12DAA ISISBEAM        LEF      6   132040   0 00:00:01.40       284    241
26F991FC ISISBEAM_1      HIB      4  2416385   0 00:08:24.20      9589   3173 MS

[ISISBEAM_1 is a sub-process of ISISBEAM and will die when you kill ISISBEAM] The first number is the process id, in this case type

stop /id=26E12DAA

to kill it, then wait for it to restart (may take up to 30 seconds). Use the above pipe command to see then it has restarted, and then check isisbeam.log again. Look for messages after the Starting iocInit line in the file

more complicated details

The asyn parameters that are served by the IOC are mapped to VISTA parameters (this is the accelerator control system). You can see the mapping with:

type params.txt

a line like

beam_ions        float    t  0    IDTOR::IRT1:CURRENT

means asyn parameter beam_ions (in the IOC Db files) is mapped to VISTA parameter IDTOR::IRT1:CURRENT. The other columns are related to data type and how the programs tries to check for stale (non updating) values. If the isisbeam.log indicated a huge number of errors for a particular parameter, then this could affect reading other parameters - after a certain number of errors the program restarts, but if it starts restarting too frequently this can cause PVs never to reconnect properly. In that case you may need to temporarily remove a line, but seek advice first.

You can read the VISTA parameter directly on MERECKX if you think the issue is with the IOC e.g.

db_access IDTOR::IRT1:CURRENT
db_access t1shut::n1_overview:sta

you can search for errors about a particular parameter by e.g.

sea isisbeam.log IDTOR::IRT1:CURRENT

If you killed the ISISBEAM process above it has restarted, then the isisbeam.log file will only contain values since that restart. you can look at the previous log file by adding ;-1 to the file name

sea isisbeam.log;-1 IDTOR::IRT1:CURRENT

To see all log file versions type dir isisbeam.log

If something does appear to have gone wrong with this service (e.g. values are not updating) you should get in touch with the accelerator controls group. The easiest way to do this is to call the MCR and find out who is on call.

Value shows zero in IBEX/SECI but non-zero with db_access

If the third column in params.txt contains a z (e.g. tz) then this means that the parameter will be monitored for a stale (non updating) state and if this is detected it will send 0 as the value to IBEX/SECI. At time of writing this had only been requested for the decoupled methane, sending 0 when the value is uncertain means they will go into a WAITING state as they run control on methane temperature and it is important that they are not collecting data when a methane charge-change happens. In future the value could be EPICS alarmed, but for SECI instruments we need to send 0

You can confirm a value is not updating by running db_access on it a few times with a reasonable time delay inbetween. The methane moderator temperature for example would not be expected to remain exactly the same to two decimal places over an extended time period. You can view the typical value and variation in an accelerator parameter by following the links on values at http://beamlog.nd.rl.ac.uk/status.xml

Checking channel access on MERCKX

if you type

dir [--.db]

you will see all the db files used by the program, you can display one to screen using e.g.

type/page [--.db]isisbeam.db

On MERCKX $(P) is "" so there is no prefix to PVs you see listed. To use caget you first need to set an epics address list as broadcasts do not work (they require privileges). So type

def EPICS_CA_ADDR_LIST merckx

and then you can use caget on values e.g.

caget TG:TS2:DMOD:METH:TEMP

You can browse the Db file source on the web

Clone this wiki locally