Changes for page Partial Coherence Simulation
Last modified by rangeadm on 2025/04/23 16:13
Summary
-
Page properties (2 modified, 0 added, 0 removed)
-
Attachments (0 modified, 0 added, 15 removed)
- 2020-07-07 16_48_07-Window.png
- 2020-07-07 16_51_14-Window.png
- 2020-07-07 16_52_27-Window.png
- 2020-07-07 16_53_22-Window.png
- GenerateSASE.ipynb
- GenerateSASE.py
- SASEPulseGenV2.ipynb
- SASEPulseGenV4.ipynb
- badge_logo.svg
- binder_badge.png
- image2020-2-5_15-14-4.png
- partia__coherence1.png
- partia__coherence2.png
- simulating_SASE_pulses.ipynb
- simulating_SASE_pulses.pdf
Details
- Page properties
-
- Tags
-
... ... @@ -1,1 +1,0 @@ 1 -favourite|fel|simulation - Content
-
... ... @@ -31,14 +31,12 @@ 31 31 32 32 \\ 33 33 34 - offline version:34 +\\ 35 35 36 +[[attach:GenerateSASE.ipynb]] 36 36 38 +[[attach:GenerateSASE.py]] 37 37 38 -{{view-file att--filename="simulating_SASE_pulses.pdf" height="250"/}} 39 - 40 -[[attach:simulating_SASE_pulses.ipynb]] 41 - 42 42 \\ 43 43 44 44 \\ ... ... @@ -48,5 +48,3 @@ 48 48 \\ 49 49 50 50 \\ 51 - 52 -\\
- 2020-07-07 16_48_07-Window.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -82.8 KB - Content
- 2020-07-07 16_51_14-Window.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -59.9 KB - Content
- 2020-07-07 16_52_27-Window.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -95.5 KB - Content
- 2020-07-07 16_53_22-Window.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -75.7 KB - Content
- GenerateSASE.ipynb
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -3.5 KB - Content
-
... ... @@ -1,104 +1,0 @@ 1 -{ 2 - "cells": [ 3 - { 4 - "cell_type": "code", 5 - "execution_count": 1, 6 - "metadata": { 7 - "collapsed": true 8 - }, 9 - "outputs": [], 10 - "source": [ 11 - "import numpy as np\n", 12 - "import matplotlib.pyplot as plt\n", 13 - "\n", 14 - "def GetSASE(CentralEnergy, dE_FWHM, dt_FWHM, samples=0, Axis=True):\n", 15 - " h=4.135667662 #in eV*fs\n", 16 - " dE=dE_FWHM/2.355 #in eV, converts to sigma\n", 17 - " dt=dt_FWHM/2.355 #in fs, converts to sigma\n", 18 - " if samples == 0:\n", 19 - " \tsamples=int(400.*dt*CentralEnergy/h)\n", 20 - " else:\n", 21 - " \tif (samples < 400.*dt*CentralEnergy/h):\n", 22 - " \t\tprint(\"Number of samples is a little small, proceeding anyway. Got\", samples, \"prefer more than\",400.*dt*CentralEnergy/h)\n", 23 - "\n", 24 - " EnAxis=np.linspace(0.,20.*CentralEnergy,num=samples)\n", 25 - " EnInput=np.zeros(samples, dtype=np.complex64)\n", 26 - " #for i in range(samples):\n", 27 - " EnInput=np.exp(-(EnAxis-CentralEnergy)**2/2./dE**2+2*np.pi*1j*np.random.random(size=samples))\n", 28 - " En_FFT=np.fft.fft(EnInput)\n", 29 - " TAxis=np.fft.fftfreq(samples,d=(20.*CentralEnergy)/samples)*h\n", 30 - " TOutput=np.exp(-TAxis**2/2./dt**2)*En_FFT\n", 31 - " EnOutput=np.fft.ifft(TOutput)\n", 32 - " if (Axis):\n", 33 - " \treturn EnAxis, EnOutput, TAxis, TOutput\n", 34 - " else:\n", 35 - " \treturn EnOutput, TOutput\n", 36 - "\n" 37 - ] 38 - }, 39 - { 40 - "cell_type": "code", 41 - "execution_count": 2, 42 - "metadata": { 43 - "collapsed": true 44 - }, 45 - "outputs": [], 46 - "source": [ 47 - "\n", 48 - "# set the main parameters here:\n", 49 - "CentralEnergy=80. # in eV\n", 50 - "bandwidth=0.5 # bandwidth in %\n", 51 - "dt_FWHM=30. # FWHM of the temporal duration on average \n", 52 - "\n", 53 - "dE_FWHM=CentralEnergy/100 *bandwidth # calculate bandwidth of the spectrum in eV\n", 54 - "\n", 55 - "# calculate 3 SASE pulses\n", 56 - "EnAxis, EnOutput, TAxis, TOutput = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 57 - "EnAxis2, EnOutput2, TAxis2, TOutput2 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 58 - "EnAxis3, EnOutput3, TAxis3, TOutput3 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 59 - "\n", 60 - "\n", 61 - "# plot spectrum\n", 62 - "ax1 = plt.subplot(1, 2, 1)\n", 63 - "plt.plot(EnAxis,np.absolute(EnOutput),EnAxis2,np.absolute(EnOutput2),EnAxis3,np.absolute(EnOutput3) )\n", 64 - "plt.xlim(CentralEnergy-2.*dE_FWHM,CentralEnergy+2.*dE_FWHM)\n", 65 - "plt.title('Average pulse duration: %.1f fs' % dt_FWHM ) \n", 66 - "ax1.set_xlabel('Photon energy in eV')\n", 67 - "ax1.set_ylabel('spectral intensity')\n", 68 - "\n", 69 - "# plot time structure\n", 70 - "ax1 =plt.subplot(1, 2, 2)\n", 71 - "plt.plot(TAxis,np.absolute(TOutput),TAxis2,np.absolute(TOutput2), TAxis3,np.absolute(TOutput3))\n", 72 - "plt.xlim(-2.*dt_FWHM,+2.*dt_FWHM)\n", 73 - "ax1.set_xlabel('time in fs')\n", 74 - "ax1.set_ylabel('pulse amplitude')\n", 75 - "\n", 76 - "plt.show()\n", 77 - "\n", 78 - "\n" 79 - ] 80 - } 81 - ], 82 - "metadata": { 83 - "kernelspec": { 84 - "display_name": "Python 3", 85 - "language": "python", 86 - "name": "python3" 87 - }, 88 - "language_info": { 89 - "codemirror_mode": { 90 - "name": "ipython", 91 - "version": 3 92 - }, 93 - "file_extension": ".py", 94 - "mimetype": "text/x-python", 95 - "name": "python", 96 - "nbconvert_exporter": "python", 97 - "pygments_lexer": "ipython3", 98 - "version": "3.4.3" 99 - } 100 - }, 101 - "nbformat": 4, 102 - "nbformat_minor": 0 103 -} 104 -
- GenerateSASE.py
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -2.0 KB - Content
-
... ... @@ -1,56 +1,0 @@ 1 -import numpy as np 2 -import matplotlib.pyplot as plt 3 - 4 -def GetSASE(CentralEnergy, dE_FWHM, dt_FWHM, samples=0, Axis=True): 5 -h=4.135667662 #in eV*fs 6 -dE=dE_FWHM/2.355 #in eV, converts to sigma 7 -dt=dt_FWHM/2.355 #in fs, converts to sigma 8 -if samples == 0: 9 -samples=int(400.*dt*CentralEnergy/h) 10 -else: 11 -if (samples < 400.*dt*CentralEnergy/h): 12 -print("Number of samples is a little small, proceeding anyway. Got", samples, "prefer more than",400.*dt*CentralEnergy/h) 13 - 14 -EnAxis=np.linspace(0.,20.*CentralEnergy,num=samples) 15 -EnInput=np.zeros(samples, dtype=np.complex64) 16 -EnInput=np.exp(-(EnAxis-CentralEnergy)**2/2./dE**2+2*np.pi*1j*np.random.random(size=samples)) 17 -En_FFT=np.fft.fft(EnInput) 18 -TAxis=np.fft.fftfreq(samples,d=(20.*CentralEnergy)/samples)*h 19 -TOutput=np.exp(-TAxis**2/2./dt**2)*En_FFT 20 -EnOutput=np.fft.ifft(TOutput) 21 -if (Axis): 22 -return EnAxis, EnOutput, TAxis, TOutput 23 -else: 24 -return EnOutput, TOutput 25 - 26 - 27 -# set the main parameters here: 28 -CentralEnergy=80. # in eV 29 -bandwidth=0.5 # bandwidth in % 30 -dt_FWHM=30. # FWHM of the temporal duration on average 31 - 32 -dE_FWHM=CentralEnergy/100 *bandwidth # calculate bandwidth of the spectrum in eV 33 - 34 -# calculate 3 SASE pulses 35 -EnAxis, EnOutput, TAxis, TOutput = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM) 36 -EnAxis2, EnOutput2, TAxis2, TOutput2 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM) 37 -EnAxis3, EnOutput3, TAxis3, TOutput3 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM) 38 - 39 - 40 -# plot spectrum 41 -ax1 = plt.subplot(1, 2, 1) 42 -plt.plot(EnAxis,np.absolute(EnOutput),EnAxis2,np.absolute(EnOutput2),EnAxis3,np.absolute(EnOutput3) ) 43 -plt.xlim(CentralEnergy-2.*dE_FWHM,CentralEnergy+2.*dE_FWHM) 44 -plt.title('Average pulse duration: %.1f fs' % dt_FWHM ) 45 -ax1.set_xlabel('Photon energy in eV') 46 -ax1.set_ylabel('spectral intensity') 47 - 48 -# plot time structure 49 -ax1 =plt.subplot(1, 2, 2) 50 -plt.plot(TAxis,np.absolute(TOutput),TAxis2,np.absolute(TOutput2), TAxis3,np.absolute(TOutput3)) 51 -plt.xlim(-2.*dt_FWHM,+2.*dt_FWHM) 52 -ax1.set_xlabel('time in fs') 53 -ax1.set_ylabel('pulse amplitude') 54 - 55 -plt.show() 56 -
- SASEPulseGenV2.ipynb
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -103.3 KB - Content
- SASEPulseGenV4.ipynb
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -3.7 KB - Content
-
... ... @@ -1,105 +1,0 @@ 1 -{ 2 - "cells": [ 3 - { 4 - "cell_type": "code", 5 - "execution_count": 1, 6 - "metadata": { 7 - "collapsed": false 8 - }, 9 - "outputs": [], 10 - "source": [ 11 - "# -*- coding: utf-8 -*-\n", 12 - "import numpy as np\n", 13 - "from IPython import embed\n", 14 - "import matplotlib.pyplot as plt\n", 15 - "\n", 16 - "def GetSASE(CentralEnergy, dE_FWHM, dt_FWHM, samples=0, Axis=True):\n", 17 - " h=4.135667662 #in eV*fs\n", 18 - " dE=dE_FWHM/2.355 #in eV, converts to sigma\n", 19 - " dt=dt_FWHM/2.355 #in fs, converts to sigma\n", 20 - " if samples == 0:\n", 21 - " \tsamples=int(400.*dt*CentralEnergy/h)\n", 22 - " else:\n", 23 - " \tif (samples < 400.*dt*CentralEnergy/h):\n", 24 - " \t\tprint(\"Number of samples is a little small, proceeding anyway. Got\", samples, \"prefer more than\",400.*dt*CentralEnergy/h)\n", 25 - "\n", 26 - " EnAxis=np.linspace(0.,20.*CentralEnergy,num=samples)\n", 27 - " EnInput=np.zeros(samples, dtype=np.complex64)\n", 28 - " #for i in range(samples):\n", 29 - " EnInput=np.exp(-(EnAxis-CentralEnergy)**2/4./dE**2+2*np.pi*1j*np.random.random(size=samples))\n", 30 - " En_FFT=np.fft.fft(EnInput)\n", 31 - " TAxis=np.fft.fftfreq(samples,d=(20.*CentralEnergy)/samples)*h\n", 32 - " TOutput=np.exp(-TAxis**2/4./dt**2)*En_FFT\n", 33 - " EnOutput=np.fft.ifft(TOutput)\n", 34 - " if (Axis):\n", 35 - " \treturn EnAxis, EnOutput, TAxis, TOutput\n", 36 - " else:\n", 37 - " \treturn EnOutput, TOutput\n", 38 - "\n" 39 - ] 40 - }, 41 - { 42 - "cell_type": "code", 43 - "execution_count": 2, 44 - "metadata": { 45 - "collapsed": false 46 - }, 47 - "outputs": [], 48 - "source": [ 49 - "# set the main parameters here:\n", 50 - "CentralEnergy=80. # in eV\n", 51 - "bandwidth=0.3 # bandwidth in %\n", 52 - "dt_FWHM=30. # FWHM of the temporal duration on average \n", 53 - "\n", 54 - "dE_FWHM=CentralEnergy/100 *bandwidth # calculate bandwidth of the spectrum in eV\n", 55 - "\n", 56 - "# calculate 3 SASE pulses\n", 57 - "EnAxis, EnOutput, TAxis, TOutput = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 58 - "EnAxis2, EnOutput2, TAxis2, TOutput2 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 59 - "EnAxis3, EnOutput3, TAxis3, TOutput3 = GetSASE(CentralEnergy=CentralEnergy, dE_FWHM=dE_FWHM, dt_FWHM=dt_FWHM)\n", 60 - "\n", 61 - "\n", 62 - "# plot them\n", 63 - "ax1 = plt.subplot(1, 2, 1)\n", 64 - "plt.plot(EnAxis,np.absolute(EnOutput),EnAxis2,np.absolute(EnOutput2),EnAxis3,np.absolute(EnOutput3) )\n", 65 - "plt.xlim(CentralEnergy-2.*dE_FWHM,CentralEnergy+2.*dE_FWHM)\n", 66 - "plt.title('Average pulse duration: %.1f fs' % dt_FWHM ) \n", 67 - "ax1.set_xlabel('Photon energy in eV')\n", 68 - "ax1.set_ylabel('spectral intensity')\n", 69 - "\n", 70 - "ax1 =plt.subplot(1, 2, 2)\n", 71 - "plt.plot(TAxis,np.absolute(TOutput),TAxis2,np.absolute(TOutput2), TAxis, np.max(np.absolute(TOutput))*np.exp(-TAxis**2/2/dt_FWHM**2*2.355**2))\n", 72 - "plt.plot(TAxis,np.absolute(TOutput),TAxis2,np.absolute(TOutput2), TAxis3,np.absolute(TOutput3))\n", 73 - "\n", 74 - "plt.xlim(-2.*dt_FWHM,+2.*dt_FWHM)\n", 75 - "ax1.set_xlabel('time in fs')\n", 76 - "ax1.set_ylabel('pulse amplitude')\n", 77 - "\n", 78 - "plt.show()\n" 79 - ] 80 - } 81 - ], 82 - "metadata": { 83 - "celltoolbar": "Raw Cell Format", 84 - "kernelspec": { 85 - "display_name": "Python 3", 86 - "language": "python", 87 - "name": "python3" 88 - }, 89 - "language_info": { 90 - "codemirror_mode": { 91 - "name": "ipython", 92 - "version": 3 93 - }, 94 - "file_extension": ".py", 95 - "mimetype": "text/x-python", 96 - "name": "python", 97 - "nbconvert_exporter": "python", 98 - "pygments_lexer": "ipython3", 99 - "version": "3.4.3" 100 - } 101 - }, 102 - "nbformat": 4, 103 - "nbformat_minor": 2 104 -} 105 -
- badge_logo.svg
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -3.3 KB - Content
-
... ... @@ -1,1 +1,0 @@ 1 -<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="109" height="20"><linearGradient id="b" x2="0" y2="100%"><stop offset="0" stop-color="#bbb" stop-opacity=".1"/><stop offset="1" stop-opacity=".1"/></linearGradient><clipPath id="a"><rect width="109" height="20" rx="3" fill="#fff"/></clipPath><g clip-path="url(#a)"><path fill="#555" d="M0 0h64v20H0z"/><path fill="#579aca" d="M64 0h45v20H64z"/><path fill="url(#b)" d="M0 0h109v20H0z"/></g><g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="110"><image x="5" y="3" width="14" height="14" xlink:href=""/> <text x="415" y="150" fill="#010101" fill-opacity=".3" transform="scale(.1)" textLength="370">launch</text><text x="415" y="140" transform="scale(.1)" textLength="370">launch</text><text x="855" y="150" fill="#010101" fill-opacity=".3" transform="scale(.1)" textLength="350">binder</text><text x="855" y="140" transform="scale(.1)" textLength="350">binder</text></g> </svg>
- binder_badge.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -6.6 KB - Content
- image2020-2-5_15-14-4.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -55.4 KB - Content
- partia__coherence1.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -328.7 KB - Content
- partia__coherence2.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -72.5 KB - Content
- simulating_SASE_pulses.ipynb
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -147.1 KB - Content
- simulating_SASE_pulses.pdf
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.XWikiGuest - Size
-
... ... @@ -1,1 +1,0 @@ 1 -33.4 KB - Content