Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Major Upgrades & Projects

TaskApplication/areaPerson(s) ResponsibleStatusPriorityNotesGitHub/CATER/etc
  •  Bmad live model
    •  BmadLiveModel 
    •  python PVA service
    •  GUI conversion
GlobalBuschmannWIP1

Lattice files for Bmad already exist. Current high-level goals are:

  • Establish agreement with Lucretia (S2E et al)
  • Implement interface to live machine parameters (Buschmann)
  • Add Bmad model to python PVA server
  • (TBD) Convert GUIs
    • Depends on tao→matlab compatibility
    • alternative: PyTao would let us rejoin the LCLS shared application ecosystem in some areas (emittance GUI, wires)
  • Update 08/06/24:  development of BmadLiveModel and server infrastructure is underway. 
    • long term plan is to migrate apps to python, in-line with AD LFD diagnostics group
    • python model interface makes sharing apps with LCLS easier
  • Update 08/22/2024: first real-time test successful, live model cold-start is ~3-15s, single-device update response is O(10ms)
  • Update 08/26/24: v0.1 non-stable released to production. Added "official" API documentation: https://f2-live-model.readthedocs.io/en/latest/
  • Update 08/29/24: PVA server tested successfully
  • Update 09/06/24: alpha BmadLiveModel & PVA server deployed to production, server running 24/7 for the time being to stress test
  • Update 09/29/24: Added LEM, split server into two processes
  • Update 10/9/24: heartbeats are setup, server is deployed 24/7

design page: Bmad live modeling

Github: https://github.com/slaclab/F2_live_model

  •  
LEM server + watcher conversion
  •  server
  •  GUI
LEM
  •  live dispersion GUI
1
  • LCLS dispersion live is, in principle, adaptable to this task. However the complication of needing to read both SLC buffer data and EPICS BSA buffers might make a new implementation simpler
  • Update 10/9/24: SLC buffacq is disruptive, need to strategize... EPICs-only live dispersion can be done simply w/ RTBSA tools
  •  New Phase scan GUI
    •  L0 phase scan automation
Phase ScansBuschmannDONE2

rudimentary functionality, needs with-beam test

update 05/06/24: tested with beam L0, L1 and L2-3 are working, deployment soon...

  • New longitudinal feedbacks
    •  DL10 energy
    •  BC11 energy
    •  BC11 bunch length
    •  BC14 energy
    •  BC14 bunch length
    •  BC20 energy
FeedbacksBuschmannWIP
2

Waiting on model server deployment

  • 3/13/24: current plan is to deploy a second PVA server that writes LEM EREF/EACT/BDES etc to an NTTTable, then the ModelReceiver can be updated in-kind to provide those quantities
    • python PVA will make it straightforward to build a LEM CUD
  • Update 08/06/24: LEM will run using the Bmad model
  • Update 09/10/24: prototyping, will run as a component of the BmadLiveModel
  • Update 09/29/24: server part is done, trim code WIP
  • Update 10/9/24: ready to test GUI with-beam

Full design notes on Bmad live model page

Github: https://github.com/slaclab/F2_LEM_GUI

  •  New longitudinal feedbacks
    •  DL10 energy
    •  BC11 energy
    •  BC11 bunch length
    •  BC14 energy
    •  BC14 bunch length
    •  BC20 energy
FeedbacksBuschmann1
  • Current feedbacks regulate poorly and are not easily tuned/maintained
    • overall goal: improve overall beam stability, reduce feedback convergence times
  • LCLS-SC energy feedbacks are designed with off-the-shelf PID libraries, and written in python, plan is to implement the same
  • (from a controls perspective) this is straightforward since through BC11 everything is in EPICS
  • SLC device control can be accomplished through python PVA libraries, though this will take some research on RPC usage
  • deployment plan:
    • replace feedbacks one-by-one, i.e. run a new DL10 energy feedback, then use preexisting feedbacks downstream
  •  RTBSA for FACET-II
    •  python class for streaming BSA data
    •  python class for real-time BSA time series & correlation plots
    •  GUI
BSABuschmannWIP2
  • 07/05/2024: Developed proof-of-concept GUI using lcls BSA PVs - works for us as well since our BSA encodes pulse IDs the same way. Corr plot with fitting, time series and FFT are all working.
    • still need to optimize syncing for network performance
    • likely can replace the current RTBSA GUI for lcls as well
  • Update 10/9/24: some sync errors to debug, but basic functionality is OK
  • Update 10/11/24: released to prod, added to physics apps page (labeled as "experimental" for now)
