manager.ts 3.01 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

'use strict';

import { MetricDataRecord, MetricType, TrialJobInfo } from './datastore';
Yuge Zhang's avatar
Yuge Zhang committed
7
import { TrialJobStatus } from './trainingService';
8
import { ExperimentConfig } from './experimentConfig';
Deshui Yu's avatar
Deshui Yu committed
9

QuanluZhang's avatar
QuanluZhang committed
10
type ProfileUpdateType = 'TRIAL_CONCURRENCY' | 'MAX_EXEC_DURATION' | 'SEARCH_SPACE' | 'MAX_TRIAL_NUM';
11
type ExperimentStatus = 'INITIALIZED' | 'RUNNING' | 'ERROR' | 'STOPPING' | 'STOPPED' | 'DONE' | 'NO_MORE_TRIAL' | 'TUNER_NO_MORE_TRIAL' | 'VIEWED';
SparkSnail's avatar
SparkSnail committed
12
13
14
15
namespace ExperimentStartUpMode {
    export const NEW = 'new';
    export const RESUME = 'resume';
}
Deshui Yu's avatar
Deshui Yu committed
16
17

interface ExperimentProfile {
18
    params: ExperimentConfig;
Deshui Yu's avatar
Deshui Yu committed
19
20
    id: string;
    execDuration: number;
21
22
    logDir: string;
    startTime: number;
23
    endTime?: number;
24
    nextSequenceId: number;
Deshui Yu's avatar
Deshui Yu committed
25
26
27
28
29
30
31
32
    revision: number;
}

interface TrialJobStatistics {
    trialJobStatus: TrialJobStatus;
    trialJobNumber: number;
}

33
interface NNIManagerStatus {
chicm-ms's avatar
chicm-ms committed
34
    status: ExperimentStatus;
35
36
37
    errors: string[];
}

Deshui Yu's avatar
Deshui Yu committed
38
abstract class Manager {
39
    public abstract startExperiment(experimentConfig: ExperimentConfig): Promise<string>;
SparkSnail's avatar
SparkSnail committed
40
    public abstract resumeExperiment(readonly: boolean): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
41
    public abstract stopExperiment(): Promise<void>;
42
43
    public abstract stopExperimentTopHalf(): Promise<void>;
    public abstract stopExperimentBottomHalf(): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
44
45
    public abstract getExperimentProfile(): Promise<ExperimentProfile>;
    public abstract updateExperimentProfile(experimentProfile: ExperimentProfile, updateType: ProfileUpdateType): Promise<void>;
46
    public abstract importData(data: string): Promise<void>;
47
    public abstract getImportedData(): Promise<string[]>;
48
    public abstract exportData(): Promise<string>;
Deshui Yu's avatar
Deshui Yu committed
49

50
    public abstract addCustomizedTrialJob(hyperParams: string): Promise<number>;
Deshui Yu's avatar
Deshui Yu committed
51
52
53
54
55
56
57
    public abstract cancelTrialJobByUser(trialJobId: string): Promise<void>;

    public abstract listTrialJobs(status?: TrialJobStatus): Promise<TrialJobInfo[]>;
    public abstract getTrialJob(trialJobId: string): Promise<TrialJobInfo>;
    public abstract setClusterMetadata(key: string, value: string): Promise<void>;
    public abstract getClusterMetadata(key: string): Promise<string>;

58
    public abstract getMetricData(trialJobId?: string, metricType?: MetricType): Promise<MetricDataRecord[]>;
59
60
61
    public abstract getMetricDataByRange(minSeqId: number, maxSeqId: number): Promise<MetricDataRecord[]>;
    public abstract getLatestMetricData(): Promise<MetricDataRecord[]>;

Yuge Zhang's avatar
Yuge Zhang committed
62
    public abstract getTrialFile(trialJobId: string, fileName: string): Promise<Buffer | string>;
63

Deshui Yu's avatar
Deshui Yu committed
64
    public abstract getTrialJobStatistics(): Promise<TrialJobStatistics[]>;
65
    public abstract getStatus(): NNIManagerStatus;
J-shang's avatar
J-shang committed
66
67
68

    public abstract getTrialOutputLocalPath(trialJobId: string): Promise<string>;
    public abstract fetchTrialOutput(trialJobId: string, subpath: string): Promise<void>;
Deshui Yu's avatar
Deshui Yu committed
69
70
}

71
export { Manager, ExperimentConfig, ExperimentProfile, TrialJobStatistics, ProfileUpdateType, NNIManagerStatus, ExperimentStatus, ExperimentStartUpMode };