فیلتر کالمن توسعه یافته (EKF) در متلب – از صفر تا صد

۵۲۶۳
۱۴۰۲/۰۲/۲۳
۱۳ دقیقه
PDF
آموزش متنی جامع
امکان دانلود نسخه PDF

فیلترهای کالمن به عنوان یک ابزار اساسی برای تخمین و شناسایی، در بسیاری از سیستم‌های صنعتی، رباتیک، هوافضا، خودروهای خودران و الکتریکی و... مورد استفاده قرار گرفته‌اند و هر روز بر کاربردهای آن‌ها افزوده می‌شود. در این مطلب قصد داریم با یکی دیگر از تکنیک‌های فیلتر کالمن، یعنی «فیلتر کالمن توسعه یافته» (Extended Kalman Filter) یا به اختصار EKF آشنا شویم.

فیلتر کالمن توسعه یافته (EKF) در متلب – از صفر تا صدفیلتر کالمن توسعه یافته (EKF) در متلب – از صفر تا صد
997696

فیلتر کالمن چیست؟

فیلترهای کالمن در حقیقت فیلترهای تخمین‌گر بهینه درجه دوم هستند که توسط «رودولف کالمن» اختراع شدند و هدف اساسی آن‌ها تخمین حالت‌های سیستم با داشتن اطلاعات جزیی از آن سیستم است. به عنوان مثال یک سیستم مرتبه ده را در نظر بگیرید. طبیعتا این سیستم دارای ده متغیر حالت است، اما اندازه‌گیری همه متغیرهای حالت با استفاده از ده سنسور مختلف هزینه‌های زیادی دارد و در کاربردهای عملی نمی‌توان از این روش استفاده کرد. در نتیجه فقط تعداد محدودی از متغیرهای حالت و یا تابعی از آن‌ها اندازه‌گیری می‌شود و با داشتن مدل ریاضی سیستم بقیه متغیرهای حالت باید تخمین زده شوند.

البته این تنها کاربرد فیلترهای کالمن نیست. گاهی اوقات ما فقط می‌توانیم یک داده‌ با نویز شدید را از سیستم دریافت کنیم. به عنوان مثالی از این حالت می‌توان به داده‌های موقعیت اندازه‌گیری‌ شده توسط سنسورهای GPS اشاره کرد. در قدم بعد می‌توان توسط یک فیلتر این داده‌ به‌ شدت نویزی را پالایش کرد و داده‌ بهتر و دقیق‌تری به‌دست آورد. یکی از بهترین فیلترهایی که در اغلب کاربردهای صنعتی برای این هدف مورد استفاده قرار می‌گیرند، فیلترهای کالمن هستند.

البته ممکن است عنوان فیلتر برای فیلتر کالمن مبهم باشد. برای رفع این ابهام یک فیلتر پایین‌ گذر را در نظر بگیرید. وظیفه فیلتر پایین‌ گذر این است که نویزهای فرکانس‌ بالا که در سیگنال ورودی وجود دارد را حذف کند تا سیگنال صاف‌تر و بهتری بدست‌ آید. به‌ صورت مشابه وظیفه فیلتر کالمن نیز این است که از داده‌های خامی که وجود دارد، اثرات نویزهای خارجی و عدم‌ قطعیت‌ها بیرون کشیده‌ شود و تخمین بهتری از اطلاعات واقعی حاصل شود. این تشابه در شکل زیر نیز به تصویر کشیده شده است. فیلتر کالمن اطلاعاتی که دارای مقداری خطا، نویز و عدم‌ قطعیت هستند را دریافت می‌کند و اطلاعات دقیق‌تری را در اختیار قرار می‌دهد. در تصویر زیر مقایسه‌ای بین فیلتر پایین گذر و فیلتر کالمن انجام شده است.

مقایسه‌ای بین فیلتر پایین گذر و فیلتر کالمن
مقایسه‌ای بین فیلتر پایین گذر و فیلتر کالمن

فیلتر کالمن توسعه یافته یا EKF

در مطالب قبلی مجله فرادرس به فیلتر کالمن خطی پرداخته شد. این فیلتر به منظور تخمین حالت بهینه در سیستم‌های با دینامیک خطی کاربرد دارد. اما برای سیستم‌های غیرخطی با اعمال اصلاح کوچکی می‌توان از همان فیلترهای کالمن خطی استفاده کرد. کافی است در هر مرحله از تخمین حالت‌های سیستم، از روی داده‌هایی که تخمین زده شده‌اند، دینامیک سیستم غیرخطی با استفاده از سری تیلور خطی‌سازی شود.

