-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.tex
1104 lines (917 loc) · 61.9 KB
/
main.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
\documentclass[11pt, a4paper]{article}
\usepackage[utf8]{inputenc}
\usepackage{graphicx}
\usepackage{setspace}
\usepackage{array}
\usepackage{fancyhdr}
\usepackage[none]{hyphenat}
\usepackage{rotating}
\usepackage{anyfontsize}
\usepackage{multirow}
\usepackage{listings}
\usepackage{xcolor}
\usepackage{tikz}
\usetikzlibrary {graphs,graphdrawing}
\usegdlibrary{layered}
\usegdlibrary{trees}
\usetikzlibrary{backgrounds, fit}
\tikzset{
invisible/.style={opacity=0},
visible on/.style={alt=#1{}{invisible}},
alt/.code args={<#1>#2#3}{%
\alt<#1>{\pgfkeysalso{#2}}{\pgfkeysalso{#3}} % \pgfkeysalso doesn't change the path
},
}
\tikzset{title/.style={fill=white,inner sep=0pt,font={\scshape},anchor=center,yshift=1pt}}
\definecolor{codegreen}{rgb}{0,0.6,0}
\definecolor{codegray}{rgb}{0.5,0.5,0.5}
\definecolor{codepurple}{rgb}{0.58,0,0.82}
\definecolor{backcolour}{rgb}{0.95,0.95,0.92}
\lstdefinestyle{mystyle}{
backgroundcolor=\color{backcolour},
commentstyle=\color{codegreen},
keywordstyle=\color{magenta},
numberstyle=\tiny\color{codegray},
stringstyle=\color{codepurple},
basicstyle=\ttfamily\footnotesize,
breakatwhitespace=false,
breaklines=true,
captionpos=b,
keepspaces=true,
numbers=left,
numbersep=5pt,
showspaces=false,
showstringspaces=false,
showtabs=false,
tabsize=2
}
\lstset{style=mystyle}
% For subfigures
\usepackage{caption}
\usepackage{subcaption}
% Get rid of the indent of the first line
\edef\restoreparindent{\parindent=\the\parindent\relax}
\usepackage{parskip}
% Fix text out of margin
\emergencystretch 3em
% Set date format
\usepackage[ddmmyyyy]{datetime}
% Set fonts
% \usepackage{fontspec}
% \setmainfont{Muli}[
% Path = fonts/ ,
% Extension = .ttf ,
% UprightFont = *-Regular ,
% ItalicFont = *-Italic ,
% BoldFont = *-Bold ,
% BoldItalicFont = *-BoldItalic
% ]
% \setsansfont{Muli-Black}[
% Path = fonts/ ,
% Extension = .ttf ,
% ItalicFont = *Italic
% ]
% Set page margin
\usepackage{geometry}
\geometry{a4paper,
% total={175mm,257mm}, %space for content
headheight=80pt,
headsep=2pt,
% top=3cm,
bottom=2.5cm,
left=2cm,
right=1.75cm}
% Set the name of the table of contents
\usepackage{url} % for correct typesettings of URLs
\usepackage{hyperref} % for sophisticated linking of urls, dois, pictures, tables, etc.
\hypersetup{
unicode=true, % non-Latin characters in Acrobat’s bookmarks
pdftoolbar=true, % show Acrobat’s toolbar?
pdfmenubar=true, % show Acrobat’s menu?
pdffitwindow=false, % window fit to page when opened
pdfstartview={FitH}, % fits the width of the page to the window
pdfauthor={C. Fortmann-Grote}, % author
pdftitle={D5.3: Release of documented simulation APIs}, % title
pdfsubject={PaNOSC WP5 (ViNYL) Deliverable D5.3}, % subject of the document
pdfcreator={pdflatex}, % creator of the document
pdfnewwindow=true, % links in new PDF window
colorlinks=true, % false: boxed links; true: colored links
linkcolor=black, % color of internal links (change box color with linkbordercolor)
citecolor=blue, % color of links to bibliography
filecolor=blue, % color of file links
urlcolor=blue % color of external links
}
% \usepackage[style=nature]{biblatex}
% \addbibresource{references.bib}
\pagestyle{fancy}
\fancyhead{} % clear all header fields
\fancyfoot{} % clear all footer fields
\renewcommand{\headrulewidth}{0pt} % clear the header ruler line
\setlength{\footskip}{14pt}
\fancyfoot{} % clear all footer fields
\fancyfoot[R]{\hspace{1em}}
% \fancyfoot[c]{\begin{tabular}{c}
% \includegraphics[width=\textwidth, valign=b]{footer.pdf}& \\
% \end{tabular}}
\fancyfoot[L]{\hspace{1cm} \includegraphics[width=0.95\textwidth]{footer.pdf}}
% \cfoot{\includegraphics[width=0.95\textwidth]{footer.pdf}}
% Set line spacing
\emergencystretch 3em
\setstretch{1.2}
% \setlength{\footskip}{10pt}
\begin{document}
% \thispagestyle{empty}
\chead{\includegraphics[width=\textwidth]{header.pdf}}
{
\centering
\begin{onehalfspace}
\sffamily
\vspace*{5ex}
{\fontsize{20}{24}\selectfont PaNOSC \par}
{\fontsize{20}{24}\selectfont Photon and Neutron Open Science Cloud \par}
{\fontsize{20}{24}\selectfont H2020-INFRAEOSC-04-2018 \par}
{\fontsize{20}{24}\selectfont Grant Agreement Number: 823852 \par}
\end{onehalfspace}
\vspace*{7ex}
\includegraphics[width=\textwidth]{PaNOSClogo_web_RGB.pdf}\par
\vfill
{\large \textbf{\sffamily D5.3: Repository of documented jupyter notebooks and Oasys canvases}}\par
} % end of centering
\includegraphics[width=1.27in]{by.eps}\par
This work is licensed under a Creative Commons Attribution 4.0 International License\\
(\url{http://creativecommons.org/licenses/by/4.0/})\par
% \vspace*{0ex}
\newpage
% Set footer for the second page
% \setlength{\footnotesep}{50pt}
% \setlength{\footskip}{0pt}
\fancyfoot{} % clear all footer fields
\fancyfoot[R]{\thepage}
% \fancyfoot[c]{\begin{tabular}{c}
% \includegraphics[width=\textwidth, valign=b]{footer.pdf}& \\
% \end{tabular}}
\fancyfoot[L]{\hspace{1cm} \includegraphics[width=0.95\textwidth]{footer.pdf}}
{ %Front page
\restoreparindent
% \renewcommand{\arraystretch}{1.2} % change table row height
{\sffamily\huge Project Deliverable Information Sheet \par}
\begin{center}
\begin{tabular}{ | m{5.2cm}| m{10.7cm} | }
\hline
Project Reference No. & 823852 \\
\hline
Project acronym: & PaNOSC \\
\hline
Project full name: & Photon and Neutron Open Science Cloud \\
\hline
H2020 Call: & INFRAEOSC-04-2018 \\
\hline
Project Coordinator: & Andy Götz (andy.gotz@esrf.fr) \\
\hline
Coordinating Organization: & ESRF \\
\hline
Project Website: & www.panosc.eu \\
\hline
Deliverable No: & D5.3: Repository of documented jupyter notebooks and Oasys canvases \\
\hline
Deliverable Type: & Software \\
\hline
Dissemination Level: & Public \\
\hline
Contractual Delivery Date: & 30/05/2022 \\
\hline
Actual Delivery Date: & \today \\
\hline
EC project Officer: & Ren\'e Martins \\
\hline
\end{tabular}
\end{center}
{\large \textbf{Document Control Sheet} \par}
\begin{center}
\begin{tabular}{ | m{5.2cm}| @{}c@{} | }
\hline
\textbf{Document}
&
\begin{tabular}{| m{10.7cm} |}
Title: D5.3: Repository of documented jupyter notebooks and Oasys canvases \\\hline
Version: 1 \\\hline
Available at: \\\hline
Files: 1 \\\hline
\end{tabular}
\tabularnewline\hline
\textbf{Authorship}
&
\begin{tabular}{| m{10.7cm} |}
Written by: Carsten Fortmann-Grote \\\hline
Contributors: Mads Bertelsen,
Stella d'Ambrumenil,
Juncheng E,
Aljo\v{s}a Hafner,
Gergely Norbert Nagy,
Shervin Nourbakhsh,
Mousumi Upadhyay Kahaly \\\hline
Reviewed by: Jordi Bodera Sempere\\\hline
Approved: Andy Götz\\\hline
\end{tabular}
\tabularnewline\hline
\end{tabular}
\end{center}
{\large \textbf{List of participants} \par}
\begin{center}
\begin{tabular}{|m{3.0cm}|m{9.5cm}|m{3cm}|}
\hline
\textbf{Participant No.} & \textbf{Participant organisation name} & \textbf{Country} \\
\hline
1 & European Synchrotron Radiation Facility (ESRF) & France \\
\hline
2 & Institut Laue-Langevin (ILL) & France \\
\hline
3 & European XFEL (XFEL.EU) & Germany \\
\hline
4 & The European Spallation Source (ESS) & Sweden \\
\hline
5 & Extreme Light Infrastructure Delivery Consortium (ELI-DC) & Belgium \\
\hline
6 & Central European Research Infrastructure Consortium (CERIC-ERIC) & Italy \\
\hline
7 & EGI Foundation (EGI.eu) & The Netherlands \\
\hline
\end{tabular}
\end{center}
}%End front page
% Table of contents
\newpage
\addtocontents{toc}{\protect\thispagestyle{fancy}}
\newpage
\tableofcontents
\newpage
% End Table of contents
\section{Introduction}
\label{sec:introduction}
Deliverable D5.3 in PaNOSC is the release of jupyter notebooks and Oasys
workspaces
that demonstrate the utilization of simulation services in appropriate cloud
services, i.e. jupyter hub instances or cloud based Oasys installations,
respectively. This document lists the published notebooks and workspaces and
gives a brief outline of their scientific content as well as instructions how to
launch them. All notebooks and workspaces can be accessed through a common entry
point, the ViNYL-notebooks repository at
\url{https://github.com/PaNOSC-ViNYL/ViNYL-notebooks}. Installation instructions
are provided in the README file of that repository. The repository is registered
on zenodo at \url{https://dx.doi.org/10.5281/zenodo.6562106/}.
\section{Simulation infrastructure}
\label{sec:simulation_infrastructure}
This Deliverable is accompagnied by Milestone MS5.3, the release of the
simulation API library \textit{libpyvinyl}. \textit{libpyvinyl}
ensures a common interface for
simulations that choose to build upon this foundation. In addition, we built
a instrument database to represent beamline and instrument components in neutron
or x--ray RIs, their parameters and permissible parameter values.
Instruments can be easily retrieved from an
accompanying Python API, and expert users can update the instrument description
directly through github where we host the database. By hosting the instrument
database on github we ensure it is accessible to a broad user base without
specialized knowledge of database technology such as SQL and we avoid having to
implement and maintain web frontends. Another benefit is the
option to run quality checks on proposed updates of instruments using
Continuous Integration.
Our simulation services are backed by three distinct simulation frameworks:
Simex for x--ray laser experiments, Oasys for x--ray optics, mainly focussing on
synchrotron sources and McStasScript for neutron simulations. The underlying
simulation codes are described in the respective framework's documentation. In
the following, we document dedicated github repositories that host our jupyter
notebooks and workspaces.
\section{McStasScript notebooks}
\label{sec:mcstas}
The McStasScript notebook repository and the code repository are listed
in Table~\ref{tab:mcstasscript_resources}.
\begin{table}[ht]
\centering
\caption{McStasScript resources}
\begin{center}
\begin{tabular}{ll}
\hline
McStasScript code repo & \url{https://github.com/PaNOSC-ViNYL/McStasScript} \\
McStasScript notebooks & \url{https://github.com/PaNOSC-ViNYL/McStasScript-notebooks} \\
McStasScript documentation & \url{https://mads-bertelsen.github.io}\\
\hline
\end{tabular}
\end{center}
\label{tab:mcstasscript_resources}
\end{table}
The McStasScript notebook repository currently contains a full 11 notebook
tutorial on McStas using the McStasScript Python interface developed under WP5.
This tutorial is also available through the online McStasScript documentation.
The repository also contains an example on using the widget interface for
McStasScript, and an example on using a cryostat construction tool included in
McStasScript.
\section{SimEx notebooks}
\label{sec:simex}
Numerous notebooks have been developed that showcase the use of the SIMEX
library for simulation of photon experiments at x--ray laser facilities. The
following table gives an overview and links directly to a static version of the
notebooks on github.
To run these notebooks, a working SIMEX installation is needed.
% \begin{sidewaystable}[ht]
\begin{table}[ht]
\caption{SIMEX notebooks}
\begin{tabular}{l|p{9.8cm}}
\hline
\textbf{Notebook title} (link) & \textbf{Description} \\
\hline
\href{https://github.com/PaNOSC-ViNYL/SimEx-notebooks/blob/main/ESRF-SerialCrystallography/Jungfrau-ESRF.ipynb}{Jungfrau-ESRF.ipynb} & Crystallograhy at ESRF with 4M Jungfrau detector\\
\href{https://github.com/PaNOSC-ViNYL/SimEx-notebooks/blob/main/SFX/crystFEL.ipynb}{crystFEL.ipynb} & Nanocrystal diffraction at Eu.XFEL SFX instrument \\
\href{https://github.com/PaNOSC-ViNYL/SimEx-notebooks/blob/main/SPB/diffrChaperonins.ipynb}{diffrChaperonins.ipynby} & Singe particle imaging at Eu.XFEL SPB instrument\\
\href{https://github.com/PaNOSC-ViNYL/SimEx-notebooks/blob/main/s2e/start_to_end_demo.ipynb}{start\_to\_end\_demo.ipynb} & Start--to--end simulation for single particle imaging at Eu.XFEL SPB instrument. \\
\href{https://github.com/PaNOSC-ViNYL/wavefrontDB/blob/main/examples/EuXFEL_SASE1_SPB_KBfocus.ipynb}{EuXFEL\_SASE1\_SPB\_KBfocus.ipynb} & KB mirror focusing of SASE1 beam at Eu.XFEL \\
\href{https://github.com/PaNOSC-ViNYL/wavefrontDB/blob/main/examples/crl_focus.ipynb}{crl\_focus.ipynb} & CRL focusing of SASE1 beam at Eu.XFEL \\
\href{https://github.com/PaNOSC-ViNYL/wavefrontDB/blob/main/examples/edge.ipynb}{edge.ipynb} & Coherent x--ray diffraction from a solid edge \\
\href{https://github.com/PaNOSC-ViNYL/wavefrontDB/blob/main/examples/spheres.ipynb}{spheres.ipynb} & Coherent x--ray diffraction from solid spheres \\
\href{https://github.com/PaNOSC-ViNYL/wavefrontDB/blob/main/examples/wire.ipynb}{wire.ipynb} & Coherent x--ray diffraction from a thin wire \\
\hline
\end{tabular}
\label{tab:simex-notebooks}
\end{table}
% \end{sidewaystable}
% \printbibliography
% \fancypagestyle{plain}{}
\section{Abstract}
This document outlines the contributions made by the European Spallation Source (ESS) to the PaNOSC Work package 5 on simulation. A powerful Python API for the popular simulation package McStas was created in a manner consistent with the standards proposed by WP 5. The ESS also participated in design of the libpyvinyl package and instrument database.
\section{Introduction}
Arguably the main purpose of the PaNOSC WP 5 simulation project have been to harmonize the user interface for simulations of X-ray and neutron beamlines. It was decided that a Python interface suitable for Jupyter Notebooks was the best solution. For neutron scattering, the \href{https://www.mcstas.org}{McStas package} is the standard tool for instrument simulations, yet it has a specialized user interface built on the C programming language. McStas has a sister project called McXtrace that simulates X-ray instrumentation. The main contribution from the ESS have been the McStasScript Python API that allows nearly full access to McStas/McXtrace features through an elegant Python interface, and even offers some functionality in addition to the basic package. The ESS have also been involved in defining standards for handling beam descriptions as openPMD files, development of the common Python user interface LibPyvinyl and contributed to the design of the instrument database. This document provides an overview of these contributions.
\section{McStasScript}
\subsection{Scope and purpose of the package}
The McStasScript package aims to be an alternative user interface that covers the vast majority of McStas features. McStas itself is a Monte Carlo ray-tracing simulation code that covers neutron beamlines from source to detector, including sample scattering. Since the same software is used for the entire beamline, access to McStas from Python covers task 5.2 to 5.4, as it provides source simulation, beamline simulation and sample physics. Before McStasScript, McStas offered two ways of working with instrument simulations. Central to both are the instrument file that describes the instrument to be simulated in a C meta language. In this file the instrument is built from components and it is possible to have input parameters along with calculations. It is possible to run a simulation by using the command line tools to execute such a simulation by providing the instrument file, and then plot the resulting data using a different command line tool. McStas also provides a GUI with a text editor that provides some help features when inserting components, and then dialog boxes for running simulations and viewing the data. The data is always written to disk, usually as text files with metadata in a specialized format.
McStasScript thus provides a third way of writing McStas instruments, where everything can be done from the Python API. One defines an instrument object, adds components, parameters and calculations as necessary, and then runs the simulation from within the Python environment. The data is returned as objects with metadata and the numerical data is available as standard numpy arrays, making it easy to work with the generated data.
In order to harmonize the API's of the different simulation packages for X-ray and neutron scattering, WP5 collaborated on a base package for simulations called libpyvinyl. This package provides base classes from which one can build simulation packages, and these simulations packages will thus follow a similar logic and share the most important method names. The libpyvinyl package is in this way the answer to the harmonization part of task 5.1, and McStasScript is built upon this base package.
\subsection{Current status of the project}
The main goals of the project has been achieved and there are a number of users of the package both within PaNOSC and outside. It has grown into a healthy project and is foreseen to continue development after the PaNOSC project. This section provides an overview of the status of the project from a technical standpoint.
\subsubsection{Repository}
The project is open source and available on the WP5 github repository. There are two repositories, one for the main package and a separate one for example notebooks, this makes it easier for users to get examples in a location more easily accessible than the install location. Links to the repositories are shown in table \ref{tab:links}. The McStasScript-notebook repository contributes to deliverable 5.3 which requires simulation examples in the form of notebooks.
\begin{table}[h!!!]
\centering
\begin{tabular}{l|l}
Name & Link \\\hline
McStasScript & \href{https://github.com/PaNOSC-ViNYL/McStasScript}{https://github.com/PaNOSC-ViNYL/McStasScript} \\
McStasScript-notebooks & \href{https://github.com/PaNOSC-ViNYL/McStasScript-notebooks}{https://github.com/PaNOSC-ViNYL/McStasScript-notebooks}
\end{tabular}
\caption{\label{tab:links} Links to McStasScript repositories.}
\end{table}
\subsubsection{Tests}
The package has good coverage with unit tests and these are used in continuous integration (CI). In addition, integration tests are available, as these do Monte Carlo simulations and require a local McStas installation, these are not included in CI.
\subsubsection{Installation}
It is possible to install the package through the Python package index pip as shown below. The package can also be installed from source by cloning the github repository. Regardless of the method, configuration is necessary to tell McStasScript where the local McStas/McXtrace installation is located.
\begin{verbatim}
pip install McStasScript
\end{verbatim}
\subsubsection{Documentation}
The documentation is available at \href{https://mads-bertelsen.github.io}{https://mads-bertelsen.github.io}, where significant efforts have been made to provide comprehensive documentation. The documentation includes the purpose of the package, how to use it and tutorials on a large part of the McStas package as well as the McStas Union components. The release of the documentation along with online availability of the package was the ESS contribution to the completion of deliverable 5.2.
\subsubsection{Dissemination}
It is important to inform the community about the package in order to create a user community. Table \ref{tab:Dissemination} contains an overview of events where McStasScript was shown outside of PaNOSC events.
\begin{table}[h!!!]
\centering
\begin{tabular}{l|l}
Event & Format \\\hline
ECNS 2019 & Poster \\
ICANS 2019 & Poster and Presentation \\
SNS visit & Presentation for simulation group \\
HighNESS McStas course & Presentation \\
ISIS McStas course & Presentation \\
MLZ Garching group meeting & Presentation and online demo \\
PNPI group meeting & Presentation \\
ESS McStas days & Presentation and quiz exercises \\
ICNS 2022 & Poster and award speech for Instrumentation and Innovation prize \\
ESS-ILL User meeting 2022 & Poster \\
\end{tabular}
\caption{\label{tab:Dissemination} Overview of McStasScript dissemination activities.}
\end{table}
\subsubsection{User base}
It is difficult to judge the size of the current McStasScript user base as the download statistics include downloads of the package made through continuous integration, bots that mirror the package and so forth. There have been days with more than 300 downloads of the package, but it has not been possible to find a total number of downloads across all versions. Users provide issues to the github project, pull requests are being submitted and support requests are regularly received by the author over e-mail. It can be concluded that the package is reaching some level of adoption within the McStas/McXtrace community. Known users are located at ILL, SNS, KU, DTU, MLZ, TUDelft and have even been used to design X-ray optics for space based telescope.
\subsection{McStasScript features}
This section aims to provide an overview of the feature set of McStasScript.
\subsubsection{Write instrument}
An instrument is made by creating an instrument object, and this instrument object can then have components added. These are a sequence of smaller codes that describe the beamline, and are each represented by a file on the users disk. McStasScript parses these files to internalize information on their parameters and units. It is possible to add components to any point in the sequence of components, but it is most common to place new components at the end. The instrument object inherits from the LibPyVinyl calculator class in order to adhere to the standardized user interface created by WP5.
\subsubsection{Parameters}
It is also possible to add parameters to an instrument, these can be changed easily between runs. When changing components, McStas requires the underlying C code to be recompiled, but this can be avoided when only changing parameters. McStasScript has yet to implement code that avoids compiling when unnecessary, this is still the users responsibility.
\subsubsection{Error checking}
When writing a McStas instrument there are many possible ways to make an error that would result in the generated C code to fail to compile. A number of these are recognized by McStasScript and reported immediately instead of only when the user attempts to run the simulation. The exceptions raised by McStasScript are more specific that the compiler errors generated by McStas. Not all errors are caught, but the compiler output can be seen from McStasScript.
\subsubsection{Help features}
McStasScript contains a number of help features ranging from simple text overviews of the parameters, variables and components to diagrams of components included in an instrument. The help features can be used to find the right component in the library and to understand the parameters of components even before they are included in the instrument. When components are included in the instrument, colored text is used to show different states of the component parameters, such as default, required and set by user. The generated instrument diagrams such as seen in figure \ref{fig:diagram} are great for getting a quick overview of an instrument and are only available in McStasScript.
\begin{figure}[h!!!]
\centering
\includegraphics[width=0.5\textwidth]{figures/diagram_example.png}
\caption{\label{fig:diagram}Example of diagram from McStasScript. In widget mode one can hover the mouse over the left side of the boxes to see further info on each component.}
\end{figure}
\subsubsection{Run simulation}
The simulation can be executed from the Python environment, this is achieved with a system call using the subprocess module. The user can use the same controls available on the command line tools, such as setting the number of rays, location of data output, enabling gravity and selecting how many CPU cores will be used. The actual run method is called backengine to conform the LibPyVinyl standard.
\subsubsection{Return of data}
Running a simulation returns data as a list of Python objects corresponding to each monitor in the instrument. These contain metadata such as the used parameters and information about the monitor as well as the actual data in nunmpy arrays. The objects also contain preferences on how this object should be plotted so the plotting tools in McStasScript can use appropriate settings when plotting the included data.
\subsubsection{Widgets}
McStasScript also contains widgets specifically designed for use in Jupyter Notebooks. One widget can take a list of data objects and plot each of them with easy access to plot options and colorscales in the widget. The other widget takes an instrument object and is able to run the simulation with parameters set by the user, this widget shows the data from the simulation just as the plotting widget would. An example of the run widget can be seen in figure \ref{fig:widget}.
\begin{figure}
\centering
\includegraphics[width=0.9\textwidth]{figures/widget.png}
\caption{\label{fig:widget}Example of run widget from McStasScript. Here showing scattering in an imaging calibration sample with several embedded materials. Notice the streaks of lower intensity behind materials that scatter / absorb more than the others.}
\end{figure}
\clearpage
\section{openPMD}
The openPMD \href{https://www.openpmd.org}{https://www.openpmd.org} format is to be used for transferring descriptions of beams between different simulations. The ESS contributed to the beam standard that was proposed and included into the openPMD standard, which was an objective of task 5.1 and deliverable 5.1.
\subsection{openPMD McStas compatability}
A McStas components for reading and writing by Shervin and some review was performed, but these components have not made it to the McStas distribution. This should be completed before the end of the project.
\section{LibPyVinyl development}
ESS contributed to the development of the LibPyVinyl package from the early stages of design, including requirements. The first version of the parameter class and parameter collection class were contributed.
\section{Instrument database}
\subsection{Scope and purpose}
Facility users have hardly access to complete and up-to-date instrument descriptions to run sample simulations and they are difficult to manipulate for a user not expert in the specific simulation software.
The libpyvinyl API offers the high level interface to harmonize the interaction with an instrument described with different simulation softwares.
The instrument database has been designed to collect in a central place instrument descriptions created with softwares adopting the libpyvinyl API. Users are then able to access the instrument with few lines of code and run the simulation with a set of implemented samples (expandable). The instrument comes with the set of high level parameters defining the settings of the instrument that the user is supposed to be able to manipulate at the facility for the data acquisition, while all internal complexities are hidden.
\subsection{Current status of the project and contributions}
The structure of the database have been defined and a dedicated API is available to list its content and access the required instrument description.
Only few pilot instruments are described and are supposed to be used as examples for implementing new instruments.
A complete validation of the instruments has not been performed.
The instrument database and its API designs have been leaded by ILL and co-designed with ESS and EuXFEL.
%ESS have been involved in design of the instrument database and the structure of the API.
It is envisioned several ESS instruments and sample environments will be submitted to the database soon, further testing and extending the system as needed. The instrument database will also address task 5.3 at a higher level of ambition than foreseen at the start of the project.
\subsection{Repository}
The database defined as a git repository hosted on the WP5 github organization as well as
he API to access the insturment database and make insturment descriptions available.
\href{https://github.com/PaNOSC-ViNYL/instrument_database}{https://github.com/PaNOSC-ViNYL/instrument\_database}
\href{https://github.com/PaNOSC-ViNYL/instrument_database_API}{https://github.com/PaNOSC-ViNYL/instrument\_database\_API}
\subsection{Structure}
\subsection{Maintainance and contribution policy}
\subsection{Installation and access}
The repository can be cloned in local using git commands:
\begin{verbatim}
git clone --recurse-submodules https://github.com/PaNOSC-ViNYL/instrument_database.git
\end{verbatim}
%or via the Python package index pip:
%\begin{verbatim}
%pip install XXX
%\end[verbatim]
\subsection{Documentation}
The documentation is self contained in the repository as Markdown file.
The documentation targets both users of the instrument database and developers implementing instrument descriptions.
\subsection{Dissemination}
It is crucial to have a significant contribution from the research facilities by providing accurate and complete instrument descriptions and to maintain them.
A workshop dedicated to WP5 tools and prospects would be ideal to reach both expert and non-expert simulation users as well as developers.
\subsection{User base}
Currently limited but potentially every user submitting a proposal for beam time.
\subsection{Features}
\section{OASYS}
\subsection{Introduction}
OASYS (OrAnge SYnchrotron Suite) is an open source environment for modelling X-ray beamlines and experiments. It is based on Orange (\url{https://orangedatamining.com/}) framework which provides an easy-to-use graphical user interface (GUI). Various OASYS widgets (optical elements) are connected to each other, thus creating a workflow (beamline). This is particularly useful for X-ray optics simulations, as the wavefront propagation direction is well-defined and known in advance (from the source to the experimental station).
Several successful calculation packages exist and are actively maintained by the community. Among the most popular are \emph{SHADOW} for ray-tracing simulations and \emph{SRW} for wavefront propagation. During the PaNOSC project, we have addressed several different topics. This chapter provides an overview of all the development. All PaNOSC-specific widgets can be installed through OASYS1-PaNOSC (shown in Fig. \ref{fig:toolbox} package hosted on PyPI and available through the internal add-on manager. All contributions to the OASYS part described below come from CERIC-ERIC and ESRF.
\begin{figure}[htb]
\centering
\setkeys{Gin}{width=\linewidth}
\begin{subfigure}{0.3\textwidth}
\includegraphics{figures/panosc_toolbox.png}
\caption{}
\label{fig:toolbox}
\end{subfigure}
\hfil
\begin{subfigure}{0.5\textwidth}
\includegraphics{figures/github_remote_access.png}
\caption{}
\label{fig:github_access}
\end{subfigure}% trailing space between `subfigure` environments had to be removed
\caption{(a) PaNOSC widget toolbox. (b) Remote repository of OASYS workspaces (OWS) access through a widget in the GUI.}
\end{figure}
\begin{table}[ht]
\label{tab:repos}
\centering
\begin{center}
\caption{Relevant OASYS repositories. The current release of OASYS1-PaNOSC is \href{https://pypi.org/project/OASYS1-PaNOSC/0.3.2/}{v0.3.2} and of OASYS1-oasyswiser \href{https://pypi.org/project/OASYS1-oasyswiser/0.3.22/}{v0.3.22}.}
\begin{tabular}{l p{10cm}l}
\hline
OASYS Panosc toolbox code & \url{https://github.com/PaNOSC-ViNYL/OASYS1-PaNOSC} \\
Wiser (Library) repository & \url{https://github.com/oasys-elettra-kit/WISEr} \\
OasysWiser (GUI) repository & \url{https://github.com/oasys-elettra-kit/OASYS1-Wiser} \\
OASYS local Docker container & \url{https://gitlab.elettra.eu/panosc/ceric/oasys-local-docker} \\
OASYS Jupyter Docker container & \url{https://gitlab.elettra.eu/panosc/jupyter-desktop-oasys} \\
Dockerhub release & \url{https://hub.docker.com/r/ceric/panosc-oasys-local}\\
E-learning Docker container & \url{https://github.com/pan-training/Docker/tree/main/wp8-summerschool} \\
PaNOSC OWS database & \url{https://github.com/PaNOSC-ViNYL/Oasys-PaNOSC-Workspaces} \\
\hline
\end{tabular}
\end{center}
\end{table}
\subsection{Wiser}
Wiser is a new package for wavefront propagation calculations based on Python implementation of WISE calculation code which stemmed from and is still maintained by Elettra Synchrotron. It is targeted at simulating the optical performance of X-ray mirrors. Propagation is done using Huygens-Fresnel integratal and allows for simultaneous 2-dimensional calculations of both figure errors (profiles) and roughness (statistical). Several optical elements have been implemented so far: plane mirror, elliptic mirror, spherical mirror, slit, detector, grating.
OASYS implementation consists of several abstraction layers of which the user interacts only with the top-most one - OASYS1-oasyswiser (available for installation on PyPI and through internal OASYS add-on manager). The back-end is a numerically optimized (able to use multi-core CPU processing) stand-alone Python library \emph{Wiser} which then interacts with \emph{WOFRY} package which strives to be a generic high-level abstraction of wavefront propagation workflows in OASYS.
The development was done in three stages, it first focused on numerical optimization of Wiser. Since solving the Huygens-Fresnel integral is very expensive, this was a crucial step in usability and accessibility of the code. A few different optimization methods have been used. Using \emph{numba} Python library for just-in-time compiling of calculation kernel, a speed-up on the order of 10-100x has been reached. Afterwards, several new optical elements had to be implemented and a testing phase was conducted. When numerical consistency has been confirmed, work started on the GUI part. At present, all the elements beside the grating are available and ready-to-use as widgets in OASYS.
The package has been presented at the SPIE 2020 conference \cite{manfredda2020} and since then used in several applications (see Section \ref{subsec:panosc_use_cases}).
\subsection{COMSYL}
COMSYL (COherent Modes for SYnchrotron Light) is a software package to perform numerically the coherent mode decomposition of undulator radiation in a storage ring \cite{Glass2017}. COMSYL requires the use of high-performance computer resources. COMSYL is used for beamline modelling at the ESRF-EBS. Several tasks that directly concern COMSYL have been carried out in the context of PaNOSC. COMSYL has evolved from the old OAR task manager to the new SLURM at the ESRF clusters. The OASYS add-on has also been updated. But, with no doubts, the most important and useful development concerns the development of a fast and lightweight tool for partially coherent beamline simulations \cite{SanchezdelRio2022} based on the same concepts of COMSYL, but fully implemented in python. This method has been thoroughly benchmarked against COMSYL and other tools used to simulate partially coherent x-rays \cite{SanchezdelRio2022}, and it is fully integrated in the OASYS package.
Not directly linked with COMSYL, but in the heart of OASYS, it is important to mention that the ray tracing engine SHADOW and the corresponding add-on ShadowOui have been upgraded to allow simulations for monochromators using crystals with high d-spacing \cite{Yu2022}, which is of particular interest for storages-rings producing soft X-rays.
\subsection{Remote usage}
Being based on Orange which itself is using PyQT, OASYS is a standalone desktop application. By default it offers no remote access and/or collaborative development capabilites. A major portion of development has thus been focused on these features.
\subsubsection{Remote workspace access}
As part of PaNOSC deliverable D5.3, we have developed a widget for access to a remote repository of OWS workspaces (binary files in which OASYS projects are saved). The widget is able to read the file content of an arbitrary github repository where the files are be stored. The metadata description is read automatically from the workspace. It allows for access to several online repositories and opening of the workspace directly from within OASYS (Fig. \ref{fig:github_access}).
\subsubsection{Access to computing resources}
\label{sec:docker}
Running programs with rich GUIs remotely is non-trivial. One option is to use remote desktop solutions, but they are non-collaborative and require quite extensive user permissions. HPC servers normally also do not provide desktop environments. We have developed and experimented with several remote access options (see deliverable D5.2), but only the final one is presented and described here. A solution was developed through which arbitrary GUI software can be run as a Jupyter hub plugin as shown in Fig. \ref{fig:jupyter_select}. This links OASYS package with the rest of the WP5 simulation codes and can be installed into any existing Jupyter hub instance and allows OASYS to be run in a web browser (Fig. \ref{fig:oasys_run}), accessing any dedicated computing resources. This also avoids complex user permissions and relegates them to the Jupyter hub instance.
\begin{figure}[htb]
\centering
\setkeys{Gin}{width=\linewidth}
\begin{subfigure}{0.3\textwidth}
\includegraphics{figures/jupyter_select_desktop.png}
\caption{}
\label{fig:jupyter_select}
\end{subfigure}
\hfil
\begin{subfigure}{0.5\textwidth}
\includegraphics{figures/jupyter_oasys_run.png}
\caption{}
\label{fig:oasys_run}
\end{subfigure}% trailing space between `subfigure` environments had to be removed
\caption{(a) Running the XFCE desktop environment from within Jupyter hub. (b) A new browser tab opens with XFCE desktop, providing a way to run OASYS inside the web browser while sharing the computing resources with the Jupyter hub instance.}
\label{fig:oasysJupyter}
\end{figure}
\subsubsection{E-learning}
Building on the solution described in Sec. \ref{sec:docker}, a Docker container has been prepared for the purpose of E-learning. The said Docker container has been successfully used during the PaNOSC summer school organized by the training workpackage, WP8. It was further enriched with all necessary software for the course: Crispy, McStas and OASYS. Students could then seamlessly access all the required software without any installation on local machines and sharing the remote computing resources.
\subsection{openPMD}
As a part of task 5.1 and deliverable D5.1, we (CERIC-ERIC) have developed OASYS support for openPMD format and contributed to the standard for ray-tracing simulations. Two specific widgets, one for reading and one for writing openPMD files, are a part of the PaNOSC toolbox (Fig. \ref{fig:toolbox}).
\subsection{Beyond optics - Full beamline simulations}
Synergy between different simulation codes has been an important part of the developments in WP5. As OASYS simulates the X-ray spot parameters at various points along the beamline, the addition of beam-sample interaction through other codes was sought. Specifically, GAPD calculator found in Simex was used for demonstration purposes and is a part of deliverable D5.3. A prototype widget has been designed that can be seamlessly connected to the standard workflow. With this, one uses the result of X-ray propagation at the sample position and performs diffraction calculations on it. The architecture of the widget was further improved and it now allows for different calculators to be implemented in the future. A checking mechanism whether a given calculation code is properly installed on the system has also been implemented. The widget itself is shown in Fig. \ref{fig:widget} and an example workflow in Fig. \ref{fig:workflow}.
\begin{figure}[htb]
\centering
\setkeys{Gin}{width=\linewidth}
\begin{subfigure}{0.35\textwidth}
\includegraphics{figures/simexOasysWidget2.png}
\caption{}
\label{fig:widget}
\end{subfigure}
\hfil
\begin{subfigure}{0.55\textwidth}
\includegraphics{figures/simexOasysWidget.png}
\caption{}
\label{fig:workflow}
\end{subfigure}% trailing space between `subfigure` environments had to be removed
\caption{(a) Widget for running SimEx calculation directly from Oasys. (b) Example workflow where a beamline simulation result is used as an input to SimEx GAPD calculator.}
\end{figure}
\subsection{OASYS PaNOSC use cases}
\label{subsec:panosc_use_cases}
A list of use cases using OASYS, submitted to PaNOSC website is provided in Table \ref{tab:use_cases}. Our of 31 submitted use cases, 5 of them are either direct contributions to OASYS code or connected to infrastructural uses and setup of OASYS, i. e. remote access, e-learning, etc. This amounts to 16\% of all use cases, implying a significant impact in the community.
\begin{table}[h!!!]
\centering
\begin{tabular}{c l}
\# & Name \\\hline
8 & \href{https://www.panosc.eu/use-cases/use-case-8-remote-collaborative-access-to-beamline-optics-simulations/}{Remote, collaborative access to beamline optics simulations} \\
12 & \href{https://www.panosc.eu/use-cases/panosc-use-case-12-k-b-system-performance-analysis/}{K-B System performance analysis} \\
13 & \href{https://www.panosc.eu/use-cases/panosc-use-case-13-effects-on-the-spot-quality-of-mirror-error-profile-and-source-pointing-instability/}{Effects on the spot quality of the mirror error profile and source pointing instability} \\
16 & \href{https://www.panosc.eu/use-cases/panosc-use-case-16-coherent-mode-decomposition-of-synchrotron-emission-by-comsyl/}{Coherent mode decomposition of synchrotron emission by COMSYL} \\
31 & \href{https://www.panosc.eu/use-cases/use-case-31-seamless-connection-of-jupyter-notebooks-and-gui-applications-for-e-learning-purposes/}{Seamless connection of Jupyter notebooks and GUI applications for e-learning purposes}
\end{tabular}
\caption{\label{tab:use_cases} Links to PaNOSC use cases linked to OASYS. All use cases are published on \url{www.panosc.eu}.}
\end{table}
\section{Contribution from EuXFEL}
\subsection{libpyvinyl development}
libpyvinyl, the python APIs for Virtual Neutron and x-raY Laboratory, is a python package providing a way to harmonize the user interfaces of neutron and X-ray simulation codes by defining essential base and auxiliary classes for developers of a start-to-end simulation platform. Its source code is hosted at: https://github.com/PaNOSC-ViNYL/libpyvinyl and its documentation can be found at: https://libpyvinyl.readthedocs.io/en/latest.
The base classes are:
\begin{itemize}
\item BaseCalculator: the interface to set parameters and perform calculation.
\item BaseData: the representation of the input/output data of a Calculator class.
\item BaseFormat: the interface to exchange data between the memory and the file on the disk in a specific format.
\end{itemize}
The auxiliary classes are:
\begin{itemize}
\item Parameter: the Parameter class describes a single parameter with its limits (valid/invalid range) and unit (if applicable) defined.
\item CalculatorParameters: a container for holding all the Parameter objects that pertain to a single Calculator.
\item DataCollection: a thin layer interface between the Calculator and DataClass. It aggregates the input and output into a single variable, respectively.
\item Instrument: a container for integrating different Calculator objects into a complete start-to-end simulation workflow.
\end{itemize}
A simple example of the usage of libpyvinyl was created to explain its concept (\url{https://github.com/PaNOSC-ViNYL/libpyvinyl/tree/master/tests/integration/plusminus}). It shows how a simple start-to-end instrument simulation platform can be easily built up with libpyvinyl.
The overarching concept was proposed by Carsten Fortmann-Grote, the BaseCalculator and classes related to data were designed by Juncheng E, the Parameter-relevant classes were designed by Mads Bertelsen and Shervin Nourbakhsh, and the Instrument class was developed by Shervin Nourbakhsh and Juncheng E.
\subsection{SimEx-Lite development}
SimEx-Lite is the core package of the SIMEX platform providing the calculator interfaces and data APIs. It is hosted at \url{https://github.com/PaNOSC-ViNYL/SimEx-Lite}, and its documentation can be found at \url{https://simex-lite.readthedocs.io/en/latest/}. There are several calculator and data APIs already developed in SimEx-Lite.
Calculators:
\begin{itemize}
\item SourceCalculators
\begin{itemize}
\item GaussianSourceCalculator
\end{itemize}
\item PropagationCalculators
\begin{itemize}
\item WPGPropagationCalculator
\end{itemize}
\item PMICalculators (PhotonMattterInteractionCalculators)
\begin{itemize}
\item SimpleScatteringPMICalculator
\end{itemize}
\item DiffractionCalculators
\begin{itemize}
\item SingFELDiffractionCalculator
\item CrystFELDiffractionCalculator
\end{itemize}
\item DetectorCalculators
\begin{itemize}
\item GaussianNoiseCalculator
\end{itemize}
\end{itemize}
Data APIs:
\begin{itemize}
\item WavefrontData
\begin{itemize}
\item WPGFormat
\end{itemize}
\item SampleData
\begin{itemize}
\item ASEFormat (For atomic structure formats supported by ASE)
\end{itemize}
\item PMIData (PhotonMatterInteractionData)
\begin{itemize}
\item ASEFormat (For atomic structure formats supported by ASE)
\end{itemize}
\item Diffractiondata
\item SingFELFormat
\item EMCFormat
\item DetectorData
\begin{itemize}
\item CXIFormat
\end{itemize}
\end{itemize}
A calculator can be easily constructed within SimEx-Lite. Here, we take the\\
SingFELDiffractionCalculator as an example to explain its usage.
\begin{lstlisting}[language=Python]
from SimExLite.PMIData import PMIData, XMDYNFormat
from SimExLite.DiffractionCalculators import SingFELDiffractionCalculator
input_data = PMIData.from_file("./testFiles/PMI.h5", XMDYNFormat, "PMI_data")
diffraction = SingFELDiffractionCalculator(
name="SingFELCalculator",
input=input_data,)
print(diffraction.parameters)
\end{lstlisting}
With \verb|print(diffraction.parameters)| at the end, one can check the default values of the calculator's parameters. The output will look like this:
\begin{lstlisting}
- Parameters object -
random_rotation True If it's False, the orientations...
calculate_Compton False If calculate the compton...
slice_interval 100 The slice interval of the pmi...
slice_index_upper 1 The upper limit of the slice...
pmi_start_ID 1 The start ID of the pmi files
pmi_stop_ID 1 The stop ID of the pmi files
number_of_diffraction_patterns 10 The number of diffraction...
pixel_size 0.001 [meter] The pixel size of the detector
pixels_x 10 Number of pixels in x direction
pixels_y 5 Number of pixels in y direction
distance 0.13 [meter] Sample to detector distance
mpi_command mpirun -n 2 The mpi command to run pysingfel
\end{lstlisting}
To run a simulation, as long as the corresponding backengine software is installed in the system, one can start the simulation with this function:
\begin{lstlisting}
output = diffraction.backengine()
\end{lstlisting}
The output is a data class mapping to the native output of the simulation software, with the \verb|output.get_data()| function, one can read the output data into memory as a python dictionary and conduct further analysis.
With different calculators representing different stages of an experiment, one can create an \verb|Instrument| instance to perform start-to-end simulation. An example is provided at
\url{https://github.com/PaNOSC-ViNYL/instrument_database/blob/spb/institutes/EuXFEL/instruments/SPB-SFX/HEAD/simex-lite/SPB-SFX.py}. One can load this defined instrument and run the defined simulation
The packages integrated in the SIMEX platform have been applied in researches reported in several peer-reviewed publications\cite{fortmann-grote2017iucrj,e2021,e2022}.
% \begin{table}
% \centering
% % \begin{tabular}{| >{\centering\arraybackslash} m{8cm}| >{\centering\arraybackslash}m{6cm}|}
% \begin{tabular}{| >{\bfseries} m{7cm}|m{6cm}|}
% \hline
% SourceCalculators & GaussianSourceCalculator \\\hline
% PropagationCalculators & WPGPropagationCalculator \\\hline
% PMICalculators \newline (PhotonMattterInteractionCalculators) & SimpleScatteringPMICalculator \\\hline
% \multirow{2}{*}{DiffractionCalculators} & SingFELDiffractionCalculator \\\cline{2-2}
% & CrystFELDiffractionCalculator \\\hline
% DetectorCalculators & GaussianNoiseCalculator \\\hline
% \end{tabular}
% \caption{\label{tab:simexlite} Calculators developed in SimEx-Lite by Nov 17, 2022.}
% \end{table}
\subsection{Integrated simulation data workflows}
EXtra-xwiz is a command-line tool for automated processing of the calibrated serial crystalography data. \cite{xwiz} As described in the Task 5.5 of the proposal of Work Package 5, we have created a workflow to couple SimEx-Lite and EXtra-xwiz together to optimize instrument parameters for serial femtosecond crystallography (SFX) experiments by analyzing the simulation data from SimEx-Lite with EXtra-xwiz.
As the schematic of the workflow shown in Fig.~\ref{fig:feedbackloop}, the simulation parameters and sample structure (can be any format compatible with the PDB format) are set for the CrystFEL calculator in SimEx-Lite. After running the simulation, the diffraction patterns output in CXI format is analysed by EXtra-xwiz. By making use of the metrics obtained with EXtra-xwiz, we can optimize the parameters to maximize the metric of interest in a certain condition. The optimized parameters can be a useful reference to achieve better experiment quality.
\begin{figure}[h!!!]
\centering
\includegraphics[width=0.75\columnwidth]{figures/feedbackloop.png}
\caption{The schematic of the coupling of simulation software and data analysis tools.}
\label{fig:feedbackloop}
\end{figure}
One of the workflow's use cases is to optimize the sample-to-detector distance for SFX experiments to reach the highest index rate within an acceptable range of resolution. We scanned several data points of sample-to-detector distance for the SFX simulation and analyzed the output with EXtra-xwiz to get the index rate in the corresponding condition (Fig.~\ref{fig:optSim}) {\color{blue}[The figure is currently just a place holder, the results will be updated next week.]}
\begin{figure}
\centering
\begin{tabular}{m{3.2in} m{3.2in}}
\LARGE{(a)} & \LARGE{(b)}\\
\includegraphics[width=0.48\textwidth]{figures/SFX_pattern.png} &
\includegraphics[width=0.48\textwidth]{figures/optimize_curve.png}
\end{tabular}
\caption
{\label{fig:optSim}
(a) An example SFX pattern for the simulation, the white rectangle boxes indicate found peaks. (b) The index rate curve as a function of the sample-to-detector distance.}
\end{figure}
\clearpage
\section{Towards Digital Twin}
\subsection{Goal}
Interface Mcstas simulations of an instrument from a research facility to the data acquisition system in order to offer to users the same experience as during their experiments. Users are then able to prepare proposals, preparing in advance their experiments optimizing the instrument settings to maximize their scientific outcome and reduce beam time needed.
\subsection{Current status}
The project is still in an advanced prototype state.
A new tab dedicated to specific settings for the simulation mode has been added to Nomad (see Fig.~\ref{fig:Nomad_sim_settings}.
The data acquisition is performed as for the real data and results are visualised and treated accordingly.
In Fig.~\ref{fig:Nomad_ThALES_vanadium_scan} a scan with the triple axis spectrometer ThALES is performed using a vanadium sample.
\subsection{Repository}
Currently in internal ILL gitlab, will be migrated to the PANOSC github repository in the next days.
Everything is released under the GPLv3 licence.
\subsection{Structure}
\begin{figure}[tbh]
\includegraphics[width=\textwidth]{figures/communication.dot.pdf}
\label{fig:DT_comm}
\caption{Digital Twin Communication Diagram.}
\end{figure}
\begin{figure}[htbp]
\includegraphics[width=0.5\textwidth]{figures/McStas-settings.png}
\caption{ILL's Nomad simulation settings tab}
\label{fig:Nomad_sim_settings}
\end{figure}
\begin{figure}[htbp]
\includegraphics[width=0.5\textwidth]{figures/McStas-scan-plot.png}
\caption{Plot of a scan with ThALES instrument with a Vanadium sample. The instrument description retrieved from the instrument database}
\label{fig:Nomad_ThALES_vanadium_scan}
\end{figure}
The framework consists in:
\begin{itemize}
\item one client library (C++)
\item one simulation server
\item one application manager server
\item McStas instrument executables
\end{itemize}
The client is integrated in the data acquisition system at ILL, named Nomad, that can be started either in \emph{REAL} mode to control the instrument and acquire real data, or in \emph[SIMULATED] mode to communicate to the simulation server.
The simulation server objective is to receive simulation requests from a client, schedule and launch the McStas instrument applications, read and cache the results, and send them back to the client.
The managing of the application is performed using the Cameo library developed at the ILL (open source and publicly available). Cameo allows not only to control other applications (start, stop, etc.) but also communication between them with requester-responder publisher-subscriber models implemented using the Zmq library.
The communication between the different components is sketched in Fig.~\ref{fig:DT_comm}
\newcommand{\libpyvinyl}{libpyvinyl}
\section{Something more about \libpyvinyl (by Shervin)}
Goals:
\begin{itemize}
\item high level neutron and X-ray simulation API
\item providing harmonized user interface
\item allowing seamless interoperability of individual simulations
\item facilitating the concatenation of simulation steps into a simulation pipeline
\end{itemize}
How:
\begin{itemize}
\item The simulation workflow has been segmented in independent units
\item Abstraction of connections and components allow flexibility in inclusion of new simulation modules/softwares
\end{itemize}
\begin{figure}[tp]
\begin{tikzpicture}[nodes={draw}]
\graph [layered layout] {
source -> optics // [layered layout]{
optical element 1 -> opt/\dots -> optical element N;}
-> sample
-> optics2/optics
-> detector;
};
\end{tikzpicture}
\label{fig:instrument_diagram}
\caption{A simplified description of an instrument and its elements}
\end{figure}
\begin{figure}[tp]
\begin{tikzpicture}[draw, text width=2.5cm,component align=first node]
\graph[layered layout,nodes={draw},component direction=right]{
instrument/Instrument[draw,text width=3cm]// [layered layout]{
calc1/calculator 1 -- calc2/\dots -- calc3/\dots -- calc4/\dots -- calcN/calculator N;
};
BaseCalculator[draw,text width=3cm] // [layered layout]{
engine -- parameters -- input/input data[x=0,y=0] -- output/output data;};
BaseData[regardless at={(4,-0.5)}] -> {input,output};
Parameter[regardless at={(4,1)}] -> parameters;
};
\draw (calc3) edge[<-] (BaseCalculator);
\end{tikzpicture}
\label{fig:libpyvinyl_class_relations}
\caption{Simplified diagram showing the relations between the main \libpyvinyl classes}
\end{figure}
\subsection{\libpyvinyl parameters usage example}
The Parameter class describes a single parameter intended to be an input for a calculator.
\begin{itemize}
\item no a priori for the type
\item usually a physical quantity that can be expressed by a floating point number or a string
\item units can be defined and unit conversions taken into account automagically to provide to the calculator the value in the units it expects
\end{itemize}
\begin{lstlisting}
energy_parameter = Parameter(name="energy", unit="meV", comment="Energy of emitted particles")
energy_parameter.value = 5.0
\end{lstlisting}
We defined the default unit to be meV, but since the object is aware of the unit, it is possible to provide in another energy unit using Pint.
\begin{lstlisting}
import pint
ureg = pint.UnitRegistry()
energy_parameter.value = 5.0*ureg.eV
\end{lstlisting}
\subsection{Parameters common to multiple calculators}
\begin{itemize}
\item same meaning
\item different units (maybe)
\item affecting multiple calculators
\end{itemize}
\textbf{ They need to be changed together when running the simulation:
}
\begin{tikzpicture}
\graph[layered layout]{
instrument[draw]//[layered layout]{
//[layered layout]{calc1 -> {par1, par2, par3};},
//[layered layout]{calc2 -> {par4, par5, par6}}
calc1 -> calc2;
mp1[draw,font=\bfseries] <- {par3,par4};
par6 -> mp2[draw,font=\bfseries];
};
};
\draw (calc1) edge[->] (calc2);
\end{tikzpicture}
\begin{itemize}
\item Example: master is the neutron energy, calc1 is source and calc2 is a monochromator
\item A single parameter promoted as ``master'' to distinguish parameters to be changed by the ``end user'' or for setting up the workflow.
\end{itemize}