تجسم و مسیریابی شبکه پایه (QGIS3)

ایجاد، تجسم و مدیریت شبکه ها بخش مهمی از GIS است. بسیاری از انواع زیرساخت‌های فیزیکی مانند جاده‌ها، راه‌آهن‌ها، خدمات شهری را می‌توان به عنوان شبکه‌هایی با خطوط و گره‌ها - با ویژگی‌های متصل به آنها مدل‌سازی کرد. در این آموزش، نحوه مدل‌سازی شبکه‌های جاده‌ای را یاد می‌گیریم و از برخی تکنیک‌های سبک برای تجسم ویژگی‌های مسیریابی استفاده می‌کنیم. ما همچنین از ابزارهای داخلی QGIS3 برای تجزیه و تحلیل شبکه استفاده خواهیم کرد که برای یافتن کوتاهترین مسیر بین 2 نقطه همراه با شبکه.

بررسی اجمالی کار

ما یک لایه بلوک جاده را برای واشنگتن دی سی می گیریم، اتصال را تجسم می کنیم و یک شبکه برای پیدا کردن کوتاه ترین مسیر بین هر 2 نقطه در شهر ایجاد می کنیم.

مهارت های دیگری که یاد خواهید گرفت

  • نحوه استفاده از لغو تعریف شده داده برای تراز کردن نماد فلش بر اساس جهت خط.

داده ها را دریافت کنید

دولت ناحیه کلمبیا صدها مجموعه داده را آزادانه در «کاتالوگ داده باز <https://opendata.dc.gov/>» به اشتراک می گذارد.

"Block Roadway <https://opendata.dc.gov/datasets/roadway-block>"_ را که توسط داده های DCGISopendata به اشتراک گذاشته شده است را به عنوان یک فایل شکل دانلود کنید.

../../_images/data11.png

برای راحتی کار، می‌توانید مستقیماً یک نسخه از مجموعه داده‌ها را از لینک‌های زیر دانلود کنید:

Roadway_Block-shp.zip

منبع داده: [DCOPENDATA]

روش

  1. فایل «Roadway_Block-shp.zip» دانلود شده را در پنل :guilabel:`Browser پیدا کنید. آن را گسترش دهید و فایل «Roadway_Block.shp» را روی بوم بکشید.

../../_images/115.png
  1. You will see a new line layer called Roadway_Block added to the Layers panel. This layer represents each road in Washington DC. Select the Identify tool in the Attributes Toolbar. Click on any road segment to see what attributes are attached to it. There are standard attributes like Route-name, Road-type etc. there is an attribute called SUMMARYDIR. This is an important attribute for routing as it specifies whether the segment is two-way or one-way. It contains 4 different values. BD (Both Directions) for two-way streets. OB (Out Bound) for one-way streets where the traffic is allowed in the direction of the line (start-point to end-point) and IB (In Bound) for one-way streets where the traffic flows in the opposite direction of the line. There is also ?? value where we will assume two-way traffic. We will now use the information in that attribute to display an arrow on one-way streets.

../../_images/213.png
  1. روی دکمه :guilabel:'Open the layer Styling Panel' در پنل :guilabel:`Layers کلیک کنید. رندر «مبتنی بر قانون» را از منوی کشویی انتخاب کنید.

../../_images/310.png
  1. ما یک سبک جدید با فیلتر فقط برای جاده های یک طرفه ایجاد خواهیم کرد. روی دکمه Add rule + کلیک کنید.

../../_images/42.png
  1. در گفتگوی :guilabel:'Edit rule'، روی دکمه :guilabel:'Expression کلیک کنید.

../../_images/52.png
  1. در گفتگوی سازنده رشته بیانی، بخش :guilabel:`Fields and Values را در پنل میانی گسترش دهید. ویژگی SUMMARYDIR را انتخاب کنید و روی :guilabel:`All Unique در پنل سمت راست کلیک کنید. 4 مقداری که قبلاً در مورد آنها صحبت کردیم ظاهر می شوند. داشتن این مقادیر در اینجا به عنوان مرجع در ساخت عبارت کمک می کند. همچنین، می‌توانید روی هر مقداری دوبار کلیک کنید تا آن‌ها را به عبارت اضافه کنید.

../../_images/62.png
  1. هدف ایجاد عبارتی است که تمام خیابان های یک طرفه را انتخاب کند. عبارت زیر را وارد کرده و روی OK کلیک کنید.

"SUMMARYDIR" in ('IB', 'OB')
../../_images/72.png
  1. در مرحله بعد، :guilabel:` نوع لایه نماد را به خط نشانگر تغییر دهید.

../../_images/82.png
  1. "در نقطه مرکزی" را در زیر :guilabel:"قرار دادن نشانگر" انتخاب کنید.

../../_images/92.png
  1. روی نماد "نشانگر ساده" کلیک کنید. به پایین پیمایش کنید و نشانگر «سرپیکان_پرشده» را انتخاب کنید. خواهید دید که علامت فلش مانند اکنون در خیابان های یک طرفه ظاهر می شود. اما همه آنها به یک جهت اشاره می کنند، در حالی که ما می دانیم که فیلتر ما شامل جاده هایی در چندین جهت است. ما می‌توانیم نمادها را با یک بازنویسی تعریف‌شده از داده برای مقدار :guilabel:` Rotation اصلاح کنیم.

../../_images/105.png
  1. روی دکمه رد تعریف داده‌های نادیده گرفته شده در کنار :guilabel:`چرخش کلیک کنید.

../../_images/116.png
  1. می توانیم یک عبارت شرطی قرار دهیم که بسته به جهت یک طرفه، مقادیر چرخش متفاوتی را برمی گرداند. چرخش 180 درجه برای جاده با جهت مخالف، جهت را کامل می‌کند، در این حالت، جاده‌های با ویژگی "IB" را 180 درجه می‌چرخانیم، بنابراین همه جاده‌ها جهت جریان ترافیک صحیح را خواهند داشت. عبارت زیر را وارد کرده و روی OK کلیک کنید.

if( "SUMMARYDIR" = 'IB', 180, 0)
../../_images/125.png
  1. اکنون سر پیکان ها را می بینید که در جهت درست جاده تراز شده اند. برای بی نظم نگه داشتن استایل، پیکان ها را فقط در خیابان های یک طرفه نمایش می دهیم. خیابان های بدون برچسب دو طرفه فرض می شوند. اکنون که سبک شبکه را به درستی طراحی کرده ایم، می توانیم تحلیلی انجام دهیم. به Processing ‣ Toolbox بروید.

../../_images/134.png
  1. الگوریتم تجزیه و تحلیل شبکه ‣ کوتاهترین مسیر (نقطه به نقطه) را جستجو و مکان یابی کنید. برای راه اندازی آن دوبار کلیک کنید.

../../_images/144.png
  1. In the Shortest Path (Point to Point) dialog, select Roadway_Block as the Vector layer representing network. Keep the Path type to calculate as Shortest. Next, we need to pick a start and endpoint. You can click the ... button and click on any point on the network in the canvas. If you want to replicate the results in this tutorial, you can enter -76.99730092166396,38.887624846748984 as the Start point and -76.99154831062152,38.89151000569929 as the End point. Expand the Advanced parameter section. Choose SUMMARYDIR as the Direction field. You must be familiar with the one-way direction values for the forward and backward traffic flow. Enter OB as the Value for the forward direction and IB as the Value for the backward direction. Keep other options to their default values and click Run.

../../_images/154.png
  1. الگوریتم از هندسه لایه و پارامترهای ارائه شده برای ساخت یک نمودار شبکه استفاده می کند. سپس از این نمودار برای یافتن کوتاه ترین مسیر بین نقطه شروع و پایان استفاده می شود. پس از اتمام الگوریتم، یک لایه جدید "کوتاه ترین مسیر" را خواهید دید که به پنل :guilabel:`Layers اضافه شده است که کوتاه ترین مسیر را بین نقطه شروع و پایان نشان می دهد.

../../_images/164.png
  1. خواهید دید که مسیرهای ممکن زیادی بین نقطه شروع و پایان وجود دارد. اما با توجه به محدودیت های شبکه - مانند یک طرفه بودن، نتیجه کوتاه ترین مسیر ممکن است. همیشه ایده خوبی است که تحلیل ها و فرضیات خود را تأیید کنید. یکی از راه‌های آسان برای تأیید اعتبار این است که از یک سرویس نقشه‌برداری شخص ثالث استفاده کنید تا ببینید آیا نتایج آنها با نتایجی که ما به دست آورده‌ایم مطابقت دارد یا خیر. در اینجا کوتاه‌ترین مسیری است که توسط Google Maps <https://goo.gl/maps/XwTXTkvuaCuteocr8>` بین همان نقطه شروع و پایان پیشنهاد شده است. همانطور که می بینید کوتاه ترین مسیر توصیه شده دقیقاً با نتایج ما مطابقت دارد - تأیید تجزیه و تحلیل ما.

../../_images/174.png

If you want to give feedback or share your experience with this tutorial, please comment below. (requires GitHub account)