dehaeze21_desig_compl_filte/journal/dehaeze21_desig_compl_filte.org

851 lines
55 KiB
Org Mode
Raw Normal View History

2021-09-02 10:02:12 +02:00
#+TITLE: Designing complementary filters for sensor fusion using $\mathcal{H}_\infty$ synthesis
2021-04-28 16:00:12 +02:00
:DRAWER:
#+LATEX_CLASS: elsarticle
#+LATEX_CLASS_OPTIONS: [preprint, sort&compress]
#+OPTIONS: toc:nil todo:nil title:nil author:nil date:nil
#+STARTUP: overview
#+LATEX_HEADER_EXTRA: \journal{Mechanical Systems and Signal Processing}
#+LATEX_HEADER_EXTRA: \author[a1,a2]{Thomas Dehaeze\corref{cor1}}
#+LATEX_HEADER_EXTRA: \author[a3,a4]{Mohit Verma}
#+LATEX_HEADER_EXTRA: \author[a2,a4]{Christophe Collette}
#+LATEX_HEADER_EXTRA: \cortext[cor1]{Corresponding author. Email Address: thomas.dehaeze@esrf.fr}
2021-04-28 16:00:12 +02:00
2021-09-08 10:56:25 +02:00
#+LATEX_HEADER_EXTRA: \address[a1]{European Synchrotron Radiation Facility, 38000 Grenoble, France}
2021-09-02 10:02:12 +02:00
#+LATEX_HEADER_EXTRA: \address[a2]{University of Li\`{e}ge, PML, Department of Aerospace and Mechanical Engineering, 4000 Li\`{e}ge, Belgium.}
2021-04-28 16:00:12 +02:00
#+LATEX_HEADER_EXTRA: \address[a3]{CSIR --- Structural Engineering Research Centre, Taramani, Chennai --- 600113, India.}
#+LATEX_HEADER_EXTRA: \address[a4]{Universit\'{e} Libre de Bruxelles, Precision Mechatronics Laboratory, BEAMS Department, 1050 Brussels, Belgium.}
#+LATEX_HEADER: \usepackage{caption,subcaption}
2021-04-29 16:55:38 +02:00
#+LATEX_HEADER: \usepackage{amsfonts}
#+LATEX_HEADER: \usepackage{siunitx}
#+LATEX_HEADER_EXTRA: \usepackage{tabularx}
#+LATEX_HEADER_EXTRA: \usepackage{booktabs}
#+LATEX_HEADER_EXTRA: \usepackage{array}
#+LATEX_HEADER_EXTRA: \usepackage[hyperref]{xcolor}
#+LATEX_HEADER_EXTRA: \usepackage[top=2cm, bottom=2cm, left=2cm, right=2cm]{geometry}
2021-04-29 16:55:38 +02:00
#+LATEX_HEADER_EXTRA: \hypersetup{colorlinks=true}
#+LATEX_HEADER_EXTRA: \setlength{\parskip}{1em}
2021-04-28 16:00:12 +02:00
:END:
2021-05-03 17:47:19 +02:00
* Build :noexport:
2021-04-28 16:00:12 +02:00
#+NAME: startblock
#+BEGIN_SRC emacs-lisp :results none
(add-to-list 'org-latex-classes
'("elsarticle"
"\\documentclass{elsarticle}"
("\\section{%s}" . "\\section*{%s}")
("\\subsection{%s}" . "\\subsection*{%s}")
("\\subsubsection{%s}" . "\\subsubsection*{%s}")
("\\paragraph{%s}" . "\\paragraph*{%s}")
("\\subparagraph{%s}" . "\\subparagraph*{%s}"))
)
2021-09-02 10:02:12 +02:00
;; Remove automatic org headings
(defun my-latex-filter-removeOrgAutoLabels (text backend info)
"Org-mode automatically generates labels for headings despite explicit use of `#+LABEL`. This filter forcibly removes all automatically generated org-labels in headings."
(when (org-export-derived-backend-p backend 'latex)
(replace-regexp-in-string "\\\\label{sec:org[a-f0-9]+}\n" "" text)))
2021-04-28 16:00:12 +02:00
2021-09-02 10:02:12 +02:00
(add-to-list 'org-export-filter-headline-functions
'my-latex-filter-removeOrgAutoLabels)
;; Automatic delete org org-comments
2021-04-28 16:00:12 +02:00
(defun delete-org-comments (backend)
(loop for comment in (reverse (org-element-map (org-element-parse-buffer)
'comment 'identity))
do
(setf (buffer-substring (org-element-property :begin comment)
(org-element-property :end comment))
"")))
;; add to export hook
(add-hook 'org-export-before-processing-hook 'delete-org-comments)
;; Remove hypersetup
(setq org-latex-with-hyperref nil)
#+END_SRC
* =hypersetup= :ignore:
\hypersetup{allcolors=teal}
* Abstract and Keywords :ignore:
#+begin_frontmatter
#+begin_abstract
In order to obtain a better estimate of a quantity being measured, several sensors having different characteristics can be merged with a technique called "sensor fusion".
2021-09-08 10:56:25 +02:00
The obtained "super sensor" combines the benefits of the individual sensors provided that the complementary filters used in the fusion are well designed.
Indeed, properties of the super sensor are linked to the magnitude of the complementary filters.
Properly shaping the magnitude of complementary filters is a difficult and time-consuming task.
2021-09-08 10:56:25 +02:00
In this study, this issue is addressed and a new method for designing complementary filters is proposed.
This method uses weighting functions to specify the wanted shape of the complementary filters that are then obtained using the standard $\mathcal{H}_\infty$ synthesis.
The proper choice of the weighting functions is discussed, and the effectiveness and simplicity of the design method is highlighted using several examples.
2021-09-08 10:56:25 +02:00
Such synthesis method is further extended for the shaping of a set of more than two complementary filters.
2021-04-28 16:00:12 +02:00
#+end_abstract
#+begin_keyword
Sensor fusion \sep{} Complementary filters \sep{} $\mathcal{H}_\infty$ synthesis \sep{} Vibration isolation \sep{} Motion control
2021-04-28 16:00:12 +02:00
#+end_keyword
#+end_frontmatter
* Introduction
<<sec:introduction>>
** Introduction to Sensor Fusion :ignore:
2021-04-28 16:00:12 +02:00
Measuring a physical quantity using sensors is always subject to several limitations.
2021-09-08 10:56:25 +02:00
First, the accuracy of the measurement is affected by several noise sources, such as electrical noise of the conditioning electronics being used.
Second, the frequency range in which the measurement is relevant is bounded by the bandwidth of the sensor.
One way to overcome these limitations is to combine several sensors using a technique called "sensor fusion"\nbsp{}cite:bendat57_optim_filter_indep_measur_two.
2021-09-08 10:56:25 +02:00
Fortunately, a wide variety of sensors exists, each with different characteristics.
By carefully choosing the fused sensors, a so called "super sensor" is obtained that can combines benefits of the individual sensors. \par
2021-04-28 16:00:12 +02:00
** Advantages of Sensor Fusion :ignore:
2021-04-28 16:00:12 +02:00
In some situations, sensor fusion is used to increase the bandwidth of the measurement\nbsp{}cite:shaw90_bandw_enhan_posit_measur_using_measur_accel,zimmermann92_high_bandw_orien_measur_contr,min15_compl_filter_desig_angle_estim.
2021-09-08 10:56:25 +02:00
For instance, in\nbsp{}cite:shaw90_bandw_enhan_posit_measur_using_measur_accel the bandwidth of a position sensor is increased by fusing it with an accelerometer providing the high frequency motion information.
2021-09-02 10:02:12 +02:00
For other applications, sensor fusion is used to obtain an estimate of the measured quantity with lower noise\nbsp{}cite:hua05_low_ligo,hua04_polyp_fir_compl_filter_contr_system,plummer06_optim_compl_filter_their_applic_motion_measur,robert12_introd_random_signal_applied_kalman.
More recently, the fusion of sensors measuring different physical quantities has been proposed to obtain interesting properties for control\nbsp{}cite:collette15_sensor_fusion_method_high_perfor,yong16_high_speed_vertic_posit_stage.
In\nbsp{}cite:collette15_sensor_fusion_method_high_perfor, an inertial sensor used for active vibration isolation is fused with a sensor collocated with the actuator for improving the stability margins of the feedback controller. \par
** Applications :ignore:
2021-04-28 16:00:12 +02:00
Practical applications of sensor fusion are numerous.
It is widely used for the attitude estimation of several autonomous vehicles such as unmanned aerial vehicle\nbsp{}cite:baerveldt97_low_cost_low_weigh_attit,corke04_inert_visual_sensin_system_small_auton_helic,jensen13_basic_uas and underwater vehicles\nbsp{}cite:pascoal99_navig_system_desig_using_time,batista10_optim_posit_veloc_navig_filter_auton_vehic.
Naturally, it is of great benefits for high performance positioning control as shown in\nbsp{}cite:shaw90_bandw_enhan_posit_measur_using_measur_accel,zimmermann92_high_bandw_orien_measur_contr,min15_compl_filter_desig_angle_estim,yong16_high_speed_vertic_posit_stage.
2021-09-02 10:02:12 +02:00
Sensor fusion was also shown to be a key technology to improve the performance of active vibration isolation systems\nbsp{}cite:tjepkema12_sensor_fusion_activ_vibrat_isolat_precis_equip.
Emblematic examples are the isolation stages of gravitational wave detectors\nbsp{}cite:collette15_sensor_fusion_method_high_perfor,heijningen18_low such as the ones used at the LIGO\nbsp{}cite:hua05_low_ligo,hua04_polyp_fir_compl_filter_contr_system and at the VIRGO\nbsp{}cite:lucia18_low_frequen_optim_perfor_advan. \par
2021-04-28 16:00:12 +02:00
** Kalman Filtering / Complementary filters :ignore:
2021-04-28 16:00:12 +02:00
There are mainly two ways to perform sensor fusion: either using a set of complementary filters\nbsp{}cite:anderson53_instr_approac_system_steer_comput or using Kalman filtering\nbsp{}cite:brown72_integ_navig_system_kalman_filter,odry18_kalman_filter_mobil_robot_attit_estim.
For sensor fusion applications, both methods are sharing many relationships\nbsp{}cite:brown72_integ_navig_system_kalman_filter,higgins75_compar_compl_kalman_filter,robert12_introd_random_signal_applied_kalman,becker15_compl_filter_desig_three_frequen_bands.
2021-09-08 10:56:25 +02:00
However, for Kalman filtering, assumptions must be made about the probabilistic character of the sensor noises\nbsp{}cite:robert12_introd_random_signal_applied_kalman whereas it is not the case with complementary filters.
2021-09-02 10:02:12 +02:00
Furthermore, the advantages of complementary filters over Kalman filtering for sensor fusion are their general applicability, their low computational cost\nbsp{}cite:higgins75_compar_compl_kalman_filter, and the fact that they are intuitive as their effects can be easily interpreted in the frequency domain. \par
2021-04-28 16:00:12 +02:00
** Design Methods of Complementary filters :ignore:
2021-04-28 17:58:44 +02:00
A set of filters is said to be complementary if the sum of their transfer functions is equal to one at all frequencies.
2021-09-02 10:02:12 +02:00
In the early days of complementary filtering, analog circuits were employed to physically realize the filters\nbsp{}cite:anderson53_instr_approac_system_steer_comput.
Analog complementary filters are still used today\nbsp{}cite:yong16_high_speed_vertic_posit_stage,moore19_capac_instr_sensor_fusion_high_bandw_nanop, but most of the time they are now implemented digitally as it allows for much more flexibility. \par
2021-04-28 17:58:44 +02:00
Several design methods have been developed over the years to optimize complementary filters.
The easiest way to design complementary filters is to use analytical formulas.
Depending on the application, the formulas used are of first order\nbsp{}cite:corke04_inert_visual_sensin_system_small_auton_helic,yeh05_model_contr_hydraul_actuat_two,yong16_high_speed_vertic_posit_stage, second order\nbsp{}cite:baerveldt97_low_cost_low_weigh_attit,stoten01_fusion_kinet_data_using_compos_filter,jensen13_basic_uas or even higher orders\nbsp{}cite:shaw90_bandw_enhan_posit_measur_using_measur_accel,zimmermann92_high_bandw_orien_measur_contr,stoten01_fusion_kinet_data_using_compos_filter,collette15_sensor_fusion_method_high_perfor,matichard15_seism_isolat_advan_ligo. \par
2021-04-28 17:58:44 +02:00
2021-09-08 10:56:25 +02:00
As the characteristics of the super sensor depends on the proper design of the complementary filters\nbsp{}cite:dehaeze19_compl_filter_shapin_using_synth, several optimization techniques have been developed.
Some are based on the finding of optimal parameters of analytical formulas\nbsp{}cite:jensen13_basic_uas,min15_compl_filter_desig_angle_estim,becker15_compl_filter_desig_three_frequen_bands, while other are using convex optimization tools\nbsp{}cite:hua04_polyp_fir_compl_filter_contr_system,hua05_low_ligo such as linear matrix inequalities\nbsp{}cite:pascoal99_navig_system_desig_using_time.
As shown in\nbsp{}cite:plummer06_optim_compl_filter_their_applic_motion_measur, the design of complementary filters can also be linked to the standard mixed-sensitivity control problem.
Therefore, all the powerful tools developed for the classical control theory can also be used for the design of complementary filters.
For instance, in\nbsp{}cite:jensen13_basic_uas the two gains of a Proportional Integral (PI) controller are optimized to minimize the noise of the super sensor. \par
2021-04-28 16:00:12 +02:00
** Problematic / gap in the research :ignore:
2021-04-28 16:00:12 +02:00
2021-09-02 10:02:12 +02:00
The common objective of all these complementary filters design methods is to obtain a super sensor that has desired characteristics, usually in terms of noise and dynamics.
2021-09-08 10:56:25 +02:00
Moreover, as reported in\nbsp{}cite:zimmermann92_high_bandw_orien_measur_contr,plummer06_optim_compl_filter_their_applic_motion_measur, phase shifts and magnitude bumps of the super sensors dynamics can be observed if either the complementary filters are poorly designed or if the sensors are not well calibrated.
Hence, the robustness of the fusion is also of concern when designing the complementary filters.
2021-09-02 10:02:12 +02:00
Although many design methods of complementary filters have been proposed in the literature, no simple method that allows to specify the desired super sensor characteristic while ensuring good fusion robustness has been proposed. \par
2021-04-28 16:00:12 +02:00
** Describe the paper itself / the problem which is addressed :ignore:
2021-04-28 16:00:12 +02:00
Fortunately, both the robustness of the fusion and the super sensor characteristics can be linked to the magnitude of the complementary filters\nbsp{}cite:dehaeze19_compl_filter_shapin_using_synth.
2021-09-08 10:56:25 +02:00
Based on that, this paper introduces a new way to design complementary filters using the $\mathcal{H}_\infty$ synthesis which allows to shape the complementary filters' magnitude in an easy and intuitive way. \par
2021-04-28 17:58:44 +02:00
** Introduce Each part of the paper :ignore:
2021-09-08 10:56:25 +02:00
Section\nbsp{}ref:sec:requirements introduces the sensor fusion architecture and demonstrates how typical requirements can be linked to the complementary filters' magnitude.
2021-09-02 10:02:12 +02:00
In Section\nbsp{}ref:sec:hinf_method, the shaping of complementary filters is formulated as an $\mathcal{H}_\infty$ optimization problem using weighting functions, and the simplicity of the proposed method is illustrated with an example.
The synthesis method is further validated in Section\nbsp{}ref:sec:application_ligo by designing complex complementary filters.
2021-09-08 10:56:25 +02:00
Section\nbsp{}ref:sec:discussion compares the proposed synthesis method with the classical mixed-sensitivity synthesis, and extends it for the shaping of more than two complementary filters.
2021-04-28 17:58:44 +02:00
2021-05-19 11:47:09 +02:00
* Sensor Fusion and Complementary Filters Requirements
2021-04-28 16:00:12 +02:00
<<sec:requirements>>
2021-04-30 11:18:08 +02:00
** Introduction :ignore:
2021-09-08 10:56:25 +02:00
Complementary filtering provides a framework for fusing signals from different sensors.
2021-04-30 11:18:08 +02:00
As the effectiveness of the fusion depends on the proper design of the complementary filters, they are expected to fulfill certain requirements.
These requirements are discussed in this section.
2021-05-03 17:47:19 +02:00
** Sensor Fusion Architecture
<<sec:sensor_fusion>>
2021-04-30 11:18:08 +02:00
A general sensor fusion architecture using complementary filters is shown in Fig.\nbsp{}ref:fig:sensor_fusion_overview where several sensors (here two) are measuring the same physical quantity $x$.
The two sensors output signals $\hat{x}_1$ and $\hat{x}_2$ are estimates of $x$.
2021-09-08 10:56:25 +02:00
These estimates are then filtered out by complementary filters and combined to form a new estimate $\hat{x}$.
2021-05-19 11:47:09 +02:00
2021-09-08 10:56:25 +02:00
The resulting sensor, termed as super sensor, can have larger bandwidth and better noise characteristics in comparison to the individual sensors.
2021-05-19 11:47:09 +02:00
This means that the super sensor provides an estimate $\hat{x}$ of $x$ which can be more accurate over a larger frequency band than the outputs of the individual sensors.
2021-04-30 11:18:08 +02:00
2021-05-03 17:47:19 +02:00
#+name: fig:sensor_fusion_overview
2021-09-02 10:02:12 +02:00
#+caption: Schematic of a sensor fusion architecture using complementary filters.
2021-05-03 17:47:19 +02:00
[[file:figs/sensor_fusion_overview.pdf]]
2021-04-29 16:55:38 +02:00
2021-09-08 10:56:25 +02:00
The complementary property of filters $H_1(s)$ and $H_2(s)$ implies that the sum of their transfer functions is equal to one.
2021-05-19 11:47:09 +02:00
That is, unity magnitude and zero phase at all frequencies.
Therefore, a pair of complementary filter needs to satisfy the following condition:
2021-05-03 17:47:19 +02:00
#+name: eq:comp_filter
\begin{equation}
H_1(s) + H_2(s) = 1
\end{equation}
2021-04-30 11:18:08 +02:00
It will soon become clear why the complementary property is important for the sensor fusion architecture.
2021-04-28 16:00:12 +02:00
2021-05-03 17:47:19 +02:00
** Sensor Models and Sensor Normalization
<<sec:sensor_models>>
2021-04-28 16:00:12 +02:00
In order to study such sensor fusion architecture, a model for the sensors is required.
Such model is shown in Fig.\nbsp{}ref:fig:sensor_model and consists of a linear time invariant (LTI) system $G_i(s)$ representing the sensor dynamics and an input $n_i$ representing the sensor noise.
2021-05-19 11:47:09 +02:00
The model input $x$ is the measured physical quantity and its output $\tilde{x}_i$ is the "raw" output of the sensor.
2021-05-03 17:47:19 +02:00
2021-05-19 11:47:09 +02:00
Before filtering the sensor outputs $\tilde{x}_i$ by the complementary filters, the sensors are usually normalized to simplify the fusion.
This normalization consists of using an estimate $\hat{G}_i(s)$ of the sensor dynamics $G_i(s)$, and filtering the sensor output by the inverse of this estimate $\hat{G}_i^{-1}(s)$ as shown in Fig.\nbsp{}ref:fig:sensor_model_calibrated.
It is here supposed that the sensor inverse $\hat{G}_i^{-1}(s)$ is proper and stable.
2021-05-03 17:47:19 +02:00
This way, the units of the estimates $\hat{x}_i$ are equal to the units of the physical quantity $x$.
2021-09-08 10:56:25 +02:00
The sensor dynamics estimate $\hat{G}_i(s)$ can be a simple gain or a more complex transfer function.
2021-05-03 17:47:19 +02:00
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_model} Basic sensor model consisting of a noise input $n_i$ and a linear time invariant transfer function $G_i(s)$.}
2021-05-03 17:47:19 +02:00
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_calibrated.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_model_calibrated} Normalized sensors using the inverse of an estimate $\hat{G}_i(s)$ of the sensor dynamics.}
2021-05-03 17:47:19 +02:00
\end{subfigure}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_models}Sensor models with and without normalization.}
2021-05-03 17:47:19 +02:00
\centering
\end{figure}
#+end_export
Two normalized sensors are then combined to form a super sensor as shown in Fig.\nbsp{}ref:fig:fusion_super_sensor.
2021-05-03 17:47:19 +02:00
The two sensors are measuring the same physical quantity $x$ with dynamics $G_1(s)$ and $G_2(s)$, and with /uncorrelated/ noises $n_1$ and $n_2$.
The signals from both normalized sensors are fed into two complementary filters $H_1(s)$ and $H_2(s)$ and then combined to yield an estimate $\hat{x}$ of $x$.
2021-05-03 17:47:19 +02:00
The super sensor output is therefore equal to:
2021-04-28 16:00:12 +02:00
#+name: eq:comp_filter_estimate
\begin{equation}
2021-05-19 11:47:09 +02:00
\hat{x} = \Big( H_1(s) \hat{G}_1^{-1}(s) G_1(s) + H_2(s) \hat{G}_2^{-1}(s) G_2(s) \Big) x + H_1(s) \hat{G}_1^{-1}(s) G_1(s) n_1 + H_2(s) \hat{G}_2^{-1}(s) G_2(s) n_2
2021-04-28 16:00:12 +02:00
\end{equation}
#+name: fig:fusion_super_sensor
2021-09-02 10:02:12 +02:00
#+caption: Sensor fusion architecture with two normalized sensors.
2021-04-28 16:00:12 +02:00
[[file:figs/fusion_super_sensor.pdf]]
** Noise Sensor Filtering
<<sec:noise_filtering>>
In this section, it is supposed that all the sensors are perfectly normalized, such that:
2021-04-28 16:00:12 +02:00
#+name: eq:perfect_dynamics
\begin{equation}
2021-05-19 11:47:09 +02:00
\frac{\hat{x}_i}{x} = \hat{G}_i(s) G_i(s) = 1
2021-04-28 16:00:12 +02:00
\end{equation}
2021-05-19 11:47:09 +02:00
The effect of a non-perfect normalization will be discussed in the next section.
2021-05-03 17:47:19 +02:00
2021-09-08 10:56:25 +02:00
Provided\nbsp{}eqref:eq:perfect_dynamics is verified, the super sensor output $\hat{x}$ is then equal to:
2021-04-28 16:00:12 +02:00
#+name: eq:estimate_perfect_dyn
\begin{equation}
2021-05-03 17:47:19 +02:00
\hat{x} = x + H_1(s) n_1 + H_2(s) n_2
2021-04-28 16:00:12 +02:00
\end{equation}
2021-09-08 10:56:25 +02:00
From\nbsp{}eqref:eq:estimate_perfect_dyn, the complementary filters $H_1(s)$ and $H_2(s)$ are shown to only operate on the noise of the sensors.
2021-04-28 16:00:12 +02:00
Thus, this sensor fusion architecture permits to filter the noise of both sensors without introducing any distortion in the physical quantity to be measured.
This is why the two filters must be complementary.
2021-04-28 16:00:12 +02:00
2021-09-02 10:02:12 +02:00
The estimation error $\delta x$, defined as the difference between the sensor output $\hat{x}$ and the measured quantity $x$, is computed for the super sensor\nbsp{}eqref:eq:estimate_error.
2021-04-28 16:00:12 +02:00
#+name: eq:estimate_error
\begin{equation}
2021-05-03 17:47:19 +02:00
\delta x \triangleq \hat{x} - x = H_1(s) n_1 + H_2(s) n_2
2021-04-28 16:00:12 +02:00
\end{equation}
2021-09-02 10:02:12 +02:00
As shown in\nbsp{}eqref:eq:noise_filtering_psd, the Power Spectral Density (PSD) of the estimation error $\Phi_{\delta x}$ depends both on the norm of the two complementary filters and on the PSD of the noise sources $\Phi_{n_1}$ and $\Phi_{n_2}$.
2021-04-28 16:00:12 +02:00
#+name: eq:noise_filtering_psd
\begin{equation}
2021-05-03 17:47:19 +02:00
\Phi_{\delta x}(\omega) = \left|H_1(j\omega)\right|^2 \Phi_{n_1}(\omega) + \left|H_2(j\omega)\right|^2 \Phi_{n_2}(\omega)
2021-04-28 16:00:12 +02:00
\end{equation}
If the two sensors have identical noise characteristics, $\Phi_{n_1}(\omega) = \Phi_{n_2}(\omega)$, a simple averaging ($H_1(s) = H_2(s) = 0.5$) is what would minimize the super sensor noise.
This is the simplest form of sensor fusion with complementary filters.
2021-04-28 16:00:12 +02:00
2021-05-19 11:47:09 +02:00
However, the two sensors have usually high noise levels over distinct frequency regions.
In such case, to lower the noise of the super sensor, the norm $|H_1(j\omega)|$ has to be small when $\Phi_{n_1}(\omega)$ is larger than $\Phi_{n_2}(\omega)$ and the norm $|H_2(j\omega)|$ has to be small when $\Phi_{n_2}(\omega)$ is larger than $\Phi_{n_1}(\omega)$.
2021-09-08 10:56:25 +02:00
Hence, by properly shaping the norm of the complementary filters, it is possible to reduce the noise of the super sensor.
2021-05-19 11:47:09 +02:00
** Sensor Fusion Robustness
2021-04-28 16:00:12 +02:00
<<sec:fusion_robustness>>
2021-09-02 10:02:12 +02:00
In practical systems the sensor normalization is not perfect and condition\nbsp{}eqref:eq:perfect_dynamics is not verified.
2021-05-03 17:47:19 +02:00
In order to study such imperfection, a multiplicative input uncertainty is added to the sensor dynamics (Fig.\nbsp{}ref:fig:sensor_model_uncertainty).
2021-09-08 10:56:25 +02:00
The nominal model is the estimated model used for the normalization $\hat{G}_i(s)$, $\Delta_i(s)$ is any stable transfer function satisfying $|\Delta_i(j\omega)| \le 1,\ \forall\omega$, and $w_i(s)$ is a weighting transfer function representing the magnitude of the uncertainty.
2021-05-03 17:47:19 +02:00
2021-09-08 10:56:25 +02:00
The weight $w_i(s)$ is chosen such that the real sensor dynamics $G_i(j\omega)$ is contained in the uncertain region represented by a circle in the complex plane, centered on $1$ and with a radius equal to $|w_i(j\omega)|$.
2021-04-28 16:00:12 +02:00
As the nominal sensor dynamics is taken as the normalized filter, the normalized sensor can be further simplified as shown in Fig.\nbsp{}ref:fig:sensor_model_uncertainty_simplified.
2021-04-30 11:18:08 +02:00
2021-05-03 17:47:19 +02:00
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_model_uncertainty} Sensor with multiplicative input uncertainty.}
2021-05-03 17:47:19 +02:00
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.39\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty_simplified.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_model_uncertainty_simplified} Simplified sensor model.}
2021-05-03 17:47:19 +02:00
\end{subfigure}
\hfill
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_models_uncertainty}Sensor models with dynamical uncertainty.}
2021-05-03 17:47:19 +02:00
\centering
\end{figure}
#+end_export
2021-04-30 11:18:08 +02:00
2021-09-08 10:56:25 +02:00
The sensor fusion architecture with the sensor models including dynamical uncertainty is shown in Fig.\nbsp{}ref:fig:sensor_fusion_dynamic_uncertainty.
2021-04-28 16:00:12 +02:00
#+name: fig:sensor_fusion_dynamic_uncertainty
2021-09-02 10:02:12 +02:00
#+caption: Sensor fusion architecture with sensor dynamics uncertainty.
2021-04-28 16:00:12 +02:00
[[file:figs/sensor_fusion_dynamic_uncertainty.pdf]]
2021-09-02 10:02:12 +02:00
The super sensor dynamics\nbsp{}eqref:eq:super_sensor_dyn_uncertainty is no longer equal to $1$ and now depends on the sensor dynamical uncertainty weights $w_i(s)$ as well as on the complementary filters $H_i(s)$.
2021-04-28 16:00:12 +02:00
#+name: eq:super_sensor_dyn_uncertainty
\begin{equation}
\frac{\hat{x}}{x} = 1 + w_1(s) H_1(s) \Delta_1(s) + w_2(s) H_2(s) \Delta_2(s)
\end{equation}
2021-09-08 10:56:25 +02:00
The dynamical uncertainty of the super sensor can be graphically represented in the complex plane by a circle centered on $1$ with a radius equal to $|w_1(j\omega) H_1(j\omega)| + |w_2(j\omega) H_2(j\omega)|$ (Fig.\nbsp{}ref:fig:uncertainty_set_super_sensor).
2021-04-28 16:00:12 +02:00
#+name: fig:uncertainty_set_super_sensor
#+caption: Uncertainty region of the super sensor dynamics in the complex plane (grey circle). The contribution of both sensors 1 and 2 to the total uncertainty are represented respectively by a blue circle and a red circle. The frequency dependency $\omega$ is here omitted.
2021-04-28 16:00:12 +02:00
[[file:figs/uncertainty_set_super_sensor.pdf]]
2021-09-08 10:56:25 +02:00
The super sensor dynamical uncertainty, and hence the robustness of the fusion, clearly depends on the complementary filters' norm.
For instance, the phase $\Delta\phi(\omega)$ added by the super sensor dynamics at frequency $\omega$ is bounded by $\Delta\phi_{\text{max}}(\omega)$ which can be found by drawing a tangent from the origin to the uncertainty circle of the super sensor (Fig.\nbsp{}ref:fig:uncertainty_set_super_sensor) and that is mathematically described by\nbsp{}eqref:eq:max_phase_uncertainty.
2021-04-28 16:00:12 +02:00
2021-05-19 11:47:09 +02:00
#+name: eq:max_phase_uncertainty
2021-04-28 16:00:12 +02:00
\begin{equation}
\Delta\phi_\text{max}(\omega) = \arcsin\big( |w_1(j\omega) H_1(j\omega)| + |w_2(j\omega) H_2(j\omega)| \big)
2021-04-28 16:00:12 +02:00
\end{equation}
2021-05-19 11:47:09 +02:00
As it is generally desired to limit the maximum phase added by the super sensor, $H_1(s)$ and $H_2(s)$ should be designed such that $\Delta \phi$ is bounded to acceptable values.
Typically, the norm of the complementary filter $|H_i(j\omega)|$ should be made small when $|w_i(j\omega)|$ is large, i.e., at frequencies where the sensor dynamics is uncertain.
2021-04-28 16:00:12 +02:00
2021-05-20 11:14:26 +02:00
* Complementary Filters Shaping
2021-04-28 16:00:12 +02:00
<<sec:hinf_method>>
** Introduction :ignore:
2021-05-20 11:14:26 +02:00
2021-09-08 10:56:25 +02:00
As shown in Section\nbsp{}ref:sec:requirements, the noise and robustness of the super sensor are a function of the complementary filters' norm.
Therefore, a synthesis method of complementary filters that allows to shape their norm would be of great use.
In this section, such synthesis is proposed by writing the synthesis objective as a standard $\mathcal{H}_\infty$ optimization problem.
2021-09-08 10:56:25 +02:00
As weighting functions are used to represent the wanted complementary filters' shape during the synthesis, their proper design is discussed.
Finally, the synthesis method is validated on an simple example.
2021-04-28 16:00:12 +02:00
2021-04-29 16:55:38 +02:00
** Synthesis Objective
<<sec:synthesis_objective>>
2021-05-20 11:14:26 +02:00
2021-09-02 10:02:12 +02:00
The synthesis objective is to shape the norm of two filters $H_1(s)$ and $H_2(s)$ while ensuring their complementary property\nbsp{}eqref:eq:comp_filter.
This is equivalent as to finding proper and stable transfer functions $H_1(s)$ and $H_2(s)$ such that conditions\nbsp{}eqref:eq:hinf_cond_complementarity, eqref:eq:hinf_cond_h1 and\nbsp{}eqref:eq:hinf_cond_h2 are satisfied.
2021-05-20 11:14:26 +02:00
2021-04-28 16:00:12 +02:00
#+name: eq:comp_filter_problem_form
\begin{subequations}
\begin{align}
& H_1(s) + H_2(s) = 1 \label{eq:hinf_cond_complementarity} \\
& |H_1(j\omega)| \le \frac{1}{|W_1(j\omega)|} \quad \forall\omega \label{eq:hinf_cond_h1} \\
& |H_2(j\omega)| \le \frac{1}{|W_2(j\omega)|} \quad \forall\omega \label{eq:hinf_cond_h2}
\end{align}
\end{subequations}
2021-09-08 10:56:25 +02:00
$W_1(s)$ and $W_2(s)$ are two weighting transfer functions that are carefully chosen to specify the maximum wanted norm of the complementary filters during the synthesis.
2021-04-28 16:00:12 +02:00
2021-04-29 16:55:38 +02:00
** Shaping of Complementary Filters using $\mathcal{H}_\infty$ synthesis
<<sec:hinf_synthesis>>
2021-05-20 11:14:26 +02:00
In this section, it is shown that the synthesis objective can be easily expressed as a standard $\mathcal{H}_\infty$ optimization problem and therefore solved using convenient tools readily available.
2021-05-20 11:14:26 +02:00
2021-09-02 10:02:12 +02:00
Consider the generalized plant $P(s)$ shown in Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_plant and mathematically described by\nbsp{}eqref:eq:generalized_plant.
2021-05-20 11:14:26 +02:00
2021-04-28 16:00:12 +02:00
#+name: eq:generalized_plant
\begin{equation}
2021-05-20 11:14:26 +02:00
\begin{bmatrix} z_1 \\ z_2 \\ v \end{bmatrix} = P(s) \begin{bmatrix} w\\u \end{bmatrix}; \quad P(s) = \begin{bmatrix}W_1(s) & -W_1(s) \\ 0 & \phantom{+}W_2(s) \\ 1 & 0 \end{bmatrix}
2021-04-28 16:00:12 +02:00
\end{equation}
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/h_infinity_robust_fusion_plant.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:h_infinity_robust_fusion_plant} Generalized plant.}
\vfill
\end{subfigure}
\hfill
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/h_infinity_robust_fusion_fb.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:h_infinity_robust_fusion_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
2021-09-02 10:02:12 +02:00
\caption{\label{fig:h_infinity_robust_fusion} Architecture for the $\mathcal{H}_\infty$ synthesis of complementary filters.}
\centering
\end{figure}
#+end_export
2021-04-28 16:00:12 +02:00
2021-09-08 10:56:25 +02:00
Applying the standard $\mathcal{H}_\infty$ synthesis to the generalized plant $P(s)$ is then equivalent as finding a stable filter $H_2(s)$ which based on $v$, generates a signal $u$ such that the $\mathcal{H}_\infty$ norm of the system in Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_fb from $w$ to $[z_1, \ z_2]$ is less than one\nbsp{}eqref:eq:hinf_syn_obj.
2021-04-28 16:00:12 +02:00
#+name: eq:hinf_syn_obj
\begin{equation}
2021-05-20 11:14:26 +02:00
\left\|\begin{matrix} \left(1 - H_2(s)\right) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
2021-04-28 16:00:12 +02:00
\end{equation}
2021-09-08 10:56:25 +02:00
By then defining $H_1(s)$ to be the complementary of $H_2(s)$ eqref:eq:definition_H1, the $\mathcal{H}_\infty$ synthesis objective becomes equivalent to\nbsp{}eqref:eq:hinf_problem which ensures that\nbsp{}eqref:eq:hinf_cond_h1 and\nbsp{}eqref:eq:hinf_cond_h2 are satisfied.
2021-04-28 16:00:12 +02:00
#+name: eq:definition_H1
\begin{equation}
H_1(s) \triangleq 1 - H_2(s)
\end{equation}
2021-05-20 11:14:26 +02:00
#+name: eq:hinf_problem
\begin{equation}
\left\|\begin{matrix} H_1(s) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
2021-09-08 10:56:25 +02:00
Therefore, applying the $\mathcal{H}_\infty$ synthesis to the standard plant $P(s)$ eqref:eq:generalized_plant will generate two filters $H_2(s)$ and $H_1(s) \triangleq 1 - H_2(s)$ that are complementary\nbsp{}eqref:eq:comp_filter_problem_form and such that there norms are bellow specified bounds [[eqref:eq:hinf_cond_h1]],\nbsp{}eqref:eq:hinf_cond_h2.
2021-05-20 11:14:26 +02:00
2021-09-08 10:56:25 +02:00
Note that there is only an implication between the $\mathcal{H}_\infty$ norm condition\nbsp{}eqref:eq:hinf_problem and the initial synthesis objectives\nbsp{}eqref:eq:hinf_cond_h1 and\nbsp{}eqref:eq:hinf_cond_h2 and not an equivalence.
Hence, the optimization may be a little bit conservative with respect to the set of filters on which it is performed, see\nbsp{}[[cite:skogestad07_multiv_feedb_contr][Chap. 2.8.3]].
In practice, this is however not an found to be an issue.
2021-04-28 16:00:12 +02:00
** Weighting Functions Design
<<sec:hinf_weighting_func>>
2021-09-08 10:56:25 +02:00
Weighting functions are used during the synthesis to specify the maximum allowed complementary filters' norm.
The proper design of these weighting functions is of primary importance for the success of the presented $\mathcal{H}_\infty$ synthesis of complementary filters.
2021-05-20 11:14:26 +02:00
First, only proper and stable transfer functions should be used.
2021-09-08 10:56:25 +02:00
Second, the order of the weighting functions should stay reasonably small in order to reduce the computational costs associated with the solving of the optimization problem and for the physical implementation of the filters (the synthesized filters' order being equal to the sum of the weighting functions' order).
2021-09-02 10:02:12 +02:00
Third, one should not forget the fundamental limitations imposed by the complementary property\nbsp{}eqref:eq:comp_filter.
2021-05-20 11:14:26 +02:00
This implies for instance that $|H_1(j\omega)|$ and $|H_2(j\omega)|$ cannot be made small at the same frequency.
When designing complementary filters, it is usually desired to specify their slopes, their "blending" frequency and their maximum gains at low and high frequency.
2021-09-08 10:56:25 +02:00
To easily express these specifications, formula\nbsp{}eqref:eq:weight_formula is proposed to help with the design of weighting functions.
2021-04-28 16:00:12 +02:00
#+name: eq:weight_formula
\begin{equation}
W(s) = \left( \frac{
2021-05-20 11:14:26 +02:00
\hfill{} \frac{1}{\omega_c} \sqrt{\frac{1 - \left(\frac{G_0}{G_c}\right)^{\frac{2}{n}}}{1 - \left(\frac{G_c}{G_\infty}\right)^{\frac{2}{n}}}} s + \left(\frac{G_0}{G_c}\right)^{\frac{1}{n}}
2021-04-28 16:00:12 +02:00
}{
2021-05-20 11:14:26 +02:00
\left(\frac{1}{G_\infty}\right)^{\frac{1}{n}} \frac{1}{\omega_c} \sqrt{\frac{1 - \left(\frac{G_0}{G_c}\right)^{\frac{2}{n}}}{1 - \left(\frac{G_c}{G_\infty}\right)^{\frac{2}{n}}}} s + \left(\frac{1}{G_c}\right)^{\frac{1}{n}}
2021-04-28 16:00:12 +02:00
}\right)^n
\end{equation}
2021-05-20 11:14:26 +02:00
2021-09-02 10:02:12 +02:00
The parameters in formula\nbsp{}eqref:eq:weight_formula are:
- $G_0 = \lim_{\omega \to 0} |W(j\omega)|$: the low frequency gain
- $G_\infty = \lim_{\omega \to \infty} |W(j\omega)|$: the high frequency gain
- $G_c = |W(j\omega_c)|$: the gain at a specific frequency $\omega_c$ in $\si{rad/s}$.
- $n$: the slope between high and low frequency. It also corresponds to the order of the weighting function.
2021-04-28 16:00:12 +02:00
2021-09-08 10:56:25 +02:00
The parameters $G_0$, $G_c$ and $G_\infty$ should either satisfy\nbsp{}eqref:eq:cond_formula_1 or\nbsp{}eqref:eq:cond_formula_2.
2021-04-28 16:00:12 +02:00
#+name: eq:condition_params_formula
\begin{subequations}
\begin{align}
G_0 < 1 < G_\infty \text{ and } G_0 < G_c < G_\infty \label{eq:cond_formula_1}\\
G_\infty < 1 < G_0 \text{ and } G_\infty < G_c < G_0 \label{eq:cond_formula_2}
\end{align}
\end{subequations}
2021-09-08 10:56:25 +02:00
The typical magnitude of a weighting function generated using\nbsp{}eqref:eq:weight_formula is shown in Fig.\nbsp{}ref:fig:weight_formula.
2021-04-28 16:00:12 +02:00
#+name: fig:weight_formula
2021-09-08 10:56:25 +02:00
#+caption: Magnitude of a weighting function generated using formula\nbsp{}eqref:eq:weight_formula, $G_0 = 1e^{-3}$, $G_\infty = 10$, $\omega_c = \SI{10}{Hz}$, $G_c = 2$, $n = 3$.
2021-04-28 16:00:12 +02:00
[[file:figs/weight_formula.pdf]]
** Validation of the proposed synthesis method
<<sec:hinf_example>>
2021-05-20 11:14:26 +02:00
2021-09-08 10:56:25 +02:00
The proposed methodology for the design of complementary filters is now applied on a simple example.
Let's suppose two complementary filters $H_1(s)$ and $H_2(s)$ have to be designed such that:
- the blending frequency is around $\SI{10}{Hz}$.
- the slope of $|H_1(j\omega)|$ is $+2$ below $\SI{10}{Hz}$.
Its low frequency gain is $10^{-3}$.
- the slope of $|H_2(j\omega)|$ is $-3$ above $\SI{10}{Hz}$.
Its high frequency gain is $10^{-3}$.
2021-09-08 10:56:25 +02:00
The first step is to translate the above requirements by properly designing the weighting functions.
2021-09-02 10:02:12 +02:00
The proposed formula\nbsp{}eqref:eq:weight_formula is here used for such purpose.
Parameters used are summarized in Table\nbsp{}ref:tab:weights_params.
The inverse magnitudes of the designed weighting functions, which are representing the maximum allowed norms of the complementary filters, are shown by the dashed lines in Fig.\nbsp{}ref:fig:weights_W1_W2.
#+begin_export latex
\begin{figure}
\begin{minipage}[b]{0.49\linewidth}
\centering
2021-09-08 10:56:25 +02:00
\begin{tabularx}{0.60\linewidth}{ccc}
\toprule
2021-09-08 10:56:25 +02:00
Parameters & \(W_1(s)\) & \(W_2(s)\)\\
\midrule
2021-09-08 10:56:25 +02:00
\(G_0\) & \(0.1\) & \(1000\)\\
\(G_\infty\) & \(1000\) & \(0.1\)\\
\(\omega_c\) & \(2\pi\cdot10\) & \(2\pi\cdot10\)\\
2021-09-08 10:56:25 +02:00
\(G_c\) & \(0.45\) & \(0.45\)\\
\(n\) & \(2\) & \(3\)\\
\bottomrule
\end{tabularx}
2021-09-08 10:56:25 +02:00
\captionof{table}{\label{tab:weights_params}Parameters used for \(W_1(s)\) and \(W_2(s)\) using~\eqref{eq:weight_formula}.}
\end{minipage}
\hfill
\begin{minipage}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/weights_W1_W2.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:weights_W1_W2}Inverse magnitude of the weighting functions.}
\end{minipage}
\end{figure}
#+end_export
2021-09-08 10:56:25 +02:00
The standard $\mathcal{H}_\infty$ synthesis is then applied to the generalized plant of Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_plant and efficiently solved using Matlab\nbsp{}cite:matlab20.
The filter $H_2(s)$ that minimizes the $\mathcal{H}_\infty$ norm between $w$ and $[z_1,\ z_2]^T$ is obtained.
2021-09-02 10:02:12 +02:00
The $\mathcal{H}_\infty$ norm is here found to be close to one\nbsp{}eqref:eq:hinf_synthesis_result which indicates that the synthesis is successful: the complementary filters norms are below the maximum specified upper bounds.
This is confirmed by the bode plots of the obtained complementary filters in Fig.\nbsp{}ref:fig:hinf_filters_results.
2021-05-20 11:14:26 +02:00
#+name: eq:hinf_synthesis_result
\begin{equation}
\left\|\begin{matrix} \left(1 - H_2(s)\right) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \approx 1
\end{equation}
2021-09-08 10:56:25 +02:00
The transfer functions in the Laplace domain of the complementary filters are given in\nbsp{}eqref:eq:hinf_synthesis_result_tf.
As expected, the obtained filters are of order $5$, that is the sum of the weighting functions' order.
2021-05-20 11:14:26 +02:00
#+name: eq:hinf_synthesis_result_tf
\begin{subequations}
\begin{align}
H_2(s) &= \frac{(s+6.6e^4) (s+160) (s+4)^3}{(s+6.6e^4) (s^2 + 106 s + 3e^3) (s^2 + 72s + 3580)} \\
H_1(s) &\triangleq H_2(s) - 1 = \frac{10^{-8} (s+6.6e^9) (s+3450)^2 (s^2 + 49s + 895)}{(s+6.6e^4) (s^2 + 106 s + 3e^3) (s^2 + 72s + 3580)}
\end{align}
\end{subequations}
2021-04-28 16:00:12 +02:00
2021-04-30 11:18:08 +02:00
#+name: fig:hinf_filters_results
2021-09-02 10:02:12 +02:00
#+caption: Bode plot of the obtained complementary filters.
2021-04-30 11:18:08 +02:00
[[file:figs/hinf_filters_results.pdf]]
2021-04-28 16:00:12 +02:00
This simple example illustrates the fact that the proposed methodology for complementary filters shaping is easy to use and effective.
2021-05-20 11:14:26 +02:00
A more complex real life example is taken up in the next section.
2021-04-28 16:00:12 +02:00
* Application: Design of Complementary Filters used in the Active Vibration Isolation System at the LIGO
<<sec:application_ligo>>
** Introduction :ignore:
2021-09-08 10:56:25 +02:00
Sensor fusion using complementary filters are widely used in the active vibration isolation systems at gravitational wave detectors, such as at the LIGO\nbsp{}cite:matichard15_seism_isolat_advan_ligo,hua05_low_ligo, the VIRGO\nbsp{}cite:lucia18_low_frequen_optim_perfor_advan,heijningen18_low and the KAGRA [[cite:sekiguchi16_study_low_frequen_vibrat_isolat_system][Chap. 5]].
2021-09-08 10:56:25 +02:00
In the first isolation stage at the LIGO, two sets of complementary filters are used to form a super sensor that is incorporated in a feedback loop\nbsp{}cite:hua04_low_ligo.
A set of complementary filters ($L_2,H_2$) is first used to fuse a seismometer and a geophone.
Then, another set of complementary filters ($L_1,H_1$) is used to merge the output of the first "inertial super sensor" with a position sensor.
A simplified block diagram of the sensor fusion architecture is shown in Fig.\nbsp{}ref:fig:ligo_super_sensor_architecture.
#+name: fig:ligo_super_sensor_architecture
2021-09-02 10:02:12 +02:00
#+caption: Simplified block diagram of the sensor blending strategy for the first stage at the LIGO\nbsp{}cite:hua04_low_ligo.
[[file:figs/ligo_super_sensor_architecture.pdf]]
2021-09-08 10:56:25 +02:00
The fusion of the position sensor at low frequency with the "inertial super sensor" at high frequency using the complementary filters ($L_1,H_1$) is done for several reasons, first of which is to give the super sensor a DC sensibility that allows the feedback loop to have authority at zero frequency.
2021-09-02 10:02:12 +02:00
The requirements on those filters are stringent and thus their design is complex and should be expressed as an optimization problem.
The approach used in\nbsp{}cite:hua05_low_ligo is to use FIR complementary filters and to write the synthesis as a convex optimization problem.
After synthesis, the obtained FIR filters were found to be compliant with the requirements.
2021-09-02 10:02:12 +02:00
However they are of high order so their implementation is quite complex.
2021-09-08 10:56:25 +02:00
In this section, the effectiveness of the proposed complementary filter synthesis strategy is demonstrated by using the same set of requirements.
2021-04-28 16:00:12 +02:00
** Complementary Filters Specifications
<<sec:ligo_specifications>>
The specifications for the set of complementary filters ($L_1,H_1$) used at the LIGO are summarized below (for further details, refer to\nbsp{}cite:hua04_polyp_fir_compl_filter_contr_system):
2021-09-08 10:56:25 +02:00
- Below $\SI{0.008}{Hz}$, the magnitude $|L_1(j\omega)|$ should be less than $8 \times 10^{-4}$.
- From $\SI{0.008}{Hz}$ to $\SI{0.04}{Hz}$, the filter $L_1(s)$ should attenuate the input signal proportional to frequency cubed.
- From $\SI{0.04}{Hz}$ to $\SI{0.1}{Hz}$, the magnitude $|L_1(j\omega)|$ should be less than $3$.
- Above $\SI{0.1}{Hz}$, the magnitude $|H_1(j\omega)|$ should be less than $0.045$.
2021-09-08 10:56:25 +02:00
These specifications are therefore upper bounds on the complementary filters' magnitude.
They are physically represented in Fig.\nbsp{}ref:fig:fir_filter_ligo as well as the obtained magnitude of the FIR filters in\nbsp{}cite:hua05_low_ligo.
#+name: fig:fir_filter_ligo
2021-09-02 10:02:12 +02:00
#+caption: Specifications and Bode plot of the obtained FIR complementary filters in\nbsp{}cite:hua05_low_ligo. The filters are here obtained using the SeDuMi Matlab toolbox\nbsp{}cite:sturm99_using_sedum.
[[file:figs/fir_filter_ligo.pdf]]
2021-04-28 16:00:12 +02:00
** Weighting Functions Design
<<sec:ligo_weights>>
2021-04-28 16:00:12 +02:00
The weighting functions should be designed such that their inverse magnitude is as close as possible to the specifications in order to not over-constrain the synthesis problem.
However, the order of each weight should stay reasonably small in order to reduce the computational costs of the optimization problem as well as for the physical implementation of the filters.
A Type I Chebyshev filter of order $20$ is used for the weighting transfer function $W_L(s)$ corresponding to the low pass filter.
2021-09-08 10:56:25 +02:00
For the one corresponding to the high pass filter $W_H(s)$, a $7^{\text{th}}$ order transfer function is manually designed.
The inverse magnitudes of the weighting functions are shown in Fig.\nbsp{}ref:fig:ligo_weights.
2021-04-28 16:00:12 +02:00
#+name: fig:ligo_weights
2021-09-08 10:56:25 +02:00
#+caption: Specifications and weighting functions' inverse magnitude.
2021-04-28 16:00:12 +02:00
[[file:figs/ligo_weights.pdf]]
** $\mathcal{H}_\infty$ Synthesis of the complementary filters
2021-04-28 16:00:12 +02:00
<<sec:ligo_results>>
The proposed $\mathcal{H}_\infty$ synthesis is performed on the generalized plant shown in Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_plant.
After optimization, the $\mathcal{H}_\infty$ norm from $w$ to $[z_1,\ z_2]^T$ is found close to one indication successful synthesis.
In Fig.\nbsp{}ref:fig:comp_fir_ligo_hinf, the bode plot of the obtained complementary filters are compared with the FIR filters of order 512 obtained in\nbsp{}cite:hua05_low_ligo.
2021-09-02 10:02:12 +02:00
Even though the complementary filters using the $\mathcal{H}_\infty$ synthesis are of much lower order (order 27), they are found to be close to the FIR filters.
This confirms the effectiveness of the proposed synthesis method even when the complementary filters are subject to complex requirements.
2021-04-28 16:00:12 +02:00
#+name: fig:comp_fir_ligo_hinf
2021-09-02 10:02:12 +02:00
#+caption: Comparison of the FIR filters (dashed) designed in\nbsp{}cite:hua05_low_ligo with the filters obtained with $\mathcal{H}_\infty$ synthesis (solid).
2021-04-28 16:00:12 +02:00
[[file:figs/comp_fir_ligo_hinf.pdf]]
2021-05-03 17:47:19 +02:00
* Discussion
2021-06-21 11:40:36 +02:00
<<sec:discussion>>
** "Closed-Loop" complementary filters
<<sec:closed_loop_complementary_filters>>
2021-09-08 10:56:25 +02:00
An alternative way to implement complementary filters is by using a fundamental property of the classical feedback architecture shown in Fig.\nbsp{}ref:fig:feedback_sensor_fusion.
2021-09-08 10:56:25 +02:00
This idea is discussed in\nbsp{}cite:mahony05_compl_filter_desig_special_orthog,plummer06_optim_compl_filter_their_applic_motion_measur,jensen13_basic_uas.
#+name: fig:feedback_sensor_fusion
2021-09-02 10:02:12 +02:00
#+caption: "Closed-Loop" complementary filters.
[[file:figs/feedback_sensor_fusion.pdf]]
Consider the feedback architecture of Fig.\nbsp{}ref:fig:feedback_sensor_fusion, with two inputs $\hat{x}_1$ and $\hat{x}_2$, and one output $\hat{x}$.
2021-09-02 10:02:12 +02:00
The output $\hat{x}$ is linked to the inputs by\nbsp{}eqref:eq:closed_loop_complementary_filters.
2021-06-21 11:40:36 +02:00
#+name: eq:closed_loop_complementary_filters
\begin{equation}
2021-06-21 11:40:36 +02:00
\hat{x} = \underbrace{\frac{1}{1 + L(s)}}_{S(s)} \hat{x}_1 + \underbrace{\frac{L(s)}{1 + L(s)}}_{T(s)} \hat{x}_2
\end{equation}
2021-09-08 10:56:25 +02:00
As for any classical feedback architecture, we have that the sum of the sensitivity transfer function $S(s)$ and complementary sensitivity transfer function $T_(s)$ is equal to one\nbsp{}eqref:eq:sensitivity_sum.
#+name: eq:sensitivity_sum
\begin{equation}
2021-09-08 10:56:25 +02:00
S(s) + T(s) = 1
\end{equation}
2021-09-08 10:56:25 +02:00
Therefore, provided that the the closed-loop system in Fig.\nbsp{}ref:fig:feedback_sensor_fusion is stable, it can be used as a set of two complementary filters.
Two sensors can then be merged as shown in Fig.\nbsp{}ref:fig:feedback_sensor_fusion_arch.
2021-06-21 11:40:36 +02:00
#+name: fig:feedback_sensor_fusion_arch
2021-09-02 10:02:12 +02:00
#+caption: Classical feedback architecture used for sensor fusion.
2021-06-21 11:40:36 +02:00
[[file:figs/feedback_sensor_fusion_arch.pdf]]
One of the main advantage of implementing and designing complementary filters using the feedback architecture of Fig.\nbsp{}ref:fig:feedback_sensor_fusion is that all the tools of the linear control theory can be applied for the design of the filters.
If one want to shape both $\frac{\hat{x}}{\hat{x}_1}(s) = S(s)$ and $\frac{\hat{x}}{\hat{x}_2}(s) = T(s)$, the $\mathcal{H}_\infty$ mixed-sensitivity synthesis can be easily applied.
2021-06-21 11:40:36 +02:00
To do so, weighting functions $W_1(s)$ and $W_2(s)$ are added to respectively shape $S(s)$ and $T(s)$ (Fig.\nbsp{}ref:fig:feedback_synthesis_architecture).
2021-09-08 10:56:25 +02:00
Then the system is rearranged to form the generalized plant $P_L(s)$ shown in Fig.\nbsp{}ref:fig:feedback_synthesis_architecture_generalized_plant.
The $\mathcal{H}_\infty$ mixed-sensitivity synthesis can finally be performed by applying the standard $\mathcal{H}_\infty$ synthesis to the generalized plant $P_L(s)$ which is described by\nbsp{}eqref:eq:generalized_plant_mixed_sensitivity.
2021-06-21 11:40:36 +02:00
#+name: eq:generalized_plant_mixed_sensitivity
\begin{equation}
2021-06-21 11:40:36 +02:00
\begin{bmatrix} z \\ v \end{bmatrix} = P_L(s) \begin{bmatrix} w_1 \\ w_2 \\ u \end{bmatrix}; \quad P_L(s) = \begin{bmatrix}
\phantom{+}W_1(s) & 0 & \phantom{+}1 \\
-W_1(s) & W_2(s) & -1
\end{bmatrix}
\end{equation}
2021-09-08 10:56:25 +02:00
The output of the synthesis is a filter $L(s)$ such that the "closed-loop" $\mathcal{H}_\infty$ norm from $[w_1,\ w_2]$ to $z$ of the system in Fig.\nbsp{}ref:fig:feedback_sensor_fusion is less than one\nbsp{}eqref:eq:comp_filters_feedback_obj.
2021-06-21 11:40:36 +02:00
#+name: eq:comp_filters_feedback_obj
\begin{equation}
\left\| \begin{matrix} \frac{z}{w_1} \\ \frac{z}{w_2} \end{matrix} \right\|_\infty = \left\| \begin{matrix} \frac{1}{1 + L(s)} W_1(s) \\ \frac{L(s)}{1 + L(s)} W_2(s) \end{matrix} \right\|_\infty \le 1
2021-06-21 11:40:36 +02:00
\end{equation}
2021-09-08 10:56:25 +02:00
If the synthesis is successful, the transfer functions from $\hat{x}_1$ to $\hat{x}$ and from $\hat{x}_2$ to $\hat{x}$ have their magnitude bounded by the inverse magnitude of the corresponding weighting functions.
The sensor fusion can then be implemented using the feedback architecture in Fig.\nbsp{}ref:fig:feedback_sensor_fusion_arch or more classically as shown in Fig.\nbsp{}ref:fig:sensor_fusion_overview by defining the two complementary filters using\nbsp{}eqref:eq:comp_filters_feedback.
The two architectures are equivalent regarding their inputs/outputs relationships.
2021-06-21 11:40:36 +02:00
#+name: eq:comp_filters_feedback
\begin{equation}
2021-06-21 11:40:36 +02:00
H_1(s) = \frac{1}{1 + L(s)}; \quad H_2(s) = \frac{L(s)}{1 + L(s)}
\end{equation}
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[t]{0.6\linewidth}
\centering
\includegraphics[scale=1]{figs/feedback_synthesis_architecture.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:feedback_synthesis_architecture} Feedback architecture with included weights.}
\end{subfigure}
\hfill
\begin{subfigure}[t]{0.4\linewidth}
\centering
\includegraphics[scale=1]{figs/feedback_synthesis_architecture_generalized_plant.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:feedback_synthesis_architecture_generalized_plant} Generalized plant.}
\end{subfigure}
\hfill
2021-09-02 10:02:12 +02:00
\caption{\label{fig:h_inf_mixed_sensitivity_synthesis} $\mathcal{H}_\infty$ mixed-sensitivity synthesis.}
\centering
\end{figure}
#+end_export
2021-06-21 11:40:36 +02:00
As an example, two "closed-loop" complementary filters are designed using the $\mathcal{H}_\infty$ mixed-sensitivity synthesis.
The weighting functions are designed using formula\nbsp{}eqref:eq:weight_formula with parameters shown in Table\nbsp{}ref:tab:weights_params.
2021-09-08 10:56:25 +02:00
After synthesis, a filter $L(s)$ is obtained whose magnitude is shown in Fig.\nbsp{}ref:fig:hinf_filters_results_mixed_sensitivity by the black dashed line.
The "closed-loop" complementary filters are compared with the inverse magnitude of the weighting functions in Fig.\nbsp{}ref:fig:hinf_filters_results_mixed_sensitivity confirming that the synthesis is successful.
The obtained "closed-loop" complementary filters are indeed equal to the ones obtained in Section\nbsp{}ref:sec:hinf_example.
2021-04-29 16:55:38 +02:00
#+name: fig:hinf_filters_results_mixed_sensitivity
2021-09-02 10:02:12 +02:00
#+caption: Bode plot of the obtained complementary filters after $\mathcal{H}_\infty$ mixed-sensitivity synthesis.
[[file:figs/hinf_filters_results_mixed_sensitivity.pdf]]
2021-04-29 16:55:38 +02:00
2021-09-08 10:56:25 +02:00
** Synthesis of a set of three complementary filters
2021-04-29 16:55:38 +02:00
<<sec:hinf_three_comp_filters>>
Some applications may require to merge more than two sensors\nbsp{}cite:stoten01_fusion_kinet_data_using_compos_filter,becker15_compl_filter_desig_three_frequen_bands.
2021-09-08 10:56:25 +02:00
For instance at the LIGO, three sensors (an LVDT, a seismometer and a geophone) are merged to form a super sensor\nbsp{}cite:matichard15_seism_isolat_advan_ligo (Fig.\nbsp{}ref:fig:ligo_super_sensor_architecture).\par
When merging $n>2$ sensors using complementary filters, two architectures can be used as shown in Fig.\nbsp{}ref:fig:sensor_fusion_three.
The fusion can either be done in a "sequential" way where $n-1$ sets of two complementary filters are used (Fig.\nbsp{}ref:fig:sensor_fusion_three_sequential), or in a "parallel" way where one set of $n$ complementary filters is used (Fig.\nbsp{}ref:fig:sensor_fusion_three_parallel).
2021-06-21 11:40:36 +02:00
In the first case, typical sensor fusion synthesis techniques can be used.
2021-09-08 10:56:25 +02:00
However, when a parallel architecture is used, a new synthesis method for a set of more than two complementary filters is required as only simple analytical formulas have been proposed in the literature\nbsp{}cite:stoten01_fusion_kinet_data_using_compos_filter,becker15_compl_filter_desig_three_frequen_bands.
A generalization of the proposed synthesis method of complementary filters is presented in this section. \par
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_fusion_three_sequential.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_fusion_three_sequential}Sequential fusion.}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.39\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_fusion_three_parallel.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_fusion_three_parallel}Parallel fusion.}
\end{subfigure}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:sensor_fusion_three}Possible sensor fusion architecture when more than two sensors are to be merged.}
\centering
\end{figure}
#+end_export
The synthesis objective is to compute a set of $n$ stable transfer functions $[H_1(s),\ H_2(s),\ \dots,\ H_n(s)]$ such that conditions\nbsp{}eqref:eq:hinf_cond_compl_gen and\nbsp{}eqref:eq:hinf_cond_perf_gen are satisfied.
2021-04-29 16:55:38 +02:00
#+name: eq:hinf_problem_gen
\begin{subequations}
\begin{align}
2021-09-08 10:56:25 +02:00
& \sum_{i=1}^n H_i(s) = 1 \label{eq:hinf_cond_compl_gen} \\
2021-04-29 16:55:38 +02:00
& \left| H_i(j\omega) \right| < \frac{1}{\left| W_i(j\omega) \right|}, \quad \forall \omega,\ i = 1 \dots n \label{eq:hinf_cond_perf_gen}
\end{align}
\end{subequations}
2021-09-08 10:56:25 +02:00
$[W_1(s),\ W_2(s),\ \dots,\ W_n(s)]$ are weighting transfer functions that are chosen to specify the maximum complementary filters' norm during the synthesis.
2021-04-29 16:55:38 +02:00
2021-09-02 10:02:12 +02:00
Such synthesis objective is closely related to the one described in Section\nbsp{}ref:sec:synthesis_objective, and indeed the proposed synthesis method is a generalization of the one presented in Section\nbsp{}ref:sec:hinf_synthesis. \par
2021-04-29 16:55:38 +02:00
2021-09-08 10:56:25 +02:00
A set of $n$ complementary filters can be shaped by applying the standard $\mathcal{H}_\infty$ synthesis to the generalized plant $P_n(s)$ described by\nbsp{}eqref:eq:generalized_plant_n_filters.
#+name: eq:generalized_plant_n_filters
\begin{equation}
\begin{bmatrix} z_1 \\ \vdots \\ z_n \\ v \end{bmatrix} = P_n(s) \begin{bmatrix} w \\ u_1 \\ \vdots \\ u_{n-1} \end{bmatrix}; \quad
P_n(s) = \begin{bmatrix}
W_1 & -W_1 & \dots & \dots & -W_1 \\
0 & W_2 & 0 & \dots & 0 \\
\vdots & \ddots & \ddots & \ddots & \vdots \\
\vdots & & \ddots & \ddots & 0 \\
0 & \dots & \dots & 0 & W_n \\
1 & 0 & \dots & \dots & 0
\end{bmatrix}
\end{equation}
If the synthesis if successful, a set of $n-1$ filters $[H_2(s),\ H_3(s),\ \dots,\ H_n(s)]$ are obtained such that\nbsp{}eqref:eq:hinf_syn_obj_gen is verified.
#+name: eq:hinf_syn_obj_gen
\begin{equation}
\left\|\begin{matrix} \left(1 - \left[ H_2(s) + H_3(s) + \dots + H_n(s) \right]\right) W_1(s) \\ H_2(s) W_2(s) \\ \vdots \\ H_n(s) W_n(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
$H_1(s)$ is then defined using\nbsp{}eqref:eq:h1_comp_h2_hn which is ensuring the complementary property for the set of $n$ filters\nbsp{}eqref:eq:hinf_cond_compl_gen.
Condition\nbsp{}eqref:eq:hinf_cond_perf_gen is satisfied thanks to\nbsp{}eqref:eq:hinf_syn_obj_gen.
#+name: eq:h1_comp_h2_hn
\begin{equation}
H_1(s) \triangleq 1 - \big[ H_2(s) + H_3(s) + \dots + H_n(s) \big]
\end{equation}
An example is given to validate the proposed method for the synthesis of a set of three complementary filters.
The sensors to be merged are a displacement sensor from DC up to $\SI{1}{Hz}$, a geophone from $1$ to $\SI{10}{Hz}$ and an accelerometer above $\SI{10}{Hz}$.
Three weighting functions are designed using formula\nbsp{}eqref:eq:weight_formula and their inverse magnitude are shown in Fig.\nbsp{}ref:fig:three_complementary_filters_results (dashed curves).
Consider the generalized plant $P_3(s)$ shown in Fig.\nbsp{}ref:fig:comp_filter_three_hinf_gen_plant which is also described by\nbsp{}eqref:eq:generalized_plant_three_filters.
2021-06-21 11:40:36 +02:00
#+name: eq:generalized_plant_three_filters
2021-04-29 16:55:38 +02:00
\begin{equation}
2021-06-21 11:40:36 +02:00
\begin{bmatrix} z_1 \\ z_2 \\ z_3 \\ v \end{bmatrix} = P_3(s) \begin{bmatrix} w \\ u_1 \\ u_2 \end{bmatrix}; \quad P_3(s) = \begin{bmatrix}W_1(s) & -W_1(s) & -W_1(s) \\ 0 & \phantom{+}W_2(s) & 0 \\ 0 & 0 & \phantom{+}W_3(s) \\ 1 & 0 & 0 \end{bmatrix}
2021-04-29 16:55:38 +02:00
\end{equation}
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/comp_filter_three_hinf_gen_plant.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:comp_filter_three_hinf_gen_plant} Generalized plant.}
\vfill
\end{subfigure}
\hfill
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/comp_filter_three_hinf_fb.pdf}
2021-09-02 10:02:12 +02:00
\caption{\label{fig:comp_filter_three_hinf_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
2021-09-02 10:02:12 +02:00
\caption{\label{fig:comp_filter_three_hinf} Architecture for the $\mathcal{H}_\infty$ synthesis of three complementary filters.}
\centering
\end{figure}
#+end_export
2021-04-29 16:55:38 +02:00
2021-09-08 10:56:25 +02:00
The standard $\mathcal{H}_\infty$ synthesis is performed on the generalized plant $P_3(s)$.
Two filters $H_2(s)$ and $H_3(s)$ are obtained such that the $\mathcal{H}_\infty$ norm of the closed-loop transfer from $w$ to $[z_1,\ z_2,\ z_3]$ of the system in Fig.\nbsp{}ref:fig:comp_filter_three_hinf_fb is less than one.
Filter $H_1(s)$ is defined using\nbsp{}eqref:eq:h1_compl_h2_h3 thus ensuring the complementary property of the obtained set of filters.
2021-06-21 11:40:36 +02:00
2021-09-08 10:56:25 +02:00
#+name: eq:h1_compl_h2_h3
2021-06-21 11:40:36 +02:00
\begin{equation}
2021-09-08 10:56:25 +02:00
H_1(s) \triangleq 1 - \big[ H_2(s) + H_3(s) \big]
2021-06-21 11:40:36 +02:00
\end{equation}
2021-09-08 10:56:25 +02:00
Figure\nbsp{}ref:fig:three_complementary_filters_results displays the three synthesized complementary filters (solid lines) which confirms that the synthesis is successful.\par
2021-04-29 16:55:38 +02:00
2021-05-03 17:47:19 +02:00
#+name: fig:three_complementary_filters_results
2021-09-02 10:02:12 +02:00
#+caption: Bode plot of the inverse weighting functions and of the three complementary filters obtained using the $\mathcal{H}_\infty$ synthesis.
2021-05-03 17:47:19 +02:00
[[file:figs/three_complementary_filters_results.pdf]]
2021-04-29 16:55:38 +02:00
2021-04-28 16:00:12 +02:00
* Conclusion
<<sec:conclusion>>
2021-09-08 10:56:25 +02:00
A new method for designing complementary filters using the $\mathcal{H}_\infty$ synthesis has been proposed.
It allows to shape the magnitude of the filters by the use of weighting functions during the synthesis.
This is very valuable in practice as the characteristics of the super sensor are linked to the complementary filters' magnitude.
Therefore typical sensor fusion objectives can be translated into requirements on the magnitudes of the filters.
2021-09-02 10:02:12 +02:00
Several examples were used to emphasize the simplicity and the effectiveness of the proposed method.
2021-09-08 10:56:25 +02:00
However, the shaping of the complementary filters' magnitude does not allow to directly optimize the super sensor noise and dynamical characteristics.
Future work will aim at developing a complementary filter synthesis method that minimizes the super sensor noise while ensuring the robustness of the fusion.
2021-04-28 16:00:12 +02:00
* Acknowledgment
:PROPERTIES:
:UNNUMBERED: t
:END:
2021-04-28 16:00:12 +02:00
This research benefited from a FRIA grant from the French Community of Belgium.
2021-09-08 10:56:25 +02:00
This paper has been assigned the LIGO document number LIGO-P2100328.
* Data Availability
:PROPERTIES:
:UNNUMBERED: t
:END:
2021-09-02 10:02:12 +02:00
Matlab\nbsp{}cite:matlab20 was used for this study.
The source code is available under a MIT License and archived in Zenodo\nbsp{}cite:dehaeze21_new_method_desig_compl_filter_code.
2021-04-28 16:00:12 +02:00
* Bibliography :ignore:
\bibliographystyle{elsarticle-num}
\bibliography{ref}
2021-04-29 16:55:38 +02:00
* Local Variables :noexport:
# Local Variables:
# org-latex-packages-alist: nil
# End: