datastore.ts 3.87 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;
26
    readonly message?: string;
Deshui Yu's avatar
Deshui Yu committed
27
28
29
30
31
32
33
34
35
36
37
}

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

interface MetricDataRecord {
38
    readonly timestamp: number;
Deshui Yu's avatar
Deshui Yu committed
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 {
J-shang's avatar
J-shang committed
47
    trialJobId: string;
48
    sequenceId?: number;
Deshui Yu's avatar
Deshui Yu committed
49
    status: TrialJobStatus;
50
    message?: string;
51
52
    startTime?: number;
    endTime?: number;
chicm-ms's avatar
chicm-ms committed
53
    hyperParameters?: string[];
Deshui Yu's avatar
Deshui Yu committed
54
    logPath?: string;
chicm-ms's avatar
chicm-ms committed
55
    finalMetricData?: MetricDataRecord[];
Deshui Yu's avatar
Deshui Yu committed
56
57
58
    stderrPath?: string;
}

59
60
interface HyperParameterFormat {
    parameter_source: string;
chicm-ms's avatar
chicm-ms committed
61
    parameters: Record<string, any>;
62
63
64
65
    parameter_id: number;
}

interface ExportedDataFormat {
chicm-ms's avatar
chicm-ms committed
66
67
    parameter: Record<string, any>;
    value: Record<string, any>;
J-shang's avatar
J-shang committed
68
    trialJobId: string;
69
70
}

Deshui Yu's avatar
Deshui Yu committed
71
72
73
74
75
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>;
76
77
    public abstract storeTrialJobEvent(
        event: TrialJobEvent, trialJobId: string, hyperParameter?: string, jobDetail?: TrialJobDetail): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
78
79
80
81
    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>;
82
    public abstract getMetricData(trialJobId?: string, metricType?: MetricType): Promise<MetricDataRecord[]>;
83
84
    public abstract exportTrialHpConfigs(): Promise<string>;
    public abstract getImportedData(): Promise<string[]>;
Deshui Yu's avatar
Deshui Yu committed
85
86
87
88
89
90
91
92
}

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>;
93
    public abstract storeTrialJobEvent(
chicm-ms's avatar
chicm-ms committed
94
        event: TrialJobEvent, trialJobId: string, timestamp: number, hyperParameter?: string, jobDetail?: TrialJobDetail): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
95
96
97
98
99
100
101
    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,
102
    ExperimentProfileRecord, TrialJobEventRecord, MetricDataRecord, HyperParameterFormat, ExportedDataFormat
103
};