mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-06-18 07:47:12 +02:00
* added empty c extension * added rotation to the decoding * added color map, options and findex * minor * move checks to before acquisition * added pixel map based decoder * cleanup * no thread creation for single thread processing * added rotation and test to compare * allow high and low water mark for zmq (also buffer size) for fast readouts * removed roatation during decoding * added Transpose to image and invert Y False to invert it * retains the zoomed state after the first image of gui, catch and display exception if no detector connected * moved start frame to dockable widget, removed extra frame number label, moved current measurement also to dockable widget, hide frame plot entirely when showing patternviewer * first image dependin on which plot * remember settings of main window size and position, dockewidget if docked, its size and posisiotn as well, then update it next time the gui is opened * change in comment * using c decoder for moench 04 and matterhorn * catch exception from invalid image from decoder * clean up * update row and col when choosing image type, neeeded to show values * fix for previous PR * disable resetting colormap values keep the range selected for every new acquisition * fix typos + tested on virtual matterhorn * minor print * refactored Slow ADCs Tab * refactored DAC tab * refactored power supplies * refactored signals tab * refactored transceiver tab * fix typo * fix typo2 * remove commented code * delete commented code * delete commented code * delete commented signals code * remove commented code for transceiver tab * refactor adc tab * refactor Pattern Tab * Refactor transceivers tab (PR#5) (#118) * refactored transceiver tab * remove commented code for transceiver tab --------- Co-authored-by: Erik Frojdh <erik.frojdh@gmail.com> * refactor adc tab (PR#6) (#119) * refactor adc tab * refactored Plot and Acquisition Tabs * fix the regression issue * restructure project files * applying singleton and renaming tabs to services * working install using pip * applies singleton to tab classes and remove CI erros * added pyzmq and pillow * remove the singleton implementation and keep changes * fix merge errors in mainWindow * moved misplaced init file * rename service to tab * reorganize imports * iterate over tabs * reorder tabs * add slowadc to the list * saving changes (buggy) power supply ui not showing in the gui * split power supply tab * fixed tests * add hardcoded values to defines file * fix error * separate power supply * fix errors for powerSuppliesTab * split dacs * split slow adcs * split signals tab * added tests for bit_utils * add slowAdc class to defines * split transceiver ui file * split adc.ui * split pattern ui file * split plot and acquisition ui file * added basic test for parsing bit names * removed redundant code in read_alias_file * fix dacs ui position * testing for correct exception * cmd and args at split * group radio buttons * fix comments from PR#1 * show legend * added python version and dev requirements to setup.py * fix dac issue * moved _decoder into pkg * added inplace build * removed clear * fixed dependencies * make tests run without slsdet * updated name of action * define colcount * fixed loading of alias file * add yapf and ruff * apply formatting * fix E and F rules * add more ruff rules * change variable name * squashing gh debugging commits and add pre-commit * update label values to mv units * add hook for yapf * reconfigure yapf precommit hook * add format and check_format to makefile * change gh actions * update readme * added check_format * WIP * added linting in github action * updated readme] * add more control for color choice * remove useless file * fix un-updated line after refactoring Defines BIT0_31_MASK is not found in Defines.signals * visually improve the interface * fix last commit * add only selected plots for legend * add hide legend button * change hide legend to show legend checkbox show legend is checked by default * add support for saving in numpy * solve conversations * fix acq index offset * fix browse button in pattern error * fix other browse button errors * finish tests and add usage.md * remove buffer * add file,numpy-like interface and tests * remove useless .npy files * subscriptible npz files * remove useless files * remove repetetive tests * save changes * add mode r+, add with support,remove logging * remove offset of acqIndex between raw and numpy saving * fix only saving last frame * save signals of multiple devices * add comments and move condition for clearer code * fix bug when vieweing pattern file * iterate over enabled and plotted plots * add padestal substraction to transceiver and analog data * init pedestal frames to detector.frames * restore old exception * add pedestal substraction for digital signals * remove frames spinbox from plotTab * remove comments and use str instead of Path * avoid saving all frames * correct exception and log error's trace * add gui tests * add waveform test * add pedestal test * refactor by using fixtures * add tests for moench analog and pattern * add pytest-qt to dependencies * add save and load gui parameters * remove nohup file * fix old bug IndexError * save plot type * a * handle canceling load, loading matterhorn pedestal for moench * remove comparing .png files for pattern test * save plot type * red error on status bar when shape mismatch for loaded pedestal * fix makefile and docstrings * fix PRs conversation * move code into different function * fix wrong function names for power supply * removed old ctbgui * removed unnecessary files --------- Co-authored-by: Erik Frojdh <erik.frojdh@gmail.com> Co-authored-by: Braham Bechir <braham_b@pc11979.psi.ch> Co-authored-by: Bechir <bechir.braham@psi.ch> Co-authored-by: Bechir <bechir.brahem420@gmail.com>
71 lines
2.9 KiB
Markdown
71 lines
2.9 KiB
Markdown
# Using numpyWriter module
|
|
## concept
|
|
numpyWriter is used to write and load huge numpy arrays that can't be fully loaded in RAM.
|
|
It is designed to write frames of a constant shape (defined by user) and incrementally add to .npy and .npz files without accessing all of its contents
|
|
|
|
### NumpyFileManager
|
|
class to handle writing in .npy files frame by frame.
|
|
its positional parameter `file` can be of type: str,pathlib.Path, zipfile.ZipExtFile. This way we can use NumpyFileManager to open files by getting their path or
|
|
**in read mode** it can receiver file-like objects to read their data.
|
|
|
|
the complexity of initializing from file-like objects is added to be able to read from .npz files which are simply a zip of .npy files. Furthermore now we can save our files .npz files and read from them (even when compressed (⊙_⊙) ) without loading the whole .npy or .npz in memory.
|
|
|
|
### NpzFileWriter
|
|
class used to handle .npz file functionalities. it can zip existing .npy files, write a whole array in an .npz file without loading the whole .npz in memory,
|
|
and read frames from .npy files inside the .npz file
|
|
|
|
## Usage
|
|
|
|
```python
|
|
# create .npy file
|
|
npw = NumpyFileManager('file.npy', 'w', (400, 400), np.int32)
|
|
npw.addFrame(np.ones([400, 400], dtype=np.int32))
|
|
npw.close()
|
|
|
|
# read frames from existing .npy file
|
|
npw = NumpyFileManager('file.npy')
|
|
# if arr is stored in the .npy file this statement will return arr[50:100]
|
|
npw.readFrames(50, 100)
|
|
|
|
# Numpy like interface
|
|
# NumpyFileManager is also subscriptable
|
|
npw[50:100] # returns the array arr[50:100]
|
|
npw[0] # returns the array arr[0]
|
|
|
|
# File like interface
|
|
# the npw class's cursors is initialized on the first frame
|
|
npw.read(5) # reads five frames and updates the cursor
|
|
npw.seek(99) # updates the cursor to point it to the 99-th frame
|
|
|
|
# to ensure that files are written to disk
|
|
npw.flush()
|
|
|
|
# zip existing .npy files (stored on disk)
|
|
# filePaths: the paths to .npy files
|
|
# keys: name of the arrays inside of the .npz file
|
|
NpzFileWriter.zipNpyFiles('file.npz', filePaths, keys, compressed=True)
|
|
|
|
# add numpy arrays incrementally to a .npz file
|
|
with NpzFileWriter('tmp.npz', 'w', compress_file=True) as npz:
|
|
npz.writeArray('adc', arr1)
|
|
npz.writeArray('tx', arr2)
|
|
|
|
# read frames from adc.npy inside of tmp.npz
|
|
with NpzFileWriter('tmp.npz', 'r') as npz:
|
|
frames = npz.readFrames('adc', 5, 8)
|
|
|
|
# NpzFileWriter is also subscriptable and returns a NumpyFileManager initialized
|
|
# to open the the file with the given key inside the .npz file
|
|
npz = NpzFileWriter('tmp.npz', 'r')
|
|
npz.writeArray('adc', arr1)
|
|
|
|
|
|
npz['adc'] # returns a NumpyFileManager
|
|
npz['adc'][50:100] # returns the array from 50 to 100
|
|
# note once a NumpyFileManager instance is created internally NpzFileWriter stores it
|
|
# this is done to avoid opening and closing the same file
|
|
# also file-like interface can be used
|
|
npz['adc'].read(5) # returns arr[:5]
|
|
npz['adc'].seek(100) # updates the cursor
|
|
npz['adc'].read(2) # returns arr[100:2]
|
|
``` |