First review

This commit is contained in:
Thomas Dehaeze 2021-09-02 10:02:12 +02:00
parent d424d56143
commit 504f0d7935
3 changed files with 188 additions and 208 deletions

View File

@ -1,4 +1,4 @@
#+TITLE: A new method of designing complementary filters for sensor fusion using the $\mathcal{H}_\infty$ synthesis
#+TITLE: Designing complementary filters for sensor fusion using $\mathcal{H}_\infty$ synthesis
:DRAWER:
#+LATEX_CLASS: elsarticle
#+LATEX_CLASS_OPTIONS: [preprint, sort&compress]
@ -13,7 +13,7 @@
#+LATEX_HEADER_EXTRA: \cortext[cor1]{Corresponding author. Email Address: thomas.dehaeze@esrf.fr}
#+LATEX_HEADER_EXTRA: \address[a1]{European Synchrotron Radiation Facility, Grenoble, France}
#+LATEX_HEADER_EXTRA: \address[a2]{University of Li\`{e}ge, Department of Aerospace and Mechanical Engineering, 4000 Li\`{e}ge, Belgium.}
#+LATEX_HEADER_EXTRA: \address[a2]{University of Li\`{e}ge, PML, Department of Aerospace and Mechanical Engineering, 4000 Li\`{e}ge, Belgium.}
#+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.}
@ -41,7 +41,16 @@
("\\paragraph{%s}" . "\\paragraph*{%s}")
("\\subparagraph{%s}" . "\\subparagraph*{%s}"))
)
;; 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)))
(add-to-list 'org-export-filter-headline-functions
'my-latex-filter-removeOrgAutoLabels)
;; Automatic delete org org-comments
(defun delete-org-comments (backend)
(loop for comment in (reverse (org-element-map (org-element-parse-buffer)
'comment 'identity))
@ -84,57 +93,57 @@ Sensor fusion \sep{} Complementary filters \sep{} $\mathcal{H}_\infty$ synthesis
** Introduction to Sensor Fusion :ignore:
Measuring a physical quantity using sensors is always subject to several limitations.
First, the accuracy of the measurement will be affected by several noise sources, such as the electrical noise of the conditioning electronics being used.
First, the accuracy of the measurement will be 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.
Fortunately, a wide variety of sensors exist, each with different characteristics.
By carefully choosing the fused sensors, a so called "super sensor" is obtain that combines benefits of individual sensors and yields a better estimate of the measured physical quantity. \par
By carefully choosing the fused sensors, a so called "super sensor" is obtained that combines benefits of individual sensors. \par
** Advantages of Sensor Fusion :ignore:
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.
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.
For other applications, sensor fusion is used to obtain a 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 obtained 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 to improve the stability margins of the feedback controller. \par
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:
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.
Sensor fusion was also shown to be a key technology to improve the performances of active vibration isolation systems\nbsp{}cite:tjepkema12_sensor_fusion_activ_vibrat_isolat_precis_equip.
This is particularly apparent for the isolation stages of gravitational wave observer\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
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
** Kalman Filtering / Complementary filters :ignore:
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.
However, for Kalman filtering, we are forced to make assumption about the probabilistic character of the sensor noises\nbsp{}cite:robert12_introd_random_signal_applied_kalman whereas it is not the case for complementary filters.
Furthermore, the main advantages of complementary filters over Kalman filtering for sensor fusion are their very general applicability, their low computational cost\nbsp{}cite:higgins75_compar_compl_kalman_filter, and the fact that they are very intuitive as their effects can be easily interpreted in the frequency domain. \par
However, for Kalman filtering, we are forced to make assumption 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.
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
** Design Methods of Complementary filters :ignore:
A set of filters is said to be complementary if the sum of their transfer functions is equal to one at all frequencies.
For the earliest used of complementary filtering for sensor fusion, analog circuits were used 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 numerically as it allows for much more flexibility. \par
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
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
As the characteristics of the "super sensor" depends on the design of the complementary filters\nbsp{}cite:dehaeze19_compl_filter_shapin_using_synth, several optimization techniques were developed over the years.
Some are based on the finding the 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 the characteristics of the "super sensor" depends on the design of the complementary filters\nbsp{}cite:dehaeze19_compl_filter_shapin_using_synth, several optimization techniques have been developed over the years.
Some are based on the finding 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
** Problematic / gap in the research :ignore:
The common objective to all these complementary filters design methods is to obtain a super sensor that has desired characteristics, usually in terms of noise and dynamics.
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.
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.
Therefore, the robustness of the fusion is also of concerned when designing the complementary filters.
Although many design methods of complementary filters have been proposed in the literature, no simple method that allows to specify the wanted super sensor characteristic while ensuring good fusion robustness has been proposed. \par
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
** Describe the paper itself / the problem which is addressed :ignore:
@ -144,7 +153,7 @@ Based on that, this paper introduces a new way to design complementary filters u
** Introduce Each part of the paper :ignore:
Section\nbsp{}ref:sec:requirements introduces the sensor fusion architecture and demonstrates how typical requirements can be linked to the complementary filters magnitudes.
In section\nbsp{}ref:sec:hinf_method, the shaping of complementary filters is written as an $\mathcal{H}_\infty$ optimization problem using weighting functions, and the simplicity of the proposed method is illustrated with an example.
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.
Section\nbsp{}ref:sec:discussion compares the proposed synthesis method with the classical mixed-sensitivity synthesis, and extends it to the shaping of more than two complementary filters.
@ -167,7 +176,7 @@ The resulting sensor, termed as super sensor, can have larger bandwidth and bett
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.
#+name: fig:sensor_fusion_overview
#+caption: Schematic of a sensor fusion architecture using complementary filters
#+caption: Schematic of a sensor fusion architecture using complementary filters.
[[file:figs/sensor_fusion_overview.pdf]]
The complementary property of filters $H_1(s)$ and $H_2(s)$ implies that the sum of their transfer functions is equal to unity.
@ -198,15 +207,15 @@ The sensor dynamics estimate $\hat{G}_1(s)$ can be a simple gain or a more compl
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model.pdf}
\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)$}
\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)$.}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_calibrated.pdf}
\caption{\label{fig:sensor_model_calibrated} Normalized sensors using the inverse of an estimate $\hat{G}_i(s)$ of the sensor dynamics}
\caption{\label{fig:sensor_model_calibrated} Normalized sensors using the inverse of an estimate $\hat{G}_i(s)$ of the sensor dynamics.}
\end{subfigure}
\caption{\label{fig:sensor_models}Sensor models with and without normalization}
\caption{\label{fig:sensor_models}Sensor models with and without normalization.}
\centering
\end{figure}
#+end_export
@ -222,7 +231,7 @@ The super sensor output is therefore equal to:
\end{equation}
#+name: fig:fusion_super_sensor
#+caption: Sensor fusion architecture with two normalized sensors
#+caption: Sensor fusion architecture with two normalized sensors.
[[file:figs/fusion_super_sensor.pdf]]
** Noise Sensor Filtering
@ -236,23 +245,23 @@ In this section, it is supposed that all the sensors are perfectly normalized, s
The effect of a non-perfect normalization will be discussed in the next section.
Provided eqref:eq:perfect_dynamics is verified, the super sensor output $\hat{x}$ is then:
Provided\nbsp{}eqref:eq:perfect_dynamics is verified, the super sensor output $\hat{x}$ is then:
#+name: eq:estimate_perfect_dyn
\begin{equation}
\hat{x} = x + H_1(s) n_1 + H_2(s) n_2
\end{equation}
From eqref:eq:estimate_perfect_dyn, the complementary filters $H_1(s)$ and $H_2(s)$ are shown to only operate on the sensor's noises.
From\nbsp{}eqref:eq:estimate_perfect_dyn, the complementary filters $H_1(s)$ and $H_2(s)$ are shown to only operate on the sensor's noises.
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.
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 eqref:eq:estimate_error.
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.
#+name: eq:estimate_error
\begin{equation}
\delta x \triangleq \hat{x} - x = H_1(s) n_1 + H_2(s) n_2
\end{equation}
As shown in 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}$.
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}$.
#+name: eq:noise_filtering_psd
\begin{equation}
\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)
@ -268,7 +277,7 @@ Therefore, by properly shaping the norm of the complementary filters, it is poss
** Sensor Fusion Robustness
<<sec:fusion_robustness>>
In practical systems the sensor normalization is not perfect and condition eqref:eq:perfect_dynamics is not verified.
In practical systems the sensor normalization is not perfect and condition\nbsp{}eqref:eq:perfect_dynamics is not verified.
In order to study such imperfection, a multiplicative input uncertainty is added to the sensor dynamics (Fig.\nbsp{}ref:fig:sensor_model_uncertainty).
The nominal model is taken as the estimated model for the normalization $\hat{G}_i(s)$, $\Delta_i$ 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.
@ -282,16 +291,16 @@ As the nominal sensor dynamics is taken as the normalized filter, the normalized
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty.pdf}
\caption{\label{fig:sensor_model_uncertainty} Sensor with multiplicative input uncertainty}
\caption{\label{fig:sensor_model_uncertainty} Sensor with multiplicative input uncertainty.}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.39\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty_simplified.pdf}
\caption{\label{fig:sensor_model_uncertainty_simplified} Simplified sensor model}
\caption{\label{fig:sensor_model_uncertainty_simplified} Simplified sensor model.}
\end{subfigure}
\hfill
\caption{\label{fig:sensor_models_uncertainty}Sensor models with dynamical uncertainty}
\caption{\label{fig:sensor_models_uncertainty}Sensor models with dynamical uncertainty.}
\centering
\end{figure}
#+end_export
@ -299,10 +308,10 @@ As the nominal sensor dynamics is taken as the normalized filter, the normalized
The sensor fusion architecture with two sensor models including dynamical uncertainty is shown in Fig.\nbsp{}ref:fig:sensor_fusion_dynamic_uncertainty.
#+name: fig:sensor_fusion_dynamic_uncertainty
#+caption: Sensor fusion architecture with sensor dynamics uncertainty
#+caption: Sensor fusion architecture with sensor dynamics uncertainty.
[[file:figs/sensor_fusion_dynamic_uncertainty.pdf]]
The super sensor dynamics 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)$.
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)$.
#+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)
@ -314,9 +323,9 @@ The dynamical uncertainty of the super sensor can be graphically represented in
#+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.
[[file:figs/uncertainty_set_super_sensor.pdf]]
The super sensor dynamical uncertainty (i.e. the robustness of the fusion) clearly depends on the complementary filters norms.
The super sensor dynamical uncertainty, and hence the robustness of the fusion, clearly depends on the complementary filters norms.
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).
Therefore, the phase uncertainty of the super sensor dynamics depends on the Complementary filters norms eqref:eq:max_phase_uncertainty.
Therefore, the phase uncertainty of the super sensor dynamics depends on the Complementary filters norms\nbsp{}eqref:eq:max_phase_uncertainty.
#+name: eq:max_phase_uncertainty
\begin{equation}
@ -339,8 +348,8 @@ Finally, the synthesis method is validated on an simple example.
** Synthesis Objective
<<sec:synthesis_objective>>
The synthesis objective is to shape the norm of two filters $H_1(s)$ and $H_2(s)$ while ensuring their complementary property 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 eqref:eq:hinf_cond_complementarity, eqref:eq:hinf_cond_h1 and eqref:eq:hinf_cond_h2 are satisfied.
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.
#+name: eq:comp_filter_problem_form
\begin{subequations}
@ -357,7 +366,7 @@ $W_1(s)$ and $W_2(s)$ are two weighting transfer functions that are carefully ch
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.
Consider the generalized plant $P(s)$ shown in Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_plant and mathematically described by eqref:eq:generalized_plant.
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.
#+name: eq:generalized_plant
\begin{equation}
@ -369,28 +378,28 @@ Consider the generalized plant $P(s)$ shown in Fig.\nbsp{}ref:fig:h_infinity_rob
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/h_infinity_robust_fusion_plant.pdf}
\caption{\label{fig:h_infinity_robust_fusion_plant} Generalized plant}
\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}
\caption{\label{fig:h_infinity_robust_fusion_fb} Generalized plant with the synthesized filter}
\caption{\label{fig:h_infinity_robust_fusion_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
\caption{\label{fig:h_infinity_robust_fusion} Architecture for the $\mathcal{H}_\infty$ synthesis of complementary filters}
\caption{\label{fig:h_infinity_robust_fusion} Architecture for the $\mathcal{H}_\infty$ synthesis of complementary filters.}
\centering
\end{figure}
#+end_export
Applying the standard $\mathcal{H}_\infty$ synthesis on 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 eqref:eq:hinf_syn_obj.
Applying the standard $\mathcal{H}_\infty$ synthesis on 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.
#+name: eq:hinf_syn_obj
\begin{equation}
\left\|\begin{matrix} \left(1 - H_2(s)\right) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
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 eqref:eq:hinf_problem which ensure that eqref:eq:hinf_cond_h1 and eqref:eq:hinf_cond_h2 are satisfied.
By then defining $H_1(s)$ to be the complementary of $H_2(s)$\nbsp{}eqref:eq:definition_H1, the $\mathcal{H}_\infty$ synthesis objective becomes equivalent to\nbsp{}eqref:eq:hinf_problem which ensure that\nbsp{}eqref:eq:hinf_cond_h1 and\nbsp{}eqref:eq:hinf_cond_h2 are satisfied.
#+name: eq:definition_H1
\begin{equation}
@ -402,7 +411,7 @@ By then defining $H_1(s)$ to be the complementary of $H_2(s)$ eqref:eq:definitio
\left\|\begin{matrix} H_1(s) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
Therefore, applying the $\mathcal{H}_\infty$ synthesis on 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 eqref:eq:comp_filter_problem_form and such that there norms are bellow specified bounds [[eqref:eq:hinf_cond_h1]],eqref:eq:hinf_cond_h2.
Therefore, applying the $\mathcal{H}_\infty$ synthesis on the standard plant $P(s)$\nbsp{}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.
Note that there is not an equivalence 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, but only an implication.
Hence, the optimization may be a little bit conservative with respect to the "set" of filters on which it is performed.
@ -417,11 +426,11 @@ The proper design of these weighting functions is of primary importance for the
First, only proper and stable transfer functions should be used.
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 order of the synthesized filters being equal to the sum of the weighting functions orders).
Third, one should not forget the fundamental limitations imposed by the complementary property eqref:eq:comp_filter.
Third, one should not forget the fundamental limitations imposed by the complementary property\nbsp{}eqref:eq:comp_filter.
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.
To help with the design of the weighting functions such that the above specification can be easily expressed, the formula eqref:eq:weight_formula is proposed.
To help with the design of the weighting functions such that the above specification can be easily expressed, the formula\nbsp{}eqref:eq:weight_formula is proposed.
#+name: eq:weight_formula
\begin{equation}
@ -432,13 +441,13 @@ To help with the design of the weighting functions such that the above specifica
}\right)^n
\end{equation}
The parameters in formula 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
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.
The parameters $G_0$, $G_c$ and $G_\infty$ should either satisfy condition eqref:eq:cond_formula_1 or eqref:eq:cond_formula_2.
The parameters $G_0$, $G_c$ and $G_\infty$ should either satisfy condition\nbsp{}eqref:eq:cond_formula_1 or\nbsp{}eqref:eq:cond_formula_2.
#+name: eq:condition_params_formula
\begin{subequations}
\begin{align}
@ -447,10 +456,10 @@ The parameters $G_0$, $G_c$ and $G_\infty$ should either satisfy condition eqref
\end{align}
\end{subequations}
An example of the obtained magnitude of a weighting function generated using eqref:eq:weight_formula is shown in Fig.\nbsp{}ref:fig:weight_formula.
An example of the obtained magnitude of a weighting function generated using\nbsp{}eqref:eq:weight_formula is shown in Fig.\nbsp{}ref:fig:weight_formula.
#+name: fig:weight_formula
#+caption: Magnitude of a weighting function generated using the proposed formula eqref:eq:weight_formula, $G_0 = 1e^{-3}$, $G_\infty = 10$, $\omega_c = \SI{10}{Hz}$, $G_c = 2$, $n = 3$
#+caption: Magnitude of a weighting function generated using the proposed formula\nbsp{}eqref:eq:weight_formula, $G_0 = 1e^{-3}$, $G_\infty = 10$, $\omega_c = \SI{10}{Hz}$, $G_c = 2$, $n = 3$.
[[file:figs/weight_formula.pdf]]
** Validation of the proposed synthesis method
@ -462,7 +471,7 @@ The proposed methodology for the design of complementary filters is now applied
- the slope of $|H_2(j\omega)|$ is $-3$ above $\SI{10}{Hz}$, its high frequency gain is $10^{-3}$
The first step is to translate the above requirements into the design of the weighting functions.
The proposed formula eqref:eq:weight_formula is here used for such purpose.
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.
@ -481,20 +490,20 @@ Parameters & \(W_1(s)\) & \(W_2(s)\)\\
\(n\) & \(2\) & \(3\)\\
\bottomrule
\end{tabularx}
\captionof{table}{\label{tab:weights_params}Parameters used for weighting functions \(W_1(s)\) and \(W_2(s)\) using \eqref{eq:weight_formula}}
\captionof{table}{\label{tab:weights_params}Parameters used for weighting functions \(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}
\caption{\label{fig:weights_W1_W2}Inverse magnitude of the weighting functions}
\caption{\label{fig:weights_W1_W2}Inverse magnitude of the weighting functions.}
\end{minipage}
\end{figure}
#+end_export
The $\mathcal{H}_\infty$ synthesis is then applied to the generalized plant of Fig.\nbsp{}ref:fig:h_infinity_robust_fusion_plant on efficiently solved in Matlab\nbsp{}cite:matlab20 using the Robust Control Toolbox.
The filter $H_2(s)$ that minimizes the $\mathcal{H}_\infty$ norm between $w$ and $[z_1,\ z_2]^T$ is obtained.
The $\mathcal{H}_\infty$ norm is here found to be close to one eqref:eq:hinf_synthesis_result which indicates that the synthesis is successful: the complementary filters norms are below the maximum specified upper bounds.
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.
#+name: eq:hinf_synthesis_result
@ -502,7 +511,7 @@ This is confirmed by the bode plots of the obtained complementary filters in Fig
\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}
Their transfer functions in the Laplace domain are given in eqref:eq:hinf_synthesis_result_tf.
Their transfer functions in the Laplace domain 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 orders.
#+name: eq:hinf_synthesis_result_tf
@ -515,7 +524,7 @@ As expected, the obtained filters are of order $5$, that is the sum of the weigh
#+name: fig:hinf_filters_results
#+caption: Bode plot of the obtained complementary filters
#+caption: Bode plot of the obtained complementary filters.
[[file:figs/hinf_filters_results.pdf]]
This simple example illustrates the fact that the proposed methodology for complementary filters shaping is easy to use and effective.
@ -533,15 +542,15 @@ Then, another set of complementary filters ($L_1,H_1$) is used to merge the outp
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
#+caption: Simplified block diagram of the sensor blending strategy for the first stage at the LIGO\nbsp{}cite:hua04_low_ligo
#+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]]
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 and therefore allow the feedback loop to have authority at zero frequency.
The requirements on those filters are very tight and thus their design is complex and should be expressed as an optimization problem.
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.
However they are of very high order so their implementation is quite complex.
However they are of high order so their implementation is quite complex.
In this section, the effectiveness of the proposed complementary filter synthesis strategy is demonstrated on the same set of requirements.
** Complementary Filters Specifications
@ -557,7 +566,7 @@ These specifications are therefore upper bounds on the complementary filters' ma
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
#+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
#+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]]
** Weighting Functions Design
@ -571,7 +580,7 @@ For the one corresponding to the high pass filter $W_H(s)$, a $7^{\text{th}}$ or
The magnitudes of the weighting functions are shown in Fig.\nbsp{}ref:fig:ligo_weights.
#+name: fig:ligo_weights
#+caption: Specifications and weighting functions inverse magnitudes
#+caption: Specifications and weighting functions inverse magnitudes.
[[file:figs/ligo_weights.pdf]]
** $\mathcal{H}_\infty$ Synthesis of the complementary filters
@ -580,11 +589,11 @@ The magnitudes of the weighting functions are shown in Fig.\nbsp{}ref:fig:ligo_w
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.
Even though the complementary filters using the $\mathcal{H}_\infty$ synthesis are of much lower order (order 27), they are found to be very close to the FIR filters.
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.
#+name: fig:comp_fir_ligo_hinf
#+caption: Comparison of the FIR filters (dashed) designed in\nbsp{}cite:hua05_low_ligo with the filters obtained with $\mathcal{H}_\infty$ synthesis (solid)
#+caption: Comparison of the FIR filters (dashed) designed in\nbsp{}cite:hua05_low_ligo with the filters obtained with $\mathcal{H}_\infty$ synthesis (solid).
[[file:figs/comp_fir_ligo_hinf.pdf]]
* Discussion
@ -594,14 +603,14 @@ This confirms the effectiveness of the proposed synthesis method even when the c
** "Closed-Loop" complementary filters
<<sec:closed_loop_complementary_filters>>
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.
This is for instance presented in cite:mahony05_compl_filter_desig_special_orthog,plummer06_optim_compl_filter_their_applic_motion_measur,jensen13_basic_uas.
This is for instance presented 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
#+caption: "Closed-Loop" complementary filters
#+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}$.
The output $\hat{x}$ is linked to the inputs by eqref:eq:closed_loop_complementary_filters.
The output $\hat{x}$ is linked to the inputs by\nbsp{}eqref:eq:closed_loop_complementary_filters.
#+name: eq:closed_loop_complementary_filters
\begin{equation}
@ -619,7 +628,7 @@ Therefore, provided that the closed-loop system is stable, the closed-loop syste
Two sensors can then be merged as shown in Fig.\nbsp{}ref:fig:feedback_sensor_fusion_arch.
#+name: fig:feedback_sensor_fusion_arch
#+caption: Classical feedback architecture used for sensor fusion
#+caption: Classical feedback architecture used for sensor fusion.
[[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.
@ -627,7 +636,7 @@ If one want to shape both $\frac{\hat{x}}{\hat{x}_1}(s) = S(s)$ and $\frac{\hat{
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).
Then the system is re-organized 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 $\mathcal{H}_\infty$ synthesis to the generalized plant $P_L(s)$ which is described by eqref:eq:generalized_plant_mixed_sensitivity.
The $\mathcal{H}_\infty$ mixed-sensitivity synthesis can finally be performed by applying the $\mathcal{H}_\infty$ synthesis to the generalized plant $P_L(s)$ which is described by\nbsp{}eqref:eq:generalized_plant_mixed_sensitivity.
#+name: eq:generalized_plant_mixed_sensitivity
\begin{equation}
@ -637,7 +646,7 @@ The $\mathcal{H}_\infty$ mixed-sensitivity synthesis can finally be performed by
\end{bmatrix}
\end{equation}
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$ is less than one eqref:eq:comp_filters_feedback_obj.
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$ is less than one\nbsp{}eqref:eq:comp_filters_feedback_obj.
#+name: eq:comp_filters_feedback_obj
\begin{equation}
@ -652,23 +661,23 @@ The sensor fusion can then be implemented as shown in Fig.\nbsp{}ref:fig:feedbac
H_1(s) = \frac{1}{1 + L(s)}; \quad H_2(s) = \frac{L(s)}{1 + L(s)}
\end{equation}
The two architecture are equivalent regarding their inputs/outputs relationships.
The two architectures are equivalent regarding their inputs/outputs relationships.
#+begin_export latex
\begin{figure}[htbp]
\begin{subfigure}[t]{0.6\linewidth}
\centering
\includegraphics[scale=1]{figs/feedback_synthesis_architecture.pdf}
\caption{\label{fig:feedback_synthesis_architecture} Feedback architecture with included weights}
\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}
\caption{\label{fig:feedback_synthesis_architecture_generalized_plant} Generalized plant}
\caption{\label{fig:feedback_synthesis_architecture_generalized_plant} Generalized plant.}
\end{subfigure}
\hfill
\caption{\label{fig:h_inf_mixed_sensitivity_synthesis} $\mathcal{H}_\infty$ mixed-sensitivity synthesis}
\caption{\label{fig:h_inf_mixed_sensitivity_synthesis} $\mathcal{H}_\infty$ mixed-sensitivity synthesis.}
\centering
\end{figure}
#+end_export
@ -680,7 +689,7 @@ The "closed-loop" complementary filters are compared with the inverse magnitude
The obtained "closed-loop" complementary filters are indeed equal to the ones obtained in Section\nbsp{}ref:sec:hinf_example.
#+name: fig:hinf_filters_results_mixed_sensitivity
#+caption: Bode plot of the obtained complementary filters after $\mathcal{H}_\infty$ mixed-sensitivity synthesis
#+caption: Bode plot of the obtained complementary filters after $\mathcal{H}_\infty$ mixed-sensitivity synthesis.
[[file:figs/hinf_filters_results_mixed_sensitivity.pdf]]
** Synthesis of more than two Complementary Filters
@ -701,15 +710,15 @@ A generalization of the proposed synthesis method of complementary filters is pr
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_fusion_three_sequential.pdf}
\caption{\label{fig:sensor_fusion_three_sequential}Sequential fusion}
\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}
\caption{\label{fig:sensor_fusion_three_parallel}Parallel fusion}
\caption{\label{fig:sensor_fusion_three_parallel}Parallel fusion.}
\end{subfigure}
\caption{\label{fig:sensor_fusion_three}Possible sensor fusion architecture when more than two sensors are to be merged}
\caption{\label{fig:sensor_fusion_three}Possible sensor fusion architecture when more than two sensors are to be merged.}
\centering
\end{figure}
#+end_export
@ -724,7 +733,7 @@ The synthesis objective is to compute a set of $n$ stable transfer functions $[H
\end{subequations}
where $[W_1(s),\ W_2(s),\ \dots,\ W_n(s)]$ are weighting transfer functions that are chosen to specify the maximum wanted norms of the complementary filters during the synthesis.
Such synthesis objective is very close 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
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
Before presenting the generalized synthesis method, the case with three sensors is presented.
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.
@ -739,17 +748,17 @@ Consider the generalized plant $P_3(s)$ shown in Fig.\nbsp{}ref:fig:comp_filter_
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/comp_filter_three_hinf_gen_plant.pdf}
\caption{\label{fig:comp_filter_three_hinf_gen_plant} Generalized plant}
\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}
\caption{\label{fig:comp_filter_three_hinf_fb} Generalized plant with the synthesized filter}
\caption{\label{fig:comp_filter_three_hinf_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
\caption{\label{fig:comp_filter_three_hinf} Architecture for the $\mathcal{H}_\infty$ synthesis of three complementary filters}
\caption{\label{fig:comp_filter_three_hinf} Architecture for the $\mathcal{H}_\infty$ synthesis of three complementary filters.}
\centering
\end{figure}
#+end_export
@ -761,7 +770,7 @@ Applying the $\mathcal{H}_\infty$ synthesis on the generalized plant $P_3(s)$ is
\left\| \begin{matrix} \left[1 - H_2(s) - H_3(s)\right] W_1(s) \\ H_2(s) W_2(s) \\ H_3(s) W_3(s) \end{matrix} \right\|_\infty \le 1
\end{equation}
By defining $H_1(s) \triangleq 1 - H_2(s) - H_3(s)$, the proposed $\mathcal{H}_\infty$ synthesis solves the design problem eqref:eq:hinf_problem_gen with $n=3$. \par
By defining $H_1(s) \triangleq 1 - H_2(s) - H_3(s)$, the proposed $\mathcal{H}_\infty$ synthesis solves the design problem\nbsp{}eqref:eq:hinf_problem_gen with $n=3$. \par
An example is given to validate the method where three sensors are used in different frequency bands.
For instance 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}$.
@ -769,7 +778,7 @@ Three weighting functions are designed using formula\nbsp{}eqref:eq:weight_formu
The $\mathcal{H}_\infty$ synthesis is performed on the generalized plant $P_3(s)$ and the bode plot of the obtained complementary filters are shown in Fig.\nbsp{}ref:fig:three_complementary_filters_results (solid lines). \par
#+name: fig:three_complementary_filters_results
#+caption: Bode plot of the inverse weighting functions and of the three complementary filters obtained using the $\mathcal{H}_\infty$ synthesis
#+caption: Bode plot of the inverse weighting functions and of the three complementary filters obtained using the $\mathcal{H}_\infty$ synthesis.
[[file:figs/three_complementary_filters_results.pdf]]
Even though there might not be any practical application for a set of more than 3 complementary filters, it can still be designed using the same procedure.
@ -791,15 +800,12 @@ A set of $n$ complementary filters can be shaped using the generalized plant $P_
* Conclusion
<<sec:conclusion>>
Sensors measuring a physical quantities are always subject to limitations both in terms of bandwidth or accuracy.
Complementary filters can be used to fuse multiple sensors with different characteristics in order to combine their benefits and yield a better estimate of the measured physical quantity.
The sensor fusion robustness and the obtained super sensor noise can be linked to the magnitude of the complementary filters.
In this paper, a synthesis method that enables the shaping of the complementary filters norms has been proposed.
Several example were used to emphasize the simplicity and the effectiveness of the proposed method.
Links with "closed-loop" complementary filters where highlighted, and the proposed method was generalized for the design of a set of more than two complementary filters.
Several examples were used to emphasize the simplicity and the effectiveness of the proposed method.
Links with "closed-loop" complementary filters were highlighted, and the proposed method was generalized for designing a set of more than two complementary filters.
Future work will aim at developing a complementary filter synthesis method that minimizes the super sensor noise while ensuring the robustness of the fusion.
The future work will aim at developing a complementary filter synthesis method that minimizes the super sensor noise while ensuring the robustness of the fusion.
* Acknowledgment
:PROPERTIES:
@ -807,14 +813,13 @@ Future work will aim at developing a complementary filter synthesis method that
:END:
This research benefited from a FRIA grant from the French Community of Belgium.
This paper is based on a paper previously presented at the ICCMA conference\nbsp{}cite:dehaeze19_compl_filter_shapin_using_synth.
* Data Availability
:PROPERTIES:
:UNNUMBERED: t
:END:
Matlab cite:matlab20 was used for this study.
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.
* Bibliography :ignore:

View File

@ -1,4 +1,4 @@
% Created 2021-09-01 mer. 17:02
% Created 2021-09-02 jeu. 10:02
% Intended LaTeX compiler: pdflatex
\documentclass[preprint, sort&compress]{elsarticle}
\usepackage[utf8]{inputenc}
@ -23,7 +23,7 @@
\author[a2,a4]{Christophe Collette}
\cortext[cor1]{Corresponding author. Email Address: thomas.dehaeze@esrf.fr}
\address[a1]{European Synchrotron Radiation Facility, Grenoble, France}
\address[a2]{University of Li\`{e}ge, Department of Aerospace and Mechanical Engineering, 4000 Li\`{e}ge, Belgium.}
\address[a2]{University of Li\`{e}ge, PML, Department of Aerospace and Mechanical Engineering, 4000 Li\`{e}ge, Belgium.}
\address[a3]{CSIR --- Structural Engineering Research Centre, Taramani, Chennai --- 600113, India.}
\address[a4]{Universit\'{e} Libre de Bruxelles, Precision Mechatronics Laboratory, BEAMS Department, 1050 Brussels, Belgium.}
\usepackage{tabularx}
@ -34,7 +34,7 @@
\hypersetup{colorlinks=true}
\setlength{\parskip}{1em}
\date{}
\title{A new method of designing complementary filters for sensor fusion using the \(\mathcal{H}_\infty\) synthesis}
\title{Designing complementary filters for sensor fusion using \(\mathcal{H}_\infty\) synthesis}
\begin{document}
@ -58,60 +58,57 @@ Sensor fusion \sep{} Complementary filters \sep{} \(\mathcal{H}_\infty\) synthes
\end{frontmatter}
\section{Introduction}
\label{sec:org2e9b248}
\label{sec:introduction}
Measuring a physical quantity using sensors is always subject to several limitations.
First, the accuracy of the measurement will be affected by several noise sources, such as the electrical noise of the conditioning electronics being used.
First, the accuracy of the measurement will be 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''~\cite{bendat57_optim_filter_indep_measur_two}.
Fortunately, a wide variety of sensors exist, each with different characteristics.
By carefully choosing the fused sensors, a so called ``super sensor'' is obtain that combines benefits of individual sensors and yields a better estimate of the measured physical quantity. \par
By carefully choosing the fused sensors, a so called ``super sensor'' is obtained that combines benefits of individual sensors. \par
In some situations, sensor fusion is used to increase the bandwidth of the measurement~\cite{shaw90_bandw_enhan_posit_measur_using_measur_accel,zimmermann92_high_bandw_orien_measur_contr,min15_compl_filter_desig_angle_estim}.
For instance, in~\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.
For other applications, sensor fusion is used to obtain a estimate of the measured quantity with lower noise~\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 obtained interesting properties for control~\cite{collette15_sensor_fusion_method_high_perfor,yong16_high_speed_vertic_posit_stage}.
In~\cite{collette15_sensor_fusion_method_high_perfor}, an inertial sensor used for active vibration isolation is fused with a sensor collocated with the actuator to improve the stability margins of the feedback controller. \par
For other applications, sensor fusion is used to obtain an estimate of the measured quantity with lower noise~\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~\cite{collette15_sensor_fusion_method_high_perfor,yong16_high_speed_vertic_posit_stage}.
In~\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
Practical applications of sensor fusion are numerous.
It is widely used for the attitude estimation of several autonomous vehicles such as unmanned aerial vehicle~\cite{baerveldt97_low_cost_low_weigh_attit,corke04_inert_visual_sensin_system_small_auton_helic,jensen13_basic_uas} and underwater vehicles~\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~\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}.
Sensor fusion was also shown to be a key technology to improve the performances of active vibration isolation systems~\cite{tjepkema12_sensor_fusion_activ_vibrat_isolat_precis_equip}.
This is particularly apparent for the isolation stages of gravitational wave observer~\cite{collette15_sensor_fusion_method_high_perfor,heijningen18_low} such as the ones used at the LIGO~\cite{hua05_low_ligo,hua04_polyp_fir_compl_filter_contr_system} and at the VIRGO~\cite{lucia18_low_frequen_optim_perfor_advan}. \par
Sensor fusion was also shown to be a key technology to improve the performance of active vibration isolation systems~\cite{tjepkema12_sensor_fusion_activ_vibrat_isolat_precis_equip}.
Emblematic examples are the isolation stages of gravitational wave detectors~\cite{collette15_sensor_fusion_method_high_perfor,heijningen18_low} such as the ones used at the LIGO~\cite{hua05_low_ligo,hua04_polyp_fir_compl_filter_contr_system} and at the VIRGO~\cite{lucia18_low_frequen_optim_perfor_advan}. \par
There are mainly two ways to perform sensor fusion: either using a set of complementary filters~\cite{anderson53_instr_approac_system_steer_comput} or using Kalman filtering~\cite{brown72_integ_navig_system_kalman_filter,odry18_kalman_filter_mobil_robot_attit_estim}.
For sensor fusion applications, both methods are sharing many relationships~\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}.
However, for Kalman filtering, we are forced to make assumption about the probabilistic character of the sensor noises~\cite{robert12_introd_random_signal_applied_kalman} whereas it is not the case for complementary filters.
Furthermore, the main advantages of complementary filters over Kalman filtering for sensor fusion are their very general applicability, their low computational cost~\cite{higgins75_compar_compl_kalman_filter}, and the fact that they are very intuitive as their effects can be easily interpreted in the frequency domain. \par
However, for Kalman filtering, we are forced to make assumption about the probabilistic character of the sensor noises~\cite{robert12_introd_random_signal_applied_kalman} whereas it is not the case with complementary filters.
Furthermore, the advantages of complementary filters over Kalman filtering for sensor fusion are their general applicability, their low computational cost~\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
A set of filters is said to be complementary if the sum of their transfer functions is equal to one at all frequencies.
For the earliest used of complementary filtering for sensor fusion, analog circuits were used to physically realize the filters~\cite{anderson53_instr_approac_system_steer_comput}.
Analog complementary filters are still used today~\cite{yong16_high_speed_vertic_posit_stage,moore19_capac_instr_sensor_fusion_high_bandw_nanop}, but most of the time they are now implemented numerically as it allows for much more flexibility. \par
In the early days of complementary filtering, analog circuits were employed to physically realize the filters~\cite{anderson53_instr_approac_system_steer_comput}.
Analog complementary filters are still used today~\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
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~\cite{corke04_inert_visual_sensin_system_small_auton_helic,yeh05_model_contr_hydraul_actuat_two,yong16_high_speed_vertic_posit_stage}, second order~\cite{baerveldt97_low_cost_low_weigh_attit,stoten01_fusion_kinet_data_using_compos_filter,jensen13_basic_uas} or even higher orders~\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
As the characteristics of the ``super sensor'' depends on the design of the complementary filters~\cite{dehaeze19_compl_filter_shapin_using_synth}, several optimization techniques were developed over the years.
Some are based on the finding the optimal parameters of analytical formulas~\cite{jensen13_basic_uas,min15_compl_filter_desig_angle_estim,becker15_compl_filter_desig_three_frequen_bands}, while other are using convex optimization tools~\cite{hua04_polyp_fir_compl_filter_contr_system,hua05_low_ligo} such as linear matrix inequalities~\cite{pascoal99_navig_system_desig_using_time}.
As the characteristics of the ``super sensor'' depends on the design of the complementary filters~\cite{dehaeze19_compl_filter_shapin_using_synth}, several optimization techniques have been developed over the years.
Some are based on the finding optimal parameters of analytical formulas~\cite{jensen13_basic_uas,min15_compl_filter_desig_angle_estim,becker15_compl_filter_desig_three_frequen_bands}, while other are using convex optimization tools~\cite{hua04_polyp_fir_compl_filter_contr_system,hua05_low_ligo} such as linear matrix inequalities~\cite{pascoal99_navig_system_desig_using_time}.
As shown in~\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~\cite{jensen13_basic_uas} the two gains of a Proportional Integral (PI) controller are optimized to minimize the noise of the super sensor. \par
The common objective to all these complementary filters design methods is to obtain a super sensor that has desired characteristics, usually in terms of noise and dynamics.
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.
Moreover, as reported in~\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.
Therefore, the robustness of the fusion is also of concerned when designing the complementary filters.
Although many design methods of complementary filters have been proposed in the literature, no simple method that allows to specify the wanted super sensor characteristic while ensuring good fusion robustness has been proposed. \par
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
Fortunately, both the robustness of the fusion and the super sensor characteristics can be linked to the magnitude of the complementary filters~\cite{dehaeze19_compl_filter_shapin_using_synth}.
Based on that, this paper introduces a new way to design complementary filters using the \(\mathcal{H}_\infty\) synthesis which allows to shape the magnitude of the complementary filters in an easy and intuitive way. \par
Section~\ref{sec:requirements} introduces the sensor fusion architecture and demonstrates how typical requirements can be linked to the complementary filters magnitudes.
In section~\ref{sec:hinf_method}, the shaping of complementary filters is written as an \(\mathcal{H}_\infty\) optimization problem using weighting functions, and the simplicity of the proposed method is illustrated with an example.
In Section~\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~\ref{sec:application_ligo} by designing complex complementary filters.
Section~\ref{sec:discussion} compares the proposed synthesis method with the classical mixed-sensitivity synthesis, and extends it to the shaping of more than two complementary filters.
\section{Sensor Fusion and Complementary Filters Requirements}
\label{sec:org11c2c5d}
\label{sec:requirements}
Complementary filters provides a framework for fusing signals from different sensors.
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.
\subsection{Sensor Fusion Architecture}
\label{sec:orgf188ee8}
\label{sec:sensor_fusion}
A general sensor fusion architecture using complementary filters is shown in Fig.~\ref{fig:sensor_fusion_overview} where several sensors (here two) are measuring the same physical quantity \(x\).
@ -124,7 +121,7 @@ This means that the super sensor provides an estimate \(\hat{x}\) of \(x\) which
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/sensor_fusion_overview.pdf}
\caption{\label{fig:sensor_fusion_overview}Schematic of a sensor fusion architecture using complementary filters}
\caption{\label{fig:sensor_fusion_overview}Schematic of a sensor fusion architecture using complementary filters.}
\end{figure}
The complementary property of filters \(H_1(s)\) and \(H_2(s)\) implies that the sum of their transfer functions is equal to unity.
@ -138,7 +135,6 @@ Therefore, a pair of complementary filter needs to satisfy the following conditi
It will soon become clear why the complementary property is important for the sensor fusion architecture.
\subsection{Sensor Models and Sensor Normalization}
\label{sec:orgb672f70}
\label{sec:sensor_models}
In order to study such sensor fusion architecture, a model for the sensors is required.
@ -155,15 +151,15 @@ The sensor dynamics estimate \(\hat{G}_1(s)\) can be a simple gain or a more com
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model.pdf}
\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)$}
\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)$.}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.49\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_calibrated.pdf}
\caption{\label{fig:sensor_model_calibrated} Normalized sensors using the inverse of an estimate $\hat{G}_i(s)$ of the sensor dynamics}
\caption{\label{fig:sensor_model_calibrated} Normalized sensors using the inverse of an estimate $\hat{G}_i(s)$ of the sensor dynamics.}
\end{subfigure}
\caption{\label{fig:sensor_models}Sensor models with and without normalization}
\caption{\label{fig:sensor_models}Sensor models with and without normalization.}
\centering
\end{figure}
@ -180,11 +176,10 @@ The super sensor output is therefore equal to:
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/fusion_super_sensor.pdf}
\caption{\label{fig:fusion_super_sensor}Sensor fusion architecture with two normalized sensors}
\caption{\label{fig:fusion_super_sensor}Sensor fusion architecture with two normalized sensors.}
\end{figure}
\subsection{Noise Sensor Filtering}
\label{sec:org6621cf0}
\label{sec:noise_filtering}
In this section, it is supposed that all the sensors are perfectly normalized, such that:
@ -195,23 +190,23 @@ In this section, it is supposed that all the sensors are perfectly normalized, s
The effect of a non-perfect normalization will be discussed in the next section.
Provided \eqref{eq:perfect_dynamics} is verified, the super sensor output \(\hat{x}\) is then:
Provided~\eqref{eq:perfect_dynamics} is verified, the super sensor output \(\hat{x}\) is then:
\begin{equation}
\label{eq:estimate_perfect_dyn}
\hat{x} = x + H_1(s) n_1 + H_2(s) n_2
\end{equation}
From \eqref{eq:estimate_perfect_dyn}, the complementary filters \(H_1(s)\) and \(H_2(s)\) are shown to only operate on the sensor's noises.
From~\eqref{eq:estimate_perfect_dyn}, the complementary filters \(H_1(s)\) and \(H_2(s)\) are shown to only operate on the sensor's noises.
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.
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 \eqref{eq:estimate_error}.
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~\eqref{eq:estimate_error}.
\begin{equation}
\label{eq:estimate_error}
\delta x \triangleq \hat{x} - x = H_1(s) n_1 + H_2(s) n_2
\end{equation}
As shown in \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}\).
As shown in~\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}\).
\begin{equation}
\label{eq:noise_filtering_psd}
\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)
@ -225,10 +220,9 @@ In such case, to lower the noise of the super sensor, the norm \(|H_1(j\omega)|\
Therefore, by properly shaping the norm of the complementary filters, it is possible to minimize the noise of the super sensor noise.
\subsection{Sensor Fusion Robustness}
\label{sec:orge7e30ce}
\label{sec:fusion_robustness}
In practical systems the sensor normalization is not perfect and condition \eqref{eq:perfect_dynamics} is not verified.
In practical systems the sensor normalization is not perfect and condition~\eqref{eq:perfect_dynamics} is not verified.
In order to study such imperfection, a multiplicative input uncertainty is added to the sensor dynamics (Fig.~\ref{fig:sensor_model_uncertainty}).
The nominal model is taken as the estimated model for the normalization \(\hat{G}_i(s)\), \(\Delta_i\) 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.
@ -241,16 +235,16 @@ As the nominal sensor dynamics is taken as the normalized filter, the normalized
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty.pdf}
\caption{\label{fig:sensor_model_uncertainty} Sensor with multiplicative input uncertainty}
\caption{\label{fig:sensor_model_uncertainty} Sensor with multiplicative input uncertainty.}
\end{subfigure}
\hfill
\begin{subfigure}[b]{0.39\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_model_uncertainty_simplified.pdf}
\caption{\label{fig:sensor_model_uncertainty_simplified} Simplified sensor model}
\caption{\label{fig:sensor_model_uncertainty_simplified} Simplified sensor model.}
\end{subfigure}
\hfill
\caption{\label{fig:sensor_models_uncertainty}Sensor models with dynamical uncertainty}
\caption{\label{fig:sensor_models_uncertainty}Sensor models with dynamical uncertainty.}
\centering
\end{figure}
@ -259,10 +253,10 @@ The sensor fusion architecture with two sensor models including dynamical uncert
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/sensor_fusion_dynamic_uncertainty.pdf}
\caption{\label{fig:sensor_fusion_dynamic_uncertainty}Sensor fusion architecture with sensor dynamics uncertainty}
\caption{\label{fig:sensor_fusion_dynamic_uncertainty}Sensor fusion architecture with sensor dynamics uncertainty.}
\end{figure}
The super sensor dynamics \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)\).
The super sensor dynamics~\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)\).
\begin{equation}
\label{eq:super_sensor_dyn_uncertainty}
\frac{\hat{x}}{x} = 1 + w_1(s) H_1(s) \Delta_1(s) + w_2(s) H_2(s) \Delta_2(s)
@ -276,9 +270,9 @@ The dynamical uncertainty of the super sensor can be graphically represented in
\caption{\label{fig:uncertainty_set_super_sensor}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.}
\end{figure}
The super sensor dynamical uncertainty (i.e. the robustness of the fusion) clearly depends on the complementary filters norms.
The super sensor dynamical uncertainty, and hence the robustness of the fusion, clearly depends on the complementary filters norms.
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.~\ref{fig:uncertainty_set_super_sensor}).
Therefore, the phase uncertainty of the super sensor dynamics depends on the Complementary filters norms \eqref{eq:max_phase_uncertainty}.
Therefore, the phase uncertainty of the super sensor dynamics depends on the Complementary filters norms~\eqref{eq:max_phase_uncertainty}.
\begin{equation}
\label{eq:max_phase_uncertainty}
@ -289,7 +283,6 @@ As it is generally desired to limit the maximum phase added by the super sensor,
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.
\section{Complementary Filters Shaping}
\label{sec:orgffe483d}
\label{sec:hinf_method}
As shown in Section~\ref{sec:requirements}, the noise and robustness of the super sensor are a function of the complementary filters norms.
Therefore, a complementary filters synthesis method that allows to shape their norms would be of great use.
@ -297,11 +290,10 @@ In this section, such synthesis is proposed by writing the synthesis objective a
As weighting functions are used to represent the wanted complementary filters shapes during the synthesis, the proper design of weighting functions is discussed.
Finally, the synthesis method is validated on an simple example.
\subsection{Synthesis Objective}
\label{sec:orgc020e5d}
\label{sec:synthesis_objective}
The synthesis objective is to shape the norm of two filters \(H_1(s)\) and \(H_2(s)\) while ensuring their complementary property \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 \eqref{eq:hinf_cond_complementarity}, \eqref{eq:hinf_cond_h1} and \eqref{eq:hinf_cond_h2} are satisfied.
The synthesis objective is to shape the norm of two filters \(H_1(s)\) and \(H_2(s)\) while ensuring their complementary property~\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~\eqref{eq:hinf_cond_complementarity}, \eqref{eq:hinf_cond_h1} and~\eqref{eq:hinf_cond_h2} are satisfied.
\begin{subequations}
\label{eq:comp_filter_problem_form}
@ -314,12 +306,11 @@ This is equivalent as to finding proper and stable transfer functions \(H_1(s)\)
\(W_1(s)\) and \(W_2(s)\) are two weighting transfer functions that are carefully chosen to specify the maximum wanted norms of the complementary filters during the synthesis.
\subsection{Shaping of Complementary Filters using \(\mathcal{H}_\infty\) synthesis}
\label{sec:org6c86cb9}
\label{sec:hinf_synthesis}
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.
Consider the generalized plant \(P(s)\) shown in Fig.~\ref{fig:h_infinity_robust_fusion_plant} and mathematically described by \eqref{eq:generalized_plant}.
Consider the generalized plant \(P(s)\) shown in Fig.~\ref{fig:h_infinity_robust_fusion_plant} and mathematically described by~\eqref{eq:generalized_plant}.
\begin{equation}
\label{eq:generalized_plant}
@ -330,27 +321,27 @@ Consider the generalized plant \(P(s)\) shown in Fig.~\ref{fig:h_infinity_robust
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/h_infinity_robust_fusion_plant.pdf}
\caption{\label{fig:h_infinity_robust_fusion_plant} Generalized plant}
\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}
\caption{\label{fig:h_infinity_robust_fusion_fb} Generalized plant with the synthesized filter}
\caption{\label{fig:h_infinity_robust_fusion_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
\caption{\label{fig:h_infinity_robust_fusion} Architecture for the $\mathcal{H}_\infty$ synthesis of complementary filters}
\caption{\label{fig:h_infinity_robust_fusion} Architecture for the $\mathcal{H}_\infty$ synthesis of complementary filters.}
\centering
\end{figure}
Applying the standard \(\mathcal{H}_\infty\) synthesis on 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.~\ref{fig:h_infinity_robust_fusion_fb} from \(w\) to \([z_1, \ z_2]\) is less than one \eqref{eq:hinf_syn_obj}.
Applying the standard \(\mathcal{H}_\infty\) synthesis on 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.~\ref{fig:h_infinity_robust_fusion_fb} from \(w\) to \([z_1, \ z_2]\) is less than one~\eqref{eq:hinf_syn_obj}.
\begin{equation}
\label{eq:hinf_syn_obj}
\left\|\begin{matrix} \left(1 - H_2(s)\right) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
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 \eqref{eq:hinf_problem} which ensure that \eqref{eq:hinf_cond_h1} and \eqref{eq:hinf_cond_h2} are satisfied.
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~\eqref{eq:hinf_problem} which ensure that~\eqref{eq:hinf_cond_h1} and~\eqref{eq:hinf_cond_h2} are satisfied.
\begin{equation}
\label{eq:definition_H1}
@ -362,7 +353,7 @@ By then defining \(H_1(s)\) to be the complementary of \(H_2(s)\) \eqref{eq:defi
\left\|\begin{matrix} H_1(s) W_1(s) \\ H_2(s) W_2(s) \end{matrix}\right\|_\infty \le 1
\end{equation}
Therefore, applying the \(\mathcal{H}_\infty\) synthesis on 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 \eqref{eq:comp_filter_problem_form} and such that there norms are bellow specified bounds \eqref{eq:hinf_cond_h1},\eqref{eq:hinf_cond_h2}.
Therefore, applying the \(\mathcal{H}_\infty\) synthesis on 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~\eqref{eq:comp_filter_problem_form} and such that there norms are bellow specified bounds \eqref{eq:hinf_cond_h1},~\eqref{eq:hinf_cond_h2}.
Note that there is not an equivalence between the \(\mathcal{H}_\infty\) norm condition~\eqref{eq:hinf_problem} and the initial synthesis objectives~\eqref{eq:hinf_cond_h1} and~\eqref{eq:hinf_cond_h2}, but only an implication.
Hence, the optimization may be a little bit conservative with respect to the ``set'' of filters on which it is performed.
@ -370,7 +361,6 @@ There might be solutions were the objectives~\eqref{eq:hinf_cond_h1} and~\eqref{
In practice, this is however not an found to be an issue.
\subsection{Weighting Functions Design}
\label{sec:orgf11126f}
\label{sec:hinf_weighting_func}
Weighting functions are used during the synthesis to specify the maximum allowed norms of the complementary filters.
@ -378,11 +368,11 @@ The proper design of these weighting functions is of primary importance for the
First, only proper and stable transfer functions should be used.
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 order of the synthesized filters being equal to the sum of the weighting functions orders).
Third, one should not forget the fundamental limitations imposed by the complementary property \eqref{eq:comp_filter}.
Third, one should not forget the fundamental limitations imposed by the complementary property~\eqref{eq:comp_filter}.
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.
To help with the design of the weighting functions such that the above specification can be easily expressed, the formula \eqref{eq:weight_formula} is proposed.
To help with the design of the weighting functions such that the above specification can be easily expressed, the formula~\eqref{eq:weight_formula} is proposed.
\begin{equation}
\label{eq:weight_formula}
@ -393,15 +383,15 @@ To help with the design of the weighting functions such that the above specifica
}\right)^n
\end{equation}
The parameters in formula \eqref{eq:weight_formula} are:
The parameters in formula~\eqref{eq:weight_formula} are:
\begin{itemize}
\item \(G_0 = lim_{\omega \to 0} |W(j\omega)|\): the low frequency gain
\item \(G_\infty = lim_{\omega \to \infty} |W(j\omega)|\): the high frequency gain
\item \(G_0 = \lim_{\omega \to 0} |W(j\omega)|\): the low frequency gain
\item \(G_\infty = \lim_{\omega \to \infty} |W(j\omega)|\): the high frequency gain
\item \(G_c = |W(j\omega_c)|\): the gain at a specific frequency \(\omega_c\) in \(\si{rad/s}\).
\item \(n\): the slope between high and low frequency. It also corresponds to the order of the weighting function.
\end{itemize}
The parameters \(G_0\), \(G_c\) and \(G_\infty\) should either satisfy condition \eqref{eq:cond_formula_1} or \eqref{eq:cond_formula_2}.
The parameters \(G_0\), \(G_c\) and \(G_\infty\) should either satisfy condition~\eqref{eq:cond_formula_1} or~\eqref{eq:cond_formula_2}.
\begin{subequations}
\label{eq:condition_params_formula}
\begin{align}
@ -410,16 +400,15 @@ The parameters \(G_0\), \(G_c\) and \(G_\infty\) should either satisfy condition
\end{align}
\end{subequations}
An example of the obtained magnitude of a weighting function generated using \eqref{eq:weight_formula} is shown in Fig.~\ref{fig:weight_formula}.
An example of the obtained magnitude of a weighting function generated using~\eqref{eq:weight_formula} is shown in Fig.~\ref{fig:weight_formula}.
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/weight_formula.pdf}
\caption{\label{fig:weight_formula}Magnitude of a weighting function generated using the proposed formula \eqref{eq:weight_formula}, \(G_0 = 1e^{-3}\), \(G_\infty = 10\), \(\omega_c = \SI{10}{Hz}\), \(G_c = 2\), \(n = 3\)}
\caption{\label{fig:weight_formula}Magnitude of a weighting function generated using the proposed formula~\eqref{eq:weight_formula}, \(G_0 = 1e^{-3}\), \(G_\infty = 10\), \(\omega_c = \SI{10}{Hz}\), \(G_c = 2\), \(n = 3\).}
\end{figure}
\subsection{Validation of the proposed synthesis method}
\label{sec:org254cb4b}
\label{sec:hinf_example}
The proposed methodology for the design of complementary filters is now applied on a simple example where two complementary filters \(H_1(s)\) and \(H_2(s)\) have to be designed such that:
@ -430,7 +419,7 @@ The proposed methodology for the design of complementary filters is now applied
\end{itemize}
The first step is to translate the above requirements into the design of the weighting functions.
The proposed formula \eqref{eq:weight_formula} is here used for such purpose.
The proposed formula~\eqref{eq:weight_formula} is here used for such purpose.
Parameters used are summarized in Table~\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.~\ref{fig:weights_W1_W2}.
@ -448,19 +437,19 @@ Parameters & \(W_1(s)\) & \(W_2(s)\)\\
\(n\) & \(2\) & \(3\)\\
\bottomrule
\end{tabularx}
\captionof{table}{\label{tab:weights_params}Parameters used for weighting functions \(W_1(s)\) and \(W_2(s)\) using \eqref{eq:weight_formula}}
\captionof{table}{\label{tab:weights_params}Parameters used for weighting functions \(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}
\caption{\label{fig:weights_W1_W2}Inverse magnitude of the weighting functions}
\caption{\label{fig:weights_W1_W2}Inverse magnitude of the weighting functions.}
\end{minipage}
\end{figure}
The \(\mathcal{H}_\infty\) synthesis is then applied to the generalized plant of Fig.~\ref{fig:h_infinity_robust_fusion_plant} on efficiently solved in Matlab~\cite{matlab20} using the Robust Control Toolbox.
The filter \(H_2(s)\) that minimizes the \(\mathcal{H}_\infty\) norm between \(w\) and \([z_1,\ z_2]^T\) is obtained.
The \(\mathcal{H}_\infty\) norm is here found to be close to one \eqref{eq:hinf_synthesis_result} which indicates that the synthesis is successful: the complementary filters norms are below the maximum specified upper bounds.
The \(\mathcal{H}_\infty\) norm is here found to be close to one~\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.~\ref{fig:hinf_filters_results}.
\begin{equation}
@ -468,7 +457,7 @@ This is confirmed by the bode plots of the obtained complementary filters in Fig
\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}
Their transfer functions in the Laplace domain are given in \eqref{eq:hinf_synthesis_result_tf}.
Their transfer functions in the Laplace domain are given in~\eqref{eq:hinf_synthesis_result_tf}.
As expected, the obtained filters are of order \(5\), that is the sum of the weighting functions orders.
\begin{subequations}
@ -483,14 +472,13 @@ As expected, the obtained filters are of order \(5\), that is the sum of the wei
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/hinf_filters_results.pdf}
\caption{\label{fig:hinf_filters_results}Bode plot of the obtained complementary filters}
\caption{\label{fig:hinf_filters_results}Bode plot of the obtained complementary filters.}
\end{figure}
This simple example illustrates the fact that the proposed methodology for complementary filters shaping is easy to use and effective.
A more complex real life example is taken up in the next section.
\section{Application: Design of Complementary Filters used in the Active Vibration Isolation System at the LIGO}
\label{sec:org87f5cba}
\label{sec:application_ligo}
Sensor fusion using complementary filters are widely used in active vibration isolation systems in gravitational wave detectors such at the LIGO~\cite{matichard15_seism_isolat_advan_ligo,hua05_low_ligo}, the VIRGO~\cite{lucia18_low_frequen_optim_perfor_advan,heijningen18_low} and the KAGRA \cite[Chap. 5]{sekiguchi16_study_low_frequen_vibrat_isolat_system}.
@ -502,18 +490,17 @@ A simplified block diagram of the sensor fusion architecture is shown in Fig.~\r
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/ligo_super_sensor_architecture.pdf}
\caption{\label{fig:ligo_super_sensor_architecture}Simplified block diagram of the sensor blending strategy for the first stage at the LIGO~\cite{hua04_low_ligo}}
\caption{\label{fig:ligo_super_sensor_architecture}Simplified block diagram of the sensor blending strategy for the first stage at the LIGO~\cite{hua04_low_ligo}.}
\end{figure}
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 and therefore allow the feedback loop to have authority at zero frequency.
The requirements on those filters are very tight and thus their design is complex and should be expressed as an optimization problem.
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~\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.
However they are of very high order so their implementation is quite complex.
However they are of high order so their implementation is quite complex.
In this section, the effectiveness of the proposed complementary filter synthesis strategy is demonstrated on the same set of requirements.
\subsection{Complementary Filters Specifications}
\label{sec:orgf53acf5}
\label{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~\cite{hua04_polyp_fir_compl_filter_contr_system}):
@ -530,11 +517,10 @@ They are physically represented in Fig.~\ref{fig:fir_filter_ligo} as well as the
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/fir_filter_ligo.pdf}
\caption{\label{fig:fir_filter_ligo}Specifications and Bode plot of the obtained FIR complementary filters in~\cite{hua05_low_ligo}. The filters are here obtained using the SeDuMi Matlab toolbox~\cite{sturm99_using_sedum}}
\caption{\label{fig:fir_filter_ligo}Specifications and Bode plot of the obtained FIR complementary filters in~\cite{hua05_low_ligo}. The filters are here obtained using the SeDuMi Matlab toolbox~\cite{sturm99_using_sedum}.}
\end{figure}
\subsection{Weighting Functions Design}
\label{sec:org4b996f7}
\label{sec:ligo_weights}
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.
@ -547,42 +533,39 @@ The magnitudes of the weighting functions are shown in Fig.~\ref{fig:ligo_weight
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/ligo_weights.pdf}
\caption{\label{fig:ligo_weights}Specifications and weighting functions inverse magnitudes}
\caption{\label{fig:ligo_weights}Specifications and weighting functions inverse magnitudes.}
\end{figure}
\subsection{\(\mathcal{H}_\infty\) Synthesis of the complementary filters}
\label{sec:org64068df}
\label{sec:ligo_results}
The proposed \(\mathcal{H}_\infty\) synthesis is performed on the generalized plant shown in Fig.~\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.~\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~\cite{hua05_low_ligo}.
Even though the complementary filters using the \(\mathcal{H}_\infty\) synthesis are of much lower order (order 27), they are found to be very close to the FIR filters.
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.
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/comp_fir_ligo_hinf.pdf}
\caption{\label{fig:comp_fir_ligo_hinf}Comparison of the FIR filters (dashed) designed in~\cite{hua05_low_ligo} with the filters obtained with \(\mathcal{H}_\infty\) synthesis (solid)}
\caption{\label{fig:comp_fir_ligo_hinf}Comparison of the FIR filters (dashed) designed in~\cite{hua05_low_ligo} with the filters obtained with \(\mathcal{H}_\infty\) synthesis (solid).}
\end{figure}
\section{Discussion}
\label{sec:org36bf100}
\label{sec:discussion}
\subsection{``Closed-Loop'' complementary filters}
\label{sec:org38ca6e5}
\label{sec:closed_loop_complementary_filters}
An alternative way to implement complementary filters is by using a fundamental property of the classical feedback architecture shown in Fig.~\ref{fig:feedback_sensor_fusion}.
This is for instance presented in \cite{mahony05_compl_filter_desig_special_orthog,plummer06_optim_compl_filter_their_applic_motion_measur,jensen13_basic_uas}.
This is for instance presented in~\cite{mahony05_compl_filter_desig_special_orthog,plummer06_optim_compl_filter_their_applic_motion_measur,jensen13_basic_uas}.
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/feedback_sensor_fusion.pdf}
\caption{\label{fig:feedback_sensor_fusion}``Closed-Loop'' complementary filters}
\caption{\label{fig:feedback_sensor_fusion}``Closed-Loop'' complementary filters.}
\end{figure}
Consider the feedback architecture of Fig.~\ref{fig:feedback_sensor_fusion}, with two inputs \(\hat{x}_1\) and \(\hat{x}_2\), and one output \(\hat{x}\).
The output \(\hat{x}\) is linked to the inputs by \eqref{eq:closed_loop_complementary_filters}.
The output \(\hat{x}\) is linked to the inputs by~\eqref{eq:closed_loop_complementary_filters}.
\begin{equation}
\label{eq:closed_loop_complementary_filters}
@ -602,7 +585,7 @@ Two sensors can then be merged as shown in Fig.~\ref{fig:feedback_sensor_fusion_
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/feedback_sensor_fusion_arch.pdf}
\caption{\label{fig:feedback_sensor_fusion_arch}Classical feedback architecture used for sensor fusion}
\caption{\label{fig:feedback_sensor_fusion_arch}Classical feedback architecture used for sensor fusion.}
\end{figure}
One of the main advantage of implementing and designing complementary filters using the feedback architecture of Fig.~\ref{fig:feedback_sensor_fusion} is that all the tools of the linear control theory can be applied for the design of the filters.
@ -610,7 +593,7 @@ If one want to shape both \(\frac{\hat{x}}{\hat{x}_1}(s) = S(s)\) and \(\frac{\h
To do so, weighting functions \(W_1(s)\) and \(W_2(s)\) are added to respectively shape \(S(s)\) and \(T(s)\) (Fig.~\ref{fig:feedback_synthesis_architecture}).
Then the system is re-organized to form the generalized plant \(P_L(s)\) shown in Fig.~\ref{fig:feedback_synthesis_architecture_generalized_plant}.
The \(\mathcal{H}_\infty\) mixed-sensitivity synthesis can finally be performed by applying the \(\mathcal{H}_\infty\) synthesis to the generalized plant \(P_L(s)\) which is described by \eqref{eq:generalized_plant_mixed_sensitivity}.
The \(\mathcal{H}_\infty\) mixed-sensitivity synthesis can finally be performed by applying the \(\mathcal{H}_\infty\) synthesis to the generalized plant \(P_L(s)\) which is described by~\eqref{eq:generalized_plant_mixed_sensitivity}.
\begin{equation}
\label{eq:generalized_plant_mixed_sensitivity}
@ -620,7 +603,7 @@ The \(\mathcal{H}_\infty\) mixed-sensitivity synthesis can finally be performed
\end{bmatrix}
\end{equation}
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\) is less than one \eqref{eq:comp_filters_feedback_obj}.
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\) is less than one~\eqref{eq:comp_filters_feedback_obj}.
\begin{equation}
\label{eq:comp_filters_feedback_obj}
@ -635,22 +618,22 @@ The sensor fusion can then be implemented as shown in Fig.~\ref{fig:feedback_sen
H_1(s) = \frac{1}{1 + L(s)}; \quad H_2(s) = \frac{L(s)}{1 + L(s)}
\end{equation}
The two architecture are equivalent regarding their inputs/outputs relationships.
The two architectures are equivalent regarding their inputs/outputs relationships.
\begin{figure}[htbp]
\begin{subfigure}[t]{0.6\linewidth}
\centering
\includegraphics[scale=1]{figs/feedback_synthesis_architecture.pdf}
\caption{\label{fig:feedback_synthesis_architecture} Feedback architecture with included weights}
\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}
\caption{\label{fig:feedback_synthesis_architecture_generalized_plant} Generalized plant}
\caption{\label{fig:feedback_synthesis_architecture_generalized_plant} Generalized plant.}
\end{subfigure}
\hfill
\caption{\label{fig:h_inf_mixed_sensitivity_synthesis} $\mathcal{H}_\infty$ mixed-sensitivity synthesis}
\caption{\label{fig:h_inf_mixed_sensitivity_synthesis} $\mathcal{H}_\infty$ mixed-sensitivity synthesis.}
\centering
\end{figure}
@ -663,11 +646,10 @@ The obtained ``closed-loop'' complementary filters are indeed equal to the ones
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/hinf_filters_results_mixed_sensitivity.pdf}
\caption{\label{fig:hinf_filters_results_mixed_sensitivity}Bode plot of the obtained complementary filters after \(\mathcal{H}_\infty\) mixed-sensitivity synthesis}
\caption{\label{fig:hinf_filters_results_mixed_sensitivity}Bode plot of the obtained complementary filters after \(\mathcal{H}_\infty\) mixed-sensitivity synthesis.}
\end{figure}
\subsection{Synthesis of more than two Complementary Filters}
\label{sec:org16306e2}
\label{sec:hinf_three_comp_filters}
Some applications may require to merge more than two sensors~\cite{stoten01_fusion_kinet_data_using_compos_filter,becker15_compl_filter_desig_three_frequen_bands}.
@ -684,15 +666,15 @@ A generalization of the proposed synthesis method of complementary filters is pr
\begin{subfigure}[b]{0.59\linewidth}
\centering
\includegraphics[scale=1]{figs/sensor_fusion_three_sequential.pdf}
\caption{\label{fig:sensor_fusion_three_sequential}Sequential fusion}
\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}
\caption{\label{fig:sensor_fusion_three_parallel}Parallel fusion}
\caption{\label{fig:sensor_fusion_three_parallel}Parallel fusion.}
\end{subfigure}
\caption{\label{fig:sensor_fusion_three}Possible sensor fusion architecture when more than two sensors are to be merged}
\caption{\label{fig:sensor_fusion_three}Possible sensor fusion architecture when more than two sensors are to be merged.}
\centering
\end{figure}
@ -706,7 +688,7 @@ The synthesis objective is to compute a set of \(n\) stable transfer functions \
\end{subequations}
where \([W_1(s),\ W_2(s),\ \dots,\ W_n(s)]\) are weighting transfer functions that are chosen to specify the maximum wanted norms of the complementary filters during the synthesis.
Such synthesis objective is very close to the one described in Section~\ref{sec:synthesis_objective}, and indeed the proposed synthesis method is a generalization of the one presented in Section~\ref{sec:hinf_synthesis}. \par
Such synthesis objective is closely related to the one described in Section~\ref{sec:synthesis_objective}, and indeed the proposed synthesis method is a generalization of the one presented in Section~\ref{sec:hinf_synthesis}. \par
Before presenting the generalized synthesis method, the case with three sensors is presented.
Consider the generalized plant \(P_3(s)\) shown in Fig.~\ref{fig:comp_filter_three_hinf_gen_plant} which is also described by~\eqref{eq:generalized_plant_three_filters}.
@ -720,17 +702,17 @@ Consider the generalized plant \(P_3(s)\) shown in Fig.~\ref{fig:comp_filter_thr
\begin{subfigure}[t]{0.5\linewidth}
\centering
\includegraphics[scale=1]{figs/comp_filter_three_hinf_gen_plant.pdf}
\caption{\label{fig:comp_filter_three_hinf_gen_plant} Generalized plant}
\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}
\caption{\label{fig:comp_filter_three_hinf_fb} Generalized plant with the synthesized filter}
\caption{\label{fig:comp_filter_three_hinf_fb} Generalized plant with the synthesized filter.}
\end{subfigure}
\hfill
\caption{\label{fig:comp_filter_three_hinf} Architecture for the $\mathcal{H}_\infty$ synthesis of three complementary filters}
\caption{\label{fig:comp_filter_three_hinf} Architecture for the $\mathcal{H}_\infty$ synthesis of three complementary filters.}
\centering
\end{figure}
@ -741,7 +723,7 @@ Applying the \(\mathcal{H}_\infty\) synthesis on the generalized plant \(P_3(s)\
\left\| \begin{matrix} \left[1 - H_2(s) - H_3(s)\right] W_1(s) \\ H_2(s) W_2(s) \\ H_3(s) W_3(s) \end{matrix} \right\|_\infty \le 1
\end{equation}
By defining \(H_1(s) \triangleq 1 - H_2(s) - H_3(s)\), the proposed \(\mathcal{H}_\infty\) synthesis solves the design problem \eqref{eq:hinf_problem_gen} with \(n=3\). \par
By defining \(H_1(s) \triangleq 1 - H_2(s) - H_3(s)\), the proposed \(\mathcal{H}_\infty\) synthesis solves the design problem~\eqref{eq:hinf_problem_gen} with \(n=3\). \par
An example is given to validate the method where three sensors are used in different frequency bands.
For instance 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}\).
@ -751,7 +733,7 @@ The \(\mathcal{H}_\infty\) synthesis is performed on the generalized plant \(P_3
\begin{figure}[htbp]
\centering
\includegraphics[scale=1]{figs/three_complementary_filters_results.pdf}
\caption{\label{fig:three_complementary_filters_results}Bode plot of the inverse weighting functions and of the three complementary filters obtained using the \(\mathcal{H}_\infty\) synthesis}
\caption{\label{fig:three_complementary_filters_results}Bode plot of the inverse weighting functions and of the three complementary filters obtained using the \(\mathcal{H}_\infty\) synthesis.}
\end{figure}
Even though there might not be any practical application for a set of more than 3 complementary filters, it can still be designed using the same procedure.
@ -771,27 +753,20 @@ A set of \(n\) complementary filters can be shaped using the generalized plant \
\end{equation}
\section{Conclusion}
\label{sec:org05380ec}
\label{sec:conclusion}
Sensors measuring a physical quantities are always subject to limitations both in terms of bandwidth or accuracy.
Complementary filters can be used to fuse multiple sensors with different characteristics in order to combine their benefits and yield a better estimate of the measured physical quantity.
The sensor fusion robustness and the obtained super sensor noise can be linked to the magnitude of the complementary filters.
In this paper, a synthesis method that enables the shaping of the complementary filters norms has been proposed.
Several example were used to emphasize the simplicity and the effectiveness of the proposed method.
Links with ``closed-loop'' complementary filters where highlighted, and the proposed method was generalized for the design of a set of more than two complementary filters.
Several examples were used to emphasize the simplicity and the effectiveness of the proposed method.
Links with ``closed-loop'' complementary filters were highlighted, and the proposed method was generalized for designing a set of more than two complementary filters.
Future work will aim at developing a complementary filter synthesis method that minimizes the super sensor noise while ensuring the robustness of the fusion.
The future work will aim at developing a complementary filter synthesis method that minimizes the super sensor noise while ensuring the robustness of the fusion.
\section*{Acknowledgment}
\label{sec:orgcfbe3a3}
This research benefited from a FRIA grant from the French Community of Belgium.
This paper is based on a paper previously presented at the ICCMA conference~\cite{dehaeze19_compl_filter_shapin_using_synth}.
\section*{Data Availability}
\label{sec:orga0214e5}
Matlab \cite{matlab20} was used for this study.
Matlab~\cite{matlab20} was used for this study.
The source code is available under a MIT License and archived in Zenodo~\cite{dehaeze21_new_method_desig_compl_filter_code}.
\bibliographystyle{elsarticle-num}