一些 GeoAnalytics Desktop 工具会在分析中使用 Arcade 表达式。 表达式的工具和功能概述如下。
在使用 Arcade 的情况下,字段名称的格式为 $feature["field name"] 或 $feature.fieldname。 如果字段名称包含一个空格,则需要第一个选项 $feature["field name"]。 以下所有示例都使用此选项。 所有工具都使用 $feature["field name"] 格式,连接要素除外。 对于连接要素,使用 $target["field name"] 和 $join["field name"] 指定要使用的数据集。
GeoAnalytics Desktop 工具箱中的以下工具使用 Arcade 表达式:
- 重新构建轨迹和创建缓冲区 - 使用缓冲区表达式执行数学计算以设置缓冲区大小。 您可以执行可应用于所有记录的简单计算和高级计算。 该计算会应用于每个要素。
- 重新构建轨迹 - 使用分割表达式以指定分割轨迹的条件。 当点符合条件时,轨迹将被分割并汇总到不同的轨迹。 您可以应用简单条件和基于追踪的条件。 例如,如果当前点的速度小于两米每秒,则可以分割轨迹(TrackCurrentSpeed() < 2)。
- 连接要素 - 使用连接表达式指定条件,以选择连接时应包含的要素。 可以执行简单连接条件(例如 field a > field c)和高级条件。 将针对每个要素对条件进行测试以确定分析内容。
- 计算字段 - 您可以执行应用于所有记录的简单计算和高级计算。 该计算会应用于每个要素。
- 检测事件 - 确定事件的开始和结束条件。 使用开始和结束表达式检测事件。 检测事件条件必须始终生成 true 或 false 结果。 使用条件确定要素是否应包含在事件中。 将针对每个要素测试条件,以确定哪些要素为事件。
数学运算和函数示例
表达式能够利用数学方式处理数字。 下表显示了可用运算示例。
运算符 | 说明 | 示例 |
---|---|---|
a + b | 返回 a 加 b 的和。 | fieldname 包含数值 1.5 $feature["fieldname"] + 2.5 4.0 |
a - b | 返回 a 减 b 的差。 | fieldname 包含数值 3.3 $feature["fieldname"]- 2.2 1.1 |
a * b | 返回 a 乘以 b 的积。 | fieldname 包含数值 2.0 $feature["fieldname"] * 2.2 4.4 |
a / b | 返回 a 除以 b 的商。 | fieldname 包含数值 4.0 $feature["fieldname"] / 1.25 3.2 |
abs( a ) | 返回 a 的绝对(正)值。 | fieldname 包含数值 -1.5 abs($feature["fieldname"]) 1.5 |
log( a ) | 返回 a 的自然对数(以 E 为底)。 | fieldname 包含数值 1 log($feature["fieldname"]) 0 |
sin( a ) | 返回 a 的三角正弦值。 假设输入为以弧度为单位的角。 | fieldname 包含数值 1.5707 sin($feature["fieldname"]) 1 |
cos( a ) | 返回 a 的三角余弦值。 假设输入为以弧度为单位的角。 | fieldname 包含数值 0 cos($feature["fieldname"]) 1 |
tan( a ) | 返回 a 的正切值。 假设输入为以弧度为单位的角。 | fieldname 包含数值 0 tan($feature["fieldname"]) 0 |
sqrt( a ) | 返回 a 的平方根。 | fieldname 包含数值 9 sqrt($feature["fieldname"]) 3 |
min( a, b ) | 返回 a 和 b 间的最小数值。 | fieldname 包含数值 1.5 和数值 -3 min($feature["fieldname"], -3) -3 |
max( a, b ) | 返回 a 和 b 间的最大数值。 | fieldname1 包含数值 1.5,fieldname2 包含数值 -3 max($feature["fieldname1"], $feature["fieldname2"]) 1.5 |
constrain(<value>,<low>,<high>) | 如果结果在限制范围内,则返回输入值。 如果该值小于低值,则返回低值。 如果该值大于高值,则返回高值。 | 示例 1:constrain( $feature["distance"], 0, 10) 如果 distance 小于 0,则返回 0,如果 distance 大于 10,则返回 10,其余情况下返回 distance。 示例 2:constrain($feature['Store dist'], 6, distance) 如果 Store dist 小于 6,则返回 6,如果 Store dist 大于 distance,则返回 distance,其余情况下返回 Store dist。 |
文本函数示例
Arcade 表达式可以处理文本。 下表显示了可用运算示例。
运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
concatenate(<values>, <separator>) | 将值连接在一起,然后返回字符串。
| fieldname 包含数值 GeoAnalytics Concatenate ([$features["fieldname"], "is", "great!"], ' ') | GeoAnalytics is great! |
find(<searchText>, <text>, <startPos>) | 查找字符串中的字符串。 不支持通配符。
| fieldname1 包含数值 14NorthStreet,fieldname2 包含数值 North。 find($feature["fieldname2"], $feature["fieldname1"]) | 2 |
lower(<value>) | 使字符串均为小写字母。
| fieldname 包含数值 GEOANALYTICS lower($feature["fieldname"]) | geoanalytics |
使用 find 和 lower 的文本示例。
find(("north"), lower("146NorthStreet"))
日期函数示例
Arcade 表达式可以处理日期。 下表显示了可用运算示例。 在 Arcade 中,月份值范围从 0(1 月)到 11(12 月)、日期从 1 号到 31 号、小时从 0(上午 12:00)到 23(下午 11:00)、分和秒从 0 到 59,毫秒从 0 到 999。
运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
date(<value>, <month>, <day>, <hour>, <minute>) | 将值或值集解析成日期字符串。
| fieldname 包含数值 1476987783555 示例 1:Date($features["fieldname"]) 示例 2:Date(2017,0,14,0) 示例 3:Date() | 示例 1:20 Oct 2016 11:23:03 am 示例 2:14 Jan 2017 12:00:00 am 示例 3:返回当前时间 |
DateDiff(<date1>, <date2>, <units>) | 将两个日期相减,并以指定的单位返回差值。
| 示例 1:DateDiff(Date(2017,1,14,0), Date()) 示例 2:DateDiff(Date(2017,1,14,0), Date(), "Years") | 产生的结果会随运行此命令的时间而变化。 示例 1:-20532129137 示例 2:-0.6546783768647119 |
Year(<dateValue>) | 返回给定日期中的年份。
| 示例 1:fieldname 是一个值为 09 Oct 2017 04:30:43 pm 的日期类型的字段 Year($feature["fieldname"]) 示例 2:fieldname 是一个值为 2012-09-27 的 ISO 8601 字符串格式的字符串字段。 | 示例 1:2017 示例 2:2012 |
逻辑函数示例
除简单的数学表达式外,还可使用高等函数来应用缓冲区表达式。
函数 | 说明 | 示例 | 结果 |
---|---|---|---|
iif(<condition>,<true value>,<false value>) | 如果条件评估为 true,则返回一个值,如果条件评估为 false,则返回另外一个值。 <true value> 和 <false value> 可为以下内容:
| iif($feature["field1"] > $feature["field2"], $feature["field1"], 0) iif($feature["field1"] > $feature["field2"], iif($feature["field2"] = 0, $feature["field3"], $feature["field4"]), 0) | 如果 field1 大于 field2,则返回 field1,其余情况下返回 0。 如果 field1 大于 field2,则返回第二个 iif 函数的结果,其余情况下返回 0。 |
when(<expression1> , <result1> , <expression2> , <result2> , ... , <expressionN> , <resultN>, <default>) | 按顺序评估一系列表达式,直至一个表达式评估为 true。
| when(($feature["field1"] + 10) > 1, 1,($feature["field2"] + 10) > 2 , 2, $feature["field3"]) | 如果 field1 + 10 大于 1,则返回 1。 否则,检查 field2 + 10 是否大于 2。 如果是,则返回 2。 否则,返回 field3。 |
decode(<conditional val> , <case1> , <result1>, <case2>, <result2>, ... <caseN>, <resultN>, <defaultValue> ) | 将对表达式进行评估,并将其值与后续参数进行比较。 如果表达式匹配,则返回下一个参数值。 如果均不匹配,则可以选择将最后一个参数作为默认返回值。
| decode($feature["field1"] + 3 , $feature["field1"], 1, $feature["field2"], 2, 0) | 比较条件 val field1 + 3 和 case1 field1 是否相等。 如果 true,则返回 1。 如果 false,则比较 field1 + 3 和 field2 是否相等。 如果 true,则返回 2;否则,返回 0。 |
条件运算符
条件语句可使用以下运算符:
运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
a > b a < b | a 大于 b a 小于 b | 10 > 2 | False |
a >= b a <= b | a 大于或等于 b a 小于或等于 b | abs(-10) >= 10 | True |
a != b | a 不等于 b | abs(-3) != -3 | True |
a == b | a 等于 b | abs(-5) == 5 | True |
<condition1> || <condition2> | 满足条件 1 或条件 2。 | (abs(-5) == 5) || (10 < 2) | True |
<condition1> && <condition2> | 满足条件 1 和条件 2。 | (abs(-5) == 5) && (10 < 2) | False |
跟踪感知型示例
检测事件、计算字段和重新构建轨迹可以在 Arcade 中使用跟踪感知方程。 在输入图层已启用时间、已选中表达式为跟踪感知型且已指定一个或多个字段来标识轨迹的情况下,可在计算字段中使用轨迹方程。
函数 | 说明 | 示例 | 结果 | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
TrackStartTime() | 计算轨迹的起始时间,以从新纪元开始的微秒为单位。 | 使用 2017 年 1 月 2 日起始的轨迹。 TrackStartTime() | 1483315200000 | ||||||||||||
TrackDuration() | 计算轨迹从起始到当前时间步长的持续时间,以微秒为单位。 | 使用 2017 年 1 月 2 日起始、当前时间为 2017 年 1 月 4 日的轨迹。 TrackDuration() | 172800000 | ||||||||||||
TrackCurrentTime() | 计算轨迹中的当前时间。 | 使用发生于 2017 年 1 月 3 日 9:00 a.m 的要素。 TrackCurrentTime() | 1483434000000 | ||||||||||||
TrackIndex | 返回正在计算的要素的时间索引。 | 根据轨迹中的第一个要素计算此值。 TrackIndex | 0 | ||||||||||||
TrackFieldWindow(<fieldName>, <startIndex>, <endIndex>) | 在指定字段中返回指定时间索引的值数组。 window 函数可用于使时间前进和后退。 将在轨迹中的每个要素处评估该表达式。
| MyField 具有按顺序排列的值 [10, 20, 30, 40, 50]。 将在轨迹中的每个要素处评估该表达式。 返回的结果包括起点要素,但不包括终点要素。 示例 1:TrackFieldWindow("MyField,-1,2) 示例 2:TrackFieldWindow("MyField,-2,0)[0] 示例 3:TrackFieldWindow("MyField,0,3)[2] | 示例 1:在每个要素处进行评估时,该表显示以下结果:
示例 2:在索引 2(值为 30)处进行评估时,将返回 10。 示例 3:在索引 2(值为 30)处进行评估时,将返回 50。 | ||||||||||||
TrackGeometryWindow(<startIndex>, <endIndex>) | 返回表示指定时间索引的几何的值数组。 window 函数可用于使时间前进和后退。 将在轨迹中的每个要素处评估该表达式。
| MyField 具有按顺序排列的值 [10, 20, 30, 40, 50]。 要素的几何为 [{x: 1, y: 1},{x: 2, y: 2} ,{x: null, y: null},{x: 4, y: 4}, {x: 5, y: 5}]。将在轨迹中的每个要素处对表达式进行评估。 返回的结果包括起点要素,但不包括终点要素。 示例 1:TrackGeometryWindow(-1,2) 示例 2:折线数据集上的 TrackGeometryWindow(0,1)[0] 示例 3:面数据集上的 TrackGeometryWindow(0,1)[0] 示例 4:查找上一个点 TrackGeometryWindow(-1,0)[0]["x"] 的 X 值 | 示例 1:在每个要素处进行评估时,该表显示以下结果。
示例 2:将通过以下格式返回折线: [{"paths":[[[-180,-22.88],[-177.6,-23.6]],[[180,-18.099999999999994],[179.7,-18.4],[179.4,-18.7],[178.9,-18.9],[178.5,-19.3],[178.2,-19.7],[178.4,-20],[178.8,-20.2],[178.9,-21.8],[179,-22.2],[179.4,-22.7],[180,-22.88]],[[-178,-17],[-178.8,-17.3],[-179.2,-17.5],[-179.6,-17.8],[-179.9,-18],[-180,-18.099999999999994]]]}] 示例 3:将通过以下格式返回面:[{"rings":[[[-7882559.1197999995,6376090.883500002],[-7893142.474300001,6042715.216800004],[-8544018.775999999,6045361.0554000065],[-8544018.775999999,6376090.883500002],[-7882559.1197999995,6376090.883500002]]]}] 示例 4:在索引 2(值为 30)处评估:2 | ||||||||||||
TrackWindow(<value1>, <value2>) | 返回表示指定时间索引的几何和所有属性的值数组。 window 函数可用于使时间前进和后退。
| MyField 除了 objectID、globalID 和 instant_datetime 字段之外,还具有按顺序排列的值 [10, 20, 30, 40, 50]。 要素的几何为 [{x: 1, y: 1},{x: 2, y: 2} ,{x: null, y: null},{x: 4, y: 4}, {x: 5, y: 5}]。 将在轨迹中的每个要素处评估该表达式。 返回的结果包括起点要素,但不包括终点要素。 示例 1:TrackWindow(-1,0)[0] 示例 2:geometry(TrackWindow(-1,0)[0]["x"] | 示例 1:在每个要素处进行评估时,该表显示以下结果:
示例 2:在索引 2(值为 30)处评估:2 |
使用以下追踪表达式可以计算轨迹上的距离、速度和加速度。 这类似于计算动态统计数据工具中所使用的计算。
所有距离计算均以米为单位,速度计算以米/秒为单位,加速度计算以米/秒的平方为单位。 使用测地线距离测量距离。
函数 | 说明 |
---|---|
TrackCurrentDistance() | 从第一个观测点到当前观测点的观测点之间的距离总和。 |
TrackDistanceAt(value) | 从第一个观测点到当前观测点的观测点之间的距离总和加上给定值。 |
TrackDistanceWindow(value1, value2) | 关于当前观测点 (0) 的窗口中的第一个值(包括)到最后一个值(不包括)之间的距离。 |
TrackCurrentSpeed() | 之前的观测点与当前观测点之间的速度。 |
TrackSpeedAt(value1) | 相对于当前观测点的观测点速度。 例如,在值 2 处,这是当前观测点之后两个观测点处的观测点速度。 |
TrackSpeedWindow(value1, value2) | 围绕当前观测点 (0) 的窗口中的第一个值(包括)到最后一个值(不包括)之间的速度值。 |
TrackCurrentAcceleration() | 之前的观测点与当前观测点之间的加速度。 |
TrackAccelerationAt(value1) | 相对于当前观测点的观测点加速度。 |
TrackAccelerationWindow(value1, value2) | 围绕当前观测点 (0) 的窗口中的第一个值(包括)到最后一个值(不包括)之间的加速度值。 |
距离、速度和加速度的示例计算使用以下图像中的示例。
函数 | 示例结果 | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
TrackCurrentDistance() |
| ||||||||||||||
TrackDistanceAt(2) |
| ||||||||||||||
TrackDistanceWindow(-1, 2) |
| ||||||||||||||
TrackCurrentSpeed() |
| ||||||||||||||
TrackSpeedAt(2) |
| ||||||||||||||
TrackSpeedWindow(-1, 2) |
| ||||||||||||||
TrackCurrentAcceleration() |
| ||||||||||||||
TrackAccelerationAt(2) |
| ||||||||||||||
TrackAccelerationWindow(-1, 2) |
|