Logging from the archive - ISISComputingGroup/ibex_developers_manual GitHub Wiki
An IOC can be made to log PV values to a file based on the value of a trigger PV. Consider whether your IOC needs to do this.
To add logging to an IOC you need to add certain info fields to its records. The logging is based on a trigger PV. There are currently two versions of the logging which run simultaneously.
- Continuous logging which writes values to the file in regular intervals as long as the PV is on
- On End logging, which when the trigger PV switches off (1 to 0) will write the log for the period for which it was on into the file.
There are two because I am concerned that the continuous logger may miss values if they arrive at the database late; at some point this should be checked out and maybe the on end logging removed or made optional. The logging files will appear in c:\logs\<ioc name>\<ioc name>_<logging start date-time><_continuous if continuous>.dat
To define what is in the log file add an info field of the form:
info(<info field name>, <value>)
In the <value> section, the string this_pv
will always be substituted with the PV name of the record this info field belongs to.
For the changes to logging to take effect you must have built and run the IOC and then restarted the archiver access process. If you have changed or added the archive log rate then the instrument archiver (ARINST) must have been restarted since the IOC was run.
There is some trouble shooting information.
For a PV to appear either in a header line or a column, or for it to trigger a log the PV must be archived. The rate of archive must be at least as small as the maximum scan period; otherwise values might be missed. To add it to the archive use the usual notion (see finishing touches ).
Example: PV changing a maximum of once every 0.1s use info(archive, "0.1 VAL")
Many fields accept a formatted PV value this is written as follows:
`{pvname[!converter][|format]}`
This is similar to the python format and using the same syntax except the variable name is replaced with the pvname and the colon is replaced with a pipe. The converter and format are both options. The converter will allow you to perform a conversion this is either s
from string representation, r
from representation (rep). The format are as the python formatter (see python docs). Examples:
-
{this_pv}
- is the pv of the current record -
{IN:LARMOR:SIMPLE:VALUE1|10.6f}
- the pvIN:LARMOR:SIMPLE:VALUE1
is formatted as a float with 10 character and 6dp -
{this_pv!s|10s}
- the current PV converted using the string representation and then given a width of 10
The trigger PV indicates which PV turns logging on (PV value 1) and off (PV value 0). When the PV goes from 0 to 1 it triggers log creation. Only one of these should be defined, if you define two then last one into the database wins.
The value of the field is either:
-
""
(empty string) - use the PV this is annotating as the trigger PV -
"<pvname>"
- use the pv name as the trigger
Example:
record(bi, "$(P)LOGGING")
{
field(DESC, "Set logging")
field(ZNAM, "Off")
field(ONAM, "On")
field(PINI, "YES")
field(VAL "0")
info(archive, "1 VAL")
info(LOG_trigger, "")
}
If you want header lines in your log then use this field. Header lines are ordered alphanumerically by the X; X values 1-9 probably make most sense.
The value of the field is the header you want in the file. An empty value will produce a blank line. If you include a PV value it will be the value that PV had when the logging starts. To add a PV use the standard PV format.
Example: info(LOG_header1, "Temperature {this_pv|10.6f}")
First header line is "Temperature XXX" where XXX is the PV that the field is in format as float with 10 width and 6dp
The main part of the log are columns with data. Each column can have its own header and this is specified with the LOG_column_headerX annotation. Its value is the text that will be used as the column header. If there is no header field but a template field (see below) then the value from the template is used; if the template is blank, the PV of this record is used. There should not be more than one header for each column X, if there are then one will win.
Example: info(LOG_column_header1, "Temperature (K)")
produces a header of "Temperature (K)" for column 1
NB See archive setting
The main part of the log are columns with data. Each column can have its own template and this is specified with the LOG_column_templateX annotation. The value of the template is a formatted PV value that will be used as the column data. If there is no template (just a header) or it is blank then the default is the PV name in which the header record or template record occur. There should not be more than one template for each column X, if there are then one will win.
Example: info(LOG_column_template1, "{this_pv|10.6f}")
produces a column of floats for the current records PV.
NB See archive setting
The period of the log is set using the LOG_period_seconds info field. It sets the time period between lines in the table in seconds. It should be noted that if the PV is not changing more often than the value then the value will not change more often. This is an alternative to LOG_period_pv
.
Example: info(LOG_period_seconds, "0.5")
produces a time series in half second intervals.
The period of the log can be set based on the value of a PV when the logging is started. This allows the IOC to control the period of the log. The value is the PV that is being used to set the logging period if it is blank the current record is used. It should be noted that if the PV is not changing more often than the value then the value will not change more often. This is an alternative to LOG_period_seconds
.
Examples:
- info(LOG_period_pv, "TE:INST:SIMPLE:PERIOD")
produces a time series with an interval set by the PV
TE:INST:SIMPLE:PERIOD.
- info(LOG_period_pv, "")
produces a time series with an interval set by the PV record containing this