ShipmentModel

Un modelo de envío contiene un conjunto de envíos que un conjunto de vehículos debe realizar y, al mismo tiempo, minimiza el costo total, que es la suma de lo siguiente:

  • el costo de la planificación de ruta de los vehículos (suma del costo por tiempo total, costo por tiempo de viaje y costo fijo para todos los vehículos).
  • las penalizaciones por envíos no cumplidos.
  • el costo de la duración global de los envíos
Representación JSON
{
  "shipments": [
    {
      object (Shipment)
    }
  ],
  "vehicles": [
    {
      object (Vehicle)
    }
  ],
  "globalStartTime": string,
  "globalEndTime": string,
  "globalDurationCostPerHour": number,
  "durationDistanceMatrices": [
    {
      object (DurationDistanceMatrix)
    }
  ],
  "durationDistanceMatrixSrcTags": [
    string
  ],
  "durationDistanceMatrixDstTags": [
    string
  ],
  "transitionAttributes": [
    {
      object (TransitionAttributes)
    }
  ],
  "shipmentTypeIncompatibilities": [
    {
      object (ShipmentTypeIncompatibility)
    }
  ],
  "shipmentTypeRequirements": [
    {
      object (ShipmentTypeRequirement)
    }
  ],
  "precedenceRules": [
    {
      object (PrecedenceRule)
    }
  ],
  "maxActiveVehicles": integer
}
Campos
shipments[]

object (Shipment)

Conjunto de envíos que deben realizarse en el modelo.

vehicles[]

object (Vehicle)

Es el conjunto de vehículos que se pueden usar para realizar visitas.

globalStartTime

string (Timestamp format)

Hora de inicio y finalización globales del modelo: Ninguna hora fuera de este rango puede considerarse válida.

El intervalo de tiempo del modelo debe ser inferior a un año, es decir, el globalEndTime y el globalStartTime deben estar dentro de los 3,153,600 segundos de diferencia entre sí.

Cuando uses campos cost_per_*hour, te recomendamos establecer esta ventana en un intervalo más pequeño para aumentar el rendimiento (p. ej., si haces un modelo de un solo día, debes establecer los límites de tiempo globales para ese día). Si no la estableces, se usará como valor predeterminado 00:00:00 UTC, 1 de enero de 1970 (es decir, segundos: 0, nanos: 0).

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

globalEndTime

string (Timestamp format)

Si no la estableces, se usará como valor predeterminado 00:00:00 UTC, 1 de enero de 1971 (es decir, segundos: 31536000, nanos: 0).

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

globalDurationCostPerHour

number

La "duración global" del plan general es la diferencia entre la hora de inicio efectiva más temprana y la hora de finalización efectiva más reciente de todos los vehículos. Por ejemplo, los usuarios pueden asignar un costo por hora a esa cantidad para intentar optimizar la finalización del trabajo lo antes posible. El costo debe estar en la misma unidad que Shipment.penalty_cost.

durationDistanceMatrices[]

object (DurationDistanceMatrix)

Especifica las matrices de duración y distancia que se usan en el modelo. Si este campo está vacío, se usarán Google Maps o distancias geodésicas, según el valor del campo useGeodesicDistances. Si no está vacío, useGeodesicDistances no puede ser verdadero y ni durationDistanceMatrixSrcTags ni durationDistanceMatrixDstTags pueden estar vacíos.

Ejemplos de uso:

  • Hay dos ubicaciones: locA y locB.
  • 1 vehículo comienza su ruta en locA y finaliza en locA.
  • 1 solicitud de visita para retirar en locB.
model {
  vehicles { startTags: "locA"  endTags: "locA" }
  shipments { pickups { tags: "locB" } }
  durationDistanceMatrixSrcTags: "locA"
  durationDistanceMatrixSrcTags: "locB"
  durationDistanceMatrixDstTags: "locA"
  durationDistanceMatrixDstTags: "locB"
  durationDistanceMatrices {
    rows {  # from: locA
      durations { seconds: 0 }   meters: 0    # to: locA
      durations { seconds: 100 } meters: 1000 # to: locB
    }
    rows {  # from: locB
      durations { seconds: 102 } meters: 990 # to: locA
      durations { seconds: 0 }   meters: 0   # to: locB
    }
  }
}
  • Hay tres ubicaciones: locA, locB y locC.
  • 1 vehículo inicia su ruta en la locA y la finaliza en locB, con la matriz “fast”.
  • 1 vehículo inicia su ruta en la locB y la finaliza en locB, con la matriz "slow".
  • 1 vehículo inicia su ruta en locB y lo finaliza en locB, mediante la matriz "fast".
  • 1 solicitud de visita para retirar en locC.
model {
  vehicles { startTags: "locA" endTags: "locB" startTags: "fast" }
  vehicles { startTags: "locB" endTags: "locB" startTags: "slow" }
  vehicles { startTags: "locB" endTags: "locB" startTags: "fast" }
  shipments { pickups { tags: "locC" } }
  durationDistanceMatrixSrcTags: "locA"
  durationDistanceMatrixSrcTags: "locB"
  durationDistanceMatrixSrcTags: "locC"
  durationDistanceMatrixDstTags: "locB"
  durationDistanceMatrixDstTags: "locC"
  durationDistanceMatrices {
    vehicleStartTag: "fast"
    rows {  # from: locA
      durations { seconds: 1000 } meters: 2000 # to: locB
      durations { seconds: 600 }  meters: 1000 # to: locC
    }
    rows {  # from: locB
      durations { seconds: 0 }   meters: 0    # to: locB
      durations { seconds: 700 } meters: 1200 # to: locC
    }
    rows {  # from: locC
      durations { seconds: 702 } meters: 1190 # to: locB
      durations { seconds: 0 }   meters: 0    # to: locC
    }
  }
  durationDistanceMatrices {
    vehicleStartTag: "slow"
    rows {  # from: locA
      durations { seconds: 1800 } meters: 2001 # to: locB
      durations { seconds: 900 }  meters: 1002 # to: locC
    }
    rows {  # from: locB
      durations { seconds: 0 }    meters: 0    # to: locB
      durations { seconds: 1000 } meters: 1202 # to: locC
    }
    rows {  # from: locC
      durations { seconds: 1001 } meters: 1195 # to: locB
      durations { seconds: 0 }    meters: 0    # to: locC
    }
  }
}
durationDistanceMatrixSrcTags[]

string

Etiquetas que definen las fuentes de las matrices de duración y distancia; durationDistanceMatrices(i).rows(j) define las duraciones y las distancias entre las visitas con la etiqueta durationDistanceMatrixSrcTags(j) y otras visitas en la matriz i.

