AZIIIIIIIIZ commited on
Commit
ae88928
Β·
verified Β·
1 Parent(s): 3886eba

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +80 -79
app.py CHANGED
@@ -1,79 +1,80 @@
1
- import os
2
- from operator import itemgetter
3
- import gradio as gr
4
- from mmaction.apis import init_recognizer, inference_recognizer
5
-
6
- CONFIG_FILE = 'demo/demo_configs/tsn_r50_1x1x8_video_infer.py'
7
- CHECKPOINT_FILE = 'checkpoints/tsn_r50_1x1x3_100e_kinetics400_rgb_20200614-e508be42.pth'
8
- LABEL_FILE = 'tools/data/kinetics/label_map_k400.txt'
9
-
10
- def load_labels(path):
11
- if os.path.exists(path):
12
- with open(path, 'r') as f:
13
- return [x.strip() for x in f if x.strip()]
14
- return None
15
-
16
- def build_model():
17
- if not os.path.exists(CHECKPOINT_FILE):
18
- raise FileNotFoundError(f'Checkpoint not found at {CHECKPOINT_FILE}')
19
- return init_recognizer(CONFIG_FILE, CHECKPOINT_FILE, device='cpu')
20
-
21
- print('Initializing model...')
22
- try:
23
- model = build_model()
24
- print('βœ… Model loaded successfully!')
25
- except Exception as e:
26
- print(f'❌ Error loading model: {e}')
27
- model = None
28
-
29
- labels = load_labels(LABEL_FILE)
30
-
31
- def _resolve_video_path(video_input):
32
- """Best-effort extraction of a filesystem path from Gradio Video input."""
33
- if isinstance(video_input, str):
34
- return video_input
35
- if isinstance(video_input, dict):
36
- for key in ('name', 'path', 'video', 'file'):
37
- val = video_input.get(key)
38
- if isinstance(val, str):
39
- return val
40
- return video_input
41
-
42
-
43
- def analyze_video(video_path: str):
44
- try:
45
- if video_path is None:
46
- return 'Please upload a video file.'
47
- if model is None:
48
- return '⚠️ Model not loaded. Check logs for details.'
49
-
50
- video_fs_path = _resolve_video_path(video_path)
51
- result = inference_recognizer(model, video_fs_path)
52
-
53
- pred_scores = result.pred_score.tolist()
54
- score_sorted = sorted(zip(range(len(pred_scores)), pred_scores), key=itemgetter(1), reverse=True)
55
- top5 = score_sorted[:5]
56
-
57
- lines = []
58
- for idx, score in top5:
59
- name = labels[idx] if labels and idx < len(labels) else f'class_{idx}'
60
- lines.append(f'{name}: {score}')
61
- return '\n'.join(lines)
62
- except Exception as e:
63
- return f'❌ Error processing video: {str(e)}'
64
-
65
- demo = gr.Interface(
66
- fn=analyze_video,
67
- inputs=gr.Video(label='Upload Video', height=300),
68
- outputs=gr.Textbox(label='Analysis Results', lines=12),
69
- title='🎬 GenVidBench - TSN (MMAction2)',
70
- description='Upload a video. Inference uses TSN R50 on Kinetics-400.',
71
- cache_examples=False,
72
- flagging_mode='never'
73
- )
74
-
75
- if __name__ == '__main__':
76
- demo.launch()
77
-
78
-
79
-
 
 
1
+ import os
2
+ from operator import itemgetter
3
+ import gradio as gr
4
+ from mmaction.apis import init_recognizer, inference_recognizer
5
+
6
+ CONFIG_FILE = 'demo/demo_configs/tsn_r50_1x1x8_video_infer.py'
7
+ CHECKPOINT_FILE = 'checkpoints/tsn_r50_8xb32-1x1x8-100e_kinetics400-rgb_20220818-2692d16c.pth'
8
+ # tsn_r50_8xb32-1x1x8-100e_kinetics400-rgb_20220818-2692d16c.pth
9
+ LABEL_FILE = 'tools/data/kinetics/label_map_k400.txt'
10
+
11
+ def load_labels(path):
12
+ if os.path.exists(path):
13
+ with open(path, 'r') as f:
14
+ return [x.strip() for x in f if x.strip()]
15
+ return None
16
+
17
+ def build_model():
18
+ if not os.path.exists(CHECKPOINT_FILE):
19
+ raise FileNotFoundError(f'Checkpoint not found at {CHECKPOINT_FILE}')
20
+ return init_recognizer(CONFIG_FILE, CHECKPOINT_FILE, device='cpu')
21
+
22
+ print('Initializing model...')
23
+ try:
24
+ model = build_model()
25
+ print('βœ… Model loaded successfully!')
26
+ except Exception as e:
27
+ print(f'❌ Error loading model: {e}')
28
+ model = None
29
+
30
+ labels = load_labels(LABEL_FILE)
31
+
32
+ def _resolve_video_path(video_input):
33
+ """Best-effort extraction of a filesystem path from Gradio Video input."""
34
+ if isinstance(video_input, str):
35
+ return video_input
36
+ if isinstance(video_input, dict):
37
+ for key in ('name', 'path', 'video', 'file'):
38
+ val = video_input.get(key)
39
+ if isinstance(val, str):
40
+ return val
41
+ return video_input
42
+
43
+
44
+ def analyze_video(video_path: str):
45
+ try:
46
+ if video_path is None:
47
+ return 'Please upload a video file.'
48
+ if model is None:
49
+ return '⚠️ Model not loaded. Check logs for details.'
50
+
51
+ video_fs_path = _resolve_video_path(video_path)
52
+ result = inference_recognizer(model, video_fs_path)
53
+
54
+ pred_scores = result.pred_score.tolist()
55
+ score_sorted = sorted(zip(range(len(pred_scores)), pred_scores), key=itemgetter(1), reverse=True)
56
+ top5 = score_sorted[:5]
57
+
58
+ lines = []
59
+ for idx, score in top5:
60
+ name = labels[idx] if labels and idx < len(labels) else f'class_{idx}'
61
+ lines.append(f'{name}: {score}')
62
+ return '\n'.join(lines)
63
+ except Exception as e:
64
+ return f'❌ Error processing video: {str(e)}'
65
+
66
+ demo = gr.Interface(
67
+ fn=analyze_video,
68
+ inputs=gr.Video(label='Upload Video', height=300),
69
+ outputs=gr.Textbox(label='Analysis Results', lines=12),
70
+ title='🎬 GenVidBench - TSN (MMAction2)',
71
+ description='Upload a video. Inference uses TSN R50 on Kinetics-400.',
72
+ cache_examples=False,
73
+ flagging_mode='never'
74
+ )
75
+
76
+ if __name__ == '__main__':
77
+ demo.launch()
78
+
79
+
80
+