datastore.ts 3.76 KB
Newer Older
liuzhe-lz's avatar
liuzhe-lz committed
1
2
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.
Deshui Yu's avatar
Deshui Yu committed
3
4
5
6
7
8

'use strict';

import { ExperimentProfile, TrialJobStatistics } from './manager';
import { TrialJobDetail, TrialJobStatus } from './trainingService';

9
type TrialJobEvent = TrialJobStatus | 'USER_TO_CANCEL' | 'ADD_CUSTOMIZED' | 'ADD_HYPERPARAMETER' | 'IMPORT_DATA';
chicm-ms's avatar
chicm-ms committed
10
type MetricType = 'PERIODICAL' | 'FINAL' | 'CUSTOM' | 'REQUEST_PARAMETER';
Deshui Yu's avatar
Deshui Yu committed
11
12

interface ExperimentProfileRecord {
13
    readonly timestamp: number;
Deshui Yu's avatar
Deshui Yu committed
14
15
16
17
18
19
    readonly experimentId: number;
    readonly revision: number;
    readonly data: ExperimentProfile;
}

interface TrialJobEventRecord {
20
    readonly timestamp: number;
Deshui Yu's avatar
Deshui Yu committed
21
22
23
24
    readonly trialJobId: string;
    readonly event: TrialJobEvent;
    readonly data?: string;
    readonly logPath?: string;
25
    readonly sequenceId?: number;
Deshui Yu's avatar
Deshui Yu committed
26
27
28
29
30
31
32
33
34
35
36
}

interface MetricData {
    readonly parameter_id: string;
    readonly trial_job_id: string;
    readonly type: MetricType;
    readonly sequence: number;
    readonly value: any;
}

interface MetricDataRecord {
37
    readonly timestamp: number;
Deshui Yu's avatar
Deshui Yu committed
38
39
40
41
42
43
44
45
46
    readonly trialJobId: string;
    readonly parameterId: string;
    readonly type: MetricType;
    readonly sequence: number;
    readonly data: any;
}

interface TrialJobInfo {
    id: string;
47
    sequenceId?: number;
Deshui Yu's avatar
Deshui Yu committed
48
    status: TrialJobStatus;
49
50
    startTime?: number;
    endTime?: number;
chicm-ms's avatar
chicm-ms committed
51
    hyperParameters?: string[];
Deshui Yu's avatar
Deshui Yu committed
52
    logPath?: string;
chicm-ms's avatar
chicm-ms committed
53
    finalMetricData?: MetricDataRecord[];
Deshui Yu's avatar
Deshui Yu committed
54
55
56
    stderrPath?: string;
}

57
58
59
60
61
62
63
64
65
66
67
68
interface HyperParameterFormat {
    parameter_source: string;
    parameters: Object;
    parameter_id: number;
}

interface ExportedDataFormat {
    parameter: Object;
    value: Object;
    id: string;
}

Deshui Yu's avatar
Deshui Yu committed
69
70
71
72
73
abstract class DataStore {
    public abstract init(): Promise<void>;
    public abstract close(): Promise<void>;
    public abstract storeExperimentProfile(experimentProfile: ExperimentProfile): Promise<void>;
    public abstract getExperimentProfile(experimentId: string): Promise<ExperimentProfile>;
74
75
    public abstract storeTrialJobEvent(
        event: TrialJobEvent, trialJobId: string, hyperParameter?: string, jobDetail?: TrialJobDetail): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
76
77
78
79
    public abstract getTrialJobStatistics(): Promise<TrialJobStatistics[]>;
    public abstract listTrialJobs(status?: TrialJobStatus): Promise<TrialJobInfo[]>;
    public abstract getTrialJob(trialJobId: string): Promise<TrialJobInfo>;
    public abstract storeMetricData(trialJobId: string, data: string): Promise<void>;
80
    public abstract getMetricData(trialJobId?: string, metricType?: MetricType): Promise<MetricDataRecord[]>;
81
82
    public abstract exportTrialHpConfigs(): Promise<string>;
    public abstract getImportedData(): Promise<string[]>;
Deshui Yu's avatar
Deshui Yu committed
83
84
85
86
87
88
89
90
}

abstract class Database {
    public abstract init(createNew: boolean, dbDir: string): Promise<void>;
    public abstract close(): Promise<void>;
    public abstract storeExperimentProfile(experimentProfile: ExperimentProfile): Promise<void>;
    public abstract queryExperimentProfile(experimentId: string, revision?: number): Promise<ExperimentProfile[]>;
    public abstract queryLatestExperimentProfile(experimentId: string): Promise<ExperimentProfile>;
91
    public abstract storeTrialJobEvent(
chicm-ms's avatar
chicm-ms committed
92
        event: TrialJobEvent, trialJobId: string, timestamp: number, hyperParameter?: string, jobDetail?: TrialJobDetail): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
93
94
95
96
97
98
99
    public abstract queryTrialJobEvent(trialJobId?: string, event?: TrialJobEvent): Promise<TrialJobEventRecord[]>;
    public abstract storeMetricData(trialJobId: string, data: string): Promise<void>;
    public abstract queryMetricData(trialJobId?: string, type?: MetricType): Promise<MetricDataRecord[]>;
}

export {
    DataStore, Database, TrialJobEvent, MetricType, MetricData, TrialJobInfo,
100
    ExperimentProfileRecord, TrialJobEventRecord, MetricDataRecord, HyperParameterFormat, ExportedDataFormat
101
};