diagnostic module

Define Diagnostic.

As for now, diagnostics are not used by LightWin. However, LightWin can add diagnostics (as well as ADJUST) to the final DAT in order to perform a “pass beauty”.

Note

Functionalities still under implementation. In particular, the number of attributes were not checked.

Note

This is TraceWin’s equivalent of Objective.

class Diagnostic(line, dat_idx=None, **kwargs)[source]

Bases: Element

A dummy object.

Parameters:
base_name = 'D'
increment_lattice_idx = False
is_implemented: bool = False
__init__(line, dat_idx=None, **kwargs)[source]

Force an element with null-length, with no index.

Parameters:
Return type:

None

_abc_impl = <_abc._abc_data object at 0x7318fab1f180>
class DiagCurrent(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure current.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1fe40>
class DiagDCurrent(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta current.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1f980>
class DiagPosition(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure position.

Parameters:
is_implemented: bool = True
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1fa00>
class DiagDPosition(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta position.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1edc0>
class DiagDivergence(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure divergences.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1f7c0>
class DiagDDivergence(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta divergences.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1c700>
class DiagSizeFWHM(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure full width at half maximum.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1fa80>
class DiagSize(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure sizes.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1eec0>
class DiagSizeP(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure divergences.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1cbc0>
class DiagDSizeFWHM(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta full width at half maximum.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1c880>
class DiagDSize(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta size.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1c9c0>
class DiagDSize2FWHM(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta full width at half maximum between two positions.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1d3c0>
class DiagDSize2(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta size between two positions.

Parameters:
is_implemented: bool = True
n_attributes: int | range | Collection = (3, 4)
__init__(line, dat_idx=None, **kwargs)[source]

Force an element with null-length, with no index.

Parameters:
Return type:

None

_abc_impl = <_abc._abc_data object at 0x7318fab1cdc0>
class DiagDSize3(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta phase spread between two positions.

Parameters:
is_implemented: bool = True
n_attributes: int | range | Collection = (3, 4)
__init__(line, dat_idx=None, **kwargs)[source]

Force an element with null-length, with no index.

Parameters:
Return type:

None

classmethod _args_to_line(number, rms_delta_phase_spread=0.0, accuracy=0.0, low_pass_filter_frequency=None)[source]

Convert list of arguments to corresponding line of dat file.

Parameters:
  • number (int)

  • rms_delta_phase_spread (float, default: 0.0)

  • accuracy (float, default: 0.0)

  • low_pass_filter_frequency (float | None, default: None)

Return type:

str

_abc_impl = <_abc._abc_data object at 0x7318fab1d080>
class DiagDSize4(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure something?

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1d600>
class DiagDPSize2(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta divergence between two positions.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1d1c0>
class DiagPhase(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure phase.

Parameters:
n_attributes: int | range | Collection = 2
_abc_impl = <_abc._abc_data object at 0x7318fab1de40>
class DiagEnergy(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure energy.

Parameters:
n_attributes: int | range | Collection = 3
_abc_impl = <_abc._abc_data object at 0x7318fab1d740>
class DiagDEnergy(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure difference between beam energy and perfect linac energy.

Parameters:
n_attributes: int | range | Collection = 3
_abc_impl = <_abc._abc_data object at 0x7318fab1d480>
class DiagDPhase(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure difference between beam phase and perfect linac phase.

Parameters:
n_attributes: int | range | Collection = 2
_abc_impl = <_abc._abc_data object at 0x7318fab1db00>
class DiagLuminosity(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure luminosity.

Parameters:
n_attributes: int | range | Collection = 3
_abc_impl = <_abc._abc_data object at 0x7318fab1d6c0>
class DiagWaist(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure waist setting.

Parameters:
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1db80>
class DiagAchromat(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure achromat setting.

Parameters:
n_attributes: int | range | Collection = 5
_abc_impl = <_abc._abc_data object at 0x7318fab1d7c0>
class DiagEmit(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure RMS emittance setting.

Parameters:
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1d940>
class DiagEmit99(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure 99% emittance setting.

Parameters:
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1dbc0>
class DiagHalo(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure halo setting.

Parameters:
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1e640>
class DiagSetMatrix(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure transfer matrix setting.

Parameters:
n_attributes: int | range | Collection = 6
_abc_impl = <_abc._abc_data object at 0x7318fab1dc00>
class DiagTwiss(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure beam Twiss parameters settings.

Parameters:
n_attributes: int | range | Collection = 7
_abc_impl = <_abc._abc_data object at 0x7318fab1dd40>
class DiagDTwiss(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Make equal two beam Twiss parameters between two positions or more.

Parameters:
n_attributes: int | range | Collection = 7
_abc_impl = <_abc._abc_data object at 0x7318fab1ddc0>
class DiagDTwiss2(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Make equal transverse Twiss parameters at diagnostic position.

Parameters:
n_attributes: int | range | Collection = 3
_abc_impl = <_abc._abc_data object at 0x7318fab1e080>
class DiagSeparation(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure beam separation setting.

Parameters:
n_attributes: int | range | Collection = 6
_abc_impl = <_abc._abc_data object at 0x7318fab1e100>
class DiagSizeMax(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Limit beam size max.

Parameters:
n_attributes: int | range | Collection = 6
_abc_impl = <_abc._abc_data object at 0x7318fab1e240>
class DiagSizeMin(line, dat_idx=None, **kwargs)[source]

Bases: DiagSizeMax

Limit beam size min.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1de80>
class DiagPhaseAdv(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure beam phase advance.

Parameters:
n_attributes: int | range | Collection = 4
_abc_impl = <_abc._abc_data object at 0x7318fab1e500>
class DiagBeta(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure beam beta.

Parameters:
n_attributes: int | range | Collection = 6
_abc_impl = <_abc._abc_data object at 0x7318fab1e5c0>
class DiagDBeta(line, dat_idx=None, **kwargs)[source]

Bases: Diagnostic

Measure delta beam beta.

Parameters:
_abc_impl = <_abc._abc_data object at 0x7318fab1e700>
n_attributes: int | range | Collection = 4