Las etiquetas corresponden a VisitRequest.tags o Vehicle.start_tags. Un VisitRequest o Vehicle determinado debe coincidir exactamente con una etiqueta en este campo. Ten en cuenta que las etiquetas de origen, destino y matriz de una Vehicle pueden ser iguales. Del mismo modo, las etiquetas de origen y destino de VisitRequest pueden ser iguales. Todas las etiquetas deben ser diferentes y no pueden ser cadenas vacías. Si este campo no está vacío, durationDistanceMatrices no debe estar vacío.

durationDistanceMatrixDstTags[]

string

Etiquetas que definen los destinos de las matrices de duración y distancia; durationDistanceMatrices(i).rows(j).durations(k) (resp. durationDistanceMatrices(i).rows(j).meters(k)) define la duración (resp. la distancia) del viaje desde las visitas con la etiqueta durationDistanceMatrixSrcTags(j) hasta las visitas con la etiqueta durationDistanceMatrixDstTags(k) en la matriz i.

Las etiquetas corresponden a VisitRequest.tags o Vehicle.start_tags. Un VisitRequest o Vehicle determinado debe coincidir exactamente con una etiqueta en este campo. Ten en cuenta que las etiquetas de origen, destino y matriz de una Vehicle pueden ser iguales. Del mismo modo, las etiquetas de origen y destino de VisitRequest pueden ser iguales. Todas las etiquetas deben ser diferentes y no pueden ser cadenas vacías. Si este campo no está vacío, durationDistanceMatrices no debe estar vacío.

transitionAttributes[]

object (TransitionAttributes)

Atributos de transición agregados al modelo.

shipmentTypeIncompatibilities[]

object (ShipmentTypeIncompatibility)

Conjuntos de opciones de envío incompatibles (consulte ShipmentTypeIncompatibility).

shipmentTypeRequirements[]

object (ShipmentTypeRequirement)

Conjuntos de requisitos shipmentType (consulta ShipmentTypeRequirement)

precedenceRules[]

object (PrecedenceRule)

Conjunto de reglas de precedencia que deben aplicarse en el modelo.

maxActiveVehicles

integer

Restringe la cantidad máxima de vehículos activos. Un vehículo está activo si su ruta realiza al menos un envío. Se puede utilizar para limitar la cantidad de rutas en los casos en que haya menos conductores que vehículos y la flota de vehículos sea heterogénea. La optimización seleccionará el mejor subconjunto de vehículos para usar. Debe ser estrictamente positivo.

Envío

Es el envío de un solo artículo, desde uno de sus retiros hasta uno de sus entregas. Para que el envío se considere realizado, un vehículo único debe visitar una de sus ubicaciones de retiro (y disminuir sus capacidades de repuesto según corresponda) y, luego, visitar una de sus ubicaciones de entrega más adelante (y, por lo tanto, volver a aumentar sus capacidades libres según corresponda).

Representación JSON
{
  "displayName": string,
  "pickups": [
    {
      object (VisitRequest)
    }
  ],
  "deliveries": [
    {
      object (VisitRequest)
    }
  ],
  "loadDemands": {
    string: {
      object (Load)
    },
    ...
  },
  "allowedVehicleIndices": [
    integer
  ],
  "costsPerVehicle": [
    number
  ],
  "costsPerVehicleIndices": [
    integer
  ],
  "pickupToDeliveryAbsoluteDetourLimit": string,
  "pickupToDeliveryTimeLimit": string,
  "shipmentType": string,
  "label": string,
  "ignore": boolean,
  "penaltyCost": number,
  "pickupToDeliveryRelativeDetourLimit": number
}
Campos
displayName

string

Es el nombre visible del envío definido por el usuario. Puede tener hasta 63 caracteres y puede usar caracteres UTF-8.

pickups[]

object (VisitRequest)

Es un conjunto de alternativas de retiro asociadas con el envío. Si no se especifica, el vehículo solo deberá visitar la ubicación correspondiente a la entrega.

deliveries[]

object (VisitRequest)

Es un conjunto de alternativas de entrega asociadas con el envío. Si no se especifica, el vehículo solo debe visitar una ubicación correspondiente a los puntos de partida.

loadDemands

map (key: string, value: object (Load))

Las demandas de carga del envío (por ejemplo, peso, volumen, cantidad de palés, etcétera) Las claves del mapa deben ser identificadores que describan el tipo de carga correspondiente, idealmente que también incluya las unidades. Por ejemplo: "weight_kg", "volume_gallons", "pallet_count", etc. Si una clave determinada no aparece en el mapa, la carga correspondiente se considera nula.

Es un objeto que contiene una lista de pares "key": value. Ejemplo: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

allowedVehicleIndices[]

integer

Es el conjunto de vehículos que pueden realizar este envío. Si está vacía, es posible que todos los vehículos la utilicen. Los vehículos se proporcionan según su índice en la lista vehicles de ShipmentModel.

costsPerVehicle[]

number

Especifica el costo que se genera cuando cada vehículo entrega este envío. Si se especifica, debe tener:

  • la misma cantidad de elementos que costsPerVehicleIndices. costsPerVehicle[i] corresponde al vehículo costsPerVehicleIndices[i] del modelo.
  • la misma cantidad de elementos que vehículos en el modelo. El elemento i-ésimo corresponde al vehículo núm. i del modelo.

Estos costos deben estar en la misma unidad que penaltyCost y no deben ser negativos. Si no hay tales costos, deje este campo vacío.

costsPerVehicleIndices[]

integer

Índices de los vehículos a los que se aplica costsPerVehicle. Si no está vacío, debe tener la misma cantidad de elementos que costsPerVehicle. No se puede especificar un índice vehicular más de una vez. Si se excluye un vehículo de costsPerVehicleIndices, su costo es cero.

pickupToDeliveryAbsoluteDetourLimit

string (Duration format)

Especifica el tiempo de desvío absoluto máximo en comparación con la ruta más corta desde el retiro hasta la entrega. Si se especifica, no debe ser negativo, y el envío debe contener al menos un retiro y una entrega.

Por ejemplo, que sea el tiempo más corto necesario para pasar de la alternativa de retiro seleccionada directamente a la alternativa de entrega seleccionada. Luego, configurar pickupToDeliveryAbsoluteDetourLimit aplica de manera forzosa lo siguiente:

startTime(delivery) - startTime(pickup) <=
t + pickupToDeliveryAbsoluteDetourLimit

Si se especifican límites relativos y absolutos en el mismo envío, se usa el límite más restrictivo para cada par posible de retiro y entrega. A partir de 2017/2010, los desvíos solo se admiten cuando la duración de los viajes no depende de los vehículos.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

pickupToDeliveryTimeLimit

string (Duration format)

