main.py 1.4 KB
Newer Older
Yan Ni's avatar
Yan Ni committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
"""
Test code for weight sharing
need NFS setup and mounted as `/mnt/nfs/nni`
"""

import hashlib
import os
import random
import time

import nni


def generate_rand_file(fl_name):
    """
    generate random file and write to `fl_name`
    """
    fl_size = random.randint(1024, 102400)
    fl_dir = os.path.split(fl_name)[0]
    if not os.path.exists(fl_dir):
        os.makedirs(fl_dir)
    with open(fl_name, 'wb') as fout:
        fout.write(os.urandom(fl_size))


def check_sum(fl_name, tid=None):
    """
    compute checksum for generated file of `fl_name`
    """
    hasher = hashlib.md5()
    with open(fl_name, 'rb') as fin:
        for chunk in iter(lambda: fin.read(4096), b""):
            hasher.update(chunk)
    ret = hasher.hexdigest()
    if tid is not None:
        ret = ret + str(tid)
    return ret


if __name__ == '__main__':
    nfs_path = '/mnt/nfs/nni/test'
    params = nni.get_next_parameter()
    print(params)
    if params['id'] == 0:
        model_file = os.path.join(nfs_path, str(params['id']), 'model.dat')
        generate_rand_file(model_file)
        time.sleep(10)
        nni.report_final_result({
            'checksum': check_sum(model_file, tid=params['id']),
            'path': model_file
        })
    else:
        model_file = params['prev_path']
        time.sleep(10)
        nni.report_final_result({
            'checksum': check_sum(model_file, tid=params['prev_id'])
        })