forked from felixchenfy/Realtime-Action-Recognition
-
Notifications
You must be signed in to change notification settings - Fork 0
/
config.yaml
80 lines (67 loc) · 2.75 KB
/
config.yaml
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# Configurations for this project
# Classes of the actions.
# Warning: The name of training images folder should start with "${class}_".
# In src/s2_put_skeleton_txts_to_a_single_txt.py,
# The image whose label is not in `classes` will be filtered out.
classes: ['stand', 'walk', 'run', 'jump', 'sit', 'squat', 'kick', 'punch', 'wave']
#classes: ['lying', 'other', 'sitting', 'standing']
image_filename_format: "{:05d}.jpg"
skeleton_filename_format: "{:05d}.txt"
features:
window_size: 5 # Number of adjacent frames for extracting features.
s1_get_skeletons_from_training_imgs.py:
openpose:
model: cmu # cmu or mobilenet_thin. "cmu" is more accurate but slower.
img_size: 656x368 # 656x368, or 432x368, 336x288. Bigger is more accurate.
input:
images_description_txt: data/source_images3/valid_images.txt
images_folder: data/source_images3/
output:
images_info_txt: data_proc/raw_skeletons/images_info.txt
detected_skeletons_folder: &skels_folder data_proc/raw_skeletons/skeleton_res/
viz_imgs_folders: data_proc/raw_skeletons/image_viz/
s2_put_skeleton_txts_to_a_single_txt.py:
input:
# A folder of skeleton txts. Each txt corresponds to one image.
detected_skeletons_folder: *skels_folder
output:
# One txt containing all valid skeletons.
all_skeletons_txt: &skels_txt data_proc/raw_skeletons/skeletons_info.txt
s3_preprocess_features.py:
input:
all_skeletons_txt: *skels_txt
output:
processed_features: &features_x data_proc/features_X.csv
processed_features_labels: &features_y data_proc/features_Y.csv
s4_train.py:
input:
processed_features: *features_x
processed_features_labels: *features_y
output:
model_path: model/trained_classifier.pickle
s5_test.py:
# Input:
# For the input data_type, data_path, and model_path,
# please use the command line arguments.
# Output:
# The result video and skeleton txts will be saved to
# ${args.output_folder}/${DST_FOLDER_NAME}/${video_name}
# ${args.output_folder}/${DST_FOLDER_NAME}/${skeleton_folder_name}/${skeleton_filename_format}
# where `DST_FOLDER_NAME` is defined in the function `get_dst_folder_name`.
# In short, the input video or folder will have the same output folder name;
# the input webcam will have a time stamp as the folder name.
settings:
source:
webcam_max_framerate: 10.0
video_sample_interval: 1
openpose:
model: mobilenet_thin
img_size: 656x368
# model: cmu
# img_size: 432x368
display:
desired_rows: 480 # Resize the image and then display
output:
video_name: "video.avi" # save the resultant video to file
video_fps: 10.0 # at what frame rate to write the output video
skeleton_folder_name: "skeletons/"