در واقع الگوریتم فیلتر کالمن خطی تا حدی تطبیقی می‌شود تا بتواند حالت‌های سیستم‌های غیرخطی را نیز تخمین بزند. باید توجه کرد که اغلب فیلترهای کالمن به‌ صورت گسسته پیاده‌سازی می‌شوند. بنابراین، دینامیک سیستم غیرخطی به‌ صورت زیر فرض می‌شود:

xk=f(xk1,uk1)+wk1yk=h(xk)+vk\begin {array} {c} \mathbf { x } _ { k } = \mathbf { f } \left( \mathbf { x } _ { k - 1 }, \mathbf { u } _ { k - 1 } \right ) + \mathbf { w } _ { k - 1 } \\ \mathbf { y } _ { k } = \mathbf { h } \left( \mathbf { x } _ { k } \right) + \mathbf { v } _ { k } \end {array}

متغیرهای فرمول بالا در جدول زیر معرفی شده است.

متغیرتعریف
kkشماره نمونه
xkx _ kبردار متغیرهای حالت در نمونه K
wkw _ kنویز پروسه در نمونه K
vkv _ kنویز اندازه‌گیری در نمونه K
yky _ kخروجی پروسه در نمونه K
fدینامیک متغیرهای حالت
hتابع اندازه‌گیری سیستم
uk1u _ { k - 1 }سیگنال ورودی سیستم در نمونه K

نویز پروسه ناشی از عدم قطعیت در مدلسازی ریاضی سیستم است. واضح است که تابع f با مدل واقعی و عملی سیستم اختلاف دارد. این اختلاف در نویز پروسه مدلسازی خواهد شد. نویز اندازه‌گیری همان نویز سنسورها است که برخی از متغیرهای حالت و یا تابعی از آنها را اندازه‌گیری می‌کند. نویز اندازه‌گیری و پروسه اغلب به صورت فرآیند‌های گاوسی مدلسازی می‌شوند و ماتریس کواریانس آن‌ها را نیز به ترتیب با RkR _ k و QkQ _ k مشخص می‌کنند. با انجام تحلیل‌های آماری بر روی سنسورها می‌توان ماتریس کواریانس اندازه‌گیری را مشخص کرد ولی به‌دلیل تنوع و پیچیدگی سیستم‌های غیرخطی، الگوریتم مشخصی برای تعیین ماتریس کواریانس نویز پروسه وجود ندارد و در عمل اغلب به‌ صورت سعی و خطایی تنظیم می‌شود.

الگوریتم فیلتر کالمن توسعه یافته در دو فاز انجام خواهد شد. فرض کنید تمام اطلاعات سیستم تا نمونه k-1 در دسترس باشد. در این‌ صورت بر اساس مدل ریاضی سیستم و سیگنال‌های موجود تا زمان k-1، یک تخمین اولیه از متغیرهای حالت در نمونه k محاسبه می‌شود. این گام از فیلتر کالمن را فرآیند پیش‌بینی می‌گوییم. حال طبیعتا در زمان k یک اندازه‌گیری جدید توسط سنسورها انجام می‌شود یعنی yky _ k در دسترس قرار می‌گیرد. در گام دوم فیلتر کالمن که فاز به‌روزرسانی نام دارد، پیش‌بینی انجام‌ شده در گام اول بر اساس داده‌ی جدیدی که در دسترس قرار گرفته است، بهبود داده می‌شود تا حالت‌های تخمینی نهایی در نمونه kام بدست آید. فاز پیش‌بینی توسط دو معادله زیر انجام خواهد شد:

x^kk1=f(x^k1,uk1)Pkk1=Fk1Pk1Fk1T+Qk1\begin {aligned} & \hat { \mathbf { x } } _ { k | k - 1 } = \mathbf { f } \left ( \hat { \mathbf { x } } _ { k - 1 }, \mathbf { u } _ { k - 1 } \right)\\ & \mathbf { P } _ { k | k - 1 } = \mathbf { F } _ { k - 1 } \mathbf { P } _ { k - 1 } \mathbf { F } _ { k - 1 } ^ { T } + \mathbf { Q } _ { k - 1 } \end {aligned}

