ServiceAreaSolverProperties (arcpy.na)

摘要

用于访问服务区网络分析图层中的分析属性。GetSolverProperties 函数用于从服务区网络分析图层中获取 ServiceAreaSolverProperties 对象。

讨论

ServiceAreaSolverProperties 对象提供对服务区网络分析图层中所有分析属性的读取和写入权限。该对象可用于修改服务区图层的分析属性,并可重新求解相应图层以确定合适结果。使用 Make Service Area Layer 地理处理工具可创建新的服务区图层。通过从新的服务区图层获取 ServiceAreaSolverProperties 对象,可重新对现有图层进行后续分析,而无需每次分析都创建一个新图层,以节省时间。

修改 ServiceAreaSolverProperties 对象的属性后,可立即使用其他函数和地理处理工具分析相应图层。无需刷新或更新图层,通过上述对象进行的修改便可生效。

属性

属性说明数据类型
accumulators
(读写)

Provides the ability to get or set a list of network cost attributes that are accumulated as part of the analysis. An empty list, [], indicates that no cost attributes are accumulated.

String
attributeParameters
(读写)

Provides the ability to get or set the parameterized attributes to be used in the analysis. The property returns a Python dictionary. The dictionary key is a two-value tuple consisting of the attribute name and the parameter name. The value for each item in the dictionary is the parameter value.

Parameterized network attributes are used to model some dynamic aspect of an attribute's value. For example, a tunnel with a height restriction of 12 feet can be modeled using a parameter. In this case, the vehicle's height in feet should be specified as the parameter value. If the vehicle is taller than 12 feet, this restriction will then evaluate to true, thereby restricting travel through the tunnel. Similarly, a bridge could have a parameter to specify a weight restriction.

Attempting to modify the attributeParameters property in place won't result in updated values. Instead, you should always use a new dictionary object to set values for the property. The following two code blocks demonstrate the difference between these two approaches.

#Don't attempt to modify the attributeParameters property in place.
#This coding method won't work.

solverProps.attributeParameters[('HeightRestriction', 'RestrictionUsage')] = "PROHIBITED"
#Modify the attributeParameters property using a new dictionary object.
#This coding method works. 

params = solverProps.attributeParameters
params[('HeightRestriction', 'RestrictionUsage')] = "PROHIBITED"
solverProps.attributeParameters = params
If the network analysis layer does not have parameterized attributes, this property returns None.

Dictionary
defaultBreaks
(读写)

用于获取或设置阻抗值,从而表示要计算的服务区范围。可以设置多个面中断来创建同心服务区。例如,要查找同一设施点的 2 分钟、3 分钟和 5 分钟服务区域,将值指定为 [2, 3, 5]

Double
excludeSources
(读写)

用于获取或设置生成面时将排除的网络源的列表。所有面都将忽略排除的源中遍历元素的几何。空列表 [] 表示不排除任何网络源。

String
impedance
(读写)

用于获取或设置用作阻抗的网络成本属性。当确定服务区时,成本属性将累积。

String
includeNetworkSourceFields
(读写)

控制是否在将分析添加到服务区线期间从基础源要素遍历其他字段。以下是可能值列表:

  • LINES_SOURCE_FIELDS 向服务区线添加 SourceID、SourceOID、FromPosition 和 ToPosition 字段,以保存分析过程中已遍历的基础源要素的信息。此选项可用于将服务区线的结果连接到原始源数据。值 True 也可用于指定此选项。
  • NO_LINES_SOURCE_FIELDS不向服务区线添加源字段(SourceID、SourceOID、FromPosition 和 ToPosition)。值 False 也可用于指定此选项。
String
lineOverlap
(读写)

控制计算服务区线时是否生成重叠线。以下是可能值列表:

  • OVERLAP 当设施点具有重合的服务区线时,将包含各个设施点的单独线要素。值 True 也可用于指定此选项。
  • NON_OVERLAP 每个服务区线被包含一次,并将它与最近(阻抗最小)的设施点相关联。值 False 也可用于指定此选项。
String
lineType
(读写)

用于获取或设置要根据分析生成的服务区线的类型。以下是可能值列表:

  • NO_LINES不生成线。
  • TRUE_LINES生成没有测量值的线。
  • TRUE_LINES_WITH_MEASURES生成具有测量值的线。基于插入了中间结点的边上每个端点的阻抗值生成测量值。如果对性能要求较高,请勿使用此选项。
String
polygonMerge
(读写)

