From 6670245b5dc26db183a21f5d599d01868f70fc9b Mon Sep 17 00:00:00 2001 From: Kimoon Han <98246499+kmnhan@users.noreply.github.com> Date: Mon, 10 Jul 2023 16:05:50 +0900 Subject: [PATCH 1/3] feat(packed): enable specifying initial byte order --- igor2/packed.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/igor2/packed.py b/igor2/packed.py index 15c8cdf..caf413a 100644 --- a/igor2/packed.py +++ b/igor2/packed.py @@ -43,7 +43,7 @@ # a later record in the packed file. -def load(filename, strict=True, ignore_unknown=True): +def load(filename, strict=True, ignore_unknown=True, initial_byte_order=None): logger.debug('loading a packed experiment file from {}'.format(filename)) records = [] if hasattr(filename, 'read'): @@ -51,7 +51,8 @@ def load(filename, strict=True, ignore_unknown=True): else: f = open(filename, 'rb') byte_order = None - initial_byte_order = '=' + if initial_byte_order is None: + initial_byte_order = '=' try: while True: PackedFileRecordHeader.byte_order = initial_byte_order From 143f1277a1e5a1d9193529c97c3e5408d90e95d3 Mon Sep 17 00:00:00 2001 From: Kimoon Han <98246499+kmnhan@users.noreply.github.com> Date: Wed, 3 Apr 2024 23:27:09 +0900 Subject: [PATCH 2/3] docs: Add docstring to load() in packed.py --- igor2/packed.py | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/igor2/packed.py b/igor2/packed.py index caf413a..d41ffd1 100644 --- a/igor2/packed.py +++ b/igor2/packed.py @@ -44,6 +44,28 @@ def load(filename, strict=True, ignore_unknown=True, initial_byte_order=None): + """Load a packed experiment file. + + Parameters + ---------- + filename : str or file-like object + The path to the file or a file-like object representing the packed + experiment file. + strict : bool, optional + This parameter is ignored. Defaults to True. + ignore_unknown : bool, optional + If True, ignore unknown record types. Defaults to True. + initial_byte_order : str or None, optional + The initial byte order to use for unpacking. Must be one of '>', '=', + '<'. If None, '=' is used. Defaults to None. + + Returns + ------- + records : list of Record + The records in the packed experiment file. + filesystem : dict + The filesystem structure of the packed experiment file. + """ logger.debug('loading a packed experiment file from {}'.format(filename)) records = [] if hasattr(filename, 'read'): @@ -81,7 +103,8 @@ def load(filename, strict=True, ignore_unknown=True, initial_byte_order=None): data = bytes(f.read(header['numDataBytes'])) if len(data) < header['numDataBytes']: raise ValueError( - ('not enough data for the next record ({} < {})' + ('not enough data for the next record ({} < {}), ' + 'try loading with a different initial byte order' ).format(len(b), header['numDataBytes'])) record_type = _RECORD_TYPE.get( header['recordType'] & PACKEDRECTYPE_MASK, _UnknownRecord) From 025fb0f7af31383c6a8d5a1506a89c7942fcf335 Mon Sep 17 00:00:00 2001 From: Kimoon Han <98246499+kmnhan@users.noreply.github.com> Date: Wed, 3 Apr 2024 23:28:53 +0900 Subject: [PATCH 3/3] tests: add test for loading .pxt file with different byteorder --- tests/data/packed-byteorder.pxt | Bin 0 -> 13138 bytes tests/test_pxp.py | 23 +++++++++++++++++++++++ 2 files changed, 23 insertions(+) create mode 100755 tests/data/packed-byteorder.pxt diff --git a/tests/data/packed-byteorder.pxt b/tests/data/packed-byteorder.pxt new file mode 100755 index 0000000000000000000000000000000000000000..25fc43888234c2fca9a25d28b29e224955a51999 GIT binary patch literal 13138 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 literal 0 HcmV?d00001 diff --git a/tests/test_pxp.py b/tests/test_pxp.py index f779a1c..d1b3bf6 100644 --- a/tests/test_pxp.py +++ b/tests/test_pxp.py @@ -129,3 +129,26 @@ def test_pxp(): 28.72983551, 28.05199242, 29.29024887, 31.3501091, 32.7331543, 32.87995529, 32.28799438, 31.99738503], dtype=np.float32)) + + +def test_pxt(): + data = loadpxp(data_dir / 'packed-byteorder.pxt', initial_byte_order='>') + records = data[0] + assert len(records) == 2 + assert records[0].variables == {'version': 2, + 'variables': { + 'var_header': {'numSysVars': 0, + 'numUserVars': 0, + 'numUserStrs': 0, + 'numDependentVars': 0, + 'numDependentStrs': 0}, + 'sysVars': {}, + 'userVars': {}, + 'userStrs': {}, + 'dependentVars': [], + 'dependentStrs': []}} + assert np.allclose(records[1].wave['wave']["wData"][:30, 0], np.array( + [14603., 13701., 14907., 13795., 14339., 14942., 14984., 14261., + 12647., 14242., 14470., 13913., 14158., 14754., 14462., 14346., + 14219., 13467., 13595., 14331., 13960., 12934., 12897., 13557., + 13105., 12797., 13234., 13053., 13455., 12825.], dtype='>f8'))