Especifica la duración máxima desde el inicio del retiro hasta el inicio de la entrega de un envío. Si se especifica, no debe ser negativo, y el envío debe contener al menos un retiro y una entrega. Esto no depende de qué alternativas se seleccionen para el retiro y la entrega, ni de la velocidad del vehículo. Esto se puede especificar junto con las restricciones de desvío máximo: la solución respetará ambas especificaciones.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

shipmentType

string

Cadena no vacía que especifica un "tipo" para este envío. Esta función se puede usar para definir incompatibilidades o requisitos entre shipment_types (consulta shipmentTypeIncompatibilities y shipmentTypeRequirements en ShipmentModel).

Se diferencia de visitTypes, que se especifica para una sola visita: Todos los retiros o las entregas que pertenecen al mismo envío comparten el mismo shipmentType.

label

string

Especifica una etiqueta para este envío. Esta etiqueta se informa en la respuesta del shipmentLabel de la ShipmentRoute.Visit correspondiente.

ignore

boolean

Si esta preferencia se establece como "true", omitir este envío, pero no apliques penaltyCost

Ignorar un envío genera un error de validación cuando hay cualquier shipmentTypeRequirements en el modelo.

Se permite ignorar un envío realizado en injectedFirstSolutionRoutes o injectedSolutionConstraint. La herramienta quita de la ruta de rendimiento las visitas de retiro o entrega relacionadas. También se ignorará el atributo precedenceRules que haga referencia a envíos ignorados.

penaltyCost

number

Si no se completa el envío, esta penalización se agrega al costo general de las rutas. Un envío se considera completado si se visita una de sus alternativas de retiro y entrega. El costo se puede expresar en la misma unidad que se usa para todos los demás campos relacionados con costos en el modelo y debe ser positivo.

IMPORTANTE: Si no se especifica esta penalización, se considera infinita, es decir, debe completarse el envío.

pickupToDeliveryRelativeDetourLimit

number

Especifica el tiempo de desvío relativo máximo en comparación con la ruta más corta desde el retiro hasta la entrega. Si se especifica, no debe ser negativo, y el envío debe contener al menos un retiro y una entrega.

Por ejemplo, que sea el tiempo más corto necesario para pasar de la alternativa de retiro seleccionada directamente a la alternativa de entrega seleccionada. Luego, configurar pickupToDeliveryRelativeDetourLimit aplica de manera forzosa lo siguiente:

startTime(delivery) - startTime(pickup) <=
std::ceil(t * (1.0 + pickupToDeliveryRelativeDetourLimit))

Si se especifican límites relativos y absolutos en el mismo envío, se usa el límite más restrictivo para cada par posible de retiro y entrega. A partir de 2017/2010, los desvíos solo se admiten cuando la duración de los viajes no depende de los vehículos.

VisitRequest

Solicitud de una visita que se puede realizar desde un vehículo: tiene una ubicación geográfica (o dos, ver a continuación), horarios de apertura y cierre representados por períodos, y un tiempo de duración del servicio (tiempo que pasa el vehículo una vez que llega a retirar o dejar productos).

Representación JSON
{
  "arrivalLocation": {
    object (LatLng)
  },
  "arrivalWaypoint": {
    object (Waypoint)
  },
  "departureLocation": {
    object (LatLng)
  },
  "departureWaypoint": {
    object (Waypoint)
  },
  "tags": [
    string
  ],
  "timeWindows": [
    {
      object (TimeWindow)
    }
  ],
  "duration": string,
  "cost": number,
  "loadDemands": {
    string: {
      object (Load)
    },
    ...
  },
  "visitTypes": [
    string
  ],
  "label": string
}
Campos
arrivalLocation

object (LatLng)

Es la ubicación geográfica a la que llega el vehículo cuando realiza esta VisitRequest. Si el modelo de envío tiene matrices de distancia de duración, no se debe especificar arrivalLocation.

arrivalWaypoint

object (Waypoint)

Es el punto de referencia al que llega el vehículo cuando realiza este VisitRequest. Si el modelo de envío tiene matrices de distancia de duración, no se debe especificar arrivalWaypoint.

departureLocation

object (LatLng)

La ubicación geográfica donde sale el vehículo después de completar este VisitRequest. Se puede omitir si es igual que arrivalLocation. Si el modelo de envío tiene matrices de distancia de duración, no se debe especificar departureLocation.

departureWaypoint

object (Waypoint)

El punto de referencia desde el que sale el vehículo después de completar este VisitRequest. Se puede omitir si es igual que arrivalWaypoint. Si el modelo de envío tiene matrices de distancia de duración, no se debe especificar departureWaypoint.

tags[]

string

Especifica las etiquetas adjuntas a la solicitud de visita. No se permiten cadenas vacías o duplicadas.

timeWindows[]

object (TimeWindow)

Ventanas de tiempo que limitan la hora de llegada a una visita. Ten en cuenta que un vehículo podría salir fuera del horario de llegada; es decir, no es necesario que la hora de llegada y la duración estén dentro de un período establecido. Esto puede generar tiempo de espera si el vehículo llega antes de las TimeWindow.start_time.

La ausencia de TimeWindow significa que el vehículo puede realizar esta visita en cualquier momento.

Los períodos deben ser inconexos, es decir, no deben superponerse ni ser adyacentes a otros, y deben estar en orden creciente.

costPerHourAfterSoftEndTime y softEndTime solo se pueden configurar si hay un período único.

duration

string (Duration format)

Duración de la visita, es decir, el tiempo que pasa el vehículo entre la llegada y la salida (se debe agregar al posible tiempo de espera; consulta timeWindows).

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

cost

number

Es el costo del servicio de esta solicitud de visita en una ruta vehicular. Se puede usar para pagar diferentes costos por cada retiro o entrega alternativo de un envío. Este costo debe estar en la misma unidad que Shipment.penalty_cost y no debe ser negativo.

loadDemands

map (key: string, value: object (Load))

Cargar demandas de esta solicitud de visita. Es similar al campo Shipment.load_demands, con la excepción de que solo se aplica a este VisitRequest en lugar de a todo el Shipment. Las demandas que se enumeran aquí se agregan a las que se enumeran en Shipment.load_demands.

Es un objeto que contiene una lista de pares "key": value. Ejemplo: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

visitTypes[]

string

Especifica los tipos de visita. Se puede usar para asignar el tiempo adicional necesario para que un vehículo complete esta visita (consulta Vehicle.extra_visit_duration_for_visit_type).

Un tipo solo puede aparecer una vez.

label

string

Especifica una etiqueta para este VisitRequest. Esta etiqueta se informa en la respuesta como visitLabel en el ShipmentRoute.Visit correspondiente.

LatLng

Es un objeto que representa un par de valores de latitud y longitud. Esto se expresa como un par de dobles para representar la latitud en grados y la longitud en grados. A menos que se especifique lo contrario, este objeto debe cumplir con el estándar WGS84. Los valores deben pertenecer a rangos normalizados.

Representación JSON
{
  "latitude": number,
  "longitude": number
}
Campos
latitude

number

La latitud expresada en grados. Debe pertenecer al rango [-90.0, +90.0].

longitude

number

La longitud expresada en grados. Debe pertenecer al rango [-180.0, +180.0].

Punto de referencia

Encapsula un punto de referencia. Los puntos de referencia marcan las ubicaciones de llegada y salida de VisitRequests, así como las ubicaciones de partida y llegada de los Vehículos.

Representación JSON
{
  "sideOfRoad": boolean,

  // Union field location_type can be only one of the following:
  "location": {
    object (Location)
  },
  "placeId": string
  // End of list of possible types for union field location_type.
}
Campos
sideOfRoad

boolean

Opcional. Indica que la ubicación de este punto de referencia tiene preferencia para que el vehículo se detenga en un lado en particular de la ruta. Si estableces este valor, la ruta pasará por la ubicación para que el vehículo pueda detenerse en el lado de la ruta hacia el que se segmenta la ubicación desde el centro de la ruta. Esta opción no funciona para “WALKING” medio de transporte.

Campo de unión location_type. Diferentes maneras de representar una ubicación. Las direcciones (location_type) solo pueden ser una de las siguientes opciones:
location

object (Location)

Es un punto que se especifica mediante coordenadas geográficas y que incluye una orientación opcional.

placeId

string

Es el ID del lugar de interés asociado con el punto de referencia.

Ubicación

Encapsula una ubicación (un punto geográfico y una orientación opcional).

Representación JSON
{
  "latLng": {
    object (LatLng)
  },
  "heading": integer
}
Campos
latLng

object (LatLng)

Las coordenadas geográficas del punto de referencia.

heading

integer

Orientación según la brújula asociada a la dirección del flujo del tráfico. Este valor se usa para especificar el lado de la ruta que se usará para la partida y el destino. Los valores de encabezado pueden variar de 0 a 360, donde 0 especifica la orientación hacia el norte, el 90 especifica la orientación hacia el este, etc.

TimeWindow

Las ventanas de tiempo limitan la hora de un evento, como la hora de llegada a una visita o la hora de inicio y finalización de un vehículo.

Los límites de períodos de tiempo estricto, startTime y endTime, aplican la hora más temprana y más reciente del evento, de modo que startTime <= event_time <= endTime. El límite inferior del período flexible, softStartTime, expresa una preferencia para que el evento ocurra en softStartTime o después de esta si incurre en un costo proporcional al tiempo antes de que se produzca el evento softStartTime. El límite superior del período flexible, softEndTime, expresa una preferencia para que el evento ocurra a las softEndTime o antes de esa fecha, ya que incurre en un costo proporcional al tiempo que pasa después del softEndTime en el que ocurre el evento. startTime, endTime, softStartTime y softEndTime deben estar dentro de los límites de tiempo globales (consulta ShipmentModel.global_start_time y ShipmentModel.global_end_time), y deben respetar lo siguiente:

  0 <= `startTime` <= `softStartTime` <= `endTime` and
  0 <= `startTime` <= `softEndTime` <= `endTime`.
Representación JSON
{
  "startTime": string,
  "endTime": string,
  "softStartTime": string,
  "softEndTime": string,
  "costPerHourBeforeSoftStartTime": number,
  "costPerHourAfterSoftEndTime": number
}
Campos
startTime

string (Timestamp format)

La hora de inicio del período de tiempo real. Si no se especifica, se configurará como ShipmentModel.global_start_time.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

endTime

string (Timestamp format)

Es la hora de finalización del período de tiempo real. Si no se especifica, se configurará como ShipmentModel.global_end_time.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

softStartTime

string (Timestamp format)

La hora de inicio suave del período.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

softEndTime

string (Timestamp format)

La hora de finalización suave del período.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

costPerHourBeforeSoftStartTime

number

Un costo por hora que se agrega a otros costos en el modelo si el evento ocurre antes de softStartTime, que se calcula de la siguiente manera:

   max(0, softStartTime - t.seconds)
                          * costPerHourBeforeSoftStartTime / 3600,
t being the time of the event.

Este costo debe ser positivo, y el campo solo se puede establecer si se configuró softStartTime.

costPerHourAfterSoftEndTime

number

Un costo por hora agregado a otros costos en el modelo si el evento ocurre después del softEndTime, que se calcula de la siguiente manera:

   max(0, t.seconds - softEndTime.seconds)
                    * costPerHourAfterSoftEndTime / 3600,
t being the time of the event.

Este costo debe ser positivo, y el campo solo se puede establecer si se configuró softEndTime.

Vehículo

Modela un vehículo con un problema de envío. Si resuelves un problema de envío, se creará una ruta que comenzará en startLocation y finalizará a las endLocation para este vehículo. Una ruta es una secuencia de visitas (consulta ShipmentRoute).

Representación JSON
{
  "displayName": string,
  "travelMode": enum (TravelMode),
  "startLocation": {
    object (LatLng)
  },
  "startWaypoint": {
    object (Waypoint)
  },
  "endLocation": {
    object (LatLng)
  },
  "endWaypoint": {
    object (Waypoint)
  },
  "startTags": [
    string
  ],
  "endTags": [
    string
  ],
  "startTimeWindows": [
    {
      object (TimeWindow)
    }
  ],
  "endTimeWindows": [
    {
      object (TimeWindow)
    }
  ],
  "unloadingPolicy": enum (UnloadingPolicy),
  "loadLimits": {
    string: {
      object (LoadLimit)
    },
    ...
  },
  "costPerHour": number,
  "costPerTraveledHour": number,
  "costPerKilometer": number,
  "fixedCost": number,
  "usedIfRouteIsEmpty": boolean,
  "routeDurationLimit": {
    object (DurationLimit)
  },
  "travelDurationLimit": {
    object (DurationLimit)
  },
  "routeDistanceLimit": {
    object (DistanceLimit)
  },
  "extraVisitDurationForVisitType": {
    string: string,
    ...
  },
  "breakRule": {
    object (BreakRule)
  },
  "label": string,
  "ignore": boolean,
  "travelDurationMultiple": number
}
Campos
displayName

string

El nombre visible del vehículo definido por el usuario. Puede tener hasta 63 caracteres y puede usar caracteres UTF-8.

travelMode

enum (TravelMode)

Indica el medio de transporte que afecta las rutas que utiliza el vehículo y su velocidad. Consulta también travelDurationMultiple.

startLocation

object (LatLng)

Es la ubicación geográfica donde se inicia el vehículo antes de recoger cualquier envío. Si no se especifica, el vehículo inicia en el primer lugar de partida. Si el modelo de envío tiene matrices de duración y distancia, no se debe especificar startLocation.

startWaypoint

object (Waypoint)

Es un punto de referencia que representa una ubicación geográfica donde el vehículo comienza antes de recoger cualquier envío. Si no se especifica startWaypoint ni startLocation, el vehículo comienza en su primer recogida. Si el modelo de envío tiene matrices de duración y distancia, no se debe especificar startWaypoint.

endLocation

object (LatLng)

Ubicación geográfica donde finaliza el vehículo después de completar su último VisitRequest. Si no se especifica, el ShipmentRoute del vehículo finalizará de inmediato cuando se complete el último VisitRequest. Si el modelo de envío tiene matrices de duración y distancia, no se debe especificar endLocation.

endWaypoint

object (Waypoint)

Punto de referencia que representa una ubicación geográfica en la que finaliza el vehículo después de completar su último VisitRequest. Si no se especifica endWaypoint ni endLocation, el ShipmentRoute del vehículo finaliza de inmediato cuando completa su último VisitRequest. Si el modelo de envío tiene matrices de duración y distancia, no se debe especificar endWaypoint.

startTags[]

string

Especifica las etiquetas adjuntas al inicio de la ruta del vehículo.

No se permiten cadenas vacías o duplicadas.

endTags[]

string

Especifica las etiquetas adjuntas al final de la ruta del vehículo.

No se permiten cadenas vacías o duplicadas.

startTimeWindows[]

object (TimeWindow)

Períodos durante los cuales el vehículo puede salir de su ubicación de partida. Deben estar dentro de los límites de tiempo globales (consulta los campos ShipmentModel.global_*). Si no se especifican, no hay limitación aparte de esos límites de tiempo globales.

Los períodos que pertenecen al mismo campo repetido deben ser inconexos, es decir, ningún período puede superponerse o ser adyacente a otro, y deben estar en orden cronológico.

costPerHourAfterSoftEndTime y softEndTime solo se pueden configurar si hay un período único.

endTimeWindows[]

object (TimeWindow)

Períodos durante los cuales el vehículo puede llegar a su ubicación final. Deben estar dentro de los límites de tiempo globales (consulta los campos ShipmentModel.global_*). Si no se especifican, no hay limitación aparte de esos límites de tiempo globales.

Los períodos que pertenecen al mismo campo repetido deben ser inconexos, es decir, ningún período puede superponerse o ser adyacente a otro, y deben estar en orden cronológico.

costPerHourAfterSoftEndTime y softEndTime solo se pueden configurar si hay un período único.

unloadingPolicy

enum (UnloadingPolicy)

Se aplica una política de descarga en el vehículo.

loadLimits

map (key: string, value: object (LoadLimit))

Capacidades del vehículo (peso, volumen, cantidad de palés, por ejemplo) Las claves del mapa son los identificadores del tipo de carga, coherentes con las claves del campo Shipment.load_demands. Si una clave determinada no se encuentra en este mapa, la capacidad correspondiente se considera ilimitada.

Es un objeto que contiene una lista de pares "key": value. Ejemplo: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

costPerHour

number

Costos de los vehículos: Todos los costos se suman y deben estar en la misma unidad que Shipment.penalty_cost.

Es el costo por hora de la ruta del vehículo. Este costo se aplica al tiempo total que toma la ruta y comprende el tiempo de viaje, de espera y de la visita. Usar costPerHour en lugar de solo costPerTraveledHour puede generar latencia adicional.

costPerTraveledHour

number

Es el costo por hora recorrida de la ruta del vehículo. Este costo se aplica solo al tiempo de viaje de la ruta (es decir, el que se informa en ShipmentRoute.transitions) y excluye el tiempo de espera y la visita.

costPerKilometer

number

Costo por kilómetro de la ruta vehicular Este costo se aplica a la distancia informada en el ShipmentRoute.transitions y no se aplica a ninguna distancia recorrida implícitamente desde el arrivalLocation hasta el departureLocation de un solo VisitRequest.

fixedCost

number

Se aplica un costo fijo si este vehículo se usa para gestionar un envío.

usedIfRouteIsEmpty

boolean

Este campo solo se aplica a vehículos cuando en su ruta no se hacen envíos. Indica si el vehículo se debe considerar como usado o no en este caso.

Si es verdadero, el vehículo va desde la ubicación de partida hasta la de finalización, incluso si no entrega envíos, y los costos de tiempo y distancia que resultan de su inicio. --> al final del viaje se tienen en cuenta.

De lo contrario, no viaja desde su ubicación de inicio hasta su ubicación de finalización, y no hay breakRule ni ningún retraso (desde TransitionAttributes) programados para este vehículo. En este caso, el ShipmentRoute del vehículo no contiene información, excepto el índice y la etiqueta del vehículo.

routeDurationLimit

object (DurationLimit)

El límite se aplica a la duración total de la ruta del vehículo. En un OptimizeToursResponse determinado, la duración de la ruta de un vehículo es la diferencia entre sus vehicleEndTime y vehicleStartTime.

travelDurationLimit

object (DurationLimit)

El límite se aplica a la duración del viaje de la ruta del vehículo. En un OptimizeToursResponse determinado, la duración del viaje de la ruta es la suma de todos sus transitions.travel_duration.

routeDistanceLimit

object (DistanceLimit)

El límite se aplica a la distancia total de la ruta del vehículo. En un OptimizeToursResponse determinado, la distancia de la ruta es la suma de todos sus transitions.travel_distance_meters.

extraVisitDurationForVisitType

map (key: string, value: string (Duration format))

Especifica un mapa de las cadenas visitTypes a las duraciones. La duración es el tiempo adicional que se toma en VisitRequest.duration para las visitas con el visitTypes especificado. Esta duración adicional de la visita agrega un costo si se especifica costPerHour. Las claves (es decir, visitTypes) no pueden ser cadenas vacías.

Si una solicitud de visita tiene varios tipos, se agregará una duración para cada tipo en el mapa.

Es un objeto que contiene una lista de pares "key": value. Ejemplo: { "name": "wrench", "mass": "1.3kg", "count": "3" }.

breakRule

object (BreakRule)

Describe el programa de descanso que se aplicará en este vehículo. Si está vacía, no se programarán descansos para este vehículo.

label

string

Especifica una etiqueta para este vehículo. Esta etiqueta se informa en la respuesta como el vehicleLabel del ShipmentRoute correspondiente.

ignore

boolean