控制是否合并共享相似中断值的面。仅当为多个设施点生成面时,此选项才可用。以下是可能值列表:

  • NO_MERGE为各个设施点创建单独的面。这些面可以相互叠置。
  • NO_OVERLAP为各个设施点创建最接近的单独面。这些面不会相互叠置。
  • MERGE 连接具有相同中断值的多个设施点的面。
String
polygonNesting
(读写)

控制是否将同心服务区面创建为圆盘或圆环。仅当为这些设施点指定多个中断值时,此选项才可用。以下是可能值列表:

  • RINGS不包括较小中断的区域。这将在连续的中断之间创建面。如果要查找从一个中断到另一个中断的区域,请使用此选项。值 True 也可用于指定此选项。
  • DISKS 在设施点与中断之间创建面。例如,如果创建 5 分钟和 10 分钟服务区,则 10 分钟服务区面将包含 5 分钟服务区面内的区域。如果要为各个中断查找从设施点到中断的整个区域,请使用此选项。值 False 也可用于指定此选项。
String
polygonType
(读写)

用于获取或设置要生成的面的类型。以下是可能值列表:

  • SIMPLE_POLYS创建生成速度快并且相当精确的概化面,边缘除外。
  • DETAILED_POLYS创建详细面,用于对服务区线进行精确建模并且可包含未到达区域的岛。这种面比概化面的生成速度慢。
  • NO_POLYS在仅需要服务区线的情况下,将关闭“面生成”选项。
String
restrictions
(读写)

Provides the ability to get or set a list of restriction attributes that are applied for the analysis. An empty list, [], indicates that no restriction attributes are used for the analysis.

String
solverName
(只读)

返回被用于获取求解程序属性对象的网络分析图层所引用的求解程序的名称。从 ServiceAreaSolverProperties 对象访问时,该属性始终返回字符串值 Service Area Solver

String
splitLinesAtBreaks
(读写)

控制当服务区线跨越中断值时是否分割服务区线。以下是可能值列表:

  • SPLIT将两个中断之间的每条线分割为两条线,各自位于其对应中断内。如果要按中断对服务区线进行符号化,此选项很有用;否则,使用 NO_SPLIT 选项以达到最佳性能。
  • NO_SPLIT在中断的边界处不对线进行分割。
String
timeOfDay
(读写)

用于获取或设置离开或到达设施点的时间。对该值的解释取决于行驶方向是朝向设施点还是远离设施点。如果 travelDirection 属性设置为 TRAVEL_FROM,则表示离开时间;如果 travelDirection 属性设置为 TRAVEL_TO,则表示到达时间。可以用值 None 指定不应使用任何日期和时间。

可使用以下日期来指定一周中的每一天,而无需使用特定的日期:

  • 今天 - 12/30/1899
  • 星期日 - 12/31/1899
  • 星期一 - 1/1/1900
  • 星期二 - 1/2/1900
  • 星期三 - 1/3/1900
  • 星期四 - 1/4/1900
  • 星期五 - 1/5/1900
  • 星期六 - 1/6/1900

例如,要指定应该在星期五 8:00 a.m. 离开设施点,则将值指定为 datetime.datetime(1900, 1, 5, 8,0,0)

timeZoneUsage 参数指定该日期和时间是 UTC 还是设施点所在时区。

DateTime
timeZoneUsage
(读写)

指定 timeOfDay 参数的时区或区域。

  • GEO_LOCALtimeOfDay 参数是指设施点所处的时区或区域。因此,服务区开始时间或结束时间的时区交错。将 timeOfDay 设为 9:00 a.m.,选择 GEO_LOCAL,然后进行求解,将为处于东部时区的所有设施点生成东部时间 9:00 a.m. 的服务区、为处于中部时区的设施点生成中部时间 9:00 a.m. 的服务区、为处于山区时区的设施点生成山区时间 9:00 a.m. 的服务区等等。时间始终为本地时间 9:00 a.m.,但会因不同时区而实时交错。如果商店处于覆盖美国、在当地时间 9:00 a.m. 开业的商店链中,则可以在一次求解中选择此参数值来查找处于所有商店开业时间的市场地区。首先,东部时区的商店开业并生成一个面,一小时后中部时区的商店开业,以此类推。
  • UTCtimeOfDay 参数是指协调世界时间 (UTC)。因此,无论各设施点处于哪些时区或区域都会同时到达或出发。将 timeOfDay 设为 2:00 p.m.,选择 UTC,然后进行求解,将为处于东部时区的所有设施点生成东部标准时间 9:00 a.m. 的服务区、为处于中部时区的设施点生成中部标准时间 8:00 a.m. 的服务区、为处于山地时区的设施点生成山地标准时间 7:00 a.m. 的服务区,等等。
    注注:

    以上情况均假定为标准时间。在夏令时期间,东部、中部和山地时间应各提前 1 小时(即分别为 10:00 a.m.、9:00 a.m. 和 8:00 a.m.)。

    UTC 选项可用于为跨两个时区的管辖区显示紧急响应范围。将急救车辆加载为设施点。将 timeOfDay 设置为 UTC 的当前时间。(您需要确定准确的当前 UTC 时间和日期,以便正确使用此选项。)其他属性已设置,分析已求解。尽管时区边界会分割车辆,但结果仍将显示当前交通状况下可以到达的区域。也可对其他时间使用相同的过程,而不仅是当前时间。

