Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improperly Reading Header #17

Open
BlueNalgene opened this issue Dec 22, 2021 · 1 comment
Open

Improperly Reading Header #17

BlueNalgene opened this issue Dec 22, 2021 · 1 comment

Comments

@BlueNalgene
Copy link

I had some high hopes for your code as a way to simplify OPUS processing while retaining Linux compatibility for large batch jobs, however I ran into a snag while testing the program. Spectragryph loads the files just fine, so there may be something silly the Python script is stumbling on. When I try to read a file from my instrument, Python kicks back a Key Error.

First, some housekeeping:

  • Python v3.8.10
  • brukeropusreader version: 1.3 (from pip3)
  • OS/Kernel: Ubuntu 20.04 focal/x86_64 Linux 5.11.0-40-generic
  • Bruker Hardware: EM-27/Sun

Example 1

This is the most basic example of the error encountered.

Minimal Working Failing Example:

from brukeropusreader import read_file
opus_data = read_file('211118_EM27-SUN_#155_BA.0000')

Error raised:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python3.8/dist-packages/brukeropusreader/opus_parser.py", line 23, in read_file
    opus_data = parse_data(data, meta_data)
  File "/usr/local/lib/python3.8/dist-packages/brukeropusreader/opus_parser.py", line 60, in parse_data
    name, parser = block_meta.get_name_and_parser()
  File "/usr/local/lib/python3.8/dist-packages/brukeropusreader/block_data.py", line 67, in get_name_and_parser
    return BLOCK_7[self.channel_type], parse_series
KeyError: 136

Example 2

Here, I dug through the code a bit to see what about the blocks is not behaving

Minimal Working Example:

import brukeropusreader
with open("211118_EM27-SUN_#155_BA.0000", 'rb') as infile:
     mydata = infile.read()
metas = brukeropusreader.opus_parser.parse_meta(mydata)
for i in metas:
     print(i.data_type)

Result:

0
96
64
48
7
23
7
7
23
7
0
23
23
160
32

As you can see, there are multiple block types that do not match your existing prototypes. Not accustomed to much Bruker data, I'm not sure if this is normal. However, the frequency of 0, 7, and 23 suggest that we have a reasonable cursor offset. This may be irrelevant to the BLOCK_7 key error I see, but it was an interesting observation. If most of OPUS code the author is used to seeing comes from more traditional benchtop instruments, the EM-27 may be introducing some strange new formats.

Reference Code

Binary data I used

https://www.dropbox.com/s/5jawojpjmboop0c/211118_EM27-SUN_%23155_BA.0000?dl=0

Hex dumped to plain text for your convenience

https://www.dropbox.com/s/vjwf0ibxlniptfz/tmp.xxd?dl=0

@bruno-grouiez
Copy link

Hello everyone,
Yes, the EM27/SUN have an extra detector channel which results in an extra interferogram block and Sc if the TF is used.

I identified them as blocks 33 and 34 but in this code I don't know why but there is a factor of 4 which means that they are identified as 132 (Ig) and 136 (Sc).

I've modified the original code in block_data.py like this so that I can read them:

BLOCK_7 = {4: ‘ScSm’, 8: ‘IgSm’, 12: ‘PhSm’, 132: ‘ScSm2’,136: ‘IgSm2’}

BLOCK_23 = {
4: ‘ScSm Data Parameter’,
8: ‘IgSm Data Parameter’,
12: ‘PhSm Data Parameter’,
132: ‘ScSm2 Data Parameter’,
136: ‘IgSm2 Data Parameter’
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants