_ce.py 3.0 KB
Newer Older
1
####this file is only used for continuous evaluation test!
R
root 已提交
2 3 4
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
5 6 7 8 9 10 11
import os
import sys
sys.path.append(os.environ['ceroot'])
from kpi import CostKpi, DurationKpi, AccKpi

#### NOTE kpi.py should shared in models in some way!!!!

D
Dang Qingqing 已提交
12
train_acc_top1_kpi = AccKpi(
D
Dang Qingqing 已提交
13
    'train_acc_top1', 0.02, 0, actived=True, desc='TOP1 ACC')
14
train_acc_top5_kpi = AccKpi(
D
Dang Qingqing 已提交
15 16
    'train_acc_top5', 0.02, 0, actived=True, desc='TOP5 ACC')
train_cost_kpi = CostKpi('train_cost', 0.02, 0, actived=True, desc='train cost')
D
Dang Qingqing 已提交
17
test_acc_top1_kpi = AccKpi(
D
Dang Qingqing 已提交
18
    'test_acc_top1', 0.02, 0, actived=True, desc='TOP1 ACC')
19
test_acc_top5_kpi = AccKpi(
D
Dang Qingqing 已提交
20 21
    'test_acc_top5', 0.02, 0, actived=True, desc='TOP5 ACC')
test_cost_kpi = CostKpi('test_cost', 0.02, 0, actived=True, desc='train cost')
Q
qingqing01 已提交
22
train_speed_kpi = DurationKpi(
23
    'train_speed',
D
Dang Qingqing 已提交
24
    0.05,
25
    0,
D
Dang Qingqing 已提交
26
    actived=True,
27 28 29
    unit_repr='seconds/image',
    desc='train speed in one GPU card')
train_acc_top1_card4_kpi = AccKpi(
D
Dang Qingqing 已提交
30
    'train_acc_top1_card4', 0.02, 0, actived=True, desc='TOP1 ACC')
31
train_acc_top5_card4_kpi = AccKpi(
D
Dang Qingqing 已提交
32
    'train_acc_top5_card4', 0.02, 0, actived=True, desc='TOP5 ACC')
33
train_cost_card4_kpi = CostKpi(
D
Dang Qingqing 已提交
34
    'train_cost_card4', 0.02, 0, actived=True, desc='train cost')
35
test_acc_top1_card4_kpi = AccKpi(
D
Dang Qingqing 已提交
36
    'test_acc_top1_card4', 0.02, 0, actived=True, desc='TOP1 ACC')
37
test_acc_top5_card4_kpi = AccKpi(
D
Dang Qingqing 已提交
38
    'test_acc_top5_card4', 0.02, 0, actived=True, desc='TOP5 ACC')
39
test_cost_card4_kpi = CostKpi(
D
Dang Qingqing 已提交
40
    'test_cost_card4', 0.02, 0, actived=True, desc='train cost')
Q
qingqing01 已提交
41
train_speed_card4_kpi = DurationKpi(
42
    'train_speed_card4',
D
Dang Qingqing 已提交
43
    0.05,
44
    0,
D
Dang Qingqing 已提交
45
    actived=True,
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
    unit_repr='seconds/image',
    desc='train speed in four GPU card')
tracking_kpis = [
    train_acc_top1_kpi, train_acc_top5_kpi, train_cost_kpi, test_acc_top1_kpi,
    test_acc_top5_kpi, test_cost_kpi, train_speed_kpi, train_acc_top1_card4_kpi,
    train_acc_top5_card4_kpi, train_cost_card4_kpi, test_acc_top1_card4_kpi,
    test_acc_top5_card4_kpi, test_cost_card4_kpi, train_speed_card4_kpi
]


def parse_log(log):
    '''
    This method should be implemented by model developers.

    The suggestion:

    each line in the log should be key, value, for example:

    "
    train_cost\t1.0
    test_cost\t1.0
    train_cost\t1.0
    train_cost\t1.0
    train_acc\t1.2
    "
    '''
    for line in log.split('\n'):
        fs = line.strip().split('\t')
        print(fs)
        if len(fs) == 3 and fs[0] == 'kpis':
            print("-----%s" % fs)
            kpi_name = fs[1]
            kpi_value = float(fs[2])
            yield kpi_name, kpi_value


def log_to_ce(log):
    kpi_tracker = {}
    for kpi in tracking_kpis:
        kpi_tracker[kpi.name] = kpi

    for (kpi_name, kpi_value) in parse_log(log):
        print(kpi_name, kpi_value)
        kpi_tracker[kpi_name].add_record(kpi_value)
        kpi_tracker[kpi_name].persist()


if __name__ == '__main__':
    log = sys.stdin.read()
    print("*****")
B
Bai Yifan 已提交
96
    print(log)
97 98
    print("****")
    log_to_ce(log)