无论 timeZoneUsage 的设置如何,当 timeOfDay 的值不为空且 polygonMerge 设置为创建合并或非重叠面时,所有设施点必须处于同一时区。

String
travelDirection
(读写)

控制在服务区分析期间累积阻抗的方向。以下是可能值列表:

  • TRAVEL_FROM在远离设施点的方向上创建服务区。
  • TRAVEL_TO在朝向设施点的方向上创建服务区。
String
trimDistance
(读写)

用于获取或设置一个距离,将对该距离范围内的服务区面进行修剪。属性值包括距离的数值和单位,用空格分隔;例如,要指定 100 米的修剪距离,使用 "100 Meters"

String
trimPolygons
(读写)

控制是否修剪服务区面。以下是可能值列表:

  • TRIM_POLYS对包含服务区外围边的面进行修剪,以使其外边界达到指定的距离。这在网络非常稀疏且不需要服务区覆盖大片不含要素的区域时十分有用。值 True 也可用于指定此选项。
  • NO_TRIM_POLYS不修剪面。值 False 也可用于指定此选项。
String
useHierarchy
(读写)

Controls the use of the hierarchy attribute while performing the analysis. The following is a list of possible values:

  • USE_HIERARCHY Use the hierarchy attribute for the analysis. Using a hierarchy results in the solver preferring higher-order edges to lower-order edges. Hierarchical solves are faster, and they can be used to simulate the preference of a driver who chooses to travel on freeways over local roads when possible—even if that means a longer trip. This option is applicable only if the network dataset referenced by the Network Analyst layer has a hierarchy attribute. A value of True can also be used to specify this option.
  • NO_HIERARCHYDo not use the hierarchy attribute for the analysis. Not using a hierarchy yields an exact route for the network dataset. A value of False can also be used to specify this option.
String
uTurns
(读写)

Provides the ability to get or set the policy that indicates how the U-turns at junctions that could occur during network traversal between stops are being handled by the solver. The following is a list of possible values:

  • ALLOW_UTURNSU-turns are permitted at junctions with any number of connected edges.
  • NO_UTURNSU-turns are prohibited at all junctions, regardless of junction valency. Note, however, that U-turns are still permitted at network locations even when this setting is chosen; however, you can set the individual network locations' CurbApproach property to prohibit U-turns there as well.
  • ALLOW_DEAD_ENDS_ONLYU-turns are prohibited at all junctions, except those that have only one adjacent edge (a dead end).
  • ALLOW_DEAD_ENDS_AND_INTERSECTIONS_ONLYU-turns are prohibited at junctions where exactly two adjacent edges meet but are permitted at intersections (junctions with three or more adjacent edges) and dead ends (junctions with exactly one adjacent edge). Oftentimes, networks have extraneous junctions in the middle of road segments. This option prevents vehicles from making U-turns at these locations.
String

代码实例

ServiceAreaSolverProperties 示例(Python 窗口)

该脚本显示如何更新服务区网络分析图层,以使用等级属性并将 5、10 和 15 分钟设置为中断值。它假设已经在新地图文档中根据旧金山地区的网络数据集创建名为 Store Trade Areas 的服务区图层。

#Get the service area layer object from a layer named "Store Trade Areas" in
#the table of contents
saLayer = arcpy.mapping.Layer("Store Trade Areas")

#Get the solver properties object from the service area layer
solverProps = arcpy.na.GetSolverProperties(saLayer)

#Update the properties for the service area layer using the solver properties
#object
solverProps.defaultBreaks = [5, 10, 15]
solverProps.useHierarchy = "USE_HIERARCHY"

相关主题

5/10/2014