Si es verdadero, usedIfRouteIsEmpty debe ser falso, y este vehículo permanecerá sin uso.

Si un vehículo ignorado en injectedFirstSolutionRoutes realiza un envío, se omitirá en la primera solución, pero se podrá realizar libremente en la respuesta.

Si un vehículo ignorado en injectedSolutionConstraint realiza un envío y cualquier retiro o entrega relacionado está limitado a permanecer en el vehículo (es decir, no relajado hasta el nivel RELAX_ALL_AFTER_THRESHOLD), se omitirá en la respuesta. Si un envío tiene un campo allowedVehicleIndices que no está vacío y se ignoran todos los vehículos permitidos, este se omite en la respuesta.

travelDurationMultiple

number

Especifica un factor multiplicativo que se puede usar para aumentar o reducir los tiempos de viaje del vehículo. Por ejemplo, establecer este valor en 2.0 significa que este vehículo es más lento y tiene tiempos de viaje que son el doble de los que tienen los vehículos estándar. Esta cantidad múltiple no afecta la duración de las visitas. Afecta el costo si se especifican costPerHour o costPerTraveledHour. Debe pertenecer al rango [0.001, 1000.0]. Si no se establece, el vehículo es estándar y este múltiplo se considera 1.0.

ADVERTENCIA: Los tiempos de viaje se redondearán al segundo más cercano después de que se aplique este múltiplo, pero antes de realizar cualquier operación numérica, por lo tanto, un pequeño múltiplo puede generar una pérdida de precisión.

Consulta también extraVisitDurationForVisitType a continuación.

TravelMode

Son los medios de transporte que pueden utilizar los vehículos.

Deben ser un subconjunto de los medios de transporte de la API de Google Maps Platform Routes Preferred. Consulta: https://developers.google.com/maps/documentation/routes_preferred/reference/rest/Shared.Types/RouteTravelMode.

Enumeraciones
TRAVEL_MODE_UNSPECIFIED Medio de transporte no especificado, equivalente a DRIVING.
DRIVING Es el medio de transporte correspondiente a la ruta en auto (automóvil, ...).
WALKING Medio de transporte correspondiente a las instrucciones sobre cómo llegar a pie.

UnloadingPolicy

Política sobre cómo se puede descargar un vehículo. Se aplica solo a los envíos que tengan retiro y entrega.

Otros envíos son gratuitos para realizarse en cualquier lugar de la ruta, independientemente de unloadingPolicy.

Enumeraciones
UNLOADING_POLICY_UNSPECIFIED Política de descarga no especificada; las entregas deben ocurrir después de sus retiros correspondientes.
LAST_IN_FIRST_OUT Las entregas deben realizarse en orden inverso al de retiro
FIRST_IN_FIRST_OUT Las entregas deben realizarse en el mismo orden que los retiros

LoadLimit

Define un límite de carga que se aplica a un vehículo, p.ej., "este camión solo puede transportar hasta 3,500 kg". Consulta los loadLimits.

Representación JSON
{
  "softMaxLoad": string,
  "costPerUnitAboveSoftMax": number,
  "startLoadInterval": {
    object (Interval)
  },
  "endLoadInterval": {
    object (Interval)
  },
  "maxLoad": string
}
Campos
softMaxLoad

string (int64 format)

Un límite flexible de la carga Consulta los costPerUnitAboveSoftMax.

costPerUnitAboveSoftMax

number

Si en algún momento la carga supera los softMaxLoad en la ruta de este vehículo, se aplicará la siguiente penalización de costo (solo una vez por vehículo): (carga - softMaxLoad) * costPerUnitAboveSoftMax. Todos los costos se suman y deben estar en la misma unidad que Shipment.penalty_cost.

startLoadInterval

object (Interval)

El intervalo de carga aceptable del vehículo al comienzo de la ruta.

endLoadInterval

object (Interval)

El intervalo de carga aceptable del vehículo al final de la ruta.

maxLoad

string (int64 format)

La cantidad de carga máxima aceptable.

Intervalo

Intervalo de cantidades de carga aceptables

Representación JSON
{
  "min": string,
  "max": string
}
Campos
min

string (int64 format)

Una carga mínima aceptable Debe ser mayor o igual que 0. Si se especifican ambos, min debe ser ≤ max.

max

string (int64 format)

Una carga aceptable máxima Debe ser mayor o igual que 0. Si no se especifica, este mensaje no restringe la carga máxima. Si se especifican ambos, min debe ser ≤ max.

DurationLimit

Es un límite que define una duración máxima de la ruta de un vehículo. Puede ser dura o blanda.

Cuando se define un campo de límite flexible, se deben definir juntos el umbral de máx. rendimiento y su costo asociado.

Representación JSON
{
  "maxDuration": string,
  "softMaxDuration": string,
  "quadraticSoftMaxDuration": string,
  "costPerHourAfterSoftMax": number,
  "costPerSquareHourAfterQuadraticSoftMax": number
}
Campos
maxDuration

string (Duration format)

Un límite estricto que restringe la duración a maxDuration como máximo.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

softMaxDuration

string (Duration format)

Un límite flexible no aplica un límite de duración máxima, pero, cuando se infringe, la ruta genera un costo. Este costo se suma a otros costos definidos en el modelo, con la misma unidad.

Si se define, softMaxDuration no debe ser negativo. Si también se define maxDuration, softMaxDuration debe ser menor que maxDuration.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

quadraticSoftMaxDuration

string (Duration format)

Un límite flexible que no aplica un límite de duración máxima, pero, cuando se infringe, genera un costo cuadrático en la duración de la ruta. Este costo se suma a otros costos definidos en el modelo, con la misma unidad.

Si se define, quadraticSoftMaxDuration no debe ser negativo. Si también se define maxDuration, quadraticSoftMaxDuration debe ser menor que maxDuration, y la diferencia no debe superar un día:

maxDuration - quadraticSoftMaxDuration <= 86400 seconds

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

costPerHourAfterSoftMax

number

Costo por hora generado si se infringe el umbral de softMaxDuration. El costo adicional es de 0 si la duración está por debajo del umbral. De lo contrario, dependerá de la duración de la siguiente manera:

  costPerHourAfterSoftMax * (duration - softMaxDuration)

El costo no debe ser negativo.

costPerSquareHourAfterQuadraticSoftMax

number

Costo por hora cuadrada que se genera si se infringe el umbral de quadraticSoftMaxDuration

El costo adicional es de 0 si la duración está por debajo del umbral. De lo contrario, dependerá de la duración de la siguiente manera:

  costPerSquareHourAfterQuadraticSoftMax *
  (duration - quadraticSoftMaxDuration)^2

El costo no debe ser negativo.

DistanceLimit

