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

Update ultralite data #504

Merged
merged 6 commits into from
Nov 26, 2024
Merged

Update ultralite data #504

merged 6 commits into from
Nov 26, 2024

Conversation

dlcaballero16
Copy link
Collaborator

@dlcaballero16 dlcaballero16 commented Nov 19, 2024

Description of work

This adds support to use ultralite data.

Explanation of work

The main change to snapred was to make reading of certain logs configurable, since saved nxs data would result in different log locations, compared to normal run data.

To test

Dev testing

To set SNAPRed up, first look at application.yml. In instrument.config, there are commented out fields. Uncomment these and comment out the corresponding fields above them. In the constants section, swap the logsLocation field.

Using workbench on analysis, load up the create_ultralite_data script. In the script, there are 2 places to look and change so it points to your specified location. The variable liteInstrumentFile towards the top and the FileName for the call to LoadDiffCal towards the middle of the script. LoadDiffCal needs to point to a normal(non ultralite) diffcal file. You are now ready to run the script. You can use the default run of 58882 or select multiple runs. Runs to reduce is defined on line 62. The ultralite versions will be saved in a folder called ultralite in your Documents folder.

To run the ultralite version, copy the run to your custom calibration location and make sure the run is renamed to "SNAP_runNumber". Please generate a new state folder.
THIS IS VERY IMPORTANT: modify the default grouping map (labeled as groupingMap.json) in the state folder so there are no lite versions. We currently do not support lite mode with ultralite data. Do not delete liteFocusGroups field entirely, just make sure it has no entries. In the native section, replace all native entries with just one entry named CRACKLE, and make it point to the CRACKLEFocGroup_Column.xml file.

For Diffraction Calibration, make ultralite runs for 46680 and 58882. In the ultralite data script, make sure eventMode is set to True. For the samples, use diamond for 46680 and Si for 58882. Be sure to turn off lite mode and select CRACKLE for the grouping. When you get to the tweak peaks tab, make FWHM Left = 1.0 and Max Chi Sq = 1000 and you should be able to complete.

For Normalization, convert runs 58810 and 58813 to ultralite and set eventMode to false. 58813 is the background run and use Vanadium as the sample. Remember to turn off lite mode!

For Reduction, just use 58882. Make sure lite mode is off.

CIS testing

See dev testing.

Link to EWM item

EWM#7792

Verification

  • the author has read the EWM story and acceptance critera
  • the reviewer has read the EWM story and acceptance criteria
  • the reviewer certifies the acceptance criteria below reflect the criteria in EWM

Acceptance Criteria

This list is for ease of reference, and does not replace reading the EWM story as part of the review. Verify this list matches the EWM story before reviewing.

  • Can complete DiffCal
  • Can complete Normalization
  • Can complete reduction

@dlcaballero16 dlcaballero16 marked this pull request as ready for review November 20, 2024 15:27
Copy link

codecov bot commented Nov 25, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 96.55%. Comparing base (1d7c1dd) to head (4896a12).
Report is 13 commits behind head on next.

Additional details and impacted files
@@           Coverage Diff            @@
##             next     #504    +/-   ##
========================================
  Coverage   96.54%   96.55%            
========================================
  Files          64       66     +2     
  Lines        4836     4960   +124     
========================================
+ Hits         4669     4789   +120     
- Misses        167      171     +4     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@darshdinger
Copy link
Contributor

Testing


  1. On analysis, with a clear local Calibration_next directory, run a DiffCal and NormCal for testing requirements:
    image
    image

NOTE: Residual fit does not show up on graph.

  1. Editing application.yml:
    image
    (and also edited the section above for config)

  2. Open create_ultralite_data script within workbench on analysis:
    image

  3. Edit my FileName:
    image

  4. UltraLite data creation successful (lite instrument on the left, and ultralite on the right):
    image

Copy link
Contributor

@darshdinger darshdinger left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tested and functional. :)

@dlcaballero16 dlcaballero16 merged commit c61cf12 into next Nov 26, 2024
8 checks passed
@dlcaballero16 dlcaballero16 deleted the update-ultralite-data branch November 26, 2024 14:19
rboston628 pushed a commit that referenced this pull request Dec 6, 2024
* Initial commit, trying things to get ultralite data working

* Cleaned up application.yml, added script and required files to run
ultralite data

* Undo changes and remove prints

* Make unit tests pass

* Added use of RemoveLogs to make run even smaller
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

Successfully merging this pull request may close these issues.

2 participants