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

فرض کنید , دو ماتریس مربعی روی یک حلقه ،برای نمونه ماتریسهایی که عنصرهایشان عدد صحیح یا حقیقی است، باشند. هدف ضرب ماتریس محاسبه ماتریس است. این توضیح الگوریتم فرض میکند که اندازهی ماتریسها توانهای ۲ است (یعنی ). اگر ماتریسهای , با اندازههای نباشند، ردیفها و ستونهای خالی را میتوان با صفر پر کرد تا به این اندازه برسند - گرچه پیادهسازیهای واقعی این الگوریتم در عمل این کار را نمیکنند.
الگوریتم , و را به ماتریسهای بلوکی هم اندازه افراز میکند:
الگوریتم ضرب ماتریس استاندارد اینگونه میبود:
با این ساختار، تعداد ضربها کاهش نیافته است. هنوز هم به ۸ ضرب نیاز است تا ماتریسهای محاسبه شود.
استراسن این ماتریسهای جدید را تعریف میکند:
با بیان به کمک میتوان یک ضرب ماتریس را حذف کرد و تعداد ضربها را به ۷ کاهش داد (یک ضرب برای هر ):
این فرآیند تقسیم به صورت بازگشتی تکرار شده تا زیرماتریسها به عدد (عنصرهای حلقه ) تبدیل شوند. اگر ماتریس اصلی اندازهای جز توانهای ۲ داشته باشد، آنگاه نتیجه مانند خود و سطر و ستون صفر خواهد داشت. این سطرها و ستونها زدوده میشوند تا ماتریس (کوچکتر) که نتیجه اصلی ضرب است به دست آید.
در پیادهسازیهای عملی الگوریتم استراسن برای زیرماتریسهای به اندازه کافی کوچک از روشهای استاندارد ضرب ماتریس استفاده میشود. نقطهای که الگوریتم استراسن برای آن اندازه به بعد کارآمدتر است، به پیادهسازی و سختافزار بستگی دارد. نویسندگان پیشتر تخمین زده بودند که الگوریتم استراسن برای ماتریسهای با اندازهی ۳۲ تا ۱۲۸ برای پیادهسازیهای بهینهشده از روش استاندارد سریعتر است ولی مشاهده شده است که این نقطه در سالهای گذشته رو به افزایش بوده است. پژوهشی در سال ۲۰۱۰ نشان داد که حتی یک گام از الگوریتم استراسن در معماریهای فعلی، در مقایسه با یک ضرب سادهی بسیار بهینهشده، تا زمانی که اندازهی ماتریسها از ۱۰۰۰ بیشتر نشود، سودمند نیست و حتی برای ماتریس با اندازهی چند هزار، این سودمندی در بهترین حالت حاشیهای است (حدود ۱۰ درسد یا کمتر). پژوهشی جدیدتر (۲۰۱۶) سودمندی را برای ماتریسهایی به کوچکی 512 و به میزان حدود ۲۰ درسد مشاهده کرد.
پیچیدگی مجانبی
ضرب ماتریسی استاندارد تقریباً عملیات محاسباتی ۲n^۳ (که n=۲^n) (جمعها و ضربها) را میپذیرد؛ پیچیدگی مجانبی (O(N۳میباشد. تعداد جمعها و ضربهای مورد نیاز در الگوریتم استراسن را میتوان به صورت زیر محاسبه کرد:
فرض کنید (f(n تعداد عملیات برای یک ماتریس ۲n * ۲n باشد. آنگاه با عملیات بازگشتی الگوریتم استراسن میبینیم که برای برخی l ثابت که به تعداد جمعهای انجام شده در هر عملیات الگوریتم وابستهاست. یعنی پیچیدگی مجانبی برای ضرب ماتریسها با استفاده از الگوریتم استراسن است. هرچند کاهش در تعداد عملیات محاسباتی تا حدودی به بهای کاهش ثبات عددی میباشد.
همچنین مشاهده کنید
منابع
- استراسن، ولکر، حذف گاوسی بهینه نیست، ص ۳۵۴-۳۵۶، ۱۹۶۹
- تامس اچ. کردمن، چارلز ای. لایسرسون، رانلد ال. روست، کلیفورد استاین، آشنایی با الگوریتم، ویرایش دوم، انتشارات موسسه فناوری ماساچوست، فصل ۲۸، الگوریتم استراسن برای ضرب ماتریس، ص ۷۳۴-۷۴۱، ۲۰۰۱
پیوند به بیرون
- ویستین اچ. اریک، فرمولهای استراسن بایگانیشده در ۱۴ فوریه ۲۰۱۵ توسط Wayback Machine، (همچنین شامل فرمول برای وارونگی ماتریس سریع)
- تیلر جی. ارنست،الگوریتم استراسن در موتور پهنای باند همراه
- پیادهسازی ساده الگوریتم استراسن درC، (آسان برای اهداف آموزش و پرورش)