BuiltinAssessor.md 4.26 KB
Newer Older
Chi Song's avatar
Chi Song committed
1
2
3
4
# 内置 Assessor

NNI 提供了先进的调优算法,使用上也很简单。 下面是内置 Assessor 的介绍:

Chi Song's avatar
Chi Song committed
5
注意:点击 **Assessor 的名称**可看到 Assessor 的安装需求,建议的场景以及示例。 算法的详细说明在每个 Assessor 建议场景的最后。
Chi Song's avatar
Chi Song committed
6

7
8
当前支持的 Assessor:

Chi Song's avatar
Chi Song committed
9
10
11
12
| Assessor                          | 算法简介                                                                                                                                                                                                                                                      |
| --------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| [**Medianstop**](#MedianStop)     | Medianstop 是一个简单的提前终止算法。 如果 Trial X 的在步骤 S 的最好目标值比所有已完成 Trial 的步骤 S 的中位数值明显要低,这个 Trial 就会被提前停止。 [参考论文](https://static.googleusercontent.com/media/research.google.com/en//pubs/archive/46180.pdf)                                                         |
| [**Curvefitting**](#Curvefitting) | Curve Fitting Assessor 是一个 LPA (learning, predicting, assessing,即学习、预测、评估) 的算法。 如果预测的 Trial X 在 step S 比性能最好的 Trial 要差,就会提前终止它。 此算法中采用了 12 种曲线来拟合精度曲线。 [参考论文](http://aad.informatik.uni-freiburg.de/papers/15-IJCAI-Extrapolation_of_Learning_Curves.pdf) |
Chi Song's avatar
Chi Song committed
13
14
15

## 用法

Chi Song's avatar
Chi Song committed
16
要使用 NNI 内置的 Assessor,需要在 `config.yml` 文件中添加 **builtinAssessorName****classArgs**。 这一节会介绍推荐的场景、参数等详细用法以及示例。
Chi Song's avatar
Chi Song committed
17

Chi Song's avatar
Chi Song committed
18
注意:参考示例中的格式来创建新的 `config.yml` 文件。
Chi Song's avatar
Chi Song committed
19
20
21
22
23
24
25
26
27

<a name="MedianStop"></a>

![](https://placehold.it/15/1589F0/000000?text=+) `Median Stop Assessor`

> 名称:**Medianstop**

**建议场景**

Chi Song's avatar
Chi Song committed
28
适用于各种性能曲线,可用到各种场景中来加速优化过程。 [详细说明](./MedianstopAssessor.md)
Chi Song's avatar
Chi Song committed
29
30
31
32
33
34

**参数**

* **optimize_mode** (*maximize 或 minimize, 可选, 默认值为 maximize*) - 如果为 'maximize', Assessor 会在结果小于期望值时**终止** Trial。 如果为 'minimize',Assessor 会在结果大于期望值时**终止** Trial。
* **start_step** (*int, 可选, 默认值为 0*) - 只有收到 start_step 个中间结果后,才开始判断是否一个 Trial 应该被终止。

Chi Song's avatar
Chi Song committed
35
**使用示例:**
Chi Song's avatar
Chi Song committed
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55

```yaml
# config.yml
assessor:
    builtinAssessorName: Medianstop
    classArgs:
      optimize_mode: maximize
      start_step: 5
```

<br />

<a name="Curvefitting"></a>

![](https://placehold.it/15/1589F0/000000?text=+) `Curve Fitting Assessor`

> 名称:**Curvefitting**

**建议场景**

Chi Song's avatar
Chi Song committed
56
适用于各种性能曲线,可用到各种场景中来加速优化过程。 更好的地方是,它能处理并评估性能类似的曲线。 [详细说明](./CurvefittingAssessor.md)
Chi Song's avatar
Chi Song committed
57
58
59
60
61
62
63

**参数**

* **epoch_num** (*int, **必需***) - epoch 的总数。 需要此数据来决定需要预测点的总数。
* **optimize_mode** (*maximize 或 minimize, 可选, 默认值为 maximize*) - 如果为 'maximize', Assessor 会在结果小于期望值时**终止** Trial。 如果为 'minimize',Assessor 会在结果大于期望值时**终止** Trial。
* **start_step** (*int, 可选, 默认值为 6*) - 只有收到 start_step 个中间结果后,才开始判断是否一个 Trial 应该被终止。
* **threshold** (*float, 可选, 默认值为 0.95*) - 用来确定提前终止较差结果的阈值。 例如,如果 threshold = 0.95, optimize_mode = maximize,最好的历史结果是 0.9,那么会在 Trial 的预测值低于 0.95 * 0.9 = 0.855 时停止。
Chi Song's avatar
Chi Song committed
64
* **gap** (*int, 可选, 默认值为 1*) - Assessor 两次评估之间的间隔次数。 例如:如果 gap = 2, start_step = 6,就会评估第 6, 8, 10, 12... 个中间结果。
Chi Song's avatar
Chi Song committed
65

Chi Song's avatar
Chi Song committed
66
**使用示例:**
Chi Song's avatar
Chi Song committed
67
68
69
70
71
72
73
74
75
76

```yaml
# config.yml
assessor:
    builtinAssessorName: Curvefitting
    classArgs:
      epoch_num: 20
      optimize_mode: maximize
      start_step: 6
      threshold: 0.95
Chi Song's avatar
Chi Song committed
77
      gap: 1
Chi Song's avatar
Chi Song committed
78
```