دقت محاسباتی در رایانه – به زبان ساده


کاهش دقت محاسبات، یک اثر نامطلوب در انجام عملیات ریاضی است که به علت استفاده از تعداد ارقام مشخصی از اعداد اعشاری رخ میدهد. معمولا مشکل زمانی به وقوع میپیوندد که براساس دو عدد اعشاری گرد شده (Round) عملیات ریاضی انجام میشود. در این حالت خطای مطلق (Absolute Error) در هر دو عدد کمتر از خطای نسبی (Relative Error) خواهد بود. به عنوان مثال در تفریق دو عدد تقریباً برابر که یکی دارای تعداد ارقام بیشتری نسبت به دیگری است، اثر معروف به «حذف فاجعهبار» (catastrophic cancellation) رخ میدهد. در این متن به بررسی دقت محاسباتی در رایانه پرداخته و وجود اثر حذف فاجعهبار را در انجام عملیات ریاضی مرور میکنیم.
برای آشنایی بیشتر با موضوع این نوشتار بهتر است ابتدا مطالب نماد علمی — به زبان ساده، خطای اندازه گیری — به زبان ساده و دقت و صحت اندازه گیری – به زبان ساده را مطالعه کنید. همچنین خواندن نوشتارهای ضریب تغییرات و خطای نسبی — به زبان ساده و ریسک نسبی در مدل آماری — محاسبه و کاربردها نیز خالی از لطف نیست.
دقت محاسباتی در رایانه
«کاهش دقت محاسباتی» (Loss of Significant) را میتوان با محاسبات ساده روی اعداد اعشاری نشان داد. مثال زیر بیانگر کاهش دقت محاسبات برای یک اعداد اعشاری است. حالتی را در نظر بگیرید که سیستم محاسباتی قادر به انجام عملیات فقط روی ۱۰ رقم اعشار است. فرض کنید و اعداد مورد نظر باشند که اولی دارای ۲۰ رقم و دومی ۱۰ رقم اعشار دارد.
این دو مقدار با توجه به خطای نسبی بسیار به یکدیگر نزدیک هستند. ولی اگر میزان دقت را افزایش دهیم، این اعداد بسیار با یکدیگر تفاوت خواهند داشت.
دقت اندازهگیری برای مقدار برابر با است، در حالی که مقدار دقتی برابر با دارد. اکنون تفاضل این دو عدد را به شکل زیر انجام میدهیم.
پاسخ، با دقت ۲۰ رقم اعشار به شکل زیر است.
با این حال، اگر دستگاه محاسباتی یا رایانه ما دارای دقت ۱۰ رقم اعشار باشد، نتیجه برابر است با:
در هر دو مورد نتیجه به همان ترتیب دارای دقت ۲۰ رقم و ۱۰ رقم اعشار است. در حالت دوم، به نظر میرسد که پاسخ بدست آمده، دارای فقط یک رقم معنیدار است که باعث کاهش دقت محاسباتی شده است.
به هر حال، در محاسبات رایانهای روی اعداد اعشاری همه عملیات بوسیله عملگر «پادلگاریتم» (AntiLogarithm) یا توابع نمایی، صورت میگیرد که تعداد ارقام اعشاری معنیدار در نتایج محاسباتی براساس دقت کوچکترین «مانتیس» (Mantisa) تعیین میشود. به این ترتیب دقت محاسبات بالا را به صورت زیر نشان میدهند.
راه حل برای از دست ندادن دقت
در رایانهها، انجام محاسبات با استفاده از نمایش دقیق کسری از اعداد گویا (Rational Numbers) امکان پذیر است و تمام ارقام با معنی را حفظ میکند، ولی متاسفانه انجام محاسبات با این روش بسیار کندتر از عملیات با ممیز شناور (Floating Point) است.
یکی از مهمترین بخشهای تحلیل عددی، جلوگیری یا به حداقل رساندن کاهش دقت محاسبات در ارقام معنیدار است. اگر مشکل اصلی به خوبی مطرح شود، باید یک الگوریتم پایدار برای حل آن وجود داشته باشد.
حفظ ارقام یا بیتهای معنیدار
اجاره دهید، و که در قسمت قبل مورد استفاده قرار گرفتند به صورت عادی و به شکل ممیز شناور ثبت و در نظر گرفته شوند. در این قسمت سعی داریم مشخص کنیم که در عمل تفریق ، بیت های با اهمیت و معنیدار در کجا گم یا نادیده گرفته میشوند. در رابطه زیر، تعداد بیتهای گمشده را تعیین میکند.
رابطه ۱: تعداد ارقام (بیتهای) معنیدار گمشده در عمل تفاضل
توجه داشته باشید که در رابطه ۱، دو مقدار و مثبت هستند.
ناپایداری در پاسخهای معادله درجه دوم
مسئله دیگری که با توجه به تعداد ارقام اعشار و دقت محاسباتی، بروز میکند، پاسخهای مربوط به معادله درجه دوم (Quadratic Equation) است. به عنوان مثال، معادله درجه دوم زیر را در نظر بگیرید.
پاسخهای دقیق برای این معادله به شکل زیر خواهند بود.
رابطه ۲: پاسخهای معادله درجه دوم
نتیجه محاسبات برای این فرمول همیشه مقداری متعلق به مجموعه اعداد صحیح (Integer Number) نیست و ممکن است با از دست دادن دقت در محاسبات همراه باشد. به عنوان مثال، هنگامی که بسیار کوچک باشد، با توجه به علامت ، از دست دادن دقت در محاسبه هر یک از ریشههای چه با مقدار مثبت یا منفی، ممکن است رخ دهد.
حالتی را در نظر بگیرید که در معادله مربوط به رابطه ۲، باشد. برای نشان دادن مشکل از دست رفتن دقت در محاسبات از معادله زیر استفاده میکنیم.
به این ترتیب داریم:
پاسخهای مربوطه در مجموعه اعداد حقیقی (Real Numbers) به شکل زیر خواهند بود.
اگر پاسخها را با ۱۰ رقم اعشار در نظر بگیریم، خواهیم داشت:
توجه کنید که پاسخ با قدر مطلق بزرگتر با دقت ده رقم اعشار بیان شده است. اما اولین رقم معنیدار در قسمت اعشاری برای ریشه بعدی اشتباه است. این امر به دلیل تفریق که در معادله درجه دوم رخ میدهد حاصل شده و الگوریتم محاسبه ریشه معادلات به صورت پایدار تشکیل نشده است.
یک الگوریتم بهتر برای حل معادله درجه دوم
اجرای دقیق محاسبات مربوط به ممیز شناور با استفاده از چندین استراتژی برای ایجاد یک نتیجه قوی توسط رایانهها صورت میگیرد. با فرض اینکه مثبت و نیز غیر صفر در نظر گرفته شود، محاسبات مربوط به پیدا کردن ریشههای معادله درجه دوم، به شرح زیر قابل تغییر است:
رابطه ۳: محاسبه ریشههای معادله درجه ۲ برحسب تابع علامت
در اینجا sgn، تابع علامت (Sign Function) را نشان میدهد. به این معنی که مقدار برابر با ۱ است اگر مثبت باشد و با منفی بودن آن مقدار تابع ۱- خواهد بود. در صورتی که باشد، تابع علامت مقداری برابر با صفر خواهد داشت. توجه دارید که با در نظر گرفتن از وجود ریشه مضاعف صرف نظر کردهایم.
برای نشان دادن ناپایداری فرمول ریشههای درجه دوم استاندارد در مقایسه با فرمول مطرح شده در رابطه ۳، یک معادله درجه دوم با ریشهها زیر را در نظر بگیرید.
به این ترتیب با استفاده از دقت مضاعف (Double Precision) که در آن ۱۶ رقم اعشار در نظر گرفته میشود، شکل معادله درجه دوم به صورت زیر در میآید.
با استفاده از فرمول محاسبه ریشههای درجه دوم استاندارد و حفظ 16 رقم اعشار معنیدار در هر مرحله، ریشهها به شکل زیر حاصل میشوند.
توجه داشته باشید که چگونه حذف ارقام اعشار با اهمیت در محاسبات منجر به کاهش دقت محاسباتی در ریشههای شده است. مشخص است که ریشه فقط از ۸ رقم اعشار معنیدار تشکیل شده است.
ولی فرمول مربوط به رابطه ۳، در اینجا باعث ایجاد خطای کاهش دقت هنگام تفریق دو عبارت و نمیشود.
به حفظ تمام ارقام معنیدار و قابل توجه برای توجه داشته باشید.
هنگامی که در محاسبه مقدار زیر رادیکال (دلتای معادله درجه دوم) تفاصل و هر یک از جملهها با دقت مضاعف محاسبه شوند، ریشه دوم آنها دارای دقتی بسیار کمتر خواهد شد. به همین دلیل برای از بین بردن مشکل کاهش دقت محاسبات، برای محاسبه جمله زیر رادیکال، از «دو برابر دقت مضاعف» یا «دقت چها برابر» (Quad Precision) کمک گرفته و به این ترتیب نتیجه حاصل دارای دقت مضاعف خواهد شد. این می تواند به صورت یک عمل «ضرب-جمع تفکیک شده» (Fused Multiply-add) صورت گیرد.
مقدار دلتا (Discriminant) یا مقدار زیر رادیکال رابطه ۳، برای این معادله به صورت زیر خواهد بود.
در نتیجه ریشهها به ترتیب برابر هستند با:
با این حال ، هنگامی که با استفاده از محاسبات با دقت مضاعف (با استاندارد IEEE 754) عملیات به 15 تا 17 رقم اعشار معنیدار، محاسبه میشود، ریشههای محاسبه شده برابر خواهند بود با:
که هر دو بعد از رقم هشتم اعشار نادرست هستند. این موضوع اهمیت استفاده از دقت چهابرابر را نشان میدهد.
خلاصه و جمعبندی
در این نوشتار به موضوع دقت محاسباتی در رایانه و خصوصیات آن پرداختیم. همانطور که دیدید، در انجام بسیاری از محاسبات (بخصوص انجام عملیات روی مقادیر اعشاری) دقت رایانهها مسئلهای است که باید به آن با توجه زیادی کرد. البته در بیشتر الگوریتمها دقت محاسبات رایانه در نظر گرفته شده و عملیات به شکلی صورت میگیرد که کمترین خطای محاسباتی بوجود آید.
در این بین بعضی از الگوریتمها برای انجام محاسبات ابتدا از دو برابر دقت مضاعف استفاده کرده، سپس در پایان انجام عملیات، دقت مضاعف یا مقادیر با دقت ۸ رقم اعشار را منظور میکنند. به این ترتیب خطا در کاهش دقت محاسباتی رخ نداده یا اندازه آن بسیار کاهش مییابد.