Je suis coincé à modéliser un modèle de système, c'est-à-dire à obtenir mon vecteur d'état et mon vecteur d'entrée. Je suppose que la position et la vitesse sont des vecteurs d'état et que l'accélération est un vecteur d'entrée. Ma deuxième supposition est que les trois quantités sont dans le vecteur d'état et aucune dans le vecteur d'entrée.
Alors ... qu'est-ce qu'un vecteur d'état et quel est le vecteur d'entrée dans mon cas?
-
Information additionnelle:
J'obtiens des mesures du capteur de position et du capteur d'accélération. Tout se passe en 1D, par exemple en ligne droite. Je veux fusionner ces lectures (et supprimer le bruit) pour obtenir une estimation de la vitesse pour chaque pas de temps.
Ces équations décrivent le système; Je ne sais pas si elles sont bien modélisées. Si je comprends bien, il est prudent de prédire que l'accélération est constante (même si en réalité elle change) - parce que la matrice de covariance du processus corrige cette hypothèse (non?).
J'ai également quelques exemples de données avec lesquelles travailler (les valeurs d'entrée ne sont pas bruyantes ici pour plus de simplicité):
time pos acc what I should get as output (velocity)
[0.0s] 0.000, -0.000 | 18.850
[0.1s] 1.885, -0.113 | 18.850
[0.2s] 3.768, -0.227 | 18.839
[0.3s] 5.650, -0.340 | 18.816
[0.4s] 7.528, -0.452 | 18.782
[0.5s] 9.401, -0.565 | 18.737
ADDITION 2:
Pour une meilleure communication, je crée une nouvelle réponse mais doit être traitée comme un commentaire à la première réponse. Jason, vous m'avez déjà énormément aidé et je vous suis vraiment reconnaissant de votre temps. J'ai toujours des problèmes avec cela - les résultats de Kalman Filter ne sont pas comme prévu. Puissiez-vous trouver le temps, veuillez lire ce qui suit, merci. Je vous dois déjà une bière ou deux (ou des cafés si vous voulez) - si vous avez paypal contactez moi sur primoz [at] codehunter.eu :)
J'ai implémenté le modèle que Jason avait proposé en première réponse. J'ai ajouté la secousse comme quatrième variable d'état. Après des heures de révision, j'ai décidé de revenir ici pour de l'aide. Les valeurs que je retire de KF ne sont pas celles attendues. Le tableau ci-dessous représente les données des 10 premières itérations de l'algorithme. Remarquez comment la secousse augmente à chaque pas de temps, ce qui rend les autres estimations erronées. Après une seconde, la différence entre l'accélération réelle et estimée est supérieure à 1 m / s² (voir tableau, dernière ligne)!
real measured estimated real
time pos acc pos acc pos acc jerk vel[!] velocity
0.0 0.000 -0.000 -0.040 0.030 | -0.300 -0.060 0.000 18.850 <--> 18.850
0.1 1.885 -0.113 1.965 -0.153 | 1.585 -0.061 -0.006 18.844 <--> 18.844
0.2 3.768 -0.227 3.778 -0.247 | 3.469 -0.066 -0.035 18.835 <--> 18.827
0.3 5.650 -0.340 5.750 -0.370 | 5.351 -0.090 -0.122 18.815 <--> 18.799
0.4 7.528 -0.452 7.358 -0.452 | 7.228 -0.152 -0.291 18.769 <--> 18.759
0.5 9.401 -0.565 9.251 -0.555 | 9.094 -0.282 -0.574 18.673 <--> 18.708
0.6 11.269 -0.677 11.309 -0.717 | 10.938 -0.518 -1.006 18.494 <--> 18.646
0.7 13.130 -0.788 13.260 -0.758 | 12.752 -0.840 -1.490 18.233 <--> 18.573
0.8 14.983 -0.899 15.043 -0.949 | 14.520 -1.286 -2.096 17.854 <--> 18.488
0.9 16.827 -1.009 16.977 -1.089 | 16.235 -1.838 -2.770 17.362 <--> 18.393
1.0 18.661 -1.118 18.831 -1.168 | 17.890 -2.477 -3.476 16.762 <--> 18.287
Mes matrices sont ici:
Qu'est-ce qui cause cet ajout à chaque pas de temps pour jerk ? L'une de mes matrices est-elle incorrecte?
Il en va de même avec la première solution (modèle à seulement 3 états) - l'accélération ne change pas comme il se doit.
DERNIÈRE ÉDITION:
J'ai finalement réussi à le faire fonctionner. Je ne sais pas s'il y a eu une erreur de mise en œuvre ou de mauvaises matrices P&Q.
la source
Réponses:
Vous ne feriez pas d'hypothèse d'accélération constante dans ce cas. Vous feriez généralement cela si vous n'aviez aucun moyen de mesurer l'accélération du système, mais vous dites qu'elle est observable pour votre cas. La façon la plus évidente de modéliser ce système serait d'utiliser le vecteur d'état
oùxk est la position, vk est la vitesse, et ak est l'accélération du système à l'instant k . Puisque vous dites que vous pouvez mesurer la position et l'accélération du système, le vecteur de mesurezk serait:
avec
résultant dans le modèle de mesure:
oùvk est le bruit (gaussien) inhérent à la mesure. Maintenant, sauf si vous ajoutez une force connue au système qui affecterait sa dynamique, le vecteur d'entréeuk=0 . Voir cette question récente pour une discussion plus détaillée des différents termes du modèle de Kalman, que vous devez connaître et que vous n'avez pas .
Edit: Concernant le commentaire ci-dessous sur la façon de gérer la matrice de transition d'état pour le terme d'accélération: il existe deux façons différentes de gérer cela. Vous pourriez supposer un modèle à secousse nulle (la secousse est la dérivée temporelle de l'accélération); cela revient à supposer queak+1=ak . Ou, vous pouvez ajouter un quatrième élément à votre vecteur d'état:
oùjk est la secousse du système, ou taux de variation de l'accélération, à l'instant k . Puisque vous ne mesurez pas le jerk directement, vous auriez une matrice de mesure de:
Et la matrice de transition d'état deviendrait:
Il s'agit d'un modèle à «secousse constante» (similaire aux modèles à vitesse constante ou à accélération constante que vous pourriez voir dans des exemples simples); votre matrice de transition d'état suppose implicitement que la secousse est constante pour toutes les valeurs de k. Ce n'est probablement pas vrai. Pour gérer cet aspect du problème, vous introduiriez un terme de bruit de processus dans le composant jerk de l'équation de transition d'état.
Qualitativement, cela vous permet d'exprimer que vous n'êtes pas sûr de la façon dont le terme de secousse va changer d'un pas de temps à l'autre, mais que vous vous attendez à ce que les changements soient aléatoires avec une distribution gaussienne. Il s'agit d'un outil souvent utilisé pour "régler" des modèles de filtres adaptatifs comme celui-ci jusqu'à ce que vous trouviez un ensemble de paramètres qui fonctionne bien pour votre application.
la source
Je suppose que vos variables d'état sont conformes à la réponse de Jason. Si tel est le cas, je pense que votre problème pourrait être votreQ matrice (bruit de processus): parce qu'elle est nulle partout sauf pour la mise à jour de la secousse, les seuls termes mettant à jour les valeurs de la position, de la vitesse et de l'accélération sont les parties déterministes des équations de mise à jour (sauf là où la nature stochastique de la secousse se répercute) .
Essayez d'utiliser unQ matrice comme:
Si ces éléments diagonaux sont nuls, le modèle dit "Je ne m'attends pas à ce que la position, la vitesse ou l'accélération changent (autrement que par les équations de mise à jour)" --- ce qui n'est clairement pas le cas.
la source
Je pense que le problème est en Q. Q facturent K avec leurs valeurs. J'obtiens de bons résultats lorsque Q est préchargé avec des pouvoirs de delta_t.
Voir tout article sur le modèle wiener. Il a une bonne matrice Q.
A00 doit être multiple de delta_t puissance de 5 A11 delta_t puissance de 3 A22 delta_t puissance de 1 A01 multiple de delta_t puissance de 4
Etc
Regarder
https://www.google.com/url?sa=t&source=web&rct=j&url=https://pdfs.semanticscholar.org/9c1b/db6b5a25c1231e775c654f731e1ca1fef31a.pdf&ved=2ahUKEwj4LJAQVJAQA
la source