Changelog¶
This changelog describes the changes made between the different alpha versions of |Finesse|. When seeing unexpected behavior with existing finesse scripts after updating, you should read the entries between the last working version and the version introducing the issues, to see if there are any entries that are relevant to your code. See Updating Finesse for instructions on how to update to the latest version.
Note
You are currently looking at the documentation for |Finesse| 3.0a29-24-g9603272. Some of the changes listed for older versions may no longer be relevant, or contain broken links to non-existing documentation pages.
Next Version¶
Added¶
AstigmaticLens element added with x and y focal length parameters. Works the same a Lens and also has an OPD map attribute.
Added simple sinusoidal and Helical LG mode calculation functions to finesse.cymath.laguerre module.
Fixed¶
Fixed #685: Figure dictionary return by
solution.plot()
method has correct strings keys when single detector is present.Fixed #669: remove_piston() accepts spot_size only with type float and not np.float
Fixed #666: DCFieldsSolution and FrequencyResponseSolution cannot select themselves by name
Fixed #573: Symbolic changing division in lens focal length makes cavity unstable
Fixed a collection of warnings in various tests
Changed¶
Drop support for Python 3.9 due to various packages no longer supporting it
Allows a superclass of finesse.knm.Map to be used as a base class for custom maps. This allows for more flexibility in defining custom maps that define their own aperture and surface functions. The following example demonstrates:
class CustomMap(Map):
def __init__(self):
x = ...
y = ...
super().__init__(
self,
x,
y,
opd=self.surface,
amplitude=self.aperture,
)
def aperture(self, model=None):
return ...
def surface(self, model=None):
return ...
NotChangeableDuringSimulation now raised when trying to change a parameter that is not changeable during a simulation. This also fixes a bug where these changes are circumvented by using symbolics. Parameters that are not changeable during a simulation are flagged because some internal logic has not been implement yet to handle these changes.
3.0a29¶
Fixed¶
Fixed a critical bug in
finesse.analysis.actions.dc.DCFields
where the fields were not always recalculated after parameter changes.Fixed broken
finesse.components.isolator.Isolator
component, which caused a13 segfault in included in a model that was being run.
Added¶
Added a new utility function
finesse.utilities.bug_report.bug_report()
to make it easier to report issues by automatically collecting relevant information. See Reporting issues for an example.Added a
show
andpath
argument tofinesse.model.Model.plot_graph()
to control whether to show the plot and whether to save it to disk.
Changed¶
Use a more numerically stable method for calculating the frequency response of zpk filters which is more robust with filters with a large number of roots.
FieldDetectors now work with planewave models and no longer throw a warning.
3.0a28¶
This release includes two changes to default way of handling phases in |Finesse|, which are listed below. The effect of these changes is subtle, and described in detail in Phase configuration settings and Mirror and beamsplitter phase relationships.
Warning
If your simulations produce different results after updating to this release, it is likely that your previous results were incorrect, since the old default can break power conservation in certain setups.
You can switch between the two settings using finesse.model.Model.phase_config()
# new default
model.phase_config(False, True)
# old default
model.phase_config(True, True)
You can use this to check if your results are impacted by this change.
The changes have been tested with both the finesse-ligo and finesse-virgo packages, so if you are using these you will probably not be affected.
If you have any questions, do not hestitate to contact us via the matrix channel.
Breaking Changes¶
The default value for
zero_k00
finesse.model.Model.phase_config()
has been changed toFalse
. See Phase configuration settings for more information and an example of how the old default can break power conservation in the simulation Any simulation running with higher order modes and a cavity could be affected by this change and users usingfinesse.knm.maps.Map
should make sure they use optimizers for locking.The phase relationship on transmission has been changed to a new default. It will be identical to the previous relationship for most cases, but will prevent power conservation issues in more complicated setups. You can set the
_settings.phase_config.v2_transmission_phase
toTrue
if you want to revert to the old (Finesse 2) behavior, but the new behavior is likely more physically correct. See Mirror and beamsplitter phase relationships for more details.
Added¶
Add missing docs for many katscript Actions, Analyses, and Solutions and Model elements (incl. new group Mechanical Elements), fix many broken links
Extra documentation on Phase configuration settings
New method:
finesse.model.Model.get_open_ports()
New class
finesse.utilities.collections.OrderedSet
, used in multiple places where ordering of results/components is relevantDistance-based filtering for visualizing subgraphs of the model graph, see :re:`model_visualization`
Changed¶
finesse.model.Model.get_elements_of_type()
now returns a tuple instead of a generator, and accepts element names as strings as well as python classes as arguments:Added an option
full_output
tofinesse.gaussian.optimise_HG00_q_scipy()
to return the optimized array of HG modes alongside the fit result. This replaces the previousreturn_fit_result
argument.Include parity flip on reflection in Mirror and Beamsplitter ABCD methods. See also the new
_s
and_t
suffixes in methods infinesse.tracing.abcd
and the #123. For backward compatible code, use something like:
try:
from finesse.tracing.abcd import space, beamsplitter_refl
beamsplitter_refl_t = lambda *args: beamsplitter_refl(*args, "x")
beamsplitter_refl_s = lambda *args: beamsplitter_refl(*args, "y")
except ImportError:
# Handle newer versions which separate the beamsplitter refl # into the tangential
and sagittal planes from 3.0a28 from finesse.tracing.abcd import (
space, beamsplitter_refl_s, beamsplitter_refl_t,
)
Changes the examples in the documentation to indicate that parsing an action in KatScript and calling
model.run()
without any arguments is not recommended.
Removed¶
The
'sagittal'
and'tangential'
synonyms for'y'
and'x'
for themodes
command have been removed, since they can cause confusion with the newplane
option forfinesse.components.beamsplitter.Beamsplitter
andfinesse.components.mirror.Mirror
Fixed¶
Single solution outputs can be seleceted by their name now, so you do not need to add extra actions or put them in series unnecessarily.
Clarified the docstrings for the
finesse.components.cavity.Cavity
class itsfinesse.components.cavity.Cavity.path()
method.The shape of DCFieldsSolution is reverted to
[nodes, frequencies, HOMs]
, as described infinesse.analysis.actions.dc.DCFieldsSolutions
When removing a Readouts component, remove the associated output detectors as well (note that removing components from a model is unreliable in general)
Parameters of autogenerated spaces and wires not generating a correct
full_name
attribute.Fixed issue #659 - missing
sol = model.run()
in documentation for Maximise action
3.0a27¶
Allow detectors and ports to be visualized with component_tree method. See an example in the [docs](https://finesse.ifosim.org/docs/develop/usage/python_api/models_and_components.html#visualizing-the-model)
Fix finesse.gaussian.HGMode ignoring shape of the given y vector when n=m.
Option to keep only a subset of symbols in symbolic Model.ABCD method
Add options to specify the plane of incidence for a beamsplitter and to misalign a beamsplitter
Add pytest-xdist and configure it for faster (parallel) test running
Fix slow optimal q detector test slowdown
Fix broken cli test overwriting user config
3.0a26¶
Fixed inadvertently adding cython as a runtime dependency in 3.0a25
Added documentation on defining manual beam parameters
Expanded docstring on mirror curvature
Better error message for degree of freedom illegal self referencing
Generate conda files automatically from pyproject.toml
3.0a24¶
New features¶
Add FrequencyResponse4 action: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/202
add plot_field method to EigenmodesSolution: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/220
Documentation changes¶
Documentation on degree of freedom command/component: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/224
new example: inference on RoC to examples: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/222
Adding a link to the finesse-ligo documentation: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/218
Other¶
Fix/benchmark creation tests: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/223
Fix/641 ignore hidden folders during pyx files compilation checks: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/221
3.0a23¶
Fix memory leak issue during model building
Changing the ‘disabled’ argument of the Lock component to ‘enabled’ to avoid double negative if conditions in the code
Minor performance fixes
Fix for the Optimizer action that would sometimes leave the model in an incorrect state after optimization
“Did you mean” suggestions for katscript keyword arguments on syntax errors
Adds warning for unreasonable katscript line lengths and better message on parsing recursion errors
Evaluate symbolic references in the component info tables
allows overlap_contour to work with (qx,qy) input
3.0a22¶
phase_config now locked when the model is built
Symbol.lambdify was added to change Finesse symbolic expressions into a Python callable function
Added initial benchmarking tests for tracking performance changes over time
KnmMatrix.plot can be set to amplitude or phase now with the mode option
Locks now throw an explicit exception LostLock when it fails
Added Matplotlib helper function that plots arrows along a line at several points
3.0a21¶
Adds support for Python 3.12
3.0a20¶
Python 3.8 support dropped: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/172
Matplotlib 3.8 now works:
FrequencyResponse action fixed when using two element frequency vector: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/169
Now compiles with Cython 3, provides better debugging. Performance seems similar but not yet confirmed.
Can trace beams in reverse for propagating through isolating components: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/181
Wavefront curvature added to the beam propagation data: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/171
KatScript will now take the Python class name as an option for elements and actions: https://gitlab.com/ifosim/finesse/finesse3/-/merge_requests/160
EigenmodeSolution for a cavity now has method to compute roundtrip loss: https://gitlab.com/ifosim/finesse/finesse3/-/commit/db847bff9bf5ef4ffb109c5e234def6860f62525
Map now has a remove_piston term method: https://gitlab.com/ifosim/finesse/finesse3/-/commit/ef83443addbfa4c99d4b662c6f8058a1740775fe
New DCFields action to return a solution containing the DC optical fields at every node and frequency: https://gitlab.com/ifosim/finesse/finesse3/-/commit/b2cf34acae38d53a6dbf51906875f89e4589fee0
3.0a19¶
Requiring Matploblib < 3.8 until fixes are made for plotting routines
Parameters that are external controlled, such as those set by a DegreeOfFreedom will explicitly shown the symbolic reference now as opposed to hiding it. See #571
3.0a18¶
Fixed FieldDetector not conjugating lower sideband
Fixed DegreeOfFreedom using custom AC_IN and AC_OUT not filling the matrix correctly
Variable element removed, now calls model.add_parameter instead. this means some code using var.value.value will no longer work.
Added extra factorisation step when refactor returns a singular matrix with KLU, a warning will show when this happens.
Model.display_signal_blockdiagram now takes nodes name list and only show paths with those nodes in for cleaner diagrams
Model.path can take a symbolic=True keyword argument now for calculating symbolic path lengths
phase_level deprecated and replaced with model.phase_config method
unparing unsupported KatScript values will result in a __FIX_ME__ token
Parameters now support boolean checks
Python 3.11 wheels now built
SetLockGains now just optimises gains and not demodulation phases
OptimiseRFReadoutDemodPhaseDC now accepts Readout detector outputs REFL9_I or REFL9_Q for example, to optimise for either quadrature. Readout names supported and will default to _I with a warning
Fixed Hello-Vinet function substrate_thermal_expansion_depth #567
3.0a17¶
Fixing block diagram generation for signal paths
DOF has simpler interface for specifying just a DC actuation instead of using LocalDegreesOfFreedom
This also allows user to specify their own AC connections to the DOF.AC.i and DOF.AC.o as they see fit
Reworking signal node and port connections and attached_to attributes so they work
Wires now connect anything to anything, had some logic about input and output that isn’t needed anymore. Wires also have a gain now for simply rescaling inputs before summing with multiple other signal nodes
3.0a15¶
Adding additional features for degrees of freedom to allow for better/easier modelling of ASC and other more complex effects. LocalDegreesOfFreedom replaces DOFDefinition, which now has separate AC input and output nodes. Also tested against Sidles-Sigg theory and no internal code changes were needed.
3.0a14¶
Same as a13 but redoing conda dist for source
3.0a12¶
Pinning to less than Cython 3
3.0a11¶
Packaging/CI for windows still problematic, switching to conda instead of mamba due to 404 package errors
3.0a10¶
Attempt at fixing bad windows tag processing
3.0a9¶
New alpha update
3.0a8¶
Bad pypi source pushed for a7
3.0a7¶
Some recent fixes that improves memory allocation errors/checking and some usability errors.
3.0a6¶
Alpha 6 release
3.0a5¶
alpha 5, testing pypi deploy pipeline
3.0a4¶
alpha 4
3.0a3¶
Primarily fixes for Windows