الگوریتم استراسن

در جبر خطی الگوریتم استراسن الگوریتمی برای ضرب ماتریس است که برای ماتریس‌های بزرگ سریع‌تر از الگوریتم ضرب ماتریس استاندارد است و پیچیدگی مجانبی بهتری دارد ( در برابر )، البته الگوریتم ساده همچنان برای ماتریس‌های کوچک‌تر بهتر است. الگوریتم استراسن از سریع‌ترین الگوریتم شناخته‌شده برای ماتریس‌های بسیار بزرگ کندتر است، اما آن الگوریتم‌های کهکشانی در عمل مفید نیستند، زیرا برای ماتریس‌های در اندازه‌های رایج بسیار کندترند. برای ماتریس‌های کوچک، الگوریتم‌های سریع‌تری نیز هست.

الگوریتم استراسن برای هر حلقه‌ای، مانند جمع/ضرب، جواب می‌دهد، ولی برای همه‌ی نیم‌حلقه‌ها، مانند جبر کمینه جمع یا جبر بولی، که در آن‌ها الگوریتم ساده جواب می‌دهد، جواب نمی‌دهد.

تاریخ

ولکر استراسن الگوریتم استراسن را در سال ۱۹۶۹ منتشر کرد. او نخستین کسی بود که نشان داد الگوریتم رایج مرتبه بهینه نیست.

الگوریتم

ستون سمت چپ محاسبه‌های لازم برای ضرب ماتریس ۲x۲ را نشان می‌دهد. ضرب ماتریس ساده به ازای هر «1» در ستون سمت چپ، به یک ضرب نیاز دارد. هر یک از ستون‌های دیگر (M1-M7) نشان دهنده یک ضرب از ۷ ضرب در الگوریتم استراسن هستند. مجموع ستون‌های M1-M7 همان نتیجه ضرب ماتریس کامل در سمت چپ را می‌دهد.

فرض کنید , دو ماتریس مربعی روی یک حلقه ،برای نمونه ماتریس‌هایی که عنصرهایشان عدد صحیح یا حقیقی است، باشند. هدف ضرب ماتریس محاسبه ماتریس است. این توضیح الگوریتم فرض می‌کند که اندازه‌ی ماتریس‌ها توان‌های ۲ است (یعنی ). اگر ماتریس‌های , با اندازه‌‌های نباشند، ردیف‌ها و ستون‌های خالی را می‌توان با صفر پر کرد تا به این اندازه برسند - گرچه پیاده‌سازی‌های واقعی این الگوریتم در عمل این کار را نمی‌کنند.

الگوریتم , و را به ماتریس‌های بلوکی هم اندازه افراز می‌کند:

الگوریتم ضرب ماتریس استاندارد اینگونه می‌بود:

با این ساختار، تعداد ضرب‌ها کاهش نیافته است. هنوز هم به ۸ ضرب نیاز است تا ماتریس‌های محاسبه شود.

استراسن این ماتریس‌های جدید را تعریف می‌کند:

با بیان به کمک می‌توان یک ضرب ماتریس را حذف کرد و تعداد ضرب‌ها را به ۷ کاهش داد (یک ضرب برای هر ):

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

در پیاده‌سازی‌های عملی الگوریتم استراسن برای زیرماتریس‌های به اندازه کافی کوچک از روش‌های استاندارد ضرب ماتریس استفاده می‌شود. نقطه‌ای که الگوریتم استراسن برای آن اندازه به بعد کارآمدتر است، به پیاده‌سازی و سخت‌افزار بستگی دارد. نویسندگان پیش‌تر تخمین زده بودند که الگوریتم استراسن برای ماتریس‌های با اندازه‌ی ۳۲ تا ۱۲۸ برای پیاده‌سازی‌های بهینه‌شده از روش استاندارد سریع‌تر است ولی مشاهده شده است که این نقطه در سال‌های گذشته رو به افزایش بوده است. پژوهشی در سال ۲۰۱۰ نشان داد که حتی یک گام از الگوریتم استراسن در معماری‌های فعلی، در مقایسه با یک ضرب ساده‌ی بسیار بهینه‌شده، تا زمانی که اندازه‌ی ماتریس‌ها از ۱۰۰۰ بیشتر نشود، سودمند نیست و حتی برای ماتریس با اندازه‌ی چند هزار، این سودمندی در بهترین حالت حاشیه‌ای است (حدود ۱۰ درسد یا کمتر). پژوهشی جدیدتر (۲۰۱۶) سودمندی را برای ماتریس‌هایی به کوچکی 512 و به میزان حدود ۲۰ درسد مشاهده کرد.

پیچیدگی مجانبی

ضرب ماتریسی استاندارد تقریباً عملیات محاسباتی ۲n^۳ (که n=۲^n) (جمعها و ضرب‌ها) را می‌پذیرد؛ پیچیدگی مجانبی (O(N۳می‌باشد. تعداد جمع‌ها و ضرب‌های مورد نیاز در الگوریتم استراسن را می‌توان به صورت زیر محاسبه کرد:

فرض کنید (f(n تعداد عملیات برای یک ماتریس ۲n * ۲n باشد. آنگاه با عملیات بازگشتی الگوریتم استراسن می‌بینیم که برای برخی l ثابت که به تعداد جمع‌های انجام شده در هر عملیات الگوریتم وابسته‌است. یعنی پیچیدگی مجانبی برای ضرب ماتریسها با استفاده از الگوریتم استراسن است. هرچند کاهش در تعداد عملیات محاسباتی تا حدودی به بهای کاهش ثبات عددی می‌باشد.

همچنین مشاهده کنید

منابع

    • استراسن، ولکر، حذف گاوسی بهینه نیست، ص ۳۵۴-۳۵۶، ۱۹۶۹
    • تامس اچ. کردمن، چارلز ای. لایسرسون، رانلد ال. روست، کلیفورد استاین، آشنایی با الگوریتم، ویرایش دوم، انتشارات موسسه فناوری ماساچوست، فصل ۲۸، الگوریتم استراسن برای ضرب ماتریس، ص ۷۳۴-۷۴۱، ۲۰۰۱

    پیوند به بیرون