Skip to content

Commit

Permalink
Evaluation test added to regression test.
Browse files Browse the repository at this point in the history
Map value information is detailed.
  • Loading branch information
asyatrhl committed Sep 19, 2023
1 parent e536a08 commit 1464fb8
Show file tree
Hide file tree
Showing 5 changed files with 120 additions and 3 deletions.
65 changes: 65 additions & 0 deletions regression/create_eval_script.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
###################################################################################################
#
# Copyright © 2023 Analog Devices, Inc. All Rights Reserved.
# This software is proprietary and confidential to Analog Devices, Inc. and its licensors.
#
###################################################################################################
"""
Create training bash scripts for test
"""
import argparse
import os

import yaml


def joining(lst):
"""
Join list based on the ' ' delimiter
"""
join_str = ' '.join(lst)
return join_str


parser = argparse.ArgumentParser()
parser.add_argument('--testconf', help='Enter the config file for the test', required=True)
parser.add_argument('--testpaths', help='Enter the paths for the test', required=True)
args = parser.parse_args()
yaml_path = args.testconf
test_path = args.testpaths

# Open the YAML file
with open(yaml_path, 'r', encoding='utf-8') as yaml_file:
# Load the YAML content into a Python dictionary
config = yaml.safe_load(yaml_file)

with open(test_path, 'r', encoding='utf-8') as path_file:
# Load the YAML content into a Python dictionary
pathconfig = yaml.safe_load(path_file)

# Folder containing the files to be concatenated
script_path = pathconfig["script_path"]

# Output file name and path
output_file_path = pathconfig["output_file_path_evaluation"]

# Loop through all files in the folder
with open(output_file_path, "w", encoding='utf-8') as evaluate_file:
for filename in os.listdir(script_path):
# Check if the file is a text file
if filename.startswith("evaluate"):
# Open the file and read its contents
with open(os.path.join(script_path, filename), encoding='utf-8') as input_file:
contents = input_file.read()
temp = contents.split()
temp.insert(1, "\n")

i = temp.index("--exp-load-weights-from")
temp[i+1] = temp[i+1][1:]

temp.insert(-1, "--name " + filename[9:-3])
temp.insert(-1, "--data /data_ssd")

temp.append(" \n")
contents = joining(temp)
evaluate_file.write(contents)
46 changes: 46 additions & 0 deletions regression/eval_pass_fail.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
###################################################################################################
#
# Copyright © 2023 Analog Devices, Inc. All Rights Reserved.
# This software is proprietary and confidential to Analog Devices, Inc. and its licensors.
#
###################################################################################################
"""
Check the test results
"""
import argparse
import os

import yaml

parser = argparse.ArgumentParser()
parser.add_argument('--testpaths', help='Enter the paths for the test', required=True)
args = parser.parse_args()
test_path = args.testpaths

# Open the YAML file
with open(test_path, 'r', encoding='utf-8') as path_file:
# Load the YAML content into a Python dictionary
pathconfig = yaml.safe_load(path_file)

eval_path = pathconfig["eval_path"]
eval_file = os.listdir(eval_path)[-1]
directory_path = os.path.join(eval_path, eval_file)
passed = []
failed = []

for filename in sorted(os.listdir(directory_path)):
path = os.path.join(directory_path, filename)
file_path = os.path.join(path, os.listdir(path)[0])
with open(file_path, 'r', encoding='utf-8') as file:
content = file.read()
if "Loss" in content:
pass_file = filename.split("___")[0]
passed.append(f"\033[32m\u2714\033[0m Evaluation test passed for {pass_file}.")
else:
fail_file = filename.split("___")[0]
failed.append(f"\033[31m\u2718\033[0m Evaluation test failed for {fail_file}.")

for filename in failed:
print(filename)
for filename in passed:
print(filename)
2 changes: 1 addition & 1 deletion regression/log_comparison.py
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ def compare_logs(old_log, new_log, output_name, output_pth):
i = 0
for (map1, map2) in zip(mAP_list1, mAP_list2):
if float(map1[1]) == 0:
print("Map value of " + output_name + " is 0.00.")
print(f"Map value of {output_name} is 0.00 at epoch {i}.")
map1[1] = 0.000001
i = i+1
if '[mAP:' in map2:
Expand Down
3 changes: 2 additions & 1 deletion regression/paths.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ train_path: /home/test/max7800x/test_scripts/output_file.sh

script_path: ./scripts
output_file_path: ./scripts/output_file.sh

output_file_path_evaluation: ./scripts/evaluation_file.sh

# last_dev.py

Expand All @@ -31,3 +31,4 @@ output_path: /home/test/max7800x/log_diff/
# pass_fail.py

log_path: /home/test/max7800x/log_diff
eval_path: /home/test/max7800x/evaluation_logs/
7 changes: 6 additions & 1 deletion regression/test_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,12 @@ ImageNet:
datapath: "/data_ssd"
ai87imageneteffnetv2:
threshold: -5
epoch: 13
epoch: 15
ImageNet_Bayer:
datapath: "/data_ssd"
bayer2rgbnet:
threshold: -5
epoch: 15
KWS_20:
datapath: "/data_ssd"
ai85kws20net:
Expand Down

0 comments on commit 1464fb8

Please sign in to comment.