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

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

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

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

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

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

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

45
    public abstract addCustomizedTrialJob(hyperParams: string): Promise<number>;
Deshui Yu's avatar
Deshui Yu committed
46
47
48
49
50
51
52
    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>;

53
    public abstract getMetricData(trialJobId?: string, metricType?: MetricType): Promise<MetricDataRecord[]>;
54
55
56
    public abstract getMetricDataByRange(minSeqId: number, maxSeqId: number): Promise<MetricDataRecord[]>;
    public abstract getLatestMetricData(): Promise<MetricDataRecord[]>;

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

Deshui Yu's avatar
Deshui Yu committed
59
    public abstract getTrialJobStatistics(): Promise<TrialJobStatistics[]>;
60
    public abstract getStatus(): NNIManagerStatus;
J-shang's avatar
J-shang committed
61
62
63

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

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