هندسه محاسباتی

هندسهٔ محاسباتی[۱] یکی از شاخه‌های علوم رایانه است. هندسهٔ محاسباتی علم حل مسائل هندسی به روش الگوریتمی و با استفاده از ساختمان داده‌ها (Data Structures) است. بعضی از مسائل کاملاً هندسی، برآمده از مطالعهٔ الگوریتمهای هندسهٔ محاسباتی است و مطالعه این‌گونه مسائل نیز به عنوان بخشی از هندسهٔ محاسباتی به حساب می‌آیند.

انگیزهٔ اصلی برای قلمداد کردن هندسهٔ محاسباتی به عنوان یک رشتهٔ علمی، پیشرفت در گرافیک رایانه‌ای، طراحی و تولیدات با کمک رایانه (به‌وسیلهٔ نرم‌افزارهایی مانند کد[۲]/کم[۳]) بود؛ ولی طبیعتاً بسیاری از مسائل در هندسهٔ محاسباتی، قدیمی هستند.

کاربردهای مهم دیگر هندسهٔ محاسباتی در دانش روباتیک (برنامه‌ریزی حرکتی)، سیستم‌های اطلاعات جغرافیایی[۴](جستجو و مکان‌یابی هندسی، نقشه‌کشی راه‌ها)، طراحی مدار مجتمع[۵](طراحی و بازبینی هندسی مدارهای مجتمع) و مهندسی با کمک رایانه[۶] (برنامه‌ریزی ماشین‌های کنترل عددی)[۷] است.

شاخه‌های اصلی هندسهٔ محاسباتی عبارت‌اند از:

  • هندسهٔ محاسباتی ترکیبی (هندسهٔ الگوریتمی): این هندسهٔ محاسباتی اشیای هندسی را به‌عنوان موجودات گسسته در نظر می‌گیرد. براساس کتابی که توسط پرپاراتا[۸] و شاموس[۹] نوشته شده‌است، اصطلاح «هندسهٔ محاسباتی» با این مفهوم، نخستین بار در سال ۱۹۷۵ بیان شده‌است.
  • هندسهٔ محاسباتی عددی (هندسهٔ ماشینی، طراحی هندسی با کمک رایانه یا مدل‌سازی هندسی): اساس کار این هندسهٔ محاسباتی به این صورت است که اشیای دنیای واقعی را به‌صورت مناسبی برای محاسبات رایانه‌ای در سیستم‌های کد/کم درمی‌آورد. این شاخه ممکن است به‌عنوان هندسهٔ توصیفی پیشرفته در نظر گرفته شود و اغلب یکی از شاخه‌های گرافیک کامپیوتری یا کَد به حساب می‌آید. هندسهٔ محاسباتی با این معنا، از سال ۱۹۷۱ مورد استفاده قرار گرفت.

هندسهٔ محاسباتی ترکیبیاتی[ویرایش]

هدف اصلی از پژوهش در زمینهٔ هندسهٔ محاسباتی ترکیبیاتی این است که، برای حل مسائلی که در زمینه اشیای پایه هندسی (نقاط، خط‌ها، چندضلعی‌ها، چندوجهی‌ها[۱۰] و…) مطرح می‌شوند، الگوریتم‌ها و ساختارهای دادهٔ[۱۱] مناسبی تولید شود.

برخی از این مسائل به قدری آسان به نظر می‌رسند که تا زمان پیدایش رایانه‌ها مشکل به حساب نمی‌آمدند. برای مثال به مسئلهٔ نزدیک‌ترین زوج[۱۲] توجه کنید:

  • n نقطه در صفحه داریم. دو نقطه‌ای که کمترین فاصله را از یکدیگر دارند، پیدا کنید.

می‌توان فاصلهٔ بین جفت نقطه‌ها، که تعدادشان معلوم هست را پیدا کرد و بعد کوچک‌ترین عدد را انتخاب کرد. این الگوریتم از مرتبهٔ[۱۳] n۲ است. منظور این است که زمان اجرایش به مربع تعداد نقاط بستگی دارد. یک نتیجهٔ کلاسیک در هندسهٔ محاسباتی ایجاد الگوریتمی بود که از مرتبهٔ n log n زمان بگیرد. الگوریتم‌های تصادفی که از مرتبهٔ n زمان می‌برند، علاوه بر الگوریتم‌های تعیین‌کننده‌ای که از مرتبهٔ n log n زمان می‌برند نیز کشف شده‌اند.

برای GIS جدید،[۱۴] گرافیک کامپیوتری و سیستم‌های طراحی مدارهای مجتمع که روزانه ده‌ها و صدها میلیون نقطه را به کار می‌گیرند، تفاوت بین مرتبهٔ n۲و مرتبهٔ n log n می‌تواند تفاوت بین روزها و ثانیه‌ها محاسبه، باشد. به همین دلیل است که در هندسهٔ محاسباتی تأکید زیادی روی پیچیدگی محاسباتی شده‌است.