در روابط بالا x^k1\hat { \mathbf { x } } _ { k - 1 } بردار حالت‌های تخمینی در نمونه k-1 و Pk1\mathbf { P } _ { k - 1 } ماتریس کواریانس در نمونه k-1 و x^kk1\hat { \mathbf { x } } _ { k | k - 1 } پیش‌بینی متغیر حالت در نمونه k بر اساس اطلاعات سیستم تا نمونه k-1 و Pkk1\mathbf { P } _ { k | k - 1 } نیز پیش‌بینی ماتریس کواریانس در نمونه k بر اساس اطلاعات سیستم تا نمونه k-1 است. ماتریس‌ Fk\mathbf { F } _ { k } دینامیک حالت خطی‌ شده است که از طریق خطی‌سازی تیلور به‌ صورت زیر به‌دست می‌آید:

Fk=fxxk1\mathbf { F } _ { k } = \left. \frac { \partial \mathbf { f } } { \partial \mathbf { x } } \right | _ { \mathbf { x } _ { k - 1 } }

Hk\mathbf { H } _ { k } نیز دینامیک اندازه‌گیری خطی‌ شده است که در فاز به‌روزرسانی استفاده می‌شود. این ماتریس نیز به صورت  زیر محاسبه می‌شود:

Hk=hxx^kk1\mathbf { H } _ { k } = \left . \frac { \partial \mathbf { h } } { \partial \mathbf { x } } \right | _ { \hat { \mathbf { x } } _ { k | k - 1 } }

فاز به‌روزرسانی فیلتر کالمن توسعه یافته با استفاده از فرمول‌های زیر انجام خواهد شد:

Kk=Pkk1HkT(HkPkk1HkT+Rk)1x^k=x^kk1+Kk[zkh(x^kk1)]Pk=(IKkHk)Pkk1\begin {aligned} & \mathbf { K } _ { k } = \mathbf { P } _ { k | k - 1 } \mathbf { H } _ { k } ^ { T } \left ( \mathbf { H } _ { k } \mathbf { P } _ {k | k - 1 } \mathbf { H } _ { k } ^ { T } + \mathbf { R } _ { k } \right) ^ { - 1 } \\ & \hat { \mathbf { x } } _ { k } = \hat { \mathbf { x } } _ { k | k - 1 } + \mathbf { K } _ { k } \left[ \mathbf { z } _ { k } - \mathbf { h } \left( \hat { \mathbf { x } } _ { k | k - 1 } \right) \right] \\ & \mathbf { P } _ { k } = \left( \mathbf { I } - \mathbf { K } _ { k } \mathbf { H } _ { k } \right) \mathbf { P } _ { k | k - 1 } \end {aligned}

در فرمول بالا zk\mathbf { z } _ { k } همان خروجی اندازه‌گیری‌ شده توسط سنسورها است. بنابراین، در قدم اول بهره کالمن (Kk\mathbf { K } _ { k }) محاسبه می‌شود و سپس تخمین نهایی متغیرهای حالت (x^k\hat { \mathbf { x } } _ { k }) و ماتریس کواریانس (Pk\mathbf { P } _ { k }) در نمونه k محاسبه خواهد شد. اگر به عبارت به‌روزرسانی حالت‌ها دقت کنیم، متوجه خواهیم شد که در فاز به‌روزرسانی به حالت پیش‌بینی‌ شده در گام اول یک ترم جدید اضافه شده است که متناسب با خطای پیش‌بینی است. عبارت zkh(x^kk1)\mathbf { z } _ { k } - \mathbf { h } ( \hat { \mathbf { x } } _ { k | k - 1 } ) دقیقا بیانگر اختلاف بین خروجی واقعی اندازه‌گیری‌شده توسط سنسورها و خروجی به‌دست آمده در فاز پیش‌بینی است. در دیاگرام تصویر زیر دو فاز پیش‌بینی و به‌روزرسانی در فیلتر کالمن توسعه یافته یا EKF نشان داده شده است.

فازهای پیش‌بینی و به‌روزرسانی در فیلتر کالمن توسعه یافته یا EKF
فازهای پیش‌بینی و به‌روزرسانی در فیلتر کالمن توسعه یافته یا EKF

اگر دینامیک سیستم به‌ شدت غیرخطی نباشد، در این‌ صورت با استفاده از فیلتر کالمن توسعه یافته می‌توان با دقت بسیار خوبی حالت‌های سیستم را تخمین زد. اما اگر سیستم به‌ شدت غیرخطی باشد، در این صورت بهتر است از فیلتر کالمن بی‌اثر استفاده شود که در مطالب قبلی مجله فرادرس مورد بررسی قرار گرفته است.

