Dear all,
Thanks to help from Thomas Kittelmann (ESS DMSC), McStas is now available on conda-forge
Initially we support only support Unix platforms Linux and macOS Intel, but macOS Silicon should come shortly.
The version tag of the packages is "3.4.7" meaning functionality-wise like McStas 3.4 but with minor improvements. For next official McStas release everything should match between our classical binary-distributed platforms and conda-forge.
Should you experience problems, please write up a GitHub Issue.
In preparation for forthcoming McStas 3.5 we are very much open to contributions:
Hence, if you have nice new component developments or new instrument
files to contribute, please fork the our repo and open a
pull request adding the files!
The 25th-anniversary celebration of the McStas collaboration took place on the afternoon of November 16th, co-hosted by ESS DMSC and DTU Physics.
Commencing its journey at Risø National Laboratory in the spring of 1997, the McStas software commemorated its 25th year since the release of version 1.0 in October 1998. Over the years, the project expanded into an international collaboration, with notable contributions from institutions such as Institut Laue-Langevin (ILL) and The Paul Scherrer Institute (PSI). In 2007, Risø became part of DTU, and since 2012, the ongoing development of McStas found a new home at DTU Physics, actively collaborating with the Niels Bohr Institute, ILL, PSI, and ESS.
As an open-source software, McStas has benefited from widespread contributions by individual researchers from facilities and universities globally, enriching the codebase with new features and functionality.
McStas has evolved into the leading software globally for neutron scattering simulations, particularly in the realms of instrument design, optimization, and virtual experiments. Notably, the software played a crucial role in designing and optimizing most of the ESS instruments currently under construction in Lund, Sweden.
During the anniversary event, Peter Willendrup, the lead developer and technical-scientific support for the McStas user community since 2002, provided a comprehensive overview of the 25-year development journey, highlighting key contributions from various contributors. Peter is Senior Research Engineer at DTU Physics and ESS DMSC. Mads Bertelsen, the author of McStasScript, guide_bot, and Union presented his work on these significant developments. Mads is recently appointed to a permanent position as Scientist at ESS DMSC.
Several event participants delivered short speeches in honor of the McStas collaboration, including Kurt Clausen, originator of the "simulation framework" idea and grant holder of the first EU funding for McStas, Kim Lefmann founder and member of the McStas team since the start , Kristian Nielsen, the computer scientist who engineered the initial code-generator technology, and Thomas Holm Rod, head of the ESS DMSC. Another important guest was Emmanuel Farhi from Synchrotron SOLEIL, long time contributor to McStas and now the lead on McXtrace.
Pictures from the celebration:
Also, thanks to the colleagues at ORNL who sent us a nice birthday card! :-)
And to José Robledo and Sunyoung Yoo who were behind this lovely greeting and handcraft :-)
Dear all,
As you may have noticed, the McStas installers for Windows and macOS now come with McStasScript embedded.
To achieve the same functionality on Linux (e.g. Debian/Ubunutu), you should perform these few steps
pip install jupyterlab ipympl mcstasscript nodejs jupytext
configuration.yaml
within your pip installation, e.g.:.local/lib/python3.10/site-packages/mcstasscript/configuration.yaml
other: characters_per_line: 85 paths: mcrun_path: /usr/bin mcstas_path: /usr/share/mcstas/3.4
Once these steps are performed you should be able to perform tasks like
mcstas-pygen
to generate a McStasScript .py
version
of an existing instrument:
~> mcstas-pygen BNL_H8.instr Warning: 'V_sample' is an obsolete component (not maintained). !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !!! WARNING: Your instrument file uses an input-parameter named !!! !!! "lambda" - which is a reserved word in Python !!! !!! As a workaround the variable has been named "Lambda" in !!! !!! the output python script. !!! !!! PLEASE consider renaming lambda->Lambda in the .instr file !!! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! CFLAGS=
jupytext
to convert from .py
to .ipynb
format:
~> jupytext --to ipynb BNL_H8_generated.py [jupytext] Reading BNL_H8_generated.py in format py [jupytext] Writing BNL_H8_generated.ipynb
jupyter lab BNL_H8_generated.ipynb
to interact
with your converted instrument in Jypyter Lab.
Dear all,
A Ubuntu 22.04 + McStas-3.4 + McStasScript image is now uploaded to dockerhub. To run from your local podman / Docker / etc. installation, execute a command along the lines of:
podman run -p 8888:8888 docker.io/mccode/mcstas-3.4
+ follow instructions from podman/Docker
You may also run the same container via binder, please connect via this icon:
To start McStas, please issue the command mcgui
from a terminal.
Dear all,
A minor hickup was found with our Debian/Fedora metapackages that
both had a dependence on mcstas-mcpl-3.4
which is a
non-existent package.
Newly built, corrected meta-packages have been uploaded as replacement, so please re-attempt installation if you experienced issues earlier.
Also, please be aware that mcpl
and NCrystal
now come
in separate, non-McStas related packages - and are not included in
the "metapackage" on Fedora. To install them, simply execute
sudo dnf install mcpl ncrystal
Sorry for any inconvenience caused!
Dear all, The new McStas release v. 3.4 "next-generation" is built and ready for download!
McStas 3.4 is the fifth official release in the 3.x series, with a modernised code-generator and support for GPU acceleration on NVIDIA cards.
3.4 is a 'major' update with notable changes, e.g. tighter integration/interoperability with McStasScript, new grammar and further CMake-standardisation which will eventually bring McStas to the conda-forge ecosystem. (And todaay, almost all dependencies for McStas are brought by mamba/conda on macOS and Windows.) Thanks to Thomas Kittelmann (ESS) for lots of help and footwork!
Another notable change is that MCPL and NCrystal are now
distributed in stand-alone .deb / .rpm packages that are
McStas-release-independent, for convenience still available through the
packages.mccode.org repository. Please install using e.g.
apt install mcpl ncrystal
(The MCPL and NCrystal codes have been submitted to the
Debian ecosystem by Synchrotron SOLEIL / Emmanuel Farhi / Roland Mas
and should make it to the next Debian Stable, the same procedure is
also under way for McStas.)
Thanks:
Thanks to all members of the joint McStas-McXtrace team and input from our users via emails and GitHub issues alike!
Download and installation instructions are available via our GitHub INSTALL-doc pages.
Selected highlights from the releass are listed below. The full
list changes is also available at https://mcstas.org/CHANGES_McStas.
Dear all,
The new McStas release v. 3.3 "next-generation" is built and ready for download!
McStas 3.3 is the fourth official release in the 3.x series, with a modernised code-generator and support for GPU acceleration on NVIDIA cards.
3.3 could have been considered a 'minor' update, but new built-in
support for NeXus on all platforms and new Thanks:
Download and installation instructions are available via our GitHub INSTALL-doc pages.
Selected highlights from the releass are listed below. The full
list changes is also available at https://mcstas.org/CHANGES_McStas.
If you didn't start already, please start your migration to 3.x:
Fixes of issues from last 3.x release: Release highlights Our Docker and binder containers will be updated within the
following weeks.
We hope you will enjoy this new release!!!
Previous news items: 2022, 2021,2020,2019, 2018, 2017, 2016,
2015, 2014, 2013,
2012, 2011, 2010, 2009,
2008, 2007, 2006,
2005, 2004, 2003, 2002, 2001, 2000, 1999,
1998.
We hope you will enjoy this new release!!!
(!!! Please note that there will be no future
2.x releases !!!)
mcrun --help
in your McStas terminal to learn
about details of switches and parameters or see the the changelog
for a full description.
mcstas-pygen Instrument.instr
generates the .py
script Instrument_generated.py
Using 'jupytext' this file may easily be converted to a notebook:
jupytext --to ipynb Instrument_generated.py
generates notebook file Instrument_generated.ipynb
See https://github.com/PaNOSC-ViNYL/McStasScript
and https://mads-bertelsen.github.io for more information on McStasScript.
DEFINE INSTRUMENT template(lambda / "Aa" =
2.36)
see the changelog
for full description.
METADATA
grammar from Greg S. Tucker (ESS), can
be used to attach verbatim code/information to one or more
component instances. See the changelog
for full description.
March 31st, 2023: McStas 3.3 released
SEARCH
grammar warrant the .x increment.
Thanks to all members of the joint McStas-McXtrace team and input from our users via emails and GitHub issues alike!
- If you are still in trouble, please write us a GitHub issue or an email to mcstas-users@mcstas.org
A number of issues from 3.2 were addressed, see the relevant GitHub issues for details:
3.2 issue list
mcrun
now automatically adds NeXus support to your binary if --format=NeXus
is given on the
commandline (or if DEPENDENCY " @NEXUSFLAGS@ "
is
included in your instrument or component file).
--IDF
will run an IDF generator (i.e. mcdisplay-mantid) prior to performing
a NeXus-based simulation, i.e. for "one-click" support of output in Mantid-compatible NeXus
format with an embedded IDF. Please consult the naming-conventions for sourceMantid
, sampleMantid
and nD_Mantid_xx
found in https://github.com/McStasMcXtrace/McCode/wiki/McStas-and-Mantid#mcstas-mantid-workflow
to succesfully generate your IDF. Please also inspire from the example instruments in the Mantid
category, see mcgui -> File -> New from template -> Mantid
.
mcrun
now forwards the -I
input to the code-generator, which allows you to add a chosen folder
with extra components etc. to your search path. Setting the -I
flag implies recompilation (-c
).
(Please also note the related SEARCH
grammar below which allows working on the component search
path directly via the instrument or component grammar.)
mcgui
run dialogue now allows to directly specify --format=NeXus
and --format=NeXus --IDF
when starting a simulation.
mcdisplay-mantid
has been given a good overhaul and now works properly with all of the supported
mantid-event-detector geometries of Monitor_nD
: rectangular, cylindrical/banana and OFF-file based.
Thanks to Torben R. Nielsen and Celine Durniak (ESS) for repeated testing.
mcplot
(-pyqtgraph
) and numpy related bug was quickly spotted
and ironed out with the help of by Rose Robledo FZJ.
FZP_simple model.comp
of Fresnel Zone-Plate (phenomenologic/closed-form thin-plate approximation) added
along with test instrument Test_FZP_simple.instr
, work by Anders Komar Ravn (NBI), and Erik B Knudsen
(previously DTU, now Copenhagen Atomics)
Test_Monochromators.instr
has been updated to include NCrystal_sample
as a monochromator, plus
includes multiple ways of parametrizing Single_crystal lattice
orientation. (Please note that NCrystal support is still not complete on Windows.)
ConicTracer
interface-component codes Conics_EH.comp, Conics_PH.comp, Conics_PP.comp
have been updated to allow specifying non-equidistant radii of the nested optical shells. Please
use vector radii={a,b,c,d,e}
or initialization via an instrument-based array and use a compatible
setting of nshells.
Elliptical_guide_gravity.comp
will now complain if you are using arrays for specifying varied coating
without setting the nSegments
input.
Pol_guide_vmirror.comp
has been ported to 3.3.
Thanks to Damian Rodriguez and Hal Lee (ESS) for interactions on this component.
ESS_butterfly
component may be modified using
compile-time re-definition. Defaults are
ESS_SOURCE_DURATION0=2.857e-3
s,
ESS_SOURCE_FREQUENCY 14
Hz,
ESS_SOURCE_POWER 5
MW. (Use e.g. mcrun --D1=ESS_SOURCE_DURATION=1.0e-3
to simulate a 1 ms pulse.)
pol-lib
may also be redefined at compile-time,
defaults are: MCMAGNET_STACKSIZE=12
,
mc_pol_angular_accuracy=(1.0*DEG2RAD)
deg,
mc_pol_initial_timestep=1e-5
s.
SEARCH
has been added to the grammar, allowing users to run append a directory
to the mcstas search path when looking for components. The syntax may be given in the
instrument- or component-header directly after a SHELL
token and before the DEPENDENCY
, DECLARE
tokens, available in two variants:
But you may also apply the same two SEARCH "/the/path/to/add/"
SEARCH SHELL "the_executable --and --some --options"
SEARCH
forms in connection with a component instance in TRACE
, e.g.:
TRACE
...
SEARCH SHELL "readout-config --show compdir"
COMPONENT readout = Readout(ring="RING", fen="FEN", tube="TUBE", a="left", b="right", ...)
AT (0, 0, 0) ABSOLUTE
...
(r-)interoff-lib.c
family of codes have again received a couple of updates, thanks to McStas user
Richard Wagner (ILL).
NCrystal
library version 3.5.1 from T. Kittelmann (ESS) and X.X. Cai (CSNS), distributed
with McStas on Unix platforms only. (Cross-compiles for Windows, but still needs work
for "production" availability.)
MCPL
library from the same authors included at v. 1.6.1