Add analysis for voice coil actuators (uniaxial model)
This commit is contained in:
		
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial-cas-iff-vc.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial-cas-iff-vc.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 134 KiB | 
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial-sensitivity-vc-disturbances.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial-sensitivity-vc-disturbances.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 128 KiB | 
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial-sensitivity-vc-force-dist.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial-sensitivity-vc-force-dist.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 103 KiB | 
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial-vc-cas-dist.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial-vc-cas-dist.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 158 KiB | 
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial-vc-psd-dist.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial-vc-psd-dist.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 143 KiB | 
							
								
								
									
										
											BIN
										
									
								
								figs/uniaxial_iff_vc_open_loop.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								figs/uniaxial_iff_vc_open_loop.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 91 KiB | 
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -47,6 +47,8 @@ The idea is to use the same model as the full Simscape Model but to restrict the | |||||||
| This is done in order to more easily study the system and evaluate control techniques. | This is done in order to more easily study the system and evaluate control techniques. | ||||||
|  |  | ||||||
| * Simscape Model | * Simscape Model | ||||||
|  | <<sec:simscape_model>> | ||||||
|  |  | ||||||
| A schematic of the uniaxial model used for simulations is represented in figure [[fig:uniaxial-model-nass-flexible]]. | A schematic of the uniaxial model used for simulations is represented in figure [[fig:uniaxial-model-nass-flexible]]. | ||||||
|  |  | ||||||
| The perturbations $w$ are: | The perturbations $w$ are: | ||||||
| @@ -623,6 +625,7 @@ Schematics of the active damping techniques are displayed in figure [[fig:uniaxi | |||||||
| [[file:figs/uniaxial-model-nass-flexible-active-damping.png]] | [[file:figs/uniaxial-model-nass-flexible-active-damping.png]] | ||||||
|  |  | ||||||
| * Undamped System | * Undamped System | ||||||
|  | <<sec:undamped>> | ||||||
| ** Introduction                                                     :ignore: | ** Introduction                                                     :ignore: | ||||||
| Let's start by study the undamped system. | Let's start by study the undamped system. | ||||||
|  |  | ||||||
| @@ -2184,6 +2187,7 @@ And initialize the controllers. | |||||||
| Direct Velocity Feedback: | Direct Velocity Feedback: | ||||||
| #+end_important | #+end_important | ||||||
| * With Cedrat Piezo-electric Actuators | * With Cedrat Piezo-electric Actuators | ||||||
|  | <<sec:cedrat_actuator>> | ||||||
| ** Matlab Init                                             :noexport:ignore: | ** Matlab Init                                             :noexport:ignore: | ||||||
| #+begin_src matlab :tangle no :exports none :results silent :noweb yes :var current_dir=(file-name-directory buffer-file-name) | #+begin_src matlab :tangle no :exports none :results silent :noweb yes :var current_dir=(file-name-directory buffer-file-name) | ||||||
|   <<matlab-dir>> |   <<matlab-dir>> | ||||||
| @@ -2749,3 +2753,400 @@ It is important to note that the effect of direct forces applied to the sample a | |||||||
| | Sensitivity ($F_s$)       | - (at low freq) | +               | +        | | | Sensitivity ($F_s$)       | - (at low freq) | +               | +        | | ||||||
| | Sensitivity ($F_{ty,rz}$) | +               | -               | +        | | | Sensitivity ($F_{ty,rz}$) | +               | -               | +        | | ||||||
| | Overall RMS of $D$        | =               | =               | =        | | | Overall RMS of $D$        | =               | =               | =        | | ||||||
|  | * Voice Coil | ||||||
|  | <<sec:voice_coil>> | ||||||
|  | ** Matlab Init                                             :noexport:ignore: | ||||||
|  | #+begin_src matlab :tangle no :exports none :results silent :noweb yes :var current_dir=(file-name-directory buffer-file-name) | ||||||
|  |   <<matlab-dir>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none :results silent :noweb yes | ||||||
|  |   <<matlab-init>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab :tangle no | ||||||
|  |   simulinkproject('../'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab | ||||||
|  |   open 'simscape/sim_nano_station_uniaxial.slx' | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | ** Init | ||||||
|  | We initialize all the stages with the default parameters. | ||||||
|  | The nano-hexapod is an hexapod with voice coils and the sample has a mass of 50kg. | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   initializeGround(); | ||||||
|  |   initializeGranite(); | ||||||
|  |   initializeTy(); | ||||||
|  |   initializeRy(); | ||||||
|  |   initializeRz(); | ||||||
|  |   initializeMicroHexapod(); | ||||||
|  |   initializeAxisc(); | ||||||
|  |   initializeMirror(); | ||||||
|  |   initializeNanoHexapod(struct('actuator', 'lorentz')); | ||||||
|  |   initializeSample(struct('mass', 50)); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | All the controllers are set to 0 (Open Loop). | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   K = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K', '-append'); | ||||||
|  |   K_iff = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K_iff', '-append'); | ||||||
|  |   K_rmc = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K_rmc', '-append'); | ||||||
|  |   K_dvf = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K_dvf', '-append'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | ** Identification | ||||||
|  | We identify the dynamics of the system. | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Options for Linearized | ||||||
|  |   options = linearizeOptions; | ||||||
|  |   options.SampleTime = 0; | ||||||
|  |  | ||||||
|  |   %% Name of the Simulink File | ||||||
|  |   mdl = 'sim_nano_station_uniaxial'; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | The inputs and outputs are defined below and corresponds to the name of simulink blocks. | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Input/Output definition | ||||||
|  |   io(1)  = linio([mdl, '/Dw'],   1, 'input'); % Ground Motion | ||||||
|  |   io(2)  = linio([mdl, '/Fs'],   1, 'input'); % Force applied on the sample | ||||||
|  |   io(3)  = linio([mdl, '/Fnl'],  1, 'input'); % Force applied by the NASS | ||||||
|  |   io(4)  = linio([mdl, '/Fdty'], 1, 'input'); % Parasitic force Ty | ||||||
|  |   io(5)  = linio([mdl, '/Fdrz'], 1, 'input'); % Parasitic force Rz | ||||||
|  |  | ||||||
|  |   io(6)  = linio([mdl, '/Dsm'],  1, 'output'); % Displacement of the sample | ||||||
|  |   io(7)  = linio([mdl, '/Fnlm'], 1, 'output'); % Force sensor in NASS's legs | ||||||
|  |   io(8)  = linio([mdl, '/Dnlm'], 1, 'output'); % Displacement of NASS's legs | ||||||
|  |   io(9)  = linio([mdl, '/Dgm'],  1, 'output'); % Absolute displacement of the granite | ||||||
|  |   io(10) = linio([mdl, '/Vlm'],  1, 'output'); % Measured absolute velocity of the top NASS platform | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | Finally, we use the =linearize= Matlab function to extract a state space model from the simscape model. | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Run the linearization | ||||||
|  |   G_vc = linearize(mdl, io, options); | ||||||
|  |   G_vc.InputName  = {'Dw',   ... % Ground Motion [m] | ||||||
|  |                      'Fs',   ... % Force Applied on Sample [N] | ||||||
|  |                      'Fn',   ... % Force applied by NASS [N] | ||||||
|  |                      'Fty',  ... % Parasitic Force Ty [N] | ||||||
|  |                      'Frz'};     % Parasitic Force Rz [N] | ||||||
|  |   G_vc.OutputName = {'D',    ... % Measured sample displacement x.r.t. granite [m] | ||||||
|  |                      'Fnm',  ... % Force Sensor in NASS [N] | ||||||
|  |                      'Dnm',  ... % Displacement Sensor in NASS [m] | ||||||
|  |                      'Dgm',  ... % Asbolute displacement of Granite [m] | ||||||
|  |                      'Vlm'}; ... % Absolute Velocity of NASS [m/s] | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | Finally, we save the identified system dynamics for further analysis. | ||||||
|  | #+begin_src matlab | ||||||
|  |   save('./uniaxial/mat/plants.mat', 'G_vc', '-append'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | ** Sensitivity to Disturbances | ||||||
|  | We load the dynamics when using a piezo-electric nano hexapod to compare the results. | ||||||
|  | #+begin_src matlab | ||||||
|  |   load('./uniaxial/mat/plants.mat', 'G'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | We show several plots representing the sensitivity to disturbances: | ||||||
|  | - in figure [[fig:uniaxial-sensitivity-vc-disturbances]] the transfer functions from ground motion $D_w$ to the sample position $D$ and the transfer function from direct force on the sample $F_s$ to the sample position $D$ are shown | ||||||
|  | - in figure [[fig:uniaxial-sensitivity-vc-force-dist]], it is the effect of parasitic forces of the positioning stages ($F_{ty}$ and $F_{rz}$) on the position $D$ of the sample that are shown | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(0, 3, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |  | ||||||
|  |   subplot(2, 1, 1); | ||||||
|  |   title('$D_w$ to $D$'); | ||||||
|  |   hold on; | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G_vc('D',   'Dw'), freqs, 'Hz'))), 'k-', 'DisplayName', 'G - VC'); | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G('D',   'Dw'), freqs, 'Hz'))), 'k--', 'DisplayName', 'G - PZ'); | ||||||
|  |   hold off; | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   legend('location', 'northeast'); | ||||||
|  |   ylabel('Amplitude [m/m]'); xlabel('Frequency [Hz]'); | ||||||
|  |  | ||||||
|  |   subplot(2, 1, 2); | ||||||
|  |   title('$F_s$ to $D$'); | ||||||
|  |   hold on; | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G_vc('D', 'Fs'), freqs, 'Hz'))), 'k-'); | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G('D', 'Fs'), freqs, 'Hz'))), 'k--'); | ||||||
|  |   hold off; | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('Amplitude [m/N]'); xlabel('Frequency [Hz]'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial-sensitivity-vc-disturbances.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial-sensitivity-vc-disturbances | ||||||
|  | #+CAPTION: Sensitivity to disturbances ([[./figs/uniaxial-sensitivity-vc-disturbances.png][png]], [[./figs/uniaxial-sensitivity-vc-disturbances.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial-sensitivity-vc-disturbances.png]] | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(0, 3, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |  | ||||||
|  |   subplot(2, 1, 1); | ||||||
|  |   title('$F_{ty}$ to $D$'); | ||||||
|  |   hold on; | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G_vc('D', 'Fty'), freqs, 'Hz'))), 'k-', 'DisplayName', 'G - VC'); | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G('D', 'Fty'), freqs, 'Hz'))), 'k--', 'DisplayName', 'G - PZ'); | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   legend('location', 'northeast'); | ||||||
|  |   ylabel('Amplitude [m/N]'); xlabel('Frequency [Hz]'); | ||||||
|  |  | ||||||
|  |   subplot(2, 1, 2); | ||||||
|  |   title('$F_{rz}$ to $D$'); | ||||||
|  |   hold on; | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G_vc('D', 'Frz'), freqs, 'Hz'))), 'k-'); | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(G('D', 'Frz'), freqs, 'Hz'))), 'k--'); | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('Amplitude [m/N]'); xlabel('Frequency [Hz]'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial-sensitivity-vc-force-dist.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial-sensitivity-vc-force-dist | ||||||
|  | #+CAPTION: Sensitivity to disturbances ([[./figs/uniaxial-sensitivity-vc-force-dist.png][png]], [[./figs/uniaxial-sensitivity-vc-force-dist.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial-sensitivity-vc-force-dist.png]] | ||||||
|  |  | ||||||
|  | ** Noise Budget | ||||||
|  | We first load the measured PSD of the disturbance. | ||||||
|  | #+begin_src matlab | ||||||
|  |   load('./disturbances/mat/dist_psd.mat', 'dist_f'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | The effect of these disturbances on the distance $D$ is computed below. | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   % Power Spectral Density of the relative Displacement [m^2/Hz] | ||||||
|  |   psd_vc_gm_d = dist_f.psd_gm.*abs(squeeze(freqresp(G_vc('D', 'Dw'),  dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_vc_ty_d = dist_f.psd_ty.*abs(squeeze(freqresp(G_vc('D', 'Fty'), dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_vc_rz_d = dist_f.psd_rz.*abs(squeeze(freqresp(G_vc('D', 'Frz'), dist_f.f, 'Hz'))).^2; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   % Power Spectral Density of the relative Displacement [m^2/Hz] | ||||||
|  |   psd_gm_d = dist_f.psd_gm.*abs(squeeze(freqresp(G('D', 'Dw'),  dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_ty_d = dist_f.psd_ty.*abs(squeeze(freqresp(G('D', 'Fty'), dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_rz_d = dist_f.psd_rz.*abs(squeeze(freqresp(G('D', 'Frz'), dist_f.f, 'Hz'))).^2; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | The PSD of the obtain distance $D$ due to each of the perturbation is shown in figure [[fig:uniaxial-vc-psd-dist]] and the Cumulative Amplitude Spectrum is shown in figure [[fig:uniaxial-vc-cas-dist]]. | ||||||
|  |  | ||||||
|  | The Root Mean Square value of the obtained displacement $D$ is computed below and can be determined from the figure [[fig:uniaxial-vc-cas-dist]]. | ||||||
|  | #+begin_src matlab :results value replace :exports results | ||||||
|  |   cas_tot_d = sqrt(cumtrapz(dist_f.f, psd_vc_rz_d+psd_vc_ty_d+psd_vc_gm_d)); cas_tot_d(end) | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+RESULTS: | ||||||
|  | : 4.8793e-06 | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(0, 3, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |   hold on; | ||||||
|  |   plot(dist_f.f, psd_vc_gm_d, 'DisplayName', '$D_w$'); | ||||||
|  |   plot(dist_f.f, psd_vc_ty_d, 'DisplayName', '$T_y$'); | ||||||
|  |   plot(dist_f.f, psd_vc_rz_d, 'DisplayName', '$R_z$'); | ||||||
|  |   hold off; | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('CAS of the effect of disturbances on $D$ $\left[\frac{m^2}{Hz}\right]$');  xlabel('Frequency [Hz]'); | ||||||
|  |   legend('location', 'northeast') | ||||||
|  |   xlim([0.5, 500]); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial-vc-psd-dist.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial-vc-psd-dist | ||||||
|  | #+CAPTION: PSD of the displacement $D$ due to disturbances ([[./figs/uniaxial-vc-psd-dist.png][png]], [[./figs/uniaxial-vc-psd-dist.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial-vc-psd-dist.png]] | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(0, 3, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |   hold on; | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_gm_d)))), 'DisplayName', '$D_w$ - VC'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_ty_d)))), 'DisplayName', '$T_y$ - VC'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_rz_d)))), 'DisplayName', '$R_z$ - VC'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_gm_d+psd_vc_ty_d+psd_vc_rz_d)))), 'k-', 'DisplayName', 'tot - VC'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_gm_d+psd_ty_d+psd_rz_d)))), 'k--', 'DisplayName', 'tot - PZ'); | ||||||
|  |   hold off; | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('CAS of the effect of disturbances on $D$ [m]');  xlabel('Frequency [Hz]'); | ||||||
|  |   legend('location', 'northeast') | ||||||
|  |   xlim([0.5, 500]); ylim([1e-12, 5e-6]); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial-vc-cas-dist.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial-vc-cas-dist | ||||||
|  | #+CAPTION: CAS of the displacement $D$ due the disturbances ([[./figs/uniaxial-vc-cas-dist.png][png]], [[./figs/uniaxial-vc-cas-dist.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial-vc-cas-dist.png]] | ||||||
|  |  | ||||||
|  | #+begin_important | ||||||
|  |   Even though the RMS value of the displacement $D$ is lower when using a piezo-electric actuator, the motion is mainly due to high frequency disturbances which are more difficult to control (an higher control bandwidth is required). | ||||||
|  |  | ||||||
|  |   Thus, it may be desirable to use voice coil actuators. | ||||||
|  | #+end_important | ||||||
|  | ** Integral Force Feedback | ||||||
|  | #+begin_src matlab | ||||||
|  |   K_iff = -20/s; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(-1, 2, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |  | ||||||
|  |   ax1 = subplot(2, 1, 1); | ||||||
|  |   plot(freqs, abs(squeeze(freqresp(K_iff*G_vc('Fnm', 'Fn'), freqs, 'Hz'))), 'k-'); | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('Amplitude [N/N]'); set(gca, 'XTickLabel',[]); | ||||||
|  |  | ||||||
|  |   ax2 = subplot(2, 1, 2); | ||||||
|  |   plot(freqs, 180/pi*angle(squeeze(freqresp(K_iff*G_vc('Fnm', 'Fn'), freqs, 'Hz'))), 'k-'); | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'lin'); | ||||||
|  |   ylabel('Phase [deg]'); xlabel('Frequency [Hz]'); | ||||||
|  |   ylim([-180, 180]); | ||||||
|  |   yticks([-180, -90, 0, 90, 180]); | ||||||
|  |  | ||||||
|  |   linkaxes([ax1,ax2],'x'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial_iff_vc_open_loop.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial_iff_vc_open_loop | ||||||
|  | #+CAPTION: Open Loop Transfer Function for IFF control when using a voice coil actuator ([[./figs/uniaxial_iff_vc_open_loop.png][png]], [[./figs/uniaxial_iff_vc_open_loop.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial_iff_vc_open_loop.png]] | ||||||
|  |  | ||||||
|  | ** Identification of the Damped Plant | ||||||
|  | Let's initialize the system prior to identification. | ||||||
|  | #+begin_src matlab | ||||||
|  |   initializeGround(); | ||||||
|  |   initializeGranite(); | ||||||
|  |   initializeTy(); | ||||||
|  |   initializeRy(); | ||||||
|  |   initializeRz(); | ||||||
|  |   initializeMicroHexapod(); | ||||||
|  |   initializeAxisc(); | ||||||
|  |   initializeMirror(); | ||||||
|  |   initializeNanoHexapod(struct('actuator', 'lorentz')); | ||||||
|  |   initializeSample(struct('mass', 50)); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | All the controllers are set to 0. | ||||||
|  | #+begin_src matlab | ||||||
|  |   K = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K', '-append'); | ||||||
|  |   K_iff = -K_iff; | ||||||
|  |   save('./mat/controllers.mat', 'K_iff', '-append'); | ||||||
|  |   K_rmc = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K_rmc', '-append'); | ||||||
|  |   K_dvf = tf(0); | ||||||
|  |   save('./mat/controllers.mat', 'K_dvf', '-append'); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Options for Linearized | ||||||
|  |   options = linearizeOptions; | ||||||
|  |   options.SampleTime = 0; | ||||||
|  |  | ||||||
|  |   %% Name of the Simulink File | ||||||
|  |   mdl = 'sim_nano_station_uniaxial'; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Input/Output definition | ||||||
|  |   io(1)  = linio([mdl, '/Dw'],    1, 'input');  % Ground Motion | ||||||
|  |   io(2)  = linio([mdl, '/Fs'],    1, 'input');  % Force applied on the sample | ||||||
|  |   io(3)  = linio([mdl, '/Fnl'],   1, 'input');  % Force applied by the NASS | ||||||
|  |   io(4)  = linio([mdl, '/Fdty'],  1, 'input');  % Parasitic force Ty | ||||||
|  |   io(5)  = linio([mdl, '/Fdrz'],  1, 'input');  % Parasitic force Rz | ||||||
|  |  | ||||||
|  |   io(6)  = linio([mdl, '/Dsm'],  1, 'output'); % Displacement of the sample | ||||||
|  |   io(7)  = linio([mdl, '/Fnlm'], 1, 'output'); % Force sensor in NASS's legs | ||||||
|  |   io(8)  = linio([mdl, '/Dnlm'], 1, 'output'); % Displacement of NASS's legs | ||||||
|  |   io(9)  = linio([mdl, '/Dgm'],  1, 'output'); % Absolute displacement of the granite | ||||||
|  |   io(10) = linio([mdl, '/Vlm'],  1, 'output'); % Measured absolute velocity of the top NASS platform | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab | ||||||
|  |   %% Run the linearization | ||||||
|  |   G_vc_iff = linearize(mdl, io, options); | ||||||
|  |   G_vc_iff.InputName  = {'Dw',   ... % Ground Motion [m] | ||||||
|  |                          'Fs',   ... % Force Applied on Sample [N] | ||||||
|  |                          'Fn',   ... % Force applied by NASS [N] | ||||||
|  |                          'Fty',  ... % Parasitic Force Ty [N] | ||||||
|  |                          'Frz'};     % Parasitic Force Rz [N] | ||||||
|  |   G_vc_iff.OutputName = {'D',    ... % Measured sample displacement x.r.t. granite [m] | ||||||
|  |                          'Fnm',  ... % Force Sensor in NASS [N] | ||||||
|  |                          'Dnm',  ... % Displacement Sensor in NASS [m] | ||||||
|  |                          'Dgm',  ... % Asbolute displacement of Granite [m] | ||||||
|  |                          'Vlm'}; ... % Absolute Velocity of NASS [m/s] | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | ** Noise Budget | ||||||
|  | We compute the obtain PSD of the displacement $D$ when using IFF. | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   % Power Spectral Density of the relative Displacement [m^2/Hz] | ||||||
|  |   psd_vc_iff_gm_d = dist_f.psd_gm.*abs(squeeze(freqresp(G_vc_iff('D', 'Dw'),  dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_vc_iff_ty_d = dist_f.psd_ty.*abs(squeeze(freqresp(G_vc_iff('D', 'Fty'), dist_f.f, 'Hz'))).^2; | ||||||
|  |   psd_vc_iff_rz_d = dist_f.psd_rz.*abs(squeeze(freqresp(G_vc_iff('D', 'Frz'), dist_f.f, 'Hz'))).^2; | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+begin_src matlab :exports none | ||||||
|  |   freqs = logspace(0, 3, 1000); | ||||||
|  |  | ||||||
|  |   figure; | ||||||
|  |   hold on; | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_gm_d+psd_ty_d+psd_rz_d)))), '-', 'DisplayName', 'OL - PZ'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_gm_d+psd_vc_ty_d+psd_vc_rz_d)))), 'k-', 'DisplayName', 'OL - VC'); | ||||||
|  |   plot(dist_f.f, flip(sqrt(-cumtrapz(flip(dist_f.f), flip(psd_vc_iff_gm_d+psd_vc_iff_ty_d+psd_vc_iff_rz_d)))), 'k--', 'DisplayName', 'IFF - VC'); | ||||||
|  |   hold off; | ||||||
|  |   set(gca, 'XScale', 'log'); set(gca, 'YScale', 'log'); | ||||||
|  |   ylabel('CAS of the effect of disturbances on $D$ [m]');  xlabel('Frequency [Hz]'); | ||||||
|  |   legend('location', 'northeast') | ||||||
|  |   xlim([0.5, 500]); ylim([1e-12, 5e-6]); | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+HEADER: :tangle no :exports results :results none :noweb yes | ||||||
|  | #+begin_src matlab :var filepath="figs/uniaxial-cas-iff-vc.pdf" :var figsize="full-tall" :post pdf2svg(file=*this*, ext="png") | ||||||
|  |   <<plt-matlab>> | ||||||
|  | #+end_src | ||||||
|  |  | ||||||
|  | #+NAME: fig:uniaxial-cas-iff-vc | ||||||
|  | #+CAPTION: CAS of the displacement $D$ ([[./figs/uniaxial-cas-iff-vc.png][png]], [[./figs/uniaxial-cas-iff-vc.pdf][pdf]]) | ||||||
|  | [[file:figs/uniaxial-cas-iff-vc.png]] | ||||||
|  |  | ||||||
|  | ** Conclusion | ||||||
|  | #+begin_important | ||||||
|  |   The use of voice coil actuators would allow a better disturbance rejection for a fixed bandwidth compared with a piezo-electric hexapod. | ||||||
|  |  | ||||||
|  |   Similarly, it would require much lower bandwidth to attain the same level of disturbance rejection for $D$. | ||||||
|  | #+end_important | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user