پیاده‌سازی فیلتر کالمن توسعه یافته یا EKF در متلب

در ادامه کدنویسی تخمین حالت‌ سیستم‌های غیرخطی توسط الگوریتم فیلتر کالمن توسعه یافته به دو شکل در نرم‌افزار MATLAB ارائه می‌شود. در کد اول با استفاده از دستورات پایه متلب و خط به خط برنامه‌نویسی انجام شده است و عملکرد الگوریتم برای تخمین حالت‌های دینامیک غیرخطی واندرپول نیز مورد بررسی قرار گرفته است. در برنامه دوم با استفاده از تولباکس‌های آماده نرم افزار متلب کدنویسی انجام شده است.

برنامه اول برای افرادی مناسب است که حوزه تحقیقاتی آنها در مورد خود الگوریتم فیلتر کالمن توسعه یافته است و برنامه دوم نیز برای محققینی قابل استفاده است که صرفا یک الگوریتم برای تخمین حالت سیستم‌های غیرخطی لازم دارند. معادلات دینامیکی سیستم غیرخطی واندرپول به صورت زیر تعریف می‌شوند. رفتار سیستم نوسانی و آشوبناک است و فرض می‌کنیم موقعیت اولیه ۲ و سرعت اولیه حالت نیز ۰ باشد.

y¨(t)+(1y2(t))y˙(t)+y(t)=0\ddot { y } ( t ) + \left ( 1 - y ^ { 2 } ( t ) \right) \dot { y } ( t ) + y ( t ) = 0

در قدم اول باید سیستم را به فرم فضای حالت نوشت. متغیرهای حالت موقعیت و سرعت اولیه انتخاب می‌شوند. در نتیجه بیان فضای حالت سیستم و خروجی قابل‌ اندازه‌گیری به صورت زیر خواهد بود:

x˙(t)=[x2(t)(1x12(t))x2(t)+x1(t)]=f(x(t))y=x1(t)=h(x(t))\begin {aligned} &\dot { x } ( t ) = \left [ \begin {array} { l } x _ { 2 } ( t ) \\ \left ( 1 - x _ { 1 } ^ { 2 } ( t ) \right ) x _ { 2 } ( t ) + x _ { 1 } ( t ) \end {array} \right] = f ( x ( t ) ) \\ & y = x _ { 1 } ( t ) = h ( x ( t ) ) \end {aligned}

در قدم بعد باید توجه کرد که الگوریتم فیلتر کالمن توسعه یافته برای تخمین حالت سیستم‌های گسسته استفاده می‌شود. بنابراین با استفاده از تقریب اویلر برای مشتق می‌توان سیستم را به شکل زیر گسسته‌سازی کرد:

x(t+1)=x(t)+Tsf(x(t))x ( t + 1 ) = x ( t ) + T _ { s } f ( x ( t ) )

TsT _ { s } زمان نمونه‌برداری است و مقدار آن در شبیه‌سازی برابر با ۰٫۰۵ انتخاب می‌شود. طول بازه شبیه‌سازی نیز ۲۰ ثانیه در نظر گرفته می‌شود. همچنین باید توجه کرد که در رابطه t بالا بیانگر شماره نمونه است. دینامیک واندرپول و سیستم اندازه‌گیری آن در توابع زیر پیاده‌سازی شده‌اند.

الگوریتم تخمین حالت برای سیستم‌های غیرخطی توسط EKF نیز در تابع متلب زیر پیاده‌سازی شده است.

سپس در برنامه زیر تخمین حالت‌ سیستم غیرخطی تعریف‌ شده انجام می‌گیرد.

با اجرای برنامه بالا، خروجی به صورت شکل‌های زیر به دست می‌آید. در گراف‌های بالایی نمودارهای آبی‌ رنگ حالت‌های واقعی سیستم هستند و نمودارهای قرمز‌ رنگ نیز تخمین آن‌ها توسط الگوریتم EKF است. گراف‌های پایینی نیز خطای بین حالت‌های واقعی سیستم و مقادیر تخمینی آن‌ها را نشان می‌دهند. کاملا واضح است که عملکرد تخمین‌گر رضایت‌بخش‌ است و به خوبی توانسته است حالت‌های سیستم غیرخطی واندرپول را تخمین بزند. همچنین باید توجه کرد که در برنامه برای اینکه عملکرد الگوریتم تخمینگر با وضوح بیشتری نشان داده شود، نویز پروسه و نویز اندازه‌گیری مقادیر بالایی درنظر گرفته شده است.