1
  • Current feedbacks regulate poorly and are not easily tuned/maintained
    • overall goal: improve overall beam stability, reduce feedback convergence times
  • LCLS-SC energy feedbacks are designed with off-the-shelf PID libraries, and written in python, plan is to implement the same
  • (from a controls perspective) this is straightforward since through BC11 everything is in EPICS
  • SLC device control can be accomplished through python PVA libraries, though this will take some research on RPC usage
  • deployment plan:
    • replace feedbacks one-by-one, i.e. run a new DL10 energy feedback, then use preexisting feedbacks downstream
  • Update 11/4/24: code WIP

  •  RTBSA for FACET-II
    •  python class for streaming BSA data
    •  python class for real-time BSA time series & correlation plots
    •  GUI
BSABuschmannWIP2
  • 07/05/2024: Developed proof-of-concept GUI using lcls BSA PVs - works for us as well since our BSA encodes pulse IDs the same way. Corr plot with fitting, time series and FFT are all working.
    • still need to optimize syncing for network performance
    • likely can replace the current RTBSA GUI for lcls as well
  • Update 10/9/24: some sync errors to debug, but basic functionality is OK
  • Update 10/11/24: released to prod, added to physics apps page (labeled as "experimental" for now)

  •  dispersion GUI



2
  • LCLS dispersion live is, in principle, adaptable to this task. However the complication of needing to read both SLC buffer data and EPICS BSA buffers might make a new implementation simpler
  • Update 10/9/24: SLC buffacq is disruptive, need to strategize... EPICs-only live dispersion can be done simply w/ RTBSA tools
  • Update 11/4/24: should implement a non-live Bmad-based measurement tool

  •  New Phase scan GUI
    •  L0 phase scan automation
Phase ScansBuschmannDONE2

rudimentary functionality, needs with-beam test

update 05/06/24: tested with beam L0, L1 and L2-3 are working, deployment soon...

https://github.com/slaclab/facet-matlabTNG/pull/4
  •  LEM server + watcher conversion
    •  server
    •  GUI
LEMBuschmannDONE2

Waiting on model server deployment

  • 3/13/24: current plan is to deploy a second PVA server that writes LEM EREF/EACT/BDES etc to an NTTTable, then the ModelReceiver can be updated in-kind to provide those quantities
    • python PVA will make it straightforward to build a LEM CUD
  • Update 08/06/24: LEM will run using the Bmad model
  • Update 09/10/24: prototyping, will run as a component of the BmadLiveModel
  • Update 09/29/24: server part is done, trim code WIP
  • Update 10/9/24: ready to test GUI with-beam
  • Update 11/4/24: verified with beam, deployed


Full design notes on Bmad live model page

Github:

https://github.com/slaclab/

facet-matlabTNG/pull/4

F2_LEM_GUI

  •  Add quad scan emittance measurement function (for L0)
Optics MatchingPerezDROP3

last step needed to migrate off of the LCLS-side emittance application. seems to be already partially implemented, so the challenge here is partially archeological in nature

Update 09/29/24: should put this on hiatus pending migration back to LCLS app


  •  Lucretia model server conversion
    •  python PVA service
    •  matlab interface class
    •  GUI conversion
GlobalCesar, Perez, Buschmann
Paused
DROP3