Es un límite que define una distancia máxima que se puede recorrer. Puede ser dura o blanda.

Si se define un límite flexible, se deben definir tanto softMaxMeters como costPerKilometerAboveSoftMax, y no deben ser negativos.

Representación JSON
{
  "maxMeters": string,
  "softMaxMeters": string,
  "costPerKilometerAboveSoftMax": number
}
Campos
maxMeters

string (int64 format)

Un límite estricto que restringe la distancia para que sea como máximo maxMeters. El límite no debe ser negativo.

softMaxMeters

string (int64 format)

Un límite flexible no aplica un límite de distancia máxima, pero, cuando se infringe, genera un costo que se suma a otros costos definidos en el modelo, con la misma unidad.

Si se define softMaxMeters, debe ser menor que maxMeters y no debe ser negativo.

costPerKilometerAboveSoftMax

number

Costo por kilómetro generado si la distancia supera el límite de softMaxMeters. El costo adicional es 0 si la distancia está por debajo del límite. De lo contrario, la fórmula que se usa para calcular el costo es la siguiente:

  (distanceMeters - softMaxMeters) / 1000.0 *
  costPerKilometerAboveSoftMax.

El costo no debe ser negativo.

BreakRule

Son las reglas para generar descansos para un vehículo (p.ej., las horas de almuerzo). Una pausa es un período contiguo durante el cual el vehículo permanece inactivo en su posición actual y no puede realizar ninguna visita. Es posible que se produzca una ruptura:

  • durante el viaje entre dos visitas (lo que incluye el tiempo justo antes o después de una visita, pero no en medio de ella), en cuyo caso se extiende el tiempo en tránsito correspondiente entre las visitas
  • o antes del arranque del vehículo (es posible que no se encienda en medio de una pausa), en cuyo caso esto no afecta la hora de inicio del vehículo.
  • o después de que finaliza el vehículo (dito, con la hora de finalización del vehículo).
Representación JSON
{
  "breakRequests": [
    {
      object (BreakRequest)
    }
  ],
  "frequencyConstraints": [
    {
      object (FrequencyConstraint)
    }
  ]
}
Campos
breakRequests[]

object (BreakRequest)

Secuencia de pausas. Lee el mensaje BreakRequest.

frequencyConstraints[]

object (FrequencyConstraint)

Es posible que se apliquen varias FrequencyConstraint. Todos deben estar satisfechos con los BreakRequest de este BreakRule. Consulta FrequencyConstraint.

BreakRequest

La secuencia de descansos (es decir, el número y el orden) que corresponden a cada vehículo debe conocerse de antemano. Los objetos BreakRequest repetidos definen esa secuencia en el orden en que deben ocurrir. Sus períodos (earliestStartTime / latestStartTime) pueden superponerse, pero deben ser compatibles con el pedido (esto está marcado).

Representación JSON
{
  "earliestStartTime": string,
  "latestStartTime": string,
  "minDuration": string
}
Campos
earliestStartTime

string (Timestamp format)

Obligatorio. Límite inferior (inclusivo) al inicio de la pausa.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

latestStartTime

string (Timestamp format)

Obligatorio. Límite superior (inclusivo) al inicio de la pausa.

Una marca de tiempo en formato RFC3339 UTC “Zulú”, con una resolución de nanosegundos y hasta nueve dígitos fraccionarios. Ejemplos: "2014-10-02T15:01:23Z" y "2014-10-02T15:01:23.045123456Z".

minDuration

string (Duration format)

Obligatorio. Duración mínima de la pausa. Debe ser positivo.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

FrequencyConstraint

Se puede restringir aún más la frecuencia y la duración de las pausas especificadas anteriormente mediante la aplicación de una frecuencia de pausa mínima, como "Debe haber una pausa de al menos 1 hora cada 12 horas". Si suponemos que esto se puede interpretar como "En cualquier período variable de 12 h, debe haber al menos una pausa de, al menos, una hora". Ese ejemplo se traduciría de la siguiente manera: FrequencyConstraint:

{
   minBreakDuration { seconds: 3600 }         # 1 hour.
   maxInterBreakDuration { seconds: 39600 }  # 11 hours (12 - 1 = 11).
}

El tiempo y la duración de las pausas en la solución respetarán todas esas restricciones, además de los períodos y las duraciones mínimas ya especificadas en el BreakRequest.

En la práctica, puede aplicarse una FrequencyConstraint a las pausas no consecutivas. Por ejemplo, el siguiente programa respeta el horario que indica "1 h cada 12 h". ejemplo:

  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
Representación JSON
{
  "minBreakDuration": string,
  "maxInterBreakDuration": string
}
Campos
minBreakDuration

string (Duration format)

Obligatorio. Duración mínima de la pausa para esta restricción. No es negativo. Consulta la descripción de FrequencyConstraint.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

maxInterBreakDuration

string (Duration format)

Obligatorio. Intervalo máximo permitido de cualquier intervalo de tiempo en la ruta que no incluye, al menos, una pausa de duration >= minBreakDuration de forma parcial. Debe ser positivo.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

DurationDistanceMatrix

Especifica una matriz de duración y distancia de la visita y las ubicaciones de partida del vehículo para visitar, así como las ubicaciones de finalización del vehículo.

Representación JSON
{
  "rows": [
    {
      object (Row)
    }
  ],
  "vehicleStartTag": string
}
Campos
rows[]

object (Row)

Especifica las filas de la matriz de duración y distancia. Debe tener tantos elementos como ShipmentModel.duration_distance_matrix_src_tags.

vehicleStartTag

string

Etiqueta que define a qué vehículos se aplica esta matriz de duración y distancia. Si está vacío, se aplica a todos los vehículos, y solo puede haber una matriz.

Cada inicio de vehículo debe coincidir exactamente con una matriz, es decir, exactamente uno de sus campos startTags debe coincidir con el vehicleStartTag de una matriz (y solo de esa matriz).

Todas las matrices deben tener un vehicleStartTag diferente.

Fila

Especifica una fila de la matriz de duración y distancia.

Representación JSON
{
  "durations": [
    string
  ],
  "meters": [
    number
  ]
}
Campos
durations[]

string (Duration format)

Valores de duración para una fila determinada. Debe tener tantos elementos como ShipmentModel.duration_distance_matrix_dst_tags.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

meters[]

number

Valores de distancia para una fila determinada. Si ningún costo o restricción se refiere a las distancias en el modelo, puede dejarse vacío. De lo contrario, debe tener tantos elementos como durations.

TransitionAttributes

Especifica atributos de transiciones entre dos visitas consecutivas en una ruta. Se pueden aplicar varios TransitionAttributes a la misma transición: en ese caso, todos los costos adicionales se suman y se aplica la restricción o el límite más estrictos (según la semántica natural “AND”).