پیاده‌سازی فیلتر کالمن توسعه یافته با استفاده از دستور extendedKalmanFilter متلب

در حالت بعد الگوریتم EKF با استفاده از توابع آماده متلب پیاده‌سازی خواهد شد. با استفاده از دستور extendedKalmanFilter فیلتر کالمن توسعه یافته ایجاد خواهد شد. با دستور predict فاز پیش‌بینی و با دستور correct نیز فاز به‌روزرسانی‌ حالت‌های تخمین و ماتریس کواریانس انجام خواهد شد. به منظور تخمین حالت توسط این توابع ابتدا همانند برنامه اول توابع دینامیک سیستم و اندازه‌گیری تعریف خواهد شد و سپس از برنامه زیر استفاده می‌کنیم.

با اجرای برنامه بالا خروجی به صورت زیر به دست می‌آید. نتایج مشابه برنامه اول است و نشانگر عملکرد فوق‌العاده الگوریتم تخمین حالت غیرخطی EKF برای سیستم‌های دینامیکی غیرخطی است.

اگر این مطلب برای شما مفید بوده است، آموزش‌های زیر نیز به شما پیشنهاد می‌شوند:

××

بر اساس رای ۲۲ نفر
آیا این مطلب برای شما مفید بود؟
اگر پرسشی درباره این مطلب دارید، آن را با ما مطرح کنید.
منابع:
Kalman Filtering: Theory and Practice with MATLABمجله فرادرس
PDF
مطالب مرتبط
۷ دیدگاه برای «فیلتر کالمن توسعه یافته (EKF) در متلب – از صفر تا صد»

با عرض سلام و احترام
هنگامیکه دستور خود متلب را ران میگیرم، به تابع extendedKalmanFilter ارور میده.امکانش هست بفرمایین نحوه استفاده ازین کد چجوریه که خطا نده.
با تشکر از شما.

سلام وقتتون بخیر باتشکر از سایت خوبتون
ببخشید من این کد رو عینا کپی میکنم خطا میده مثلا میگه ekfرو تعریف کن یا measurement رو تعریف کن
امکانش هست بفرمایین نحوه استفاده ازین کد چجوریه که خطا نده ؟ حتی میگه فانکشن رو تعرف کن ممنون میشم راهنماییم کنین

سلام.
کدها پیش از انتشار آموزش آزمایش شده‌اند و به‌درستی اجرا می‌شوند.
برای اجرای صحیح کدها، مراحل زیر را انجام دهید:
۱. ابتدا ام‌فایل سه قطعه‌کد نخست را که توابع لازم برای اجرای برنامه اصلی هستند، در پوشه‌ای ذخیره کنید. نام این توابع، به‌ترتیبِ آنچه در متن آموزش آمده، SystemDynamic و MeasurementDynamic و ekf_estimator است.
۲. Current Folder متلب را روی پوشه‌ای که ام‌فایل توابع آنجا ذخیره شده، قرار دهید.
۳. برنامه اصلی (قطعه‌کد چهارم در متن آموزش) را کپی کرده، در ادیتور متلب قرار دهید و ذخیره کنید.
۴. برنامه اصلی را اجرا کنید.
موفق باشید.

سلام وقت بخیر ببخشید من این کد رو توی متلب میزنم ولی تابع measurementdynamicرو میزنه تعریف کنید ممکنه بفرمایین این تابع چی هست؟ توی کدها میگردم نمیتونم پیداش کنم ممنون

سلام.
این تابع همان متغیر x1x_1 است که کد آن در متن آموزش آورده شده است.
سپاس از همراهی‌تان.

سلام، بسیار ممنون از بیان عالی شما.
می خواستم از حضورتان خواهش کنم اگر ممکنه لطف بفرمایید کد متلب با EKF برای شبیه‌سازی (تولید) سیگنال ECG را ارسال فرمایید. با احترام

سلام ممنون بابت آموزش
اگر f، تابعی از بردار ورودی (u) هم باشه، کدهای متلب چگونه تغییر می کنند؟ تو این مثال، f فقط تابعی از متغیرهای حالت هست.

نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *