شاخص
-
RouteOptimization
(رابط) -
AggregatedMetrics
(پیام) -
BatchOptimizeToursMetadata
(پیام) -
BatchOptimizeToursRequest
(پیام) -
BatchOptimizeToursRequest.AsyncModelConfig
(پیام) -
BatchOptimizeToursResponse
(پیام) -
BreakRule
(پیام) -
BreakRule.BreakRequest
(پیام) -
BreakRule.FrequencyConstraint
(پیام) -
DataFormat
(enum) -
DistanceLimit
(پیام) -
GcsDestination
(پیام) -
GcsSource
(پیام) -
InjectedSolutionConstraint
(پیام) -
InjectedSolutionConstraint.ConstraintRelaxation
(پیام) -
InjectedSolutionConstraint.ConstraintRelaxation.Relaxation
(پیام) -
InjectedSolutionConstraint.ConstraintRelaxation.Relaxation.Level
(enum) -
InputConfig
(پیام) -
Location
(پیام) -
OptimizeToursRequest
(پیام) -
OptimizeToursRequest.SearchMode
(enum) -
OptimizeToursRequest.SolvingMode
(enum) -
OptimizeToursResponse
(پیام) -
OptimizeToursResponse.Metrics
(پیام) -
OptimizeToursValidationError
(پیام) -
OptimizeToursValidationError.FieldReference
(پیام) -
OutputConfig
(پیام) -
RouteModifiers
(پیام) -
Shipment
(پیام) -
Shipment.Load
(پیام) -
Shipment.VisitRequest
(پیام) -
ShipmentModel
(پیام) -
ShipmentModel.DurationDistanceMatrix
(پیام) -
ShipmentModel.DurationDistanceMatrix.Row
(پیام) -
ShipmentModel.PrecedenceRule
(پیام) -
ShipmentRoute
(پیام) -
ShipmentRoute.Break
(پیام) -
ShipmentRoute.EncodedPolyline
(پیام) -
ShipmentRoute.Transition
(پیام) -
ShipmentRoute.VehicleLoad
(پیام) -
ShipmentRoute.Visit
(پیام) -
ShipmentTypeIncompatibility
(پیام) -
ShipmentTypeIncompatibility.IncompatibilityMode
(enum) -
ShipmentTypeRequirement
(پیام) -
ShipmentTypeRequirement.RequirementMode
(enum) -
SkippedShipment
(پیام) -
SkippedShipment.Reason
(پیام) -
SkippedShipment.Reason.Code
(enum) -
TimeWindow
(پیام) -
TransitionAttributes
(پیام) -
Vehicle
(پیام) -
Vehicle.DurationLimit
(پیام) -
Vehicle.LoadLimit
(پیام) -
Vehicle.LoadLimit.Interval
(پیام) -
Vehicle.TravelMode
(عدد) -
Vehicle.UnloadingPolicy
(enum) -
Waypoint
(پیام)
بهینه سازی مسیر
خدماتی برای بهینه سازی تورهای خودرو.
اعتبار انواع خاصی از فیلدها:
-
google.protobuf.Timestamp
- زمان ها در زمان یونیکس هستند: ثانیه از 1970-01-01T00:00:00+00:00.
- ثانیه باید در [0, 253402300799]، یعنی در [1970-01-01T00:00:00+00:00, 9999-12-31T23:59:59+00:00] باشد.
- نانو باید تنظیم نشده یا روی 0 تنظیم شود.
-
google.protobuf.Duration
- ثانیه باید در [0, 253402300799]، یعنی در [1970-01-01T00:00:00+00:00, 9999-12-31T23:59:59+00:00] باشد.
- نانو باید تنظیم نشده یا روی 0 تنظیم شود.
-
google.type.LatLng
- عرض جغرافیایی باید در [-90.0، 90.0] باشد.
- طول جغرافیایی باید در [-180.0، 180.0] باشد.
- حداقل یکی از طول و عرض جغرافیایی باید غیر صفر باشد.
BatchOptimizeTours |
---|
تورهای وسیله نقلیه را برای یک یا چند پیام این روش یک عملیات طولانی مدت (LRO) است. ورودیهای بهینهسازی (پیامهای کاربر می تواند برای بررسی وضعیت LRO از اگر قسمت اگر قسمت
|
OptimizeTours |
---|
یک یک مدل هدف این است که تخصیصی از
|
متریک های جمع شده
معیارهای جمعآوریشده برای ShipmentRoute
(مثلاً برای OptimizeToursResponse
روی همه عناصر Transition
و/یا Visit
(در مقابل همه ShipmentRoute
).
فیلدها | |
---|---|
performed_shipment_count | تعداد محموله های انجام شده توجه داشته باشید که یک جفت تحویل و تحویل فقط یک بار حساب می شود. |
travel_duration | کل مدت سفر برای یک مسیر یا یک راه حل. |
wait_duration | کل مدت زمان انتظار برای یک مسیر یا یک راه حل. |
delay_duration | مدت زمان کلی تاخیر برای یک مسیر یا یک راه حل. |
break_duration | کل مدت زمان استراحت برای یک مسیر یا یک راه حل. |
visit_duration | کل مدت زمان بازدید برای یک مسیر یا یک راه حل. |
total_duration | کل مدت زمان باید برابر با مجموع تمام مدت زمان بالا باشد. برای مسیرها نیز با موارد زیر مطابقت دارد:
|
travel_distance_meters | کل مسافت سفر برای یک مسیر یا یک راه حل. |
max_loads | حداکثر بار بهدستآمده در کل مسیر (وظیفه راهحل)، برای هر یک از کمیتهای این مسیر (مشخصات راهحل)، که بهعنوان حداکثر روی همه |
BatchOptimizeToursMetadata
این نوع هیچ فیلدی ندارد.
فراداده عملیات برای تماس های BatchOptimizeToursRequest
.
BatchOptimizeToursRequest
درخواست بهینه سازی دسته ای تورها به عنوان یک عملیات ناهمزمان. هر فایل ورودی باید حاوی یک OptimizeToursRequest
باشد و هر فایل خروجی حاوی یک OptimizeToursResponse
باشد. درخواست حاوی اطلاعاتی برای خواندن/نوشتن و تجزیه فایلها است. تمام فایل های ورودی و خروجی باید تحت یک پروژه باشند.
فیلدها | |
---|---|
parent | مورد نیاز. پروژه و مکان مورد نظر برای برقراری تماس. قالب: * اگر مکانی مشخص نشده باشد، یک منطقه به طور خودکار انتخاب می شود. |
model_configs[] | مورد نیاز. اطلاعات ورودی/خروجی هر مدل خرید، مانند مسیرهای فایل و فرمت های داده. |
AsyncModelConfig
اطلاعاتی برای حل یک مدل بهینه سازی به صورت ناهمزمان.
فیلدها | |
---|---|
display_name | اختیاری. نام مدل تعریف شده توسط کاربر، می تواند به عنوان نام مستعار توسط کاربران برای پیگیری مدل ها استفاده شود. |
input_config | مورد نیاز. اطلاعات مربوط به مدل ورودی |
output_config | مورد نیاز. اطلاعات مکان خروجی مورد نظر |
BatchOptimizeToursResponse
این نوع هیچ فیلدی ندارد.
پاسخ به BatchOptimizeToursRequest
. این در عملیات طولانی مدت پس از اتمام عملیات برگردانده می شود.
BreakRule
قوانینی برای ایجاد وقفه زمانی برای یک وسیله نقلیه (مثلاً استراحت ناهار). استراحت یک دوره زمانی پیوسته است که طی آن وسیله نقلیه در موقعیت فعلی خود بیکار می ماند و نمی تواند هیچ بازدیدی را انجام دهد. وقفه ممکن است رخ دهد:
- در طول سفر بین دو بازدید (که شامل زمان درست قبل یا بعد از بازدید می شود، اما نه در وسط یک بازدید)، در این صورت زمان حمل و نقل مربوطه بین بازدیدها را افزایش می دهد.
- یا قبل از شروع خودرو (ممکن است وسیله نقلیه در وسط یک استراحت استارت نخورد)، در این صورت بر زمان استارت خودرو تأثیری نمی گذارد.
- یا پس از پایان خودرو (همچنین، با زمان پایان خودرو).
فیلدها | |
---|---|
break_requests[] | توالی وقفه ها پیام |
frequency_constraints[] | ممکن است چندین |
Break Request
توالی وقفه ها (یعنی تعداد و ترتیب آنها) که برای هر وسیله نقلیه اعمال می شود باید از قبل مشخص باشد. BreakRequest
های مکرر آن توالی را به ترتیبی که باید رخ دهند، تعریف می کنند. پنجرههای زمانی آنها ( earliest_start_time
/ latest_start_time
) ممکن است با هم همپوشانی داشته باشند، اما باید با سفارش سازگار باشند (این مورد بررسی شده است).
فیلدها | |
---|---|
earliest_start_time | مورد نیاز. کران پایین (شامل) در شروع استراحت. |
latest_start_time | مورد نیاز. کران بالا (شامل) در شروع استراحت. |
min_duration | مورد نیاز. حداقل مدت زمان استراحت. باید مثبت باشه |
محدودیت فرکانس
ممکن است با اعمال یک حداقل فرکانس استراحت، مانند "هر 12 ساعت حداقل 1 ساعت وقفه وجود داشته باشد." با فرض اینکه این می تواند به عنوان "در هر پنجره زمانی کشویی 12 ساعته، حداقل یک وقفه حداقل یک ساعته وجود داشته باشد" تفسیر شود، این مثال به FrequencyConstraint
زیر ترجمه می شود:
{
min_break_duration { seconds: 3600 } # 1 hour.
max_inter_break_duration { seconds: 39600 } # 11 hours (12 - 1 = 11).
}
زمان و مدت وقفهها در راهحل، به همه این محدودیتها، علاوه بر پنجرههای زمانی و حداقل مدت زمانهایی که قبلاً در BreakRequest
مشخص شدهاند، احترام میگذارد.
یک FrequencyConstraint
ممکن است در عمل برای وقفه های غیر متوالی اعمال شود. به عنوان مثال، برنامه زیر به مثال "1 ساعت هر 12 ساعت" احترام می گذارد:
04:00 vehicle start
.. performing travel and visits ..
09:00 1 hour break
10:00 end of the break
.. performing travel and visits ..
12:00 20-min lunch break
12:20 end of the break
.. performing travel and visits ..
21:00 1 hour break
22:00 end of the break
.. performing travel and visits ..
23:59 vehicle end
فیلدها | |
---|---|
min_break_duration | مورد نیاز. حداقل مدت زمان استراحت برای این محدودیت. غیر منفی. به توضیحات |
max_inter_break_duration | مورد نیاز. حداکثر بازه مجاز هر بازه زمانی در مسیر که حداقل تا حدی شامل وقفه |
DataFormat
فرمت های داده برای فایل های ورودی و خروجی
Enums | |
---|---|
DATA_FORMAT_UNSPECIFIED | مقدار نامعتبر است، قالب نباید نامشخص باشد. |
JSON | نشانه گذاری شی جاوا اسکریپت. |
PROTO_TEXT | فرمت متنی بافرهای پروتکل. به https://protobuf.dev/reference/protobuf/textformat-spec/ مراجعه کنید |
محدودیت فاصله
حدی که حداکثر مسافت قابل پیمودن را تعیین می کند. می تواند سخت یا نرم باشد.
اگر یک حد نرم تعریف شده باشد، هم soft_max_meters
و هم cost_per_kilometer_above_soft_max
باید تعریف شده و غیرمنفی باشد.
فیلدها | |
---|---|
max_meters | حد سختی که فاصله را حداکثر حداکثر مکس_متر محدود می کند. حد باید غیرمنفی باشد. |
soft_max_meters | یک حد نرم محدودیت حداکثر فاصله را اعمال نمی کند، اما زمانی که نقض شود منجر به هزینه ای می شود که به هزینه های دیگر تعریف شده در مدل، با همان واحد اضافه می شود. اگر soft_max_meters تعریف شده باید کمتر از max_meters باشد و باید غیرمنفی باشد. |
cost_per_kilometer_below_soft_max | هزینه هر کیلومتر متحمل شده، افزایش تا
این هزینه در |
cost_per_kilometer_above_soft_max | اگر مسافت بالاتر از حد مجاز
هزینه باید غیرمنفی باشد. |
GcsDestination
مکان Google Cloud Storage که فایل(های) خروجی در آن نوشته می شود.
فیلدها | |
---|---|
uri | مورد نیاز. URI Google Cloud Storage. |
منبع Gcs
مکان Google Cloud Storage که فایل ورودی از آنجا خوانده می شود.
فیلدها | |
---|---|
uri | مورد نیاز. URI یک شی Google Cloud Storage با فرمت |
InjectedSolution Constraint
راه حل تزریق شده در درخواست شامل اطلاعاتی در مورد اینکه کدام بازدیدها باید محدود شوند و چگونه باید محدود شوند.
فیلدها | |
---|---|
routes[] | مسیرهای محلول برای تزریق برخی از مسیرها ممکن است از راه حل اصلی حذف شوند. مسیرها و محموله های نادیده گرفته شده باید مفروضات اعتبار اولیه فهرست شده برای |
skipped_shipments[] | محموله های محلول برای تزریق نادیده گرفته شده است. ممکن است برخی از راه حل اصلی حذف شوند. قسمت |
constraint_relaxations[] | برای گروه های صفر یا چند وسیله نقلیه، زمان و میزان کاهش محدودیت ها را مشخص می کند. اگر این فیلد خالی باشد، تمام مسیرهای غیرخالی وسایل نقلیه کاملاً محدود می شوند. |
محدودیت آرامش
برای گروهی از وسایل نقلیه، مشخص میکند که محدودیتهای بازدید در چه آستانهای کاهش مییابند و تا چه سطحی. محموله های فهرست شده در قسمت skipped_shipment
محدود به نادیده گرفتن هستند. یعنی نمی توان آنها را اجرا کرد.
فیلدها | |
---|---|
relaxations[] | تمام محدودیتهای بازدید که برای بازدید از مسیرهایی با وسایل نقلیه در |
vehicle_indices[] | شاخصهای وسیله نقلیه را مشخص میکند که اگر |
آرامش
اگر relaxations
خالی باشد، زمان شروع و ترتیب همه بازدیدها در routes
کاملاً محدود است و هیچ بازدید جدیدی نمی تواند در آن مسیرها درج یا اضافه شود. همچنین، زمان شروع و پایان یک وسیله نقلیه در routes
کاملاً محدود است، مگر اینکه وسیله نقلیه خالی باشد (یعنی هیچ بازدیدی نداشته باشد و در مدل used_if_route_is_empty
روی false تنظیم شده باشد).
relaxations(i).level
سطح آرامش محدودیت اعمال شده برای بازدید #j را مشخص می کند که:
-
route.visits(j).start_time >= relaxations(i).threshold_time
AND -
j + 1 >= relaxations(i).threshold_visit_count
به طور مشابه، استارت وسیله نقلیه تا relaxations(i).level
آرام می شود، اگر برآورده شود:
-
vehicle_start_time >= relaxations(i).threshold_time
AND -
relaxations(i).threshold_visit_count == 0
و انتهای وسیله نقلیه بهrelaxations(i).level
رها می شود اگر برآورده شود: -
vehicle_end_time >= relaxations(i).threshold_time
AND -
route.visits_size() + 1 >= relaxations(i).threshold_visit_count
برای اعمال سطح آرامش، اگر بازدیدی با threshold_visit_count
یا threshold_time
مطابقت داشته باشد، دو relaxations
با همان level
اضافه کنید: یکی با مجموعه فقط threshold_visit_count
و دیگری با تنها threshold_time
تنظیم شده است. اگر یک بازدید شرایط relaxations
متعدد را برآورده کند، آرام ترین سطح اعمال می شود. در نتیجه، از شروع وسیله نقلیه تا بازدیدهای مسیر تا پایان وسیله نقلیه، سطح آرامش بیشتر می شود: یعنی با پیشرفت مسیر، سطح آرامش کاهش نمی یابد.
زمان و توالی بازدیدهای مسیری که شرایط آستانه هر relaxations
را برآورده نمی کند کاملاً محدود است و هیچ بازدیدی ممکن است در این توالی درج نشود. همچنین، اگر شروع یا پایان وسیله نقلیه شرایط آرامش را برآورده نکند، زمان ثابت است، مگر اینکه وسیله نقلیه خالی باشد.
فیلدها | |
---|---|
level | سطح آرامش محدودیت که زمانی اعمال می شود که شرایط در |
threshold_time | زمانی که |
threshold_visit_count | تعداد بازدیدهایی که ممکن است اگر |
سطح
سطوح مختلف آرامش محدودیت را بیان میکند که برای یک بازدید اعمال میشود و آنهایی که پس از آن زمانی که شرایط آستانه را برآورده میکنند، اعمال میشوند.
شمارش زیر به ترتیب افزایش آرامش است.
Enums | |
---|---|
LEVEL_UNSPECIFIED | سطح آرامش پیشفرض ضمنی: هیچ محدودیتی کاهش نمییابد، یعنی همه بازدیدها کاملاً محدود میشوند. این مقدار نباید به صراحت در |
RELAX_VISIT_TIMES_AFTER_THRESHOLD | زمان شروع بازدید و زمان شروع/پایان وسیله نقلیه آرام خواهد بود، اما هر بازدید به همان وسیله نقلیه محدود میشود و توالی بازدید باید رعایت شود: هیچ بازدیدی بین آنها یا قبل از آنها نمیتواند وارد شود. |
RELAX_VISIT_TIMES_AND_SEQUENCE_AFTER_THRESHOLD | مانند RELAX_VISIT_TIMES_AFTER_THRESHOLD ، اما توالی بازدید نیز آرام است: بازدیدها فقط توسط این وسیله نقلیه قابل انجام است، اما به طور بالقوه ممکن است انجام نشوند. |
RELAX_ALL_AFTER_THRESHOLD | مانند RELAX_VISIT_TIMES_AND_SEQUENCE_AFTER_THRESHOLD ، اما وسیله نقلیه نیز آرام است: بازدیدها در زمان آستانه یا بعد از آن کاملا رایگان هستند و ممکن است به طور بالقوه انجام نشوند. |
InputConfig
یک ورودی برای [BatchOptimizeTours][google.maps.routeoptimization.v1.RouteOptimizationService.BatchOptimizeTours] مشخص کنید.
فیلدها | |
---|---|
data_format | مورد نیاز. فرمت داده های ورودی |
source میدان اتحادیه مورد نیاز. source می تواند تنها یکی از موارد زیر باشد: | |
gcs_source | یک مکان Google Cloud Storage. این باید یک شی (فایل) واحد باشد. |
مکان
یک مکان (نقطه جغرافیایی و عنوان اختیاری) را در بر می گیرد.
فیلدها | |
---|---|
lat_lng | مختصات جغرافیایی نقطه راه. |
heading | عنوان قطب نما با جهت جریان ترافیک مرتبط است. این مقدار برای تعیین سمت جاده مورد استفاده برای حمل و نقل استفاده می شود. مقادیر سرفصل می تواند از 0 تا 360 باشد، جایی که 0 یک عنوان شمال را مشخص می کند، 90 عنوان یک عنوان شرق و غیره را مشخص می کند. |
OptimizeToursRequest
درخواست به یک حل کننده بهینه سازی تور داده شود که مدل حمل و نقل را برای حل و همچنین پارامترهای بهینه سازی تعریف می کند.
فیلدها | |
---|---|
parent | مورد نیاز. پروژه یا مکان را برای برقراری تماس هدف قرار دهید. قالب: * اگر مکانی مشخص نشده باشد، یک منطقه به طور خودکار انتخاب می شود. |
timeout | اگر این مهلت تنظیم شود، سرور قبل از سپری شدن مدت زمان یا رسیدن به مهلت سرور برای درخواستهای همزمان، هرکدام زودتر، پاسخی را برمیگرداند. برای درخواست های ناهمزمان، سرور یک راه حل (در صورت امکان) را قبل از سپری شدن مهلت ایجاد می کند. |
model | مدل حمل و نقل برای حل. |
solving_mode | به طور پیش فرض، حالت حل |
search_mode | حالت جستجو برای حل درخواست استفاده می شود. |
injected_first_solution_routes[] | الگوریتم بهینه سازی را در یافتن راه حل اول که مشابه راه حل قبلی است، راهنمایی کنید. وقتی اولین راه حل ساخته می شود، مدل محدود می شود. هر محموله ای که در یک مسیر انجام نشده باشد به طور ضمنی در راه حل اول نادیده گرفته می شود، اما ممکن است در راه حل های متوالی انجام شود. راه حل باید برخی از مفروضات اعتبار پایه را برآورده کند:
اگر راه حل تزریق شده امکان پذیر نباشد، یک خطای اعتبار سنجی لزوما برگردانده نمی شود و ممکن است به جای آن خطای نشان دهنده غیرممکن بودن برگردانده شود. |
injected_solution_constraint | الگوریتم بهینه سازی را برای یافتن راه حل نهایی که مشابه راه حل قبلی است محدود کنید. به عنوان مثال، این ممکن است برای مسدود کردن بخشهایی از مسیرهایی که قبلاً تکمیل شدهاند یا باید تکمیل شوند اما نباید اصلاح شوند استفاده شود. اگر راه حل تزریق شده امکان پذیر نباشد، یک خطای اعتبار سنجی لزوما برگردانده نمی شود و ممکن است به جای آن خطای نشان دهنده غیرممکن بودن برگردانده شود. |
refresh_details_routes[] | در صورت خالی نبودن، مسیرهای داده شده بدون تغییر توالی بازدیدها یا زمان سفر، به روز می شوند: فقط سایر جزئیات به روز می شوند. این مدل را حل نمی کند. از سال 2020/11، این فقط چند خطوط مسیرهای غیر خالی را پر می کند و مستلزم آن است که فیلدهای این فیلد نباید همراه با |
interpret_injected_solutions_using_labels | اگر درست باشد:
این تفسیر برای فیلدهای اگر درست باشد، برچسبهای دستههای زیر باید حداکثر یک بار در دسته خود ظاهر شوند:
اگر یک حذف بازدیدهای مسیر یا کل مسیرها از یک راه حل تزریقی ممکن است بر محدودیت های ضمنی تأثیر بگذارد، که ممکن است منجر به تغییر در راه حل، خطاهای اعتبارسنجی یا غیرممکن شود. توجه: تماس گیرنده باید اطمینان حاصل کند که هر |
consider_road_traffic | در محاسبه فیلدهای |
populate_polylines | اگر درست باشد، چند خطوط در پاسخ |
populate_transition_polylines | اگر درست باشد، چند خطوط در پاسخ |
allow_large_deadline_despite_interruption_risk | اگر این تنظیم شده باشد، درخواست می تواند حداکثر 60 دقیقه مهلت داشته باشد (به https://grpc.io/blog/deadlines مراجعه کنید). در غیر این صورت حداکثر مهلت فقط 30 دقیقه است. توجه داشته باشید که درخواست های طولانی مدت خطر وقفه به طور قابل توجهی بزرگتر (اما هنوز کوچک) دارند. |
use_geodesic_distances | اگر درست باشد، مسافتهای سفر با استفاده از فواصل ژئودزیکی به جای مسافتهای Google Maps و زمان سفر با استفاده از فواصل ژئودزیکی با سرعتی که توسط |
label | برچسبی که ممکن است برای شناسایی این درخواست استفاده شود، در |
geodesic_meters_per_second | وقتی |
max_validation_errors | تعداد خطاهای اعتبارسنجی برگشتی را کوتاه می کند. این خطاها معمولاً به یک بار خطای INVALID_ARGUMENT به عنوان جزئیات خطای BadRequest ( https://cloud.google.com/apis/design/errors#error_details) متصل می شوند، مگر اینکه solving_mode=VALIDATE_ONLY: به قسمت |
حالت جستجو
حالتی که رفتار جستجو را تعریف میکند، تاخیر در مقایسه با کیفیت راهحل را کاهش میدهد. در همه حالت ها، مهلت درخواست جهانی اجرا می شود.
Enums | |
---|---|
SEARCH_MODE_UNSPECIFIED | حالت جستجوی نامشخص، معادل RETURN_FAST . |
RETURN_FAST | پس از یافتن اولین راه حل خوب، جستجو را متوقف کنید. |
CONSUME_ALL_AVAILABLE_TIME | تمام زمان موجود را صرف جستجوی راه حل های بهتر کنید. |
حالت حل
نحوه رسیدگی به درخواست را مشخص می کند. در همه حالتها به جز VALIDATE_ONLY
، اگر درخواست نامعتبر باشد، یک خطای INVALID_REQUEST
دریافت خواهید کرد. به max_validation_errors
مراجعه کنید تا تعداد خطاهای برگشتی را محدود کنید.
Enums | |
---|---|
DEFAULT_SOLVE | مدل را حل کنید. هشدارها ممکن است در [OptimizeToursResponse.validation_errors][google.cloud.optimization.v1.OptimizeToursResponse.validation_errors] صادر شود. |
VALIDATE_ONLY | فقط مدل را بدون حل آن تأیید می کند: تا آنجا که ممکن است OptimizeToursResponse.validation_errors را پر می کند. |
DETECT_SOME_INFEASIBLE_SHIPMENTS | فقط مهم : همه محمولههای غیرممکن به اینجا بازگردانده نمیشوند، بلکه فقط آنهایی که در طول پیش پردازش غیرممکن تشخیص داده میشوند. |
OptimizeToursResponse
پاسخ پس از حل یک مشکل بهینه سازی تور شامل مسیرهایی که هر وسیله نقلیه دنبال می کند، محموله هایی که نادیده گرفته شده اند و هزینه کلی راه حل.
فیلدها | |
---|---|
routes[] | مسیرهای محاسبه شده برای هر وسیله نقلیه؛ مسیر i-ام مربوط به i-امین وسیله نقلیه در مدل است. |
request_label | کپی |
skipped_shipments[] | لیست تمام محمولههای نادیده گرفته شده |
validation_errors[] | فهرستی از تمام خطاهای اعتبارسنجی که توانستیم به طور مستقل شناسایی کنیم. توضیحات "MULTIPLE ERRORS" را برای پیام |
metrics | مدت زمان، مسافت و معیارهای استفاده برای این راه حل. |
معیارها
معیارهای کلی، در همه مسیرها جمع آوری شده است.
فیلدها | |
---|---|
aggregated_route_metrics | در مسیرها جمع شده است. هر متریک مجموع (یا حداکثر، برای بارها) در تمام فیلدهای |
skipped_mandatory_shipment_count | تعداد محموله های اجباری حذف شده |
used_vehicle_count | تعداد وسایل نقلیه استفاده شده توجه: اگر مسیر وسیله نقلیه خالی باشد و |
earliest_vehicle_start_time | اولین زمان شروع برای یک وسیله نقلیه دست دوم، که به عنوان حداقل برای همه وسایل نقلیه استفاده شده در |
latest_vehicle_end_time | آخرین زمان پایان برای یک وسیله نقلیه دست دوم، که به عنوان حداکثر برای همه وسایل نقلیه استفاده شده از |
costs | هزینه راه حل، تفکیک شده بر اساس فیلدهای درخواست مربوط به هزینه. کلیدها مسیرهای اولیه هستند، نسبت به ورودی OptimizeToursRequest، به عنوان مثال "model.shipments.pickups.cost"، و مقادیر کل هزینه تولید شده توسط فیلد هزینه مربوطه هستند که در کل راه حل جمع می شوند. به عبارت دیگر، هزینهها ["model.shipments.picups.cost"] مجموع تمام هزینههای دریافت بیش از راهحل است. تمام هزینههای تعریفشده در مدل در اینجا بهجز هزینههای مربوط به TransitionAttributes که فقط به صورت تجمیع شده از سال 2022/01 گزارش شدهاند، در اینجا گزارش میشوند. |
total_cost | هزینه کل راه حل مجموع تمام مقادیر در نقشه هزینه ها. |
OptimizeToursValidationError
خطا یا اخطاری را که هنگام تأیید اعتبار OptimizeToursRequest
با آن مواجه می شود، توصیف می کند.
فیلدها | |
---|---|
code | یک خطای اعتبارسنجی توسط جفت ( سایر فیلدها (در زیر) زمینه بیشتری را در مورد خطا ارائه می دهند. خطاهای چندگانه : هنگامی که چندین خطا وجود دارد، فرآیند اعتبارسنجی سعی می کند چندین مورد از آنها را خروجی دهد. بسیار شبیه یک کامپایلر، این یک فرآیند ناقص است. برخی از خطاهای اعتبارسنجی "کشنده" خواهند بود، به این معنی که کل فرآیند اعتبار سنجی را متوقف می کنند. این مورد برای خطاهای STABILITY : مرجع : لیستی از همه جفت ها (کد، نام):
|
display_name | نام خطای نمایش |
fields[] | زمینه خطا ممکن است شامل 0 ، 1 (بیشتر اوقات) یا قسمت های بیشتر باشد. به عنوان مثال ، مراجعه به وسیله نقلیه شماره 4 و اولین وانت حمل و نقل شماره 2 می تواند به شرح زیر باشد:
با این حال ، توجه داشته باشید که کاردینال بودن |
error_message | رشته قابل خواندن انسانی که خطا را توصیف می کند. یک نگاشت 1:1 بین پایداری : پایدار نیست: پیام خطا مرتبط با یک |
offending_values | ممکن است حاوی مقدار (های) میدان (ها) باشد. این همیشه در دسترس نیست. شما نباید کاملاً به آن اعتماد کنید و فقط برای اشکال زدایی مدل دستی استفاده کنید. |
مرجع فیلد
زمینه ای را برای خطای اعتبارسنجی مشخص می کند. یک FieldReference
همیشه به یک قسمت معین در این پرونده اشاره دارد و از همان ساختار سلسله مراتبی پیروی می کند. به عنوان مثال ، ما ممکن است عنصر شماره 2 start_time_windows
وسیله نقلیه شماره 5 را با استفاده از:
name: "vehicles" index: 5 sub_field { name: "end_time_windows" index: 2 }
با این حال ، ما از نهادهای سطح بالا مانند OptimizeToursRequest
یا ShipmentModel
برای جلوگیری از شلوغی پیام خودداری می کنیم.
فیلدها | |
---|---|
name | نام میدان ، به عنوان مثال ، "وسایل نقلیه". |
sub_field | در صورت لزوم ، به صورت بازگشتی به صورت بازگشتی ، در صورت نیاز. |
Union Field | |
index | در صورت تکرار ، فهرست قسمت. |
key | اگر این زمینه یک نقشه است ، کلید را کلید کنید. |
outputconfig
مقصدی را برای [batchoptimizetours] [google.maps.routeoptimization.v1.routeoptimizationservice.batchoptimizetours] مشخص کنید.
فیلدها | |
---|---|
data_format | مورد نیاز. فرمت داده های خروجی |
destination میدان اتحادیه. مورد نیاز. destination فقط می تواند یکی از موارد زیر باشد: | |
gcs_destination | مکان ذخیره سازی Google Cloud برای نوشتن خروجی. |
رویه سازان
مجموعه ای از شرایط اختیاری را برای برآورده کردن هنگام محاسبه مسیرهای وسیله نقلیه محاصره می کند. این شبیه به RouteModifiers
در Google Maps Platform Platform API است. مشاهده کنید: https://developers.google.com/maps/documentation/routes/reference/rest/v2/routemodifiers .
فیلدها | |
---|---|
avoid_tolls | مشخص می کند که آیا باید از جاده های عوارض معقول خودداری کنید. اولویت به مسیرهایی که حاوی جاده های عوارض نیستند ، داده می شود. فقط در مورد حالت های مسافرتی موتوری اعمال می شود. |
avoid_highways | مشخص می کند که آیا باید از بزرگراه هایی که منطقی است جلوگیری کنید. اولویت به مسیرهایی که حاوی بزرگراه ها نیستند ، داده می شود. فقط در مورد حالت های مسافرتی موتوری اعمال می شود. |
avoid_ferries | مشخص می کند که آیا باید از کشتی های معقول جلوگیری کند. اولویت به مسیرهایی که شامل مسافرت با کشتی ها نباشد ، داده می شود. فقط در مورد حالت های مسافرتی موتوری اعمال می شود. |
avoid_indoor | اختیاری. مشخص می کند که آیا باید از پیمایش در داخل خانه در جایی که منطقی باشد ، جلوگیری کند. اولویت به مسیرهایی که حاوی ناوبری داخلی نیستند داده می شود. فقط مربوط به حالت سفر |
حمل و نقل
حمل یک مورد واحد ، از یکی از وانت های آن به یکی از تحویل های آن. برای اینکه حمل و نقل همانطور که انجام شده است در نظر گرفته شود ، یک وسیله نقلیه منحصر به فرد باید از یکی از مکان های وانت خود بازدید کند (و ظرفیت های یدکی آن را بر این اساس کاهش می دهد) ، سپس بعداً به یکی از مکان های تحویل آن مراجعه کنید (و بنابراین بر این اساس ظرفیت های یدکی خود را دوباره کاهش دهید).
فیلدها | |
---|---|
display_name | نام نمایشگر تعریف شده توسط کاربر. این می تواند تا 63 کاراکتر طول داشته باشد و ممکن است از شخصیت های UTF-8 استفاده کند. |
pickups[] | مجموعه ای از گزینه های وانت مرتبط با حمل و نقل. اگر مشخص نشده باشد ، وسیله نقلیه فقط نیاز به بازدید از مکانی دارد که مربوط به تحویل ها باشد. |
deliveries[] | مجموعه ای از گزینه های تحویل مرتبط با حمل و نقل. اگر مشخص نشده باشد ، وسیله نقلیه فقط باید از مکانی متناسب با وانت بازدید کند. |
load_demands | تقاضای بار حمل و نقل (به عنوان مثال وزن ، حجم ، تعداد پالت و غیره). کلیدهای موجود در نقشه باید شناسه هایی باشند که نوع بار مربوطه را توصیف می کنند ، از نظر ایده آل شامل واحدها نیز می شوند. به عنوان مثال: "Peight_kg" ، "Volume_gallons" ، "PALLET_COUNT" و غیره. اگر یک کلید داده شده در نقشه ظاهر نشود ، بار مربوطه به عنوان تهی در نظر گرفته می شود. |
allowed_vehicle_indices[] | مجموعه وسایل نقلیه که ممکن است این محموله را انجام دهند. اگر خالی باشد ، ممکن است همه وسایل نقلیه آن را انجام دهند. وسایل نقلیه توسط شاخص آنها در لیست |
costs_per_vehicle[] | هزینه ای را که در هنگام تحویل این حمل و نقل توسط هر وسیله نقلیه متحمل می شود ، مشخص می کند. در صورت مشخص شدن ، باید داشته باشد:
این هزینه ها باید با |
costs_per_vehicle_indices[] | شاخص های وسایل نقلیه ای که |
pickup_to_delivery_absolute_detour_limit | حداکثر زمان انحراف مطلق را در مقایسه با کوتاهترین مسیر از وانت تا تحویل مشخص می کند. در صورت مشخص شدن ، باید غیر منفی باشد و حمل و نقل باید حداقل وانت و تحویل داشته باشد. به عنوان مثال ، اجازه دهید T کوتاهترین زمان لازم برای رفتن از جایگزین وانت انتخاب شده به طور مستقیم به گزینه تحویل انتخاب شده باشد. سپس تنظیم
اگر هر دو محدودیت نسبی و مطلق در همان محموله مشخص شوند ، برای هر جفت وانت/تحویل ممکن از محدودیت بیشتر استفاده می شود. از سال 2017/10 ، دوری ها فقط زمانی پشتیبانی می شوند که مدت زمان سفر به وسایل نقلیه وابسته نباشد. |
pickup_to_delivery_time_limit | حداکثر مدت زمان را از شروع وانت تا شروع تحویل محموله مشخص می کند. در صورت مشخص شدن ، باید غیر منفی باشد و حمل و نقل باید حداقل وانت و تحویل داشته باشد. این بستگی به این ندارد که کدام گزینه برای تحویل و تحویل انتخاب شده است و نه به سرعت خودرو. این را می توان در کنار حداکثر محدودیت های انحرافی مشخص کرد: راه حل هر دو مشخصات را رعایت می کند. |
shipment_type | رشته غیر خالی که "نوع" برای این محموله را مشخص می کند. این ویژگی را می توان برای تعریف ناسازگاری یا الزامات بین متفاوت از |
label | یک برچسب برای این محموله مشخص می کند. این برچسب در پاسخ در |
ignore | اگر درست است ، از این محموله پرش کنید ، اما یک نادیده گرفتن یک حمل و نقل منجر به خطای اعتبارسنجی در صورت وجود هرگونه نادیده گرفتن محمولهای که در |
penalty_cost | اگر حمل و نقل به پایان نرسد ، این مجازات به هزینه کلی مسیرها اضافه می شود. در صورت بازدید از یکی از گزینه های وانت و تحویل آن ، یک محموله تکمیل می شود. هزینه ممکن است در همان واحد مورد استفاده برای سایر زمینه های مربوط به هزینه در مدل بیان شود و باید مثبت باشد. نکته مهم : اگر این مجازات مشخص نشده باشد ، بی نهایت تلقی می شود ، یعنی حمل و نقل باید تکمیل شود. |
pickup_to_delivery_relative_detour_limit | حداکثر زمان دفع نسبی را در مقایسه با کوتاهترین مسیر از وانت تا تحویل مشخص می کند. در صورت مشخص شدن ، باید غیر منفی باشد و حمل و نقل باید حداقل وانت و تحویل داشته باشد. به عنوان مثال ، اجازه دهید T کوتاهترین زمان لازم برای رفتن از جایگزین وانت انتخاب شده به طور مستقیم به گزینه تحویل انتخاب شده باشد. سپس تنظیم
اگر هر دو محدودیت نسبی و مطلق در همان محموله مشخص شوند ، برای هر جفت وانت/تحویل ممکن از محدودیت بیشتر استفاده می شود. از سال 2017/10 ، دوری ها فقط زمانی پشتیبانی می شوند که مدت زمان سفر به وسایل نقلیه وابسته نباشد. |
بارگذاری کنید
در هنگام انجام بازدید ، در صورت وانت ممکن است مبلغ از پیش تعریف شده به بار وسیله نقلیه اضافه شود یا در صورت تحویل کم شود. این پیام چنین مبلغی را تعریف می کند. به load_demands
مراجعه کنید.
فیلدها | |
---|---|
amount | مبلغی که بار وسیله نقلیه انجام بازدید مربوطه با آن متفاوت خواهد بود. از آنجا که این یک عدد صحیح است ، به کاربران توصیه می شود یک واحد مناسب را برای جلوگیری از از دست دادن دقت انتخاب کنند. باید ≥ 0 باشد. |
بازدید از
درخواست بازدیدی که توسط یک وسیله نقلیه انجام می شود: دارای موقعیت جغرافیایی است (یا دو ، در زیر مشاهده کنید) ، زمان باز و بسته شدن توسط ویندوزهای زمان و مدت زمان خدمات (زمان صرف شده توسط وسیله نقلیه پس از رسیدن برای وانت یا رها کردن کالاها).
فیلدها | |
---|---|
arrival_location | مکان جغرافیایی که در آن وسیله نقلیه هنگام انجام این |
arrival_waypoint | نقطه راه که در آن وسیله نقلیه هنگام انجام این |
departure_location | مکان جغرافیایی که در آن وسیله نقلیه پس از اتمام این |
departure_waypoint | ایستگاه راه که در آن وسیله نقلیه پس از اتمام این |
tags[] | برچسب های پیوست شده به درخواست بازدید را مشخص می کند. رشته های خالی یا کپی مجاز نیستند. |
time_windows[] | ویندوزهای زمانی که زمان ورود را در یک بازدید محدود می کند. توجه داشته باشید که یک وسیله نقلیه ممکن است خارج از پنجره زمان ورود حرکت کند ، یعنی زمان ورود + مدت زمان لازم نیست در یک پنجره زمانی باشد. اگر وسیله نقلیه قبل از عدم وجود ویندوزهای زمانی باید از هم جدا شوند ، یعنی هیچ پنجره زمانی نباید با دیگری همپوشانی داشته باشد یا در مجاورت دیگری باشد و باید در حال افزایش باشد. |
duration | مدت زمان بازدید ، یعنی زمان صرف شده توسط وسیله نقلیه بین ورود و عزیمت (برای اضافه شدن به زمان انتظار احتمالی ؛ به |
cost | هزینه سرویس این درخواست بازدید در مسیر وسیله نقلیه. این می تواند برای پرداخت هزینه های مختلف برای هر وانت جایگزین یا تحویل حمل و نقل استفاده شود. این هزینه باید در همان واحد |
load_demands | بارگیری تقاضاهای این درخواست بازدید. این دقیقاً مانند زمینه |
visit_types[] | انواع بازدید را مشخص می کند. این ممکن است برای تخصیص زمان اضافی مورد نیاز وسیله نقلیه برای تکمیل این بازدید استفاده شود (به یک نوع فقط یک بار ظاهر می شود. |
label | یک برچسب برای این |
مدل حمل و نقل
یک مدل حمل و نقل شامل مجموعه ای از محموله ها است که باید توسط مجموعه ای از وسایل نقلیه انجام شود ، در حالی که هزینه کلی را به حداقل می رساند ، که این جمع است:
- هزینه مسیریابی وسایل نقلیه (مبلغ هزینه در کل زمان ، هزینه در هر زمان سفر و هزینه ثابت در تمام وسایل نقلیه).
- مجازات های حمل و نقل بدون عملکرد.
- هزینه مدت جهانی محموله ها
فیلدها | |
---|---|
shipments[] | مجموعه محموله هایی که باید در مدل انجام شود. |
vehicles[] | مجموعه ای از وسایل نقلیه که می توانند برای انجام بازدیدها استفاده شوند. |
global_start_time | زمان شروع و پایان جهانی مدل: هیچ بار خارج از این محدوده نمی تواند معتبر تلقی شود. مدت زمان مدل باید کمتر از یک سال باشد ، یعنی هنگام استفاده از زمینه های |
global_end_time | اگر UNET ، 00:00:00 UTC ، 1 ژانویه 1971 (یعنی ثانیه: 31536000 ، نانو: 0) به عنوان پیش فرض استفاده می شود. |
global_duration_cost_per_hour | "مدت زمان جهانی" برنامه کلی ، تفاوت بین اولین زمان شروع موثر و آخرین زمان پایان مؤثر همه وسایل نقلیه است. به عنوان مثال کاربران می توانند در هر ساعت هزینه ای را به آن مقدار اختصاص دهند تا به عنوان مثال برای اتمام کار زودرس و بهینه سازی کنند. این هزینه باید در همان واحد |
duration_distance_matrices[] | مدت زمان و ماتریس فاصله مورد استفاده در مدل را مشخص می کند. اگر این قسمت خالی باشد ، بسته به مقدار قسمت نمونه های استفاده:
|
duration_distance_matrix_src_tags[] | برچسب های تعریف منابع ماتریس مدت زمان و فاصله. برچسب ها با |
duration_distance_matrix_dst_tags[] | برچسب های تعیین کننده مقصد ماتریس مدت زمان و فاصله. برچسب ها با |
transition_attributes[] | ویژگی های انتقال به مدل اضافه شده است. |
shipment_type_incompatibilities[] | مجموعه ای از حمل و نقل ناسازگار_تایپ (به حمل و |
shipment_type_requirements[] | مجموعه ای از الزامات |
precedence_rules[] | مجموعه ای از قوانین تقدم که باید در مدل اجرا شود. |
max_active_vehicles | حداکثر تعداد وسایل نقلیه فعال را محدود می کند. اگر مسیر آن حداقل یک محموله انجام شود ، وسیله نقلیه فعال است. این می تواند برای محدود کردن تعداد مسیرها در مواردی که رانندگان کمتری نسبت به وسایل نقلیه وجود دارد استفاده شود و ناوگان وسایل نقلیه ناهمگن باشد. بهینه سازی سپس بهترین زیر مجموعه وسایل نقلیه را برای استفاده انتخاب می کند. باید کاملاً مثبت باشد. |
مدت زمان بندی
ماتریس مدت زمان و مسافت را از مکان های بازدید و شروع وسایل نقلیه برای بازدید و مکان های انتهای وسیله نقلیه مشخص می کند.
فیلدها | |
---|---|
rows[] | ردیف های ماتریس مدت زمان و فاصله را مشخص می کند. این باید به عنوان عناصر زیادی به عنوان |
vehicle_start_tag | تگ تعریف می کند که در این ماتریس مدت زمان و مسافت از وسایل نقلیه استفاده می شود. اگر خالی باشد ، این در مورد همه وسایل نقلیه صدق می کند ، و فقط یک ماتریس واحد وجود دارد. هر شروع وسیله نقلیه باید دقیقاً با یک ماتریس مطابقت داشته باشد ، یعنی دقیقاً یکی از قسمت همه ماتریس ها باید یک |
ردیف
یک ردیف از ماتریس مدت زمان و فاصله را مشخص می کند.
فیلدها | |
---|---|
durations[] | مقادیر مدت زمان برای یک ردیف معین. این باید به عنوان عناصر زیادی به عنوان |
meters[] | مقادیر فاصله برای یک ردیف معین. اگر هیچ هزینه یا محدودیتی به مسافت های مدل اشاره داشته باشد ، این می تواند خالی بماند. در غیر این صورت باید به اندازه |
پیشگام
یک قانون تقدم بین دو رویداد (هر رویداد وانت یا تحویل حمل و نقل است): رویداد "دوم" باید offset_duration
پس از شروع "اول" حداقل شروع به کار کند.
چندین سابقه می تواند به همان وقایع (یا مرتبط) مربوط باشد ، به عنوان مثال ، "وانت B پس از تحویل" و "وانت C اتفاق می افتد که پس از وانت B" اتفاق می افتد.
علاوه بر این ، مقدمات فقط در صورت انجام هر دو محموله اعمال می شود و در غیر این صورت نادیده گرفته می شوند.
فیلدها | |
---|---|
first_is_delivery | نشان می دهد که آیا رویداد "اول" تحویل است. |
second_is_delivery | نشان می دهد که آیا رویداد "دوم" تحویل است. |
offset_duration | جبران بین رویداد "اول" و "دوم". می تواند منفی باشد. |
first_index | شاخص حمل و نقل رویداد "اولین". این قسمت باید مشخص شود. |
second_index | شاخص حمل و نقل رویداد "دوم". این قسمت باید مشخص شود. |
حمل و نقل
مسیر وسیله نقلیه را می توان تجزیه کرد ، در طول محور زمان ، مانند این (فرض می کنیم تعداد بازدیدی وجود دارد):
| | | | | T[2], | | |
| Transition | Visit #0 | | | V[2], | | |
| #0 | aka | T[1] | V[1] | ... | V[n-1] | T[n] |
| aka T[0] | V[0] | | | V[n-2],| | |
| | | | | T[n-1] | | |
^ ^ ^ ^ ^ ^ ^ ^
vehicle V[0].start V[0].end V[1]. V[1]. V[n]. V[n]. vehicle
start (arrival) (departure) start end start end end
توجه داشته باشید که ما بین:
- "وقایع دقیق" ، مانند شروع و پایان خودرو و شروع و پایان هر بازدید (ورود و عزیمت با نام مستعار). آنها در یک ثانیه معین اتفاق می افتد.
- "فواصل زمانی" ، مانند خود بازدیدها و انتقال بین بازدیدها. اگرچه فواصل زمانی ممکن است گاهی اوقات صفر داشته باشد ، یعنی شروع و پایان در همان ثانیه ، آنها اغلب مدت مثبت دارند.
متغیرها:
- اگر تعداد بازدیدی وجود داشته باشد ، انتقال N+1 وجود دارد.
- یک بازدید همیشه با یک انتقال قبل از آن (همان شاخص) و انتقال پس از آن (شاخص + 1) احاطه شده است.
- شروع وسیله نقلیه همیشه با انتقال شماره 0 دنبال می شود.
- انتهای وسیله نقلیه همیشه با انتقال #N انجام می شود.
با زوم کردن، در اینجا چیزی است که در طول یک Transition
و یک Visit
اتفاق می افتد:
---+-------------------------------------+-----------------------------+-->
| TRANSITION[i] | VISIT[i] |
| | |
| * TRAVEL: the vehicle moves from | PERFORM the visit: |
| VISIT[i-1].departure_location to | |
| VISIT[i].arrival_location, which | * Spend some time: |
| takes a given travel duration | the "visit duration". |
| and distance | |
| | * Load or unload |
| * BREAKS: the driver may have | some quantities from the |
| breaks (e.g. lunch break). | vehicle: the "demand". |
| | |
| * WAIT: the driver/vehicle does | |
| nothing. This can happen for | |
| many reasons, for example when | |
| the vehicle reaches the next | |
| event's destination before the | |
| start of its time window | |
| | |
| * DELAY: *right before* the next | |
| arrival. E.g. the vehicle and/or | |
| driver spends time unloading. | |
| | |
---+-------------------------------------+-----------------------------+-->
^ ^ ^
V[i-1].end V[i].start V[i].end
سرانجام ، در اینجا نحوه سفر ، استراحت ، تأخیر و انتظار می تواند در طول انتقال ترتیب داده شود.
- همپوشانی ندارند
- تأخیر منحصر به فرد است و باید یک دوره متناوب درست قبل از بازدید بعدی (یا پایان وسیله نقلیه) باشد. بنابراین ، دانستن مدت زمان تأخیر برای دانستن زمان شروع و پایان آن کافی است.
- استراحت ها دوره های متناقض و غیر همپوشانی هستند. پاسخ زمان و مدت زمان شروع هر استراحت را مشخص می کند.
- مسافرت و انتظار "قابل حمل" است: در طی این انتقال می توان چندین بار قطع شد. مشتریان می توانند فرض کنند که سفر "در اسرع وقت" انجام می شود و "انتظار" زمان باقی مانده را پر می کند.
مثال (پیچیده):
TRANSITION[i]
--++-----+-----------------------------------------------------------++-->
|| | | | | | | ||
|| T | B | T | | B | | D ||
|| r | r | r | W | r | W | e ||
|| a | e | a | a | e | a | l ||
|| v | a | v | i | a | i | a ||
|| e | k | e | t | k | t | y ||
|| l | | l | | | | ||
|| | | | | | | ||
--++-----------------------------------------------------------------++-->
فیلدها | |
---|---|
vehicle_index | وسیله نقلیه ای که مسیر را انجام می دهد ، که توسط شاخص آن در Source |
vehicle_label | در صورت مشخص شدن ، برچسب وسیله نقلیه ای که این مسیر را انجام می دهد ، برابر با |
vehicle_start_time | زمانی که وسیله نقلیه مسیر خود را شروع می کند. |
vehicle_end_time | زمانی که وسیله نقلیه مسیر خود را تمام می کند. |
visits[] | دنباله سفارش داده شده از بازدیدهای یک مسیر. بازدیدها [i] بازدید I-Th در مسیر است. اگر این میدان خالی باشد ، وسیله نقلیه به عنوان استفاده نشده در نظر گرفته می شود. |
transitions[] | لیست سفارش داده شده برای مسیر. |
has_traffic_infeasibilities | هنگامی که
ورود به Next_visit احتمالاً دیرتر از پنجره زمانی فعلی خود به دلیل افزایش برآورد زمان سفر |
route_polyline | بازنمایی پلی خطی رمزگذاری شده از مسیر. این قسمت فقط در صورتی جمع می شود که |
breaks[] | استراحت برنامه ریزی شده برای وسیله نقلیه در حال انجام این مسیر. دنباله |
metrics | مدت زمان ، فاصله و معیارهای بار برای این مسیر. زمینه های جمع آوری شده در کلیه |
route_costs | هزینه مسیر ، توسط زمینه های درخواست مربوط به هزینه تقسیم می شود. کلیدها مسیرهای پروتئین هستند ، نسبت به ورودی OptimizetoursRequest ، به عنوان مثال "model.shipments.pickups.cost" ، و مقادیر کل هزینه تولید شده توسط میدان هزینه مربوطه است که در کل مسیر جمع می شوند. به عبارت دیگر ، هزینه ها ["model.shipments.pickups.cost"] مجموع هزینه های وانت در مسیر است. تمام هزینه های تعریف شده در مدل در اینجا به استثنای هزینه های مربوط به انتقال attributes که فقط از سال 2022/01 گزارش می شوند ، به تفصیل گزارش شده است. |
route_total_cost | هزینه کل مسیر. مجموع هزینه های موجود در نقشه هزینه. |
شکستن
داده های نمایانگر اجرای یک استراحت.
فیلدها | |
---|---|
start_time | زمان شروع استراحت. |
duration | مدت زمان استراحت. |
رمز رمز
بازنمایی رمزگذاری شده یک پلی خط. اطلاعات بیشتر در مورد رمزگذاری پلیلین را می توان در اینجا یافت: https://developers.google.com/maps/documentation/utilities/polylinealgorithm https://develops.google.com/maps/documentation/javascript/reference/geometry.encoding .
فیلدها | |
---|---|
points | رشته نمایانگر نقاط رمزگذاری شده پلی خط. |
انتقال
انتقال بین دو رویداد در مسیر. توضیحات ShipmentRoute
را ببینید.
اگر وسیله نقلیه دارای start_location
و/یا end_location
نباشد ، معیارهای سفر مربوطه 0 است.
فیلدها | |
---|---|
travel_duration | مدت زمان سفر در طول این انتقال. |
travel_distance_meters | مسافت طی شده در طول انتقال. |
traffic_info_unavailable | هنگامی که ترافیک از طریق |
delay_duration | مجموع مدت زمان تاخیر اعمال شده برای این انتقال. در صورت وجود ، تأخیر دقیقاً |
break_duration | در صورت وجود ، مجموع مدت زمان وقفه هایی که در طول این انتقال رخ می دهد. جزئیات مربوط به زمان و مدت زمان شروع هر شکست در حمل و نقل در |
wait_duration | زمان صرف انتظار در طول این انتقال. مدت زمان انتظار با زمان بیکار مطابقت دارد و شامل زمان شکستن نیست. همچنین توجه داشته باشید که این زمان انتظار ممکن است به چندین فواصل غیر مبهم تقسیم شود. |
total_duration | مدت زمان انتقال ، برای راحتی فراهم شده است. برابر است با:
|
start_time | زمان شروع این انتقال |
route_polyline | بازنمایی پلی خطی رمزگذاری شده از مسیر که در طول انتقال دنبال می شود. این قسمت فقط در صورتی جمع می شود که |
vehicle_loads | بارهای وسیله نقلیه در طول این انتقال، برای هر نوع که در بارها در اولین انتقال بارهای شروع مسیر وسیله نقلیه است. سپس ، پس از هر بازدید ، بسته به اینکه این بازدید وانت یا تحویل باشد ، اضافه شده یا کمرنگ |
بار خودرو
گزارش بار واقعی وسیله نقلیه در مقطعی در طول مسیر ، برای یک نوع معین (به Transition.vehicle_loads
مراجعه کنید).
فیلدها | |
---|---|
amount | مقدار بار در وسیله نقلیه ، برای نوع داده شده. واحد بار معمولاً توسط نوع نشان داده می شود. به |
بازدید کنید
بازدیدی که در طی یک مسیر انجام شد. این بازدید مربوط به وانت یا تحویل Shipment
است.
فیلدها | |
---|---|
shipment_index | فهرست زمینه |
is_pickup | در صورت صحت این دیدار با وانت |
visit_request_index | فهرست |
start_time | زمانی که بازدید از آن شروع می شود. توجه داشته باشید که وسیله نقلیه ممکن است زودتر از این در محل بازدید وارد شود. بارها با |
load_demands | کل تقاضای بار بازدید به عنوان مجموع محموله و درخواست بازدید |
detour | زمان دفع اضافی به دلیل محموله های بازدید شده در مسیر قبل از بازدید و زمان احتمالی انتظار ناشی از ویندوزهای زمان. اگر این بازدید تحویل باشد ، دفع از وانت مربوطه محاسبه می شود و برابر است با:
در غیر این صورت ، آن را از
|
shipment_label | کپی از |
visit_label | در صورت مشخص شدن در |
ناسازگاری نوع حمل و نقل
بسته به نوع حمل و نقل آنها ، ناسازگاری بین محموله ها را مشخص می کند. ظاهر محموله های ناسازگار در همان مسیر بر اساس حالت ناسازگاری محدود می شود.
فیلدها | |
---|---|
types[] | لیست انواع ناسازگار. دو محموله دارای |
incompatibility_mode | حالت برای ناسازگاری اعمال می شود. |
نامطلوب
حالت هایی که چگونگی محدود شدن ظاهر محموله های ناسازگار در همان مسیر را تعریف می کنند.
Enums | |
---|---|
INCOMPATIBILITY_MODE_UNSPECIFIED | حالت ناسازگاری نامشخص. این مقدار هرگز نباید استفاده شود. |
NOT_PERFORMED_BY_SAME_VEHICLE | در این حالت ، دو محموله با انواع ناسازگار هرگز نمی توانند همان وسیله نقلیه را به اشتراک بگذارند. |
NOT_IN_SAME_VEHICLE_SIMULTANEOUSLY | برای دو محموله با انواع ناسازگار با
|
نیاز نوع ارسال
الزامات بین محموله ها را بر اساس نوع_shipment آنها مشخص می کند. ویژگی های مورد نیاز توسط حالت نیازمندی تعریف می شود.
فیلدها | |
---|---|
required_shipment_type_alternatives[] | لیست انواع حمل و نقل جایگزین مورد نیاز توسط |
dependent_shipment_types[] | همه محمولههای دارای یک نوع در فیلد توجه: زنجیره ای از الزامات به گونه ای که یک |
requirement_mode | حالت اعمال شده به نیاز. |
RequirementMode
حالت هایی که ظاهر محموله های وابسته را در یک مسیر مشخص می کنند.
Enums | |
---|---|
REQUIREMENT_MODE_UNSPECIFIED | حالت نیاز نامشخص این مقدار هرگز نباید استفاده شود. |
PERFORMED_BY_SAME_VEHICLE | در این حالت، همه محمولههای «وابسته» باید حداقل یکی از محمولههای «الزامی» خود، وسیله نقلیه مشابهی داشته باشند. |
IN_SAME_VEHICLE_AT_PICKUP_TIME | با حالت بنابراین یک حمل و نقل "وابسته" باید دارای یکی از موارد زیر باشد:
|
IN_SAME_VEHICLE_AT_DELIVERY_TIME | مانند قبل، به جز محموله های "وابسته" باید یک محموله "الزامی" در وسیله نقلیه خود در زمان تحویل داشته باشند. |
ارسال نادیده گرفته شده
جزئیات محموله های انجام نشده را در یک راه حل مشخص می کند. برای موارد بی اهمیت و/یا اگر بتوانیم علت پرش را شناسایی کنیم، دلیل را در اینجا گزارش می کنیم.
فیلدها | |
---|---|
index | این فهرست با نمایه محموله در مبدا |
label | کپی از |
reasons[] | فهرستی از دلایلی که توضیح می دهد چرا حمل و نقل نادیده گرفته شده است. نظر بالای |
دلیل
اگر بتوانیم دلیل حذف محموله را توضیح دهیم، دلایل در اینجا ذکر می شود. اگر دلیل برای همه وسایل نقلیه یکسان نباشد، reason
بیش از 1 عنصر خواهد داشت. یک محموله نادیده گرفته نمیتواند دلایل تکراری داشته باشد، یعنی جایی که همه فیلدها یکسان هستند به جز example_vehicle_index
. مثال:
reasons {
code: DEMAND_EXCEEDS_VEHICLE_CAPACITY
example_vehicle_index: 1
example_exceeded_capacity_type: "Apples"
}
reasons {
code: DEMAND_EXCEEDS_VEHICLE_CAPACITY
example_vehicle_index: 3
example_exceeded_capacity_type: "Pears"
}
reasons {
code: CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DISTANCE_LIMIT
example_vehicle_index: 1
}
محموله حذف شده با همه وسایل نقلیه ناسازگار است. دلایل ممکن است برای همه وسایل نقلیه متفاوت باشد، اما حداقل یک وسیله نقلیه از ظرفیت "سیب" تجاوز می کند (از جمله وسیله نقلیه 1)، حداقل یک وسیله نقلیه از ظرفیت "گلابی" تجاوز می کند (از جمله وسیله نقلیه 3) و حداقل فاصله یک وسیله نقلیه از حد مجاز عبور می کند. بیش از حد باشد (از جمله وسیله نقلیه 1).
فیلدها | |
---|---|
code | به نظرات کد مراجعه کنید. |
example_exceeded_capacity_type | اگر کد دلیل |
example_vehicle_index | اگر دلیل مربوط به ناسازگاری حمل و نقل و وسیله نقلیه باشد، این قسمت شاخص یک وسیله نقلیه مربوطه را ارائه می دهد. |
کد
کد شناسایی نوع دلیل. دستور اینجا بی معنی است. به ویژه، هیچ نشانه ای از این که آیا یک دلیل معین در راه حل در برابر دیگری ظاهر می شود، در صورت اعمال هر دو، نمی دهد.
Enums | |
---|---|
CODE_UNSPECIFIED | این هرگز نباید استفاده شود. |
NO_VEHICLE | هیچ وسیله نقلیه ای در مدل وجود ندارد که تمام محموله ها را غیرممکن می کند. |
DEMAND_EXCEEDS_VEHICLE_CAPACITY | تقاضای محموله بیشتر از ظرفیت یک وسیله نقلیه برای برخی از انواع ظرفیت است، که یکی از آنها example_exceeded_capacity_type است. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DISTANCE_LIMIT | حداقل فاصله لازم برای انجام این حملونقل، یعنی از توجه داشته باشید که برای این محاسبه از فواصل ژئودزیکی استفاده می کنیم. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DURATION_LIMIT | حداقل زمان لازم برای انجام این حمل و نقل، از جمله زمان سفر، زمان انتظار و زمان سرویس از توجه: زمان سفر در بهترین حالت، یعنی به صورت فاصله ژئودزیکی x 36 متر بر ثانیه (تقریباً 130 کیلومتر در ساعت) محاسبه می شود. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_TRAVEL_DURATION_LIMIT | مانند بالا، اما ما فقط حداقل زمان سفر و travel_duration_limit خودرو را با هم مقایسه می کنیم. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_TIME_WINDOWS | اگر این حملونقل در اولین زمان شروع شود، وسیله نقلیه نمیتواند در بهترین حالت ( CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DURATION_LIMIT برای محاسبات زمان را ببینید) انجام دهد: کل زمان باعث میشود خودرو پس از آخرین زمان پایان آن به پایان برسد. |
VEHICLE_NOT_ALLOWED | قسمت allowed_vehicle_indices محموله خالی نیست و این وسیله نقلیه متعلق به آن نیست. |
پنجره زمانی
پنجره های زمانی زمان یک رویداد را محدود می کند، مانند زمان رسیدن به یک بازدید، یا زمان شروع و پایان یک وسیله نقلیه.
محدودیتهای پنجره زمان سخت، start_time
و end_time
، اولین و آخرین زمان رویداد را اعمال میکنند، به طوری که start_time <= event_time <= end_time
. کران پایین پنجره زمانی نرم، soft_start_time
، ترجیح می دهد که رویداد در زمان soft_start_time
یا بعد از آن اتفاق بیفتد، با متحمل شدن هزینه ای متناسب با مدت زمان قبل از soft_start_time. کران بالای پنجره زمانی نرم، soft_end_time
، ترجیح می دهد که رویداد در زمان soft_end_time
یا قبل از آن اتفاق بیفتد، با متحمل شدن هزینه ای متناسب با مدت زمانی که رویداد soft_end_time
رخ می دهد. start_time
، end_time
، soft_start_time
و soft_end_time
باید در محدوده زمانی جهانی باشند (به ShipmentModel.global_start_time
و ShipmentModel.global_end_time
مراجعه کنید) و باید رعایت کنند:
0 <= `start_time` <= `end_time` and
0 <= `start_time` <= `soft_start_time` and
0 <= `soft_end_time` <= `end_time`.
فیلدها | |
---|---|
start_time | زمان شروع پنجره زمان سخت. اگر مشخص نباشد روی |
end_time | زمان پایان پنجره زمان سخت. اگر مشخص نشده باشد، روی |
soft_start_time | زمان شروع نرم پنجره زمان. |
soft_end_time | زمان پایان نرم پنجره زمانی. |
cost_per_hour_before_soft_start_time | اگر رویداد قبل از soft_start_time رخ دهد، یک هزینه در ساعت به سایر هزینههای مدل اضافه میشود، که به صورت زیر محاسبه میشود:
این هزینه باید مثبت باشد و فقط در صورتی می توان فیلد را تنظیم کرد که soft_start_time تنظیم شده باشد. |
cost_per_hour_after_soft_end_time | اگر رویداد پس از
این هزینه باید مثبت باشد و فقط در صورتی می توان فیلد را تنظیم کرد که |
TransitionAttributes
ویژگی های انتقال بین دو بازدید متوالی در یک مسیر را مشخص می کند. چندین TransitionAttributes
ممکن است برای یک انتقال اعمال شود: در آن صورت، تمام هزینههای اضافی جمع میشوند و سختترین محدودیت یا محدودیت اعمال میشود (به دنبال معنایی طبیعی "AND").
فیلدها | |
---|---|
src_tag | برچسبهایی که مجموعه انتقالهای (src->dst) را تعریف میکنند، این ویژگیها برای آنها اعمال میشوند. بازدید از منبع یا شروع خودرو با |
excluded_src_tag | |
dst_tag | بازدید مقصد یا پایان وسیله نقلیه با |
excluded_dst_tag | |
cost | هزینه ای را برای انجام این انتقال مشخص می کند. این در همان واحد تمام هزینه های دیگر در مدل است و نباید منفی باشد. علاوه بر سایر هزینه های موجود اعمال می شود. |
cost_per_kilometer | هزینه ای را به ازای هر کیلومتر اعمال شده برای مسافت طی شده در حین انجام این انتقال مشخص می کند. به هر |
distance_limit | محدودیتی را برای مسافت طی شده در حین انجام این انتقال مشخص می کند. از سال 2021/06، فقط محدودیت های نرم پشتیبانی می شوند. |
delay | تأخیر ایجاد شده در هنگام انجام این انتقال را مشخص می کند. این تاخیر همیشه پس از اتمام بازدید از مبدا و قبل از شروع بازدید از مقصد اتفاق می افتد. |
وسیله نقلیه
یک وسیله نقلیه را در یک مشکل حمل و نقل مدل می کند. حل یک مشکل حمل و نقل، مسیری را برای این وسیله نقلیه ایجاد می کند که از start_location
شروع می شود و به end_location
ختم می شود. یک مسیر دنباله ای از بازدیدها است (به ShipmentRoute
مراجعه کنید).
فیلدها | |
---|---|
display_name | نام نمایشی تعریف شده توسط کاربر برای وسیله نقلیه. این می تواند تا 63 کاراکتر طول داشته باشد و ممکن است از شخصیت های UTF-8 استفاده کند. |
travel_mode | حالت سفر که بر جاده های قابل استفاده وسیله نقلیه و سرعت آن تأثیر می گذارد. همچنین |
route_modifiers | مجموعه ای از شرایط برای برآوردن که بر نحوه محاسبه مسیرها برای وسیله نقلیه معین تأثیر می گذارد. |
start_location | موقعیت جغرافیایی که وسیله نقلیه قبل از تحویل گرفتن محموله از آنجا شروع می شود. اگر مشخص نشده باشد، وسیله نقلیه در اولین پیکاپ خود استارت می خورد. اگر مدل حمل و نقل دارای ماتریسهای مدت و فاصله باشد، |
start_waypoint | نقطه راه نشان دهنده یک موقعیت جغرافیایی است که وسیله نقلیه قبل از تحویل گرفتن محموله از آنجا شروع می شود. اگر نه |
end_location | موقعیت جغرافیایی جایی که وسیله نقلیه پس از تکمیل آخرین |
end_waypoint | نقطه راه نشان دهنده یک مکان جغرافیایی است که خودرو پس از تکمیل آخرین |
start_tags[] | برچسب های متصل به شروع مسیر وسیله نقلیه را مشخص می کند. رشته های خالی یا کپی مجاز نیستند. |
end_tags[] | برچسب های متصل به انتهای مسیر وسیله نقلیه را مشخص می کند. رشته های خالی یا کپی مجاز نیستند. |
start_time_windows[] | پنجره های زمانی که در طی آن وسیله نقلیه ممکن است محل شروع خود را ترک کند. آنها باید در محدوده زمانی جهانی باشند (به فیلدهای پنجرههای زمانی متعلق به یک فیلد تکراری باید جدا باشند، یعنی هیچ پنجره زمانی نمیتواند با دیگری همپوشانی داشته باشد یا مجاور آن باشد و باید به ترتیب زمانی باشند. |
end_time_windows[] | پنجره های زمانی که در طی آن وسیله نقلیه ممکن است به مکان پایانی خود برسد. آنها باید در محدوده زمانی جهانی باشند (به فیلدهای پنجرههای زمانی متعلق به یک فیلد تکراری باید جدا باشند، یعنی هیچ پنجره زمانی نمیتواند با دیگری همپوشانی داشته باشد یا مجاور آن باشد و باید به ترتیب زمانی باشند. |
unloading_policy | سیاست تخلیه بار در خودرو اعمال شده است. |
load_limits | ظرفیت وسیله نقلیه (وزن ، حجم ، # پالت به عنوان مثال). کلیدهای موجود در نقشه، شناسههای نوع بار هستند که با کلیدهای فیلد |
cost_per_hour | هزینه های خودرو: همه هزینه ها جمع می شوند و باید در همان واحد هزینه هر ساعت مسیر وسیله نقلیه این هزینه برای کل زمان طی شده توسط مسیر اعمال می شود و شامل زمان سفر، زمان انتظار و زمان بازدید می شود. استفاده از |
cost_per_traveled_hour | هزینه هر ساعت پیموده شده مسیر وسیله نقلیه. این هزینه فقط برای زمان سفر طی مسیر اعمال می شود (یعنی آنچه در |
cost_per_kilometer | هزینه هر کیلومتر مسیر وسیله نقلیه این هزینه برای مسافت گزارش شده در |
fixed_cost | اگر از این وسیله نقلیه برای حمل و نقل استفاده شود، هزینه ثابت اعمال می شود. |
used_if_route_is_empty | این فیلد فقط برای وسایل نقلیه زمانی اعمال می شود که مسیر آنها به هیچ محموله ای خدمات ندهد. این نشان می دهد که آیا خودرو باید در این مورد استفاده شده در نظر گرفته شود یا خیر. اگر درست باشد، وسیله نقلیه از شروع به مکان پایانی خود میرود، حتی اگر هیچ محمولهای را ارائه ندهد، و هزینههای زمان و مسافت ناشی از سفر شروع --> پایان آن در نظر گرفته میشود. در غیر این صورت، از ابتدا تا مکان پایانی خود حرکت نمی کند، و هیچ |
route_duration_limit | حد اعمال شده در کل مدت زمان مسیر وسیله نقلیه. در |
travel_duration_limit | محدودیت برای مدت سفر در مسیر وسیله نقلیه اعمال می شود. در |
route_distance_limit | محدودیت در کل مسافت مسیر وسیله نقلیه اعمال می شود. در |
extra_visit_duration_for_visit_type | یک نقشه از رشته های visit_types تا مدت زمان را مشخص می کند. مدت زمانی است که علاوه بر اگر درخواست بازدید چندین نوع داشته باشد، مدت زمان برای هر نوع در نقشه اضافه می شود. |
break_rule | برنامه استراحتی که باید در این وسیله نقلیه اعمال شود را شرح می دهد. در صورت خالی بودن، هیچ استراحتی برای این وسیله نقلیه در نظر گرفته نمی شود. |
label | یک برچسب برای این وسیله نقلیه مشخص می کند. این برچسب در پاسخ بهعنوان |
ignore | اگر درست باشد، اگر یک محموله توسط یک وسیله نقلیه نادیده گرفته شده در اگر یک محموله توسط وسیله نقلیه نادیده گرفته شده در |
travel_duration_multiple | یک عامل ضربی را مشخص می کند که می تواند برای افزایش یا کاهش زمان سفر این وسیله نقلیه استفاده شود. به عنوان مثال ، تنظیم این در 2.0 به این معنی است که این وسیله نقلیه کندتر است و زمان سفر دارد که دو برابر آن برای وسایل نقلیه استاندارد است. این چند برابر بر مدت زمان بازدید تأثیری ندارد. اگر هشدار: زمانهای سفر پس از اعمال این مضرب، اما قبل از انجام هر گونه عملیات عددی، به نزدیکترین ثانیه گرد میشوند، بنابراین، یک مضرب کوچک ممکن است منجر به از دست دادن دقت شود. همچنین |
مدت زمان طولانی
محدودیتی که حداکثر مدت مسیر یک وسیله نقلیه را تعیین می کند. این می تواند سخت یا نرم باشد.
هنگامی که یک فیلد حد نرم تعریف می شود، هم آستانه حداکثر نرم و هم هزینه مربوط به آن باید با هم تعریف شوند.
فیلدها | |
---|---|
max_duration | یک محدودیت سخت که مدت زمان را به حداکثر حداکثر مدت زمان محدود می کند. |
soft_max_duration | یک محدودیت نرم که حداکثر مدت زمان را اعمال نمی کند، اما در صورت نقض باعث می شود مسیر متحمل هزینه شود. این هزینه به سایر هزینه های تعریف شده در مدل، با همان واحد اضافه می شود. در صورت تعریف، |
quadratic_soft_max_duration | یک محدودیت نرم که حداکثر مدت زمان را اعمال نمی کند، اما در صورت نقض باعث می شود مسیر هزینه ای داشته باشد که طول مدت آن درجه دوم است. این هزینه به سایر هزینه های تعریف شده در مدل، با همان واحد اضافه می شود. اگر تعریف شده باشد، |
cost_per_hour_after_soft_max | هزینه هر ساعت در صورت نقض آستانه
هزینه باید غیر منفی باشد. |
cost_per_square_hour_after_quadratic_soft_max | هزینه هر ساعت مربع در صورت نقض آستانه اگر مدت زمان زیر آستانه باشد، هزینه اضافی 0 است، در غیر این صورت هزینه به مدت زمان زیر بستگی دارد:
هزینه باید غیر منفی باشد. |
LoadLimit
محدودیت بار را برای یک وسیله نقلیه تعریف می کند، به عنوان مثال "این کامیون فقط می تواند تا 3500 کیلوگرم را حمل کند". load_limits
ببینید.
فیلدها | |
---|---|
soft_max_load | حد نرم از بار. به |
cost_per_unit_above_soft_max | اگر بار در طول مسیر این وسیله نقلیه از |
start_load_interval | فاصله بار قابل قبول وسیله نقلیه در شروع مسیر. |
end_load_interval | فاصله بار قابل قبول وسیله نقلیه در انتهای مسیر. |
max_load | حداکثر مقدار قابل قبول بار. |
فاصله
فاصله بار قابل قبول.
فیلدها | |
---|---|
min | حداقل بار قابل قبول باید ≥ 0 باشد. اگر هر دو مشخص شده اند، |
max | حداکثر بار قابل قبول باید ≥ 0 باشد. اگر مشخص نشده باشد، حداکثر بار توسط این پیام محدود نمی شود. اگر هر دو مشخص شده باشند، |
حالت سفر
حالت های سفر که می تواند توسط وسایل نقلیه استفاده شود.
اینها باید زیرمجموعه ای از حالت های سفر API ترجیحی مسیرهای پلتفرم Google Maps باشند، به این آدرس مراجعه کنید: https://developers.google.com/maps/documentation/routes_preferred/reference/rest/Shared.Types/RouteTravelMode .
Enums | |
---|---|
TRAVEL_MODE_UNSPECIFIED | حالت سفر نامشخص، معادل DRIVING . |
DRIVING | حالت سفر مربوط به مسیرهای رانندگی (ماشین، ...). |
WALKING | حالت سفر مربوط به مسیرهای پیاده روی. |
سیاست تخلیه
سیاست در مورد چگونگی تخلیه یک وسیله نقلیه فقط برای محموله هایی اعمال می شود که هم تحویل و هم تحویل دارند.
سایر محمولهها در هر نقطه از مسیر مستقل از unloading_policy
آزاد هستند.
Enums | |
---|---|
UNLOADING_POLICY_UNSPECIFIED | سیاست تخلیه نامشخص؛ تحویل باید فقط پس از وانت مربوطه آنها انجام شود. |
LAST_IN_FIRST_OUT | زایمان ها باید به ترتیب معکوس وانت ها انجام شود |
FIRST_IN_FIRST_OUT | تحویل باید به همان ترتیبی که پیکاپ انجام می شود |
نقطه راه
یک نقطه بین راه را در بر می گیرد. نقاط راه، مکان ورود و خروج VisitRequests، و مکان شروع و پایان وسایل نقلیه را مشخص می کنند.
فیلدها | |
---|---|
side_of_road | اختیاری. نشان می دهد که مکان این ایستگاه بین راهی برای توقف خودرو در سمت خاصی از جاده ترجیح داده می شود. هنگامی که این مقدار را تنظیم می کنید، مسیر از محل عبور می کند تا وسیله نقلیه بتواند در کنار جاده ای که مکان از مرکز جاده به سمت آن سوگیری دارد، توقف کند. این گزینه برای حالت سفر "WALKING" کار نمی کند. |
location_type فیلد اتحادیه روش های مختلف برای نشان دادن یک مکان location_type تنها می تواند یکی از موارد زیر باشد: | |
location | نقطه ای که با استفاده از مختصات جغرافیایی، از جمله عنوان اختیاری مشخص شده است. |
place_id | شناسه مکان POI مرتبط با ایستگاه بین راه. |