123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 |
- # -*-coding:UTF-8-*-
- import argparse
- import sys
- import os
- sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
- sys.path.append("../")
- from scripts.logger.lemon_logger import Logger
- import warnings
- import datetime
- import configparser
- from scripts.tools import utils
- """Init cuda"""
- warnings.filterwarnings("ignore")
- os.environ["KERAS_BACKEND"] = "tensorflow"
- os.environ["TF_CPP_MIN_LOG_LEVEL"] = "2" # 只显示 warning 和 Error
- os.environ["CUDA_DEVICE_ORDER"] = "PCI_BUS_ID"
- os.environ["CUDA_VISIBLE_DEVICES"] = ""
- """Setting random seed"""
- def lemon_process(exp, root_dir, output_dir, mutate_num, config_name):
- lemon_cfg = configparser.ConfigParser()
- cfg_path = os.path.join(root_dir, "config", config_name)
- lemon_cfg.read(cfg_path)
- parameters = lemon_cfg["parameters"]
- flags = argparse.Namespace(
- mutate_ops=parameters["mutate_ops"],
- exps=exp.lstrip().rstrip().split(" "),
- origin_model_dir=os.path.join(root_dir, parameters["origin_model_dir"]),
- output_dir=output_dir,
- backend=parameters["backend"],
- mutate_num=mutate_num,
- mutate_ratio=parameters.getfloat("mutate_ratio"),
- test_size=parameters.getint("test_size"),
- threshold=parameters.getfloat("threshold"),
- redis_db=lemon_cfg["parameters"].getint("redis_db"),
- python_prefix=parameters["python_prefix"].rstrip("/"),
- )
- if not os.path.exists(flags.output_dir):
- os.makedirs(flags.output_dir)
- main_log = Logger()
- """Lemon process"""
- main_log.logger.info("Success: Lemon start successfully!")
- start_time = datetime.datetime.now()
- for exp_identifier in flags.exps:
- """Make directory"""
- experiment_dir = os.path.join(
- flags.output_dir, exp_identifier
- ) # exp : like lenet5-mnist
- mut_dir = os.path.join(experiment_dir, "mut_model")
- crash_dir = os.path.join(experiment_dir, "crash")
- nan_dir = os.path.join(experiment_dir, "nan")
- inner_output_dir = os.path.join(experiment_dir, "inner_output")
- metrics_result_dir = os.path.join(experiment_dir, "metrics_result")
- print(experiment_dir)
- if not os.path.exists(experiment_dir):
- os.makedirs(experiment_dir)
- if not os.path.exists(mut_dir):
- os.makedirs(mut_dir)
- if not os.path.exists(crash_dir):
- os.makedirs(crash_dir)
- if not os.path.exists(nan_dir):
- os.makedirs(nan_dir)
- if not os.path.exists(inner_output_dir):
- os.makedirs(inner_output_dir)
- if not os.path.exists(metrics_result_dir):
- os.makedirs(metrics_result_dir)
- try:
- """Mutate and get output of different backends"""
- main_log.info("INFO:Lemon mutation starting!")
- main_log.info("INFO:Lemon for exp: {}".format(exp_identifier))
- if "svhn" in exp_identifier or "fashion2" in exp_identifier:
- origin_model_name = "{}_origin.hdf5".format(exp_identifier)
- else:
- origin_model_name = "{}_origin.h5".format(exp_identifier)
- origin_model_file = os.path.join(flags.origin_model_dir, origin_model_name)
- mutate_lemon = (
- "{}/lemon/bin/python -u -m mutate_lemon --mutate_op {} --model {} --output_dir {}"
- " --backends {} --mutate_num {} --mutate_ratio {} --exp {} --test_size {} --redis_db {} --config_name {}".format(
- flags.python_prefix,
- flags.mutate_ops,
- origin_model_file,
- flags.output_dir,
- flags.backend,
- flags.mutate_num,
- flags.mutate_ratio,
- exp_identifier,
- flags.test_size,
- flags.redis_db,
- config_name,
- )
- )
- os.system(mutate_lemon)
- print(mutate_lemon)
- except Exception:
- main_log.error("Error: Lemon for exp:{} Failed!".format(exp_identifier))
- main_log.exception(sys.exc_info())
- end_time = datetime.datetime.now()
- time_delta = end_time - start_time
- h, m, s = utils.ToolUtils.get_HH_mm_ss(time_delta)
- main_log.info(
- "INFO:Lemon is done: Time used: {} hour,{} min,{} sec".format(h, m, s)
- )
- if __name__ == "__main__":
- # config_name = sys.argv[1]
- config_name = "demo.conf"
- parse = argparse.ArgumentParser()
- parse.add_argument(
- "--exp",
- type=str,
- choices=[
- "lexnet-cifar10",
- "lenet5-fashion-mnist",
- "fashion2",
- "svhn",
- "lenet5-mnist",
- "alexnet-cifar10",
- "mobilenet.1.00.224-imagenet",
- "vgg16-imagenet",
- ],
- help="experiments identifiers",
- )
- parse.add_argument("--root_dir", type=str, help="root dir")
- parse.add_argument(
- "--output_dir", type=str, help="relative path of output dir(from root dir)"
- )
- parse.add_argument(
- "--mutate_num",
- type=int,
- help="number of variant models generated by each mutation operator",
- )
- parse.add_argument("--config_name", type=str, help="config name,like demo.conf")
- flags_input, unparsed = parse.parse_known_args(sys.argv[1:])
- lemon_cfg = configparser.ConfigParser()
- cfg_path = os.path.join(flags_input.root_dir, "config", flags_input.config_name)
- lemon_cfg.read(cfg_path)
- parameters = lemon_cfg["parameters"]
- flags = argparse.Namespace(
- mutate_ops=parameters["mutate_ops"],
- exps=flags_input.exp.lstrip().rstrip().split(" "),
- origin_model_dir=os.path.join(
- flags_input.root_dir, parameters["origin_model_dir"]
- ),
- output_dir=flags_input.output_dir,
- backend=parameters["backend"],
- mutate_num=flags_input.mutate_num,
- mutate_ratio=parameters.getfloat("mutate_ratio"),
- test_size=parameters.getint("test_size"),
- threshold=parameters.getfloat("threshold"),
- redis_db=lemon_cfg["parameters"].getint("redis_db"),
- python_prefix=parameters["python_prefix"].rstrip("/"),
- )
- parse = argparse.ArgumentParser()
- if not os.path.exists(flags.output_dir):
- os.makedirs(flags.output_dir)
- main_log = Logger()
- """Lemon process"""
- main_log.logger.info("Success: Lemon start successfully!")
- start_time = datetime.datetime.now()
- for exp_identifier in flags.exps:
- """Make directory"""
- experiment_dir = os.path.join(
- flags.output_dir, exp_identifier
- ) # exp : like lenet5-mnist
- mut_dir = os.path.join(experiment_dir, "mut_model")
- crash_dir = os.path.join(experiment_dir, "crash")
- nan_dir = os.path.join(experiment_dir, "nan")
- inner_output_dir = os.path.join(experiment_dir, "inner_output")
- metrics_result_dir = os.path.join(experiment_dir, "metrics_result")
- print(experiment_dir)
- if not os.path.exists(experiment_dir):
- os.makedirs(experiment_dir)
- if not os.path.exists(mut_dir):
- os.makedirs(mut_dir)
- if not os.path.exists(crash_dir):
- os.makedirs(crash_dir)
- if not os.path.exists(nan_dir):
- os.makedirs(nan_dir)
- if not os.path.exists(inner_output_dir):
- os.makedirs(inner_output_dir)
- if not os.path.exists(metrics_result_dir):
- os.makedirs(metrics_result_dir)
- try:
- """Mutate and get output of different backends"""
- main_log.info("INFO:Lemon mutation starting!")
- main_log.info("INFO:Lemon for exp: {}".format(exp_identifier))
- if "svhn" in exp_identifier or "fashion2" in exp_identifier:
- origin_model_name = "{}_origin.hdf5".format(exp_identifier)
- else:
- origin_model_name = "{}_origin.h5".format(exp_identifier)
- origin_model_file = os.path.join(flags.origin_model_dir, origin_model_name)
- mutate_lemon = (
- "{}/lemon/bin/python -u -m mutate_lemon --mutate_op {} --model {} --output_dir {}"
- " --backends {} --mutate_num {} --mutate_ratio {} --exp {} --test_size {} --redis_db {} --config_name {}".format(
- flags.python_prefix,
- flags.mutate_ops,
- origin_model_file,
- flags.output_dir,
- flags.backend,
- flags.mutate_num,
- flags.mutate_ratio,
- exp_identifier,
- flags.test_size,
- flags.redis_db,
- config_name,
- )
- )
- os.system(mutate_lemon)
- print(mutate_lemon)
- except Exception:
- main_log.error("Error: Lemon for exp:{} Failed!".format(exp_identifier))
- main_log.exception(sys.exc_info())
- end_time = datetime.datetime.now()
- time_delta = end_time - start_time
- h, m, s = utils.ToolUtils.get_HH_mm_ss(time_delta)
- main_log.info(
- "INFO:Lemon is done: Time used: {} hour,{} min,{} sec".format(h, m, s)
- )
|