naive_tuner.py 1.1 KB
Newer Older
Deshui Yu's avatar
Deshui Yu committed
1
2
import json
import logging
QuanluZhang's avatar
QuanluZhang committed
3
import os
Deshui Yu's avatar
Deshui Yu committed
4
5
6
7
8

from nni.tuner import Tuner

_logger = logging.getLogger('NaiveTuner')
_logger.info('start')
QuanluZhang's avatar
QuanluZhang committed
9
10
11

_pwd = os.path.dirname(__file__)
_result = open(os.path.join(_pwd, 'tuner_result.txt'), 'w')
Deshui Yu's avatar
Deshui Yu committed
12
13

class NaiveTuner(Tuner):
14
    def __init__(self, optimize_mode):
Deshui Yu's avatar
Deshui Yu committed
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
        self.cur = 0
        _logger.info('init')

    def generate_parameters(self, parameter_id):
        self.cur += 1
        _logger.info('generate parameters: %s' % self.cur)
        return { 'x': self.cur }

    def receive_trial_result(self, parameter_id, parameters, reward):
        _logger.info('receive trial result: %s, %s, %s' % (parameter_id, parameters, reward))
        _result.write('%d %d\n' % (parameters['x'], reward))
        _result.flush()

    def update_search_space(self, search_space):
        _logger.info('update_search_space: %s' % search_space)
QuanluZhang's avatar
QuanluZhang committed
30
        with open(os.path.join(_pwd, 'tuner_search_space.json'), 'w') as file_:
Deshui Yu's avatar
Deshui Yu committed
31
32
            json.dump(search_space, file_)

33
34
35
36
37
38
    def _on_exit(self):
        _result.close()

    def _on_error(self):
        _result.write('ERROR\n')
        _result.close()