هندسه محاسباتی
هندسه محاسباتی[1] یکی از شاخههای علوم کامپیوتر است. هندسه محاسباتی علم حل مسائل هندسی به روش الگوریتمی و با استفاده از ساختمان دادهها (Data Structures) میباشد. بعضی از مسائل کاملاً هندسی، برآمده از مطالعهٔ الگوریتمهای هندسهٔ محاسباتی است و مطالعه اینگونه مسائل نیز به عنوان بخشی از هندسه محاسباتی به حساب میآید.
انگیزهٔ اصلی برای قلمداد کردن هندسه محاسباتی به عنوان یک رشتهٔ علمی، پیشرفت در گرافیک کامپیوتری، طراحی و تولیدات با کمک رایانه (به وسیلهٔ نرمافزارهایی مانند کد[2]/کم[3]) بود؛ ولی طبیعتاً بسیاری از مسائل در هندسه محاسباتی، قدیمی هستند.
کاربردهای مهم دیگر هندسه محاسباتی در دانش روباتیک (برنامهریزی حرکتی)، سیستمهای اطلاعات جغرافیایی[4](جستجو و مکانیابی هندسی، نقشهکشی راهها)، طراحی مدار مجتمع[5](طراحی و بازبینی هندسی مدارهای مجتمع) و مهندسی با کمک رایانه [6] (برنامهریزی ماشینهای کنترل عددی)[7] میباشد.
شاخههای اصلی هندسه محاسباتی عبارتند از:
- هندسهٔ محاسباتی ترکیبی (هندسه الگوریتمی): این هندسهٔ محاسباتی اشیای هندسی را به عنوان موجودات گسسته در نظر میگیرد. براساس کتابی که توسط پرپاراتا [8] و شاموس [9] نوشته شدهاست، لفظ هندسه محاسباتی با این مفهوم، نخستین بار در سال ۱۹۷۵ بیان شدهاست.
- هندسه محاسباتی عددی (هندسه ماشینی، طراحی هندسی با کمک رایانه یا مدلسازی هندسی): اساس کار این هندسه محاسباتی به این صورت است که اشیای دنیای واقعی را به صورت مناسبی برای محاسبات رایانهای در سیستمهای کد/کم در میآورد. این شاخه ممکن است به عنوان هندسه توصیفی پیشرفته در نظر گرفته شود و اغلب یکی از شاخههای گرافیک کامپیوتری یا کَد به حساب میآید. هندسه محاسباتی با این معنا، از سال ۱۹۷۱ مورد استفاده قرار گرفت.
هندسهٔ محاسباتی ترکیبیاتی
هدف اصلی از پژوهش در زمینهٔ هندسه محاسباتی ترکیبیاتی این است که، برای حل مسائلی که در زمینه اشیای پایه هندسی (نقاط، خطها، چند ضلعیها، چند وجهیها[10] و...) مطرح میشوند، الگوریتمها و ساختارهای داده[11] ی مناسبی تولید شود.
برخی از این مسائل به قدری آسان به نظر میرسند که تا زمان پیدایش رایانهها مشکل به حساب نمیآمدند. برای مثال به مسئلهٔ نزدیکترین زوج[12] توجه کنید:
- n نقطه در صفحه داریم. دو نقطهای که کمترین فاصله را از یکدیگر دارند، پیدا کنید.
میتوان فاصله بین جفت نقطهها، که تعدادشان معلوم هست را پیدا کرد و بعد کوچکترین عدد را انتخاب کرد. این الگوریتم از مرتبهٔ[13] n۲ است. منظور این است که زمان اجرایش به مربع تعداد نقاط بستگی دارد. یک نتیجهٔ کلاسیک در هندسهٔ محاسباتی ایجاد الگوریتمی بود که از مرتبهٔ n log n زمان بگیرد. الگوریتمهای تصادفی که از مرتبهٔ n زمان میبرند، علاوه بر الگوریتمهای تعیینکنندهای که از مرتبهٔ n log n زمان میبرند نیز کشف شدهاند.
برای GIS جدید،[14] گرافیک کامپیوتری و سیستمهای طراحی مدارهای مجتمع که روزانه دهها و صدها میلیون نقطه را به کار میگیرند، تفاوت بین مرتبهٔ n۲و مرتبهٔ n log n میتواند تفاوت بین روزها و ثانیهها محاسبه، باشد. به همین دلیل است که در هندسه محاسباتی تأکید زیادی روی پیچیدگی محاسباتی شدهاست.
انواع سؤالات
مسائل اساسی در هندسه محاسباتی را میتوان با در نظر گرفتن معیارهای گوناگون، به روشهای گوناگونی طبقهبندی کرد. یکی از این ردهبندیها در زیر آمدهاست.
مسائل ایستا
در این گروه ازمسائل، نوعی ورودی داده میشود و خروجی متناسب باید به دست بیاید یا پیدا شود. برخی مسائل اساسی این نوع عبارتند از:
- رویه محدب[15]: تعدادی نقطه داریم، کوچکترین چند ضلعی یا چند وجهی محدبی را پیدا کنید که دربرگیرندهٔ همه نقطههاست.
- تقاطع پاره خطها:[16] تقاطعهای بین تعدادی پاره خط را پیدا کنید.
- مثلثبندی دلونی[17]
- نمودارهای ورونوی:[18] با دریافت مجموعهای از نقاط، فضا را بر اساس نزدیکترین نقطه تقسیمبندی کنید.
- برنامهریزی خطی[19]: برنامهریزی خطی، یا همان بهینهسازی خطی، روشی در ریاضیات است که به پیدا کردن مقدار کمینه یا بیشینه از یک تابع خطی روی یک چندضلعی محدب میپردازد.
- نزدیکترین زوج نقاط:[20] با دریافت مجموعهای از نقاط، دونقطهای را بیابید که کمترین فاصله را دارند.
- کوتاهترین مسیر اقلیدسی:[21] دو نقطه را در فضای اقلیدسی (با یک مانع چند وجهی) با کوتاهترین مسیر به هم وصل کنید.
- مثلثبندی چندضلعی:[22] با دریافت یک چند ضلعی، سطح داخل آن را به تعدادی مثلث تقسیم کنید.
پیچیدگی محاسباتی برای این دسته از مسائل براساس زمان و فضای (حافظهٔ کامپیوتری) لازم برای حل مسئله تقریب زده میشود.
مسائل جستجوی هندسی
در مسائل جستجوی هندسی[23] ورودی از دو قسمت تشکیل شدهاست: قسمت فضای جستجو و قسمت جستجو، که در هر مسئله تغییر میکند. قسمت فضای جستجو باید به گونهای پیش پردازش[24] شود که بتواند به نحو مطلوبی به سوالات متعدد جواب دهد.
برخی مسائل اساسی جستجوی هندسی عبارتند از:
- جستجوی محدوده:[25] مجموعهای از نقاط را پیش پردازش میکند برای اینکه در داخل محدوده مطلوب، تعداد نقاط را بشمارد.
- محل یابی نقطه:[26] با دریافت فضایی که تقسیم بندی شده، یک ساختار داده تولید میکند که به ما میگوید نقطه مورد نظر، در کدام قسمت قرار دارد.
- نزدیکترین همسایه:[27] مجموعهای از نقاط را به این منظور پیش پردازش میکند که تعیین کند کدام نقطه، به نقطهٔ مورد نظر نزدیکتر است.
- ردیابی پرتو:[28] با دریافت مجموعهای از اجسام در فضا، یک ساختار داده تولید میکند تا تعیین کند که پرتوی جستجو[29] ی مورد نظر، نخستین بار با کدام جسم برخورد میکند.
اگر فضای جستجو ثابت باشد، پیچیدگی محاسباتی برای این دسته از مسائل بر اساس مطالب زیر تخمین زده میشود:
- زمان و حافظهٔ لازم برای ساختن ساختار دادهای که باید در داخل آن جستجو شود.
- زمان (و برخی مواقع یک حافظهٔ اضافی) برای پاسخ به جستجوها.
برای حالتی که فضای جستجو تغییر میکند، به مسائل پویا[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, 2008.
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, 1998
منابع فارسی
1. هندسه محاسباتی: الگوریتمها و کاربردها (ویراست سوم)- تألیف: مارک دی برگ، اوتفرید چیونگ، مارک وان کریولد، مارک اُورمارس- ترجمه: مهدی ایمان پرست- انتشارات دانش نگار- تهران- چاپ اول- 1394.
پانوشتها
- computational geometry
- CAD
- CAM
- geographic information systems(GIS)
- integrated circuit (IC)
- computer-aided engineering(CAE)
- numerically controlled(NC)
- Preparata
- Shamos
- polyhedra
- data structures
- closest pair problem
- Order (O)
- modern GIS
- Convex hull
- Line segment intersection
- Delaunay triangulation
- Voronoi diagram
- Linear programming
- Closest pair of points
- Euclidean shortest path
- Polygon triangulation
- geometric query problems, geometric search problems
- preprocess
- Range searching
- Point location
- Nearest neighbor
- Ray tracing
- query ray
- Dynamic problems
- dynamic data structures
- point in polygon
- single-shot
- mouse curser
- computer-aided geometric design (CAGD)
- keyword
- parametric curves
- parametric surfaces
- Bezier curves
- spline
- level set method
- link
منابع
- ایران سازه (انگلیسی) https://web.archive.org/web/20131215134129/http://www.iransaze.com/article-print-841.html
- مشارکتکنندگان ویکیپدیا. «Computational geometry». در دانشنامهٔ ویکیپدیای انگلیسی، بازبینیشده در ۲ می ۲۰۱۱.