Millepede-II V04-17-03
|
Read millepede binary file and print records. More...
Go to the source code of this file.
Namespaces | |
namespace | readMilleBinary |
Functions | |
def | readMilleBinary.unpack (typechar, number=1) |
Variables | |
readMilleBinary.parser | |
readMilleBinary.choices | |
readMilleBinary.default | |
readMilleBinary.help | |
readMilleBinary.type | |
readMilleBinary.int | |
readMilleBinary.action | |
readMilleBinary.arg = parser.parse_args() | |
int | readMilleBinary.Cfiles = -1 |
int | readMilleBinary.CFiles = 1 |
readMilleBinary.f = open(arg.filename, "rb") | |
readMilleBinary.header_words = struct.unpack('ii', f.read(8)) | |
int | readMilleBinary.nrec = 0 |
int | readMilleBinary.nr = 0 |
def | readMilleBinary.lenf = struct.unpack('i', f.read(4)) |
def | readMilleBinary.length = unpack('i') |
string | readMilleBinary.floattype = 'f' |
def | readMilleBinary.glder = unpack(floattype, nr) |
def | readMilleBinary.inder = unpack('i', nr) |
int | readMilleBinary.i = 0 |
int | readMilleBinary.nh = 0 |
int | readMilleBinary.ja = 0 |
int | readMilleBinary.jb = 0 |
int | readMilleBinary.jsp = 0 |
int | readMilleBinary.nsp = 0 |
list | readMilleBinary.lab = [] |
list | readMilleBinary.val = [] |
Read millepede binary file and print records.
Use the -h
or --help
command options to print out the full list of options. Here are a few helpful examples for what this script is helpful for.
Select a Few Tracks:
You can look at specific tracks by changing the number of records to print and the number of records to skip before starting to print. Perhaps, you know that the 100'th track is "bad" for some reason, then you could look at it and its neighbors with
./readMilleBinary.py –num_records 3 –skip-records 99 input.bin
Check Format:
You can check the format of a mille data file by running over all the records and keeping the printout quiet.
./readMilleBinary.py –num-records -1 –quiet input.bin
If the format is correct, it will just printout the number of records and have an exit status of 0. If it is incorrect, it will print an error and have an non-zero exist status. Warning: The binary format cannot by itself distinguish between a file that has been broken at a record boundary and one that has successfully been closed correctly. For this reason, more thorough testing will be needed by the user if they wish to eliminate this possibility.
Description of the output from readMilleBinary.py
'==='
followed by record number and length (<0 for binary files containing doubles)'-g-'
followed by measurement number, first global label, number of local and global derivatives, measurement value and error. The next lines contain local and global labels (array('i')) and derivatives (array('f') or array('d')).'-l-'
followed by measurement number, first local label, number of local and global derivatives, measurement value and error. The next lines contain local labels (array('i')) and derivatives (array('f') or array('d')).Tested with SL4, SL5, SL6
Used containers to manually test Python 2.7.18 and Python 3.11.2
distrobox create -i python:2 -n py2
distrobox enter py2
One can check how this performs against a corrupted mille data file by using dd
to intentionally only copy the first N bytes of a file.
dd count=10 if=uncorrupted.bin of=corrupted.bin
will work if 'uncorrupted.bin' is greater than 512*10 bytes large.
Definition in file readMilleBinary.py.