datastore.ts 3.84 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
    readonly trialJobId: string;
    readonly parameterId: string;
    readonly type: MetricType;
    readonly sequence: number;
    readonly data: any;
}

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

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

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

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

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