naive_tuner.py 1.2 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

from nni.tuner import Tuner
6
from nni.utils import extract_scalar_reward
Deshui Yu's avatar
Deshui Yu committed
7
8
9

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

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

class NaiveTuner(Tuner):
15
    def __init__(self, optimize_mode):
Deshui Yu's avatar
Deshui Yu committed
16
17
18
        self.cur = 0
        _logger.info('init')

19
    def generate_parameters(self, parameter_id, **kwargs):
Deshui Yu's avatar
Deshui Yu committed
20
21
22
23
        self.cur += 1
        _logger.info('generate parameters: %s' % self.cur)
        return { 'x': self.cur }

24
    def receive_trial_result(self, parameter_id, parameters, value, **kwargs):
25
        reward = extract_scalar_reward(value)
Deshui Yu's avatar
Deshui Yu committed
26
27
28
29
30
31
        _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
32
        with open(os.path.join(_pwd, 'tuner_search_space.json'), 'w') as file_:
Deshui Yu's avatar
Deshui Yu committed
33
34
            json.dump(search_space, file_)

35
36
37
38
39
40
    def _on_exit(self):
        _result.close()

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