انواع سؤالات[ویرایش]

مسائل اساسی در هندسهٔ محاسباتی را می‌توان با در نظر گرفتن معیارهای گوناگون، به روش‌های گوناگونی طبقه‌بندی کرد. یکی از این رده‌بندی‌ها در زیر آمده‌است.

مسائل ایستا[ویرایش]

در این گروه از مسائل، نوعی ورودی داده می‌شود و خروجی متناسب باید به دست بیاید یا پیدا شود. برخی مسائل اساسی این نوع عبارت‌اند از:

پیچیدگی محاسباتی برای این دسته از مسائل براساس زمان و فضای (حافظهٔ کامپیوتری) لازم برای حل مسئله تقریب زده می‌شود.

مسائل جستجوی هندسی[ویرایش]

در مسائل جستجوی هندسی[۲۳] ورودی از دو قسمت تشکیل شده‌است: قسمت فضای جستجو و قسمت جستجو، که در هر مسئله تغییر می‌کند. قسمت فضای جستجو باید به گونه‌ای پیش‌پردازش[۲۴] شود که بتواند به نحو مطلوبی به سوالات متعدد جواب دهد.

برخی مسائل اساسی جستجوی هندسی عبارت‌اند از:

  • جستجوی محدوده:[۲۵] مجموعه‌ای از نقاط را پیش‌پردازش می‌کند برای این‌که درون محدودهٔ مطلوب، تعداد نقاط را بشمارد.
  • محل‌یابی نقطه:[۲۶] با دریافت فضایی که تقسیم‌بندی شده، یک ساختار داده تولید می‌کند که به ما می‌گوید نقطهٔ مورد نظر، در کدام قسمت قرار دارد.
  • نزدیک‌ترین همسایه:[۲۷] مجموعه‌ای از نقاط را به این منظور پیش‌پردازش می‌کند که تعیین کند کدام نقطه، به نقطهٔ مورد نظر نزدیک‌تر است.
  • ردیابی پرتو:[۲۸] با دریافت مجموعه‌ای از اجسام در فضا، یک ساختار داده تولید می‌کند تا تعیین کند که پرتوی جستجوی[۲۹] مورد نظر، نخستین بار با کدام جسم برخورد می‌کند.

اگر فضای جستجو ثابت باشد، پیچیدگی محاسباتی برای این دسته از مسائل بر اساس مطالب زیر تخمین زده می‌شود:

  • زمان و حافظهٔ لازم برای ساختن ساختار داده‌ای که باید در داخل آن جستجو شود.
  • زمان (و برخی مواقع یک حافظهٔ اضافی) برای پاسخ به جستجوها.

برای حالتی که فضای جستجو تغییر می‌کند، به مسائل پویا[۳۰] رجوع شود.

مسائل پویا[ویرایش]

یکی دیگر از گروه‌های اصلی مسائل، مسائل پویا هستند که در آن‌ها هدف، یافتن الگوریتمی مناسب برای یافتن راه حلی است که بعد از هر تغییر دادهٔ ورودی (اضافه یا حذف کردن عناصر هندسی) تکرار شود. الگوریتم‌های این نوع مسائل اغلب شامل ساختارهای دادهٔ پویا[۳۱] است. هر کدام از مسائل هندسهٔ محاسباتی را می‌توان به مسئلهٔ پویا تبدیل کرد. برای مثال، مسئلهٔ جستجوی محدوده را می‌توان با اضافه کردن امکان اضافه یا حذف کردن نقطه‌ها به مسئلهٔ جستجوی پویای محدوده تبدیل کرد. مسئلهٔ پوستهٔ محدب پویا همان کار مسئلهٔ پوستهٔ محدب را برای مجموعهٔ نقاطی که به‌طور پویا تغییر می‌کنند انجام می‌دهد.

پیچیدگی محاسباتی این دسته از مسائل با توجه به عوامل زیر تخمین زده می‌شود:

  • زمان و حافظهٔ لازم برای ساختن ساختار داده‌ای که باید در داخل آن جستجو شود.
  • زمان و حافظهٔ لازم برای تغییر دادن ساختار دادهٔ مورد جستجو، بعد از یک تغییر در فضای جستجو.
  • زمان (و برخی مواقع یک حافظهٔ اضافی) برای پاسخ به جستجوها.

حالت‌های گوناگون[ویرایش]