UPDATE: 08/06/24: Lucretia is being deprecated. The lack of Lucretia resources, both (written and in-person know how), and the poor maintainability of F2_LiveModelApp makes this a suboptimal time investment, especially since the desire was simply for apps to be more performant.

  • The F2_ModelReceiver is still usable as a matlab interface to the model server
  • Existing matlabTNG apps and the Lucretia model will remain in use, but with life-support only
  • physics apps will be ported to python over time (help wanted)
  • improved matlab app performance (from the control room) can be achieved with Glen's matlab server
  • 1/12/24: demo PVA server works, writing live/design Rs and twiss params, but matlab pvaGet not working yet. next step: document lucretia dependencies across matlabTNG to determine what the matlab interface needs to do
  • 1/23/24: matlab PVA access works with a python workaround (good enough for now, likely need a better long-term solution) Cesar prepped draft interface design document. reviewed high-priority GUI model uses. 
  • 2/8/24: PVA server is running but not deployed to prod yet. Drafting implementation of matlab class F2_ModelReceiver - once the lucretia functions GetRmats, RmatAtoB and GetTwiss are replicated we can proceed to test GUIs. Need to check w/ controls deputes to get some watcher PVs set up
  • 3/12/24: draft version of receiver on GitHub, testing for correctness and use by GUI controllers
  • 4/9/24: F2_ModelReceiver 0.1 version is ready for deployment, unfortunately the python models service has some errors in it, but the mechanics of the interface are mostly stable
  • 4/18/24: live model is currently starting from the gun, which produces very unrealistic twiss parameters. Need to start sim downstream at some treaty point
    • live model GUI gets marginally more realistic outputs starting from L0BFBEG, one option...
    • more realistic: take the latest PR10571 emittance measurement, back propagate to initial twiss at L0AFBEG – there are some kind of hooks in place for this already. but I'm not 100% on if they ever worked...
https://github.com/slaclab/facet-matlabTNG/pull/3

Minor Upgrades & Projects

IssueApplication/areaPerson(s) ResponsibleStatusPriorityNotesGitHub/CATER/etc
  •  LAME GUI scan automation
LAMEParkerWIP3

  •  Injector slice emittance tool

ParkerWIP


  •  Full lists of PVs used in HLAs accessible from each help menu
GlobalPerezWIP3F2_Feedbacks does this already with a hardcoded list, something similar could be done in other GUIs than have a lot of anonymous matlab PVs – ideally this could be automated by parsing the GUIs internal list of PVs
  •  Implement real-time rms energy spread PV with SYAG stats

DuranWIPBuschmann/Parker2Camera is serving stats. Just need a way to measure a conversion factor of MeV/pixel, then write both the calibration and the sigmaE to matlab PVC
  •  update 2/28/24: need to better understand what AD plugin stats actually calculate, the quantity I thought was the Xrms is not
  • simpler solution: measure the MeV/mm calibration and make an MeV axis so the sigE can be eyeballed
  • update 08/06/24: this should go into a watcher process...
  • Update 11/4/24: intrepid operator working on a python script to plug into watcher server and write to a PV

  •  Create tool to display corrector strength relative to beam energy vs Z.

Kalsi/ParkerWIP1

  •  python machine state summary script

Buschmann
3I'm imagining a script that gets 10571 + 10711 + SYAG + DTOTR2 images, and logbooks the most recent set of emittance/S20 measurements
  •  Linac bump maker

LoneyWIP1
  • simple version: matlab script that takes a BPM and an offset/angle as arguments
    • works, but depends on lucretia live (slow)
  • fancier version: GUI where one can select a BPM, preview corrector settings and undo

  •  convert wirescan plot Y axis to counts instead of charge
wirescansBuschmann
3

  •  IPWS1 Auto wire finder

LoneyWIP3simple: core plot config, preferred: script
  •  bunch length measurement with double-gaussian fitting

Buschmann
2

  •  orbit fitting script

Kalsi
2

  •  Rebrand EPICS with fancy new orange
GlobalBuschmanndone3nice
  •  CUD reference image/orbits
CUDsBuschmanndone3update 2/28/24: infrastructure exists to set new references remotely and update CUDs remotely, but the callbacks for each type of reference data are not complete – i.e. need to save DTOTR2 to a PNG, so CUDs can display, or save BPM data to a .mat etc etc
  •  Add Logbook feature to BSA GUI
BSAPerezDone2

  •  Add wire scan timestamps + skew + kurtosis to plot/logbook
Wire/Multi-WireBuschmann (+intrepid sidekick?)Done1

Both wire GUIs use the F2_WirescanApp object – save fit data/timestamps etc there, then GUIs can log & display that info as needed

  • update 3/5/2024: got the skew/kurt calculation implemented and have GUI frontends updated in-kind. still need to do some correctness checks and add timestamps

  •  FB CUD running flag (fix or remove)
F2 CUDsBuschmanndone3

update 4/9/24: working on updates to this display

5/24: done, v2 released


  •  Change default screen to 711 for injector TCAV measurements 
TCAV GUIRipmanDone2








...