Representación JSON
{
  "srcTag": string,
  "excludedSrcTag": string,
  "dstTag": string,
  "excludedDstTag": string,
  "cost": number,
  "costPerKilometer": number,
  "distanceLimit": {
    object (DistanceLimit)
  },
  "delay": string
}
Campos
srcTag

string

Etiquetas que definen el conjunto de transiciones (src->dst) a las que se aplican estos atributos.

Una visita de origen o el inicio del vehículo coincide si su VisitRequest.tags o Vehicle.start_tags contienen srcTag o no contienen excludedSrcTag (según cuál de estos dos campos no esté vacío).

excludedSrcTag

string

Consulta los srcTag. Exactamente uno de srcTag o excludedSrcTag no debe estar vacío.

dstTag

string

Una visita de destino o la finalización de un vehículo coinciden si su VisitRequest.tags o Vehicle.end_tags contienen dstTag o no contienen excludedDstTag (según cuál de estos dos campos no esté vacío).

excludedDstTag

string

Consulta los dstTag. Exactamente uno de dstTag o excludedDstTag no debe estar vacío.

cost

number

Especifica un costo por realizar esta transición. Se encuentra en la misma unidad que todos los demás costos del modelo y no debe ser negativo. Este importe se suma a todos los demás costos existentes.

costPerKilometer

number

Especifica un costo por kilómetro aplicado a la distancia recorrida mientras se realiza esta transición. Suma cualquier Vehicle.cost_per_kilometer especificado en los vehículos.

distanceLimit

object (DistanceLimit)

Especifica un límite para la distancia recorrida mientras se realiza esta transición.

A partir de 2021/06, solo se admiten límites flexibles.

delay

string (Duration format)

Especifica un retraso generado al realizar esta transición.

Esta demora siempre ocurre después de terminar la visita de origen y antes de comenzar la visita de destino.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

ShipmentTypeIncompatibility

Especifica las incompatibilidades entre envíos según su tipo de envío. La aparición de envíos incompatibles en la misma ruta se restringe en función del modo de incompatibilidad.

Representación JSON
{
  "types": [
    string
  ],
  "incompatibilityMode": enum (IncompatibilityMode)
}
Campos
types[]

string

Lista de tipos incompatibles. Dos envíos con un shipment_types diferentes de los indicados son "incompatibles".

incompatibilityMode

enum (IncompatibilityMode)

Se aplicó el modo a la incompatibilidad.

IncompatibilityMode

Modos que definen cómo se restringen los envíos incompatibles en la misma ruta.

Enumeraciones
INCOMPATIBILITY_MODE_UNSPECIFIED No se especificó el modo de incompatibilidad. Este valor nunca debe usarse.
NOT_PERFORMED_BY_SAME_VEHICLE En este modo, dos envíos con tipos incompatibles nunca pueden compartir el mismo vehículo.
NOT_IN_SAME_VEHICLE_SIMULTANEOUSLY

Para dos envíos con tipos incompatibles con el modo de incompatibilidad NOT_IN_SAME_VEHICLE_SIMULTANEOUSLY:

  • Si ambas opciones son solo para retiros (no para entregas) o solo entregas (no retiros), no podrán compartir el mismo vehículo.
  • Si uno de los envíos tiene entrega y el otro tiene retiro, los dos envíos pueden compartir el mismo vehículo si el envío anterior se entrega antes de que se retire este último.

ShipmentTypeRequirement

Especifica los requisitos entre envíos según su tipo de envío. Los detalles del requisito se definen en función del modo de requisitos.

Representación JSON
{
  "requiredShipmentTypeAlternatives": [
    string
  ],
  "dependentShipmentTypes": [
    string
  ],
  "requirementMode": enum (RequirementMode)
}
Campos
requiredShipmentTypeAlternatives[]

string

Lista de tipos de envío alternativos que requiere dependentShipmentTypes.

dependentShipmentTypes[]

string

Todos los envíos con un tipo indicado en el campo dependentShipmentTypes requieren que se visite al menos un envío del tipo requiredShipmentTypeAlternatives en la misma ruta.

NOTA: No se permiten cadenas de requisitos en las que un shipmentType dependa de sí mismo.

requirementMode

enum (RequirementMode)

Se aplica el modo al requisito.

RequirementMode

Modos que definen el aspecto de envíos dependientes en una ruta.

Enumeraciones
REQUIREMENT_MODE_UNSPECIFIED Modo de requisitos no especificado. Este valor nunca debe usarse.
PERFORMED_BY_SAME_VEHICLE En este modo, todo "dependiente" los envíos deben compartir el mismo vehículo que al menos uno de sus entre los envíos.
IN_SAME_VEHICLE_AT_PICKUP_TIME

Con el modo IN_SAME_VEHICLE_AT_PICKUP_TIME, todo “dependiente” los envíos deben tener al menos un envío en su vehículo al momento del retiro.

Un “dependiente” por lo tanto, el retiro del envío debe tener:

  • Un campo obligatorio solo para entregas envío entregado en la ruta después del
  • Un campo "obligatorio" envío recogido en la ruta antes de este y si la condición envío tiene una entrega, esta entrega debe realizarse después del dependiente retiro del envío.
IN_SAME_VEHICLE_AT_DELIVERY_TIME Igual que antes, excepto la cuenta "dependiente" los envíos deben tener un envío en su vehículo en el momento de la entrega.

PrecedenceRule

Una regla de prioridad entre dos eventos (cada evento es el retiro o la entrega de un envío): el "segundo" el evento debe comenzar, al menos, offsetDuration después de "primero". ha empezado.

Varias prioridades pueden referirse a los mismos eventos (o relacionados), p.ej., "el retiro de B se produce después de la entrega de A". y "el retiro de C ocurre después del retiro de B".

Además, las prioridades solo se aplican cuando se realizan ambos envíos y se ignoran de otra forma.

Representación JSON
{
  "firstIsDelivery": boolean,
  "secondIsDelivery": boolean,
  "offsetDuration": string,
  "firstIndex": integer,
  "secondIndex": integer
}
Campos
firstIsDelivery

boolean

Indica si el "primer" el evento es una entrega.

secondIsDelivery

boolean

Indica si el "segundo" el evento es una entrega.

offsetDuration

string (Duration format)

El desplazamiento entre los "primeros" y "second" para cada evento. Puede ser negativo.

Una duración en segundos con hasta nueve dígitos decimales, que terminan en “s”. Ejemplo: "3.5s".

firstIndex

integer

Índice de envío del “primer” para cada evento. Se debe especificar este campo.

secondIndex

integer

Índice de envío del "segundo" para cada evento. Se debe especificar este campo.