می‌توان با برخی داده‌ها به گونه‌ای برخورد کرد که با توجه به محتوایشان جزو هر کدام از گروه‌های معرفی شده قرار گیرند. برای مثال، مسئله زیر را در نظر بگیرید: نقطه در چند ضلعی:[۳۲] مشخص کنید که یک نقطهٔ مورد نظر داخل چند ضلعی است یا خارج آن. در بسیاری از موارد با این مسئله به عنوان یک تک‌تیر[۳۳] برخورد می‌شود، یعنی این‌که مربوط به گروه اول است. برای مثال، در بسیاری از نمونه‌های گرافیک کامپیوتری یک مسئلهٔ رایج این است که مشخص کند کدام ناحیه از صفحه توسط نشانه‌گر ماوس[۳۴] کلیک شده‌است. اما در برخی موارد چند ضلعی مورد نظر تغییرناپذیر است در حالی که نقطه مورد جستجو را به نمایش می‌گذارد. برای مثال، چند ضلعی وارد شده می‌تواند نمایندهٔ مرز یک کشور باشد و نقطه، مکان یک هواپیما و مسئله تعیین کردن این است که آیا هواپیما از مرز عبور کرده‌است یا نه. در نهایت، در مثال‌های بیان شده در گرافیک کامپیوتری ورودی‌های متغیر در ساختارهای دادهٔ پویا ذخیره می‌شوند، تا به حل سوالاتی که مربوط به نقاط داخل چندضلعی است، سرعت بخشد.

هندسهٔ محاسباتی عددی[ویرایش]

این شاخه به مدل‌سازی هندسی و طراحی هندسی با کمک کامپیوتر[۳۵] نیز معروف است و اغلب تحت کلیدواژهٔ[۳۶] منحنی‌ها و سطح‌ها دیده می‌شود. مسئله‌های اصلی در این نوع از هندسهٔ محاسباتی، مدل‌سازی و ارائهٔ منحنی و سطح است.

در این‌جا مهم‌ترین ابزارها، منحنی‌های پارامتری[۳۷] و سطح‌های پارامتری[۳۸] هستند، مانند خم‌های بزیر،[۳۹] خم‌ها و سطح‌های نواری.[۴۰] از مهم‌ترین روش‌های غیرپارامتری، روش تنظیم رده[۴۱] است.

از نخستین و مهم‌ترین کاربردهای هندسهٔ محاسباتی عددی، کاربرد در کشتی‌سازی، هواپیماسازی و صنایع ماشین‌آلات است. اما امروزه، به دلیل حضور گستردهٔ رایانه‌ها و پیشرفته‌تر شدن آن‌ها حتی جعبه‌های عطر و شامپو نیز با تکنیک‌هایی که برای کشتی‌سازان دههٔ ۱۹۶۰ ناشناخته بود طراحی می‌شوند.

مطالعهٔ بیشتر[ویرایش]

مجلات[ویرایش]

هندسهٔ محاسباتی الگوریتمی/ترکیبی[ویرایش]

در پیوند زیر:

مجلات در زمینهٔ الگوریتم‌های هندسی

فهرستی از مجله‌های معتبر که در زمینهٔ الگوریتم‌های هندسی، پژوهش‌هایی را چاپ کرده‌اند، آمده‌است. توجه شود که با آمدن مجله‌هایی که به هندسهٔ محاسباتی اختصاص یافته‌اند، سهم انتشارات هندسی در مجله‌های علوم کامپیوتر با هدف عمومی و مجله‌های گرافیک کامپیوتری کاهش یافت.

مدل‌سازی هندسی/طراحی هندسی به کمک کامپیوتر[ویرایش]

فهرست مجلات در زمینهٔ مدلسازی هندسی

کتاب‌ها[ویرایش]

منابع لاتین[ویرایش]

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, ۱۹۹۸

منابع فارسی[ویرایش]

۱. هندسهٔ محاسباتی: الگوریتم‌ها و کاربردها (ویراست سوم)، تألیف: مارک دی برگ، اوتفرید چیونگ، مارک وان کریولد، مارک اُورمارس- ترجمه: مهدی ایمان‌پرست، انتشارات دانش نگار، تهران، چاپ اول، ۱۳۹۴.

پانوشت‌ها[ویرایش]

  1. computational geometry
  2. CAD
  3. CAM
  4. geographic information systems(GIS)
  5. integrated circuit (IC)
  6. computer-aided engineering(CAE)
  7. numerically controlled(NC)
  8. Preparata
  9. Shamos
  10. polyhedra
  11. data structures
  12. closest pair problem
  13. Order (O)
  14. modern GIS
  15. Convex hull
  16. Line segment intersection
  17. Delaunay triangulation
  18. Voronoi diagram
  19. Linear programming
  20. Closest pair of points
  21. Euclidean shortest path
  22. Polygon triangulation
  23. geometric query problems, geometric search problems
  24. preprocess
  25. Range searching
  26. Point location
  27. Nearest neighbor
  28. Ray tracing
  29. query ray
  30. Dynamic problems
  31. dynamic data structures
  32. point in polygon
  33. single-shot
  34. mouse curser
  35. computer-aided geometric design (CAGD)
  36. keyword
  37. parametric curves
  38. parametric surfaces
  39. Bezier curves
  40. spline
  41. level set method

منابع[ویرایش]