ماتریس هیلبرت — به زبان ساده
در این آموزش با ماتریس هیلبرت آشنا میشویم که در پردازش تصویر و رمزنگاری کاربرد دارد.
ماتریس هیلبرت
«ماتریس هیلبرت» (Hilbert Matrix) یک ماتریس مربعی است که درایههای آن کسرهای واحد و به صورت زیر هستند (کسر واحد کسری است که صورت آن ۱ و مخرجش یک عدد صحیح مثبت باشد):
برای مثال، ماتریس زیر یک ماتریس هیلبرت است:
درایههای ماتریس هیلبرت را میتوان از انتگرال زیر به دست آورد:
که مشابه یک «ماتریس گرامیان» (Gramian Matrix) برحسب توانهای مختلف است. فرمول بالا در واقع از تقریب حداقل مربعات توابع دلخواه توسط چندجملهایها میآید.
ماتریسهای هیلبرت نمونههایی از ماتریسهای «بدحالت» یا «بدوضع» (ill-Conditioned) هستند که استفاده از آنها در محاسبات عددی با دشواریهایی همراه است. برای مثال، عدد حالت نُرم ۲ ماتریس بالا تقریباً است.
ویژگیهای ماتریس هیلبرت
ماتریس هیلبرت یک ماتریس متقارن و معین مثبت است. این ماتریس همچنین «کاملاً مثبت» (Totally Positive) است، یعنی دترمینان هر زیرماتریس از آن مثبت است. علاوه بر این، ماتریس هیلبرت مثالی از یک «ماتریس هنکل» (Hankel Matrix) و یک «ماتریس کوشی» (Cauchy Matrix) نیز هست.
همانطور که میدانیم، در ماتریس هنکل تابعی از است و در ماتریس کوشی است و میبینیم که ماتریس هیلبرت با توجه به یک ماتریس هنکل و بر اساس تساوی یک حالت خاص از ماتریس کوشی است.
دترمینان ماتریس هیلبرت را میتوان به فرم بسته، به عنوان یک حالت خاص از دترمینان کوشی، توصیف کرد. دترمینان ماتریس هیلبرت برابر است با:
که در آن:
البته هیلبرت پیشتر گفته بود که دترمینان ماتریس هیلبرت وارون یک عدد صحیح است که از تساوی زیر پیروی میکند:
با استفاده از تقریب استرلینگ برای فاکتوریل، میتوان عبارت زیر را نتیجه گرفت:
که در آن، وقتی به بینهایت میل کند، به مقدار ثابت همگرا میشود که در آن، «ثابت گلیشر-کینکلین» (Glaisher–Kinkelin Constant) و تقریباً است.
معکوس ماتریس هیلبرت را میتوان با استفاده از ضرایب دوجملهای به فرم بسته نشان داد که در این صورت، درایههای آن برابر هستند با:
که در آن، بعد ماتریس است. همانطور که مشخص است، درایههای معکوس ماتریس هیلبرت اعداد صحیح بوده و درایههای سطری یا ستونی آن به صورت یک در میان مثبت و منفی هستند. همچنین، درایههای قطر اصلی آن نیز همگی اعدادی مثبت هستند. برای مثال:
ماتریس هیلبرت در متلب
در متلب تابعی برای تولید ماتریس هیلبرت وجود دارد. این تابع hilb است. در واقع، H = hilb (n) یک ماتریس هیلبرت مرتبه را نتیجه خواهد داد که درایههای آن است.
برای مثال، با دستور زیر در متلب میتوان یک ماتریس هیلبرت ۴ در ۴ تولید کرد:
1H = hilb(4)
اگر دستور بالا را اجرا کنیم، نتیجه آن به صورت زیر خواهد بود:
H = 4×4
1.0000 0.5000 0.3333 0.2500
0.5000 0.3333 0.2500 0.2000
0.3333 0.2500 0.2000 0.1667
0.2500 0.2000 0.1667 0.1429
همانطور که گفتیم، ماتریس هیلبرت یک ماتریس بدحالت است. برای بررسی این موضوع، عدد حالت ماتریس بالا را با استفاده از دستور cond محاسبه میکنیم:
1cond(H)
نتیجه اجرای این دستور، بدحالت بودن ماتریس را به خوبی نشان میدهد:
ans = 1.5514e+04
گر علاقهمند به یادگیری مباحث مشابه مطلب بالا هستید، آموزشهایی که در ادامه آمدهاند نیز به شما پیشنهاد میشوند:
- مجموعه آموزشهای دروس ریاضیات
- آموزش جبر خطی با متلب
- مجموعه آموزشهای پردازش تصویر و ویدئو
- آموزش پردازش تصویر در متلب
- تجزیه مقادیر منفرد (SVD) — به زبان ساده
- پردازش تصویر با پایتون — راهنمای کاربردی
- تقلب نامه (Cheat Sheet) جبر خطی برای یادگیری ماشین — راهنمای سریع و کامل
^^