-
Notifications
You must be signed in to change notification settings - Fork 2
FZJ_Fermi_chopper
This device has a relatively complex IOC due to some communication issues we have had with the chopper. The following things are non-standard:
- Custom checksum algorithm in stream device. This is specific to this style of fermi chopper.
-
aSub
record to parse a response string from the hardware. -
aSub
record to decide how to send the speed setpoint to the device -
aSub
record to decide whether a given command is allowed to be sent -
SNL
state machine to ensure that setpoints and their readbacks stay in sync (for both gate width and phase delay) - There is logic in the DB records to prevent sending a speed setpoint that is equal to the current speed setpoint readback.
- There is (equipment) safety logic in the IOC. For more details see below.
Depending on which specific fermi chopper system is being used, there are slight variations in the communications protocol of the choppers. The expected settings are:
Beamline |
INST macro |
MHZ macro |
Drive parameters |
---|---|---|---|
MERLIN | merlin | 50.4 | "Merlin small parameters" or "Merlin large parameters" (*) |
MARI | merlin (**) | 50.4 | "Merlin large parameters" (***) |
MAPS | maps | 18.0 | The controller on MAPS does not support changing parameters |
(*) I believe this choice depends on which physical rotor is installed into the chopper
(**) The controller on MARI is identical to MERLIN's from a communications perspective - hence re-using merlin's communications code.
(***) I believe the "HET/MARI" parameters refer to a very old version of the hardware, before the chopper was upgraded to be more like Merlin's. Chopper group may be able to give a more definitive answer.
The logs for the fermi chopper are kept in C:\Instrument\var\logs\ioc\FERMCHOP_01-<date>
. These logs contain the following information:
- All commands that are used to start the driver. Whenever the driver first starts, there will be a large block of
epicsEnvSet
commands. The startup process is finished when anepics>
prompt comes up in the log (there will be lots of commands in between - these can be ignored) - Communication conditions and problems, for example unexpected replies from the chopper. These messages may include parts of the raw (hexadecimal) response from the chopper.
- Information about the chopper state (e.g. interlock statuses, temperatures out of range) when they transition between valid/invalid states. These messages are prefixed with
Chopper status:
- Information about actions that the driver is taking to ensure the settings stay correct. There is a state machine that detects when the chopper forgets it's settings and resends the correct settings. These messages are prefixed with
Keep SP and RBV in sync
. - Messages regarding whether certain commands were accepted by the driver. These messages are prefixed with
commandCheck
. The driver will reject commands (and print a message in the log) if:- The user attempts to spin up the chopper with the bearings off
- The user attempts to resend a "spin-up" command while the chopper is set and spinning at 600Hz. This is a mitigation for the 600Hz issue experienced on Merlin, details further down this page.
- The user attempts to switch off the magnetic bearings while the actual chopper speed is >10Hz.
- When the driver sends a command successfully, it will also print a message in the log with the numeric command that it has send. The translation for these numeric commands is
- 1: Switch drive on/stop mode
- 2: Switch drive off
- 3: Switch drive on/run mode
- 4: Switch magnetic bearings on
- 5: Switch magnetic bearings off
- 6: Use MERLIN large chopper parameters
- 7: Use MARI chopper parameters
- 8: Use MERLIN small chopper parameters
The delay setpoint can be wrong if the high byte and low byte of the setpoint are received in the wrong order. The observed behaviour in this state is that the setpoint readback will appear to be correct, but the actual delay will home in on a different (incorrect) value. Resending the delay setpoint in the correct order fixes this state.
This problem has been solved by defining the order of the packets in the stream device protocol, including an appropriate wait between them. For more details, see #2628.
Occasionally the device will get confused and reset its gate width to a semi-random value. Resending the gate width causes it to pick up the correct value again. This problem is mitigated in the driver by having a state machine which keeps the gate width and gate width readback in sync.
Sometimes the chopper crate simply ignores a setpoint which was sent. Unfortunately the crate does not respond to a set command so we can't tell if there was a comms error. This problem is mitigated in the driver by having state machines which keep the setpoints and their readbacks in sync for gate width, phase delay and chopper speed.
Additionally, the chopper speed is now put under run control as part of Merlin's set_ei
script to make it more obvious if the chopper speed isn't in the expected range.
At 600Hz, the chopper exhibits strange behaviour:
- If the speed setpoint is already 600Hz and a speed setpoint of 600Hz is resent, the chopper gets confused. The phase delay will appear to be zero forever. To get out of this state, need to send a different setpoint, wait for the actual device speed to drop (e.g. to 599Hz), and then 600Hz can be set successfully. This problem is mitigated in the driver by not sending a speed setpoint which is equal to the current speed setpoint readback.
- If the device is at 600Hz and already spinning, sending the "switch drive on and run" command causes the same bug as above. This problem is mitigated in the driver by disallowing the "switch drive on and run" command from being sent if the chopper speed is >595Hz and the setpoint readback is 600Hz and the drive generator is already on.
For more details, see #2741
The phase delay of the chopper is a delay between the synchrotron pulse and the the chopper being in a specific position. If the synchrotron is not running the delay will appear to fluctuate wildly as there is no reference synchrotron pulse. This should rectify itself without intervention and the chopper will re-phase once the synchrotron timing pulse comes back online.
Occasionally the chopper will get into a state where it can't phase correctly. The symptom is that the phase readback fluctuates wildly and never settles on the phase setpoint. We are unsure of the root cause. Sending the chopper to a different speed setpoint and then back to the original setpoint seems to let the chopper phase correctly.
When plotting the phase using the instrument archive, you may see a "beating" pattern like below. Here the amplitude of the oscillation is ~30us, a typical phase window would be ~10us so this will result in the DAE vetoing a percentage of frames based on the chopper being "out of phase" at that time.
There are a variety of hardware & software conditions that can cause the chopper to spin down.
Firstly, check in the "advanced" tab of the OPI - any of the following will cause the device to spin down:
- Interlock open (the scientists know how to reset this)
- Note, the interlock only has to report "open" for a moment for the chopper to spin down. If the vacuum gauge is faulty, it may trip the interlock momentarily, which will cause the chopper to spin down but when subsequently looking at the OPI the interlock will appear OK. If this is the case then contact the chopper group as this is a hardware fault and is not something we can compensate for in software.
- Electronics or motor temperatures too hot (not sure where the firmware limit is - may be 50C according to manual but this is not clear)
- A few other (less common) conditions indicated by red interlock LEDs on the OPI
There are (equipment) safety checks in the IOC which will cause the IOC to request a spin down. Hitting any of these conditions will cause a message to be logged containing the words this will cause the chopper to spin down
- this can be searched for in the log file if it is believed that the IBEX driver has caused the chopper to spin down.
- If the electronics temperatures or motor temperatures go above 45 Celsius.
- Electronics overheats occur somewhat frequently on Merlin, especially during hot weather.
- Need to wait for create to cool sufficiently and then spin the chopper back up as normal.
- Instrument scientists aware of this and know how to reset it.
- If the auto zero voltages are out of range (absolute value higher than 3 volts)
- If the actual chopper speed is above 606Hz
- If the magnetic bearing is off while the chopper is at speed
An issue was seen when first commissioning the MAPS fermi under EPICS. Symptoms were very odd:
- Cannot communicate using VISA nor Asyn under EPICS
- If chopper crate and instrument PC are power cycled, may need to run labview driver once before epics can talk. We are still not sure why this is.
- If EPICS+Visa is subsequently run, it will upset the comms and will need to run the labview to "clear" the error
On MAPS, the crate's communications layer can fail, causing the device to ignore the standard polling command (#0000000$
). To recover from this state, send the shortened command 0$
repeatedly until you get a response. The IOC should automatically do this whenever it detects no response to the standard command.
There is logic in the IOC to prevent sending commands which would put the chopper into a disallowed state. For example, it is not permitted to send "switch drive on and run" if the magnetic bearings are off. Check the IOC log - there should be entries saying either "...sending command to device..." or "...refusing to send command to device...".
Ask DAE experts to unplug and re-plug in the veto cable.
If you are getting a fluctuating fermi chopper veto, e.g. it is vetoing 50% of frames, it may be because the phase is fluctuating in and out of range. See section above about delay fluctuating for possible resolutions.
The set_ei
script (at least on Merlin) puts the chopper under run control. If a config is reloaded then these settings will be lost. To recover, simply re-run set_ei
.