Remove ads
From Wikipedia, the free encyclopedia
هندسهٔ محاسباتی[1] یکی از شاخههای علوم رایانه است. هندسهٔ محاسباتی علم حل مسائل هندسی به روش الگوریتمی و با استفاده از ساختمان دادهها (Data Structures) است. بعضی از مسائل کاملاً هندسی، برآمده از مطالعهٔ الگوریتمهای هندسهٔ محاسباتی است و مطالعه اینگونه مسائل نیز به عنوان بخشی از هندسهٔ محاسباتی به حساب میآیند.
این مقاله نیازمند ویکیسازی است. لطفاً با توجه به راهنمای ویرایش و شیوهنامه، محتوای آن را بهبود بخشید. |
انگیزهٔ اصلی برای قلمداد کردن هندسهٔ محاسباتی به عنوان یک رشتهٔ علمی، پیشرفت در گرافیک رایانهای، طراحی و تولیدات با کمک رایانه (بهوسیلهٔ نرمافزارهایی مانند کد[2]/کم[3]) بود؛ ولی طبیعتاً بسیاری از مسائل در هندسهٔ محاسباتی، قدیمی هستند.
کاربردهای مهم دیگر هندسهٔ محاسباتی در دانش روباتیک (برنامهریزی حرکتی)، سیستمهای اطلاعات جغرافیایی[4](جستجو و مکانیابی هندسی، نقشهکشی راهها)، طراحی مدار مجتمع[5](طراحی و بازبینی هندسی مدارهای مجتمع) و مهندسی با کمک رایانه[6] (برنامهریزی ماشینهای کنترل عددی)[7] است.
شاخههای اصلی هندسهٔ محاسباتی عبارتاند از:
هدف اصلی از پژوهش در زمینهٔ هندسهٔ محاسباتی ترکیبیاتی این است که، برای حل مسائلی که در زمینه اشیای پایه هندسی (نقاط، خطها، چندضلعیها، چندوجهیها[10] و…) مطرح میشوند، الگوریتمها و ساختارهای دادهٔ[11] مناسبی تولید شود.
برخی از این مسائل به قدری آسان به نظر میرسند که تا زمان پیدایش رایانهها مشکل به حساب نمیآمدند. برای مثال به مسئلهٔ نزدیکترین زوج[12] توجه کنید:
میتوان فاصلهٔ بین جفت نقطهها، که تعدادشان معلوم هست را پیدا کرد و بعد کوچکترین عدد را انتخاب کرد. این الگوریتم از مرتبهٔ[13] n۲ است. منظور این است که زمان اجرایش به مربع تعداد نقاط بستگی دارد. یک نتیجهٔ کلاسیک در هندسهٔ محاسباتی ایجاد الگوریتمی بود که از مرتبهٔ n log n زمان بگیرد. الگوریتمهای تصادفی که از مرتبهٔ n زمان میبرند، علاوه بر الگوریتمهای تعیینکنندهای که از مرتبهٔ n log n زمان میبرند نیز کشف شدهاند.
برای GIS جدید،[14] گرافیک کامپیوتری و سیستمهای طراحی مدارهای مجتمع که روزانه دهها و صدها میلیون نقطه را به کار میگیرند، تفاوت بین مرتبهٔ n۲و مرتبهٔ n log n میتواند تفاوت بین روزها و ثانیهها محاسبه، باشد. به همین دلیل است که در هندسهٔ محاسباتی تأکید زیادی روی پیچیدگی محاسباتی شدهاست.
مسائل اساسی در هندسهٔ محاسباتی را میتوان با در نظر گرفتن معیارهای گوناگون، به روشهای گوناگونی طبقهبندی کرد. یکی از این ردهبندیها در زیر آمدهاست.
در این گروه از مسائل، نوعی ورودی داده میشود و خروجی متناسب باید به دست بیاید یا پیدا شود. برخی مسائل اساسی این نوع عبارتاند از:
پیچیدگی محاسباتی برای این دسته از مسائل براساس زمان و فضای (حافظهٔ کامپیوتری) لازم برای حل مسئله تقریب زده میشود.
در مسائل جستجوی هندسی[23] ورودی از دو قسمت تشکیل شدهاست: قسمت فضای جستجو و قسمت جستجو، که در هر مسئله تغییر میکند. قسمت فضای جستجو باید به گونهای پیشپردازش[24] شود که بتواند به نحو مطلوبی به سوالات متعدد جواب دهد.
برخی مسائل اساسی جستجوی هندسی عبارتاند از:
اگر فضای جستجو ثابت باشد، پیچیدگی محاسباتی برای این دسته از مسائل بر اساس مطالب زیر تخمین زده میشود:
برای حالتی که فضای جستجو تغییر میکند، به مسائل پویا[30] رجوع شود.
یکی دیگر از گروههای اصلی مسائل، مسائل پویا هستند که در آنها هدف، یافتن الگوریتمی مناسب برای یافتن راه حلی است که بعد از هر تغییر دادهٔ ورودی (اضافه یا حذف کردن عناصر هندسی) تکرار شود. الگوریتمهای این نوع مسائل اغلب شامل ساختارهای دادهٔ پویا[31] است. هر کدام از مسائل هندسهٔ محاسباتی را میتوان به مسئلهٔ پویا تبدیل کرد. برای مثال، مسئلهٔ جستجوی محدوده را میتوان با اضافه کردن امکان اضافه یا حذف کردن نقطهها به مسئلهٔ جستجوی پویای محدوده تبدیل کرد. مسئلهٔ پوستهٔ محدب پویا همان کار مسئلهٔ پوستهٔ محدب را برای مجموعهٔ نقاطی که بهطور پویا تغییر میکنند انجام میدهد.
پیچیدگی محاسباتی این دسته از مسائل با توجه به عوامل زیر تخمین زده میشود:
میتوان با برخی دادهها به گونهای برخورد کرد که با توجه به محتوایشان جزو هر کدام از گروههای معرفی شده قرار گیرند. برای مثال، مسئله زیر را در نظر بگیرید: نقطه در چند ضلعی:[32] مشخص کنید که یک نقطهٔ مورد نظر داخل چند ضلعی است یا خارج آن. در بسیاری از موارد با این مسئله به عنوان یک تکتیر[33] برخورد میشود، یعنی اینکه مربوط به گروه اول است. برای مثال، در بسیاری از نمونههای گرافیک کامپیوتری یک مسئلهٔ رایج این است که مشخص کند کدام ناحیه از صفحه توسط نشانهگر ماوس[34] کلیک شدهاست. اما در برخی موارد چند ضلعی مورد نظر تغییرناپذیر است در حالی که نقطه مورد جستجو را به نمایش میگذارد. برای مثال، چند ضلعی وارد شده میتواند نمایندهٔ مرز یک کشور باشد و نقطه، مکان یک هواپیما و مسئله تعیین کردن این است که آیا هواپیما از مرز عبور کردهاست یا نه. در نهایت، در مثالهای بیان شده در گرافیک کامپیوتری ورودیهای متغیر در ساختارهای دادهٔ پویا ذخیره میشوند، تا به حل سوالاتی که مربوط به نقاط داخل چندضلعی است، سرعت بخشد.
این شاخه به مدلسازی هندسی و طراحی هندسی با کمک کامپیوتر[35] نیز معروف است و اغلب تحت کلیدواژهٔ[36] منحنیها و سطحها دیده میشود. مسئلههای اصلی در این نوع از هندسهٔ محاسباتی، مدلسازی و ارائهٔ منحنی و سطح است.
در اینجا مهمترین ابزارها، منحنیهای پارامتری[37] و سطحهای پارامتری[38] هستند، مانند خمهای بزیر،[39] خمها و سطحهای نواری.[40] از مهمترین روشهای غیرپارامتری، روش تنظیم رده[41] است.
از نخستین و مهمترین کاربردهای هندسهٔ محاسباتی عددی، کاربرد در کشتیسازی، هواپیماسازی و صنایع ماشینآلات است. اما امروزه، به دلیل حضور گستردهٔ رایانهها و پیشرفتهتر شدن آنها حتی جعبههای عطر و شامپو نیز با تکنیکهایی که برای کشتیسازان دههٔ ۱۹۶۰ ناشناخته بود طراحی میشوند.
در پیوند زیر:
مجلات در زمینهٔ الگوریتمهای هندسی
فهرستی از مجلههای معتبر که در زمینهٔ الگوریتمهای هندسی، پژوهشهایی را چاپ کردهاند، آمدهاست. توجه شود که با آمدن مجلههایی که به هندسهٔ محاسباتی اختصاص یافتهاند، سهم انتشارات هندسی در مجلههای علوم کامپیوتر با هدف عمومی و مجلههای گرافیک کامپیوتری کاهش یافت.
1. M. de Berg, O. Cheong, M. van Kreveld, M. Overmars, Computational Geometry: Algorithms and Applications, 3rd edition, Springer, ۲۰۰۸.
2. .2011,Satyan L. Devadoss, Joseph O'Rourke, Discrete and Computational Geometry, Princeton University
3. J. O'Rourke, Computational Geometry in C, 2nd edition, Cambridge University Press, ۱۹۹۸
۱. هندسهٔ محاسباتی: الگوریتمها و کاربردها (ویراست سوم)، تألیف: مارک دی برگ، اوتفرید چیونگ، مارک وان کریولد، مارک اُورمارس- ترجمه: مهدی ایمانپرست، انتشارات دانش نگار، تهران، چاپ اول، ۱۳۹۴.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.