mirror of
https://github.com/pjreddie/darknet.git
synced 2023-08-10 21:13:14 +03:00
Added param -dont_show to detect objects on servers without display, like Amazon EC2
This commit is contained in:
4
build/darknet/x64/darknet_many_images.cmd
Normal file
4
build/darknet/x64/darknet_many_images.cmd
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
darknet.exe detector test data/voc.data yolo-voc.cfg yolo-voc.weights -dont_show < data/train.txt > result.txt
|
||||||
|
|
||||||
|
|
||||||
|
pause
|
47
src/demo.c
47
src/demo.c
@ -49,7 +49,7 @@ static IplImage* ipl_images[FRAMES];
|
|||||||
static float *avg;
|
static float *avg;
|
||||||
|
|
||||||
void draw_detections_cv(IplImage* show_img, int num, float thresh, box *boxes, float **probs, char **names, image **alphabet, int classes);
|
void draw_detections_cv(IplImage* show_img, int num, float thresh, box *boxes, float **probs, char **names, image **alphabet, int classes);
|
||||||
void show_image_cv_ipl(IplImage *disp, const char *name, CvVideoWriter *output_video_writer, int http_stream_port);
|
void show_image_cv_ipl(IplImage *disp, const char *name);
|
||||||
image get_image_from_stream_resize(CvCapture *cap, int w, int h, IplImage** in_img);
|
image get_image_from_stream_resize(CvCapture *cap, int w, int h, IplImage** in_img);
|
||||||
IplImage* in_img;
|
IplImage* in_img;
|
||||||
IplImage* det_img;
|
IplImage* det_img;
|
||||||
@ -121,7 +121,7 @@ double get_wall_time()
|
|||||||
}
|
}
|
||||||
|
|
||||||
void demo(char *cfgfile, char *weightfile, float thresh, int cam_index, const char *filename, char **names, int classes,
|
void demo(char *cfgfile, char *weightfile, float thresh, int cam_index, const char *filename, char **names, int classes,
|
||||||
int frame_skip, char *prefix, char *out_filename, int http_stream_port)
|
int frame_skip, char *prefix, char *out_filename, int http_stream_port, int dont_show)
|
||||||
{
|
{
|
||||||
//skip = frame_skip;
|
//skip = frame_skip;
|
||||||
image **alphabet = load_alphabet();
|
image **alphabet = load_alphabet();
|
||||||
@ -184,7 +184,7 @@ void demo(char *cfgfile, char *weightfile, float thresh, int cam_index, const ch
|
|||||||
}
|
}
|
||||||
|
|
||||||
int count = 0;
|
int count = 0;
|
||||||
if(!prefix){
|
if(!prefix && !dont_show){
|
||||||
cvNamedWindow("Demo", CV_WINDOW_NORMAL);
|
cvNamedWindow("Demo", CV_WINDOW_NORMAL);
|
||||||
cvMoveWindow("Demo", 0, 0);
|
cvMoveWindow("Demo", 0, 0);
|
||||||
cvResizeWindow("Demo", 1352, 1013);
|
cvResizeWindow("Demo", 1352, 1013);
|
||||||
@ -216,21 +216,38 @@ void demo(char *cfgfile, char *weightfile, float thresh, int cam_index, const ch
|
|||||||
if(pthread_create(&detect_thread, 0, detect_in_thread, 0)) error("Thread creation failed");
|
if(pthread_create(&detect_thread, 0, detect_in_thread, 0)) error("Thread creation failed");
|
||||||
|
|
||||||
if(!prefix){
|
if(!prefix){
|
||||||
//show_image(disp, "Demo");
|
if (!dont_show) {
|
||||||
show_image_cv_ipl(show_img, "Demo", output_video_writer, http_stream_port);
|
show_image_cv_ipl(show_img, "Demo");
|
||||||
int c = cvWaitKey(1);
|
int c = cvWaitKey(1);
|
||||||
if (c == 10){
|
if (c == 10) {
|
||||||
if(frame_skip == 0) frame_skip = 60;
|
if (frame_skip == 0) frame_skip = 60;
|
||||||
else if(frame_skip == 4) frame_skip = 0;
|
else if (frame_skip == 4) frame_skip = 0;
|
||||||
else if(frame_skip == 60) frame_skip = 4;
|
else if (frame_skip == 60) frame_skip = 4;
|
||||||
else frame_skip = 0;
|
else frame_skip = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
char buff[256];
|
char buff[256];
|
||||||
sprintf(buff, "%s_%08d", prefix, count);
|
sprintf(buff, "%s_%08d", prefix, count);
|
||||||
save_image(disp, buff);
|
save_image(disp, buff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if you run it with param -http_port 8090 then open URL in your web-browser: http://localhost:8090
|
||||||
|
if (http_stream_port > 0) {
|
||||||
|
//int port = 8090;
|
||||||
|
int port = http_stream_port;
|
||||||
|
int timeout = 200;
|
||||||
|
int jpeg_quality = 30; // 1 - 100
|
||||||
|
send_mjpeg(show_img, port, timeout, jpeg_quality);
|
||||||
|
}
|
||||||
|
|
||||||
|
// save video file
|
||||||
|
if (output_video_writer) {
|
||||||
|
cvWriteFrame(output_video_writer, show_img);
|
||||||
|
printf("\n cvWriteFrame \n");
|
||||||
|
}
|
||||||
|
cvReleaseImage(&show_img);
|
||||||
|
|
||||||
pthread_join(fetch_thread, 0);
|
pthread_join(fetch_thread, 0);
|
||||||
pthread_join(detect_thread, 0);
|
pthread_join(detect_thread, 0);
|
||||||
|
|
||||||
@ -254,8 +271,10 @@ void demo(char *cfgfile, char *weightfile, float thresh, int cam_index, const ch
|
|||||||
free_image(disp);
|
free_image(disp);
|
||||||
disp = det;
|
disp = det;
|
||||||
}
|
}
|
||||||
show_image(disp, "Demo");
|
if (!dont_show) {
|
||||||
cvWaitKey(1);
|
show_image(disp, "Demo");
|
||||||
|
cvWaitKey(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
--delay;
|
--delay;
|
||||||
if(delay < 0){
|
if(delay < 0){
|
||||||
|
@ -798,7 +798,7 @@ void validate_detector_map(char *datacfg, char *cfgfile, char *weightfile)
|
|||||||
fprintf(stderr, "Total Detection Time: %f Seconds\n", (double)(time(0) - start));
|
fprintf(stderr, "Total Detection Time: %f Seconds\n", (double)(time(0) - start));
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_detector(char *datacfg, char *cfgfile, char *weightfile, char *filename, float thresh)
|
void test_detector(char *datacfg, char *cfgfile, char *weightfile, char *filename, float thresh, int dont_show)
|
||||||
{
|
{
|
||||||
list *options = read_data_cfg(datacfg);
|
list *options = read_data_cfg(datacfg);
|
||||||
char *name_list = option_find_str(options, "names", "data/names.list");
|
char *name_list = option_find_str(options, "names", "data/names.list");
|
||||||
@ -843,15 +843,19 @@ void test_detector(char *datacfg, char *cfgfile, char *weightfile, char *filenam
|
|||||||
if (nms) do_nms_sort(boxes, probs, l.w*l.h*l.n, l.classes, nms);
|
if (nms) do_nms_sort(boxes, probs, l.w*l.h*l.n, l.classes, nms);
|
||||||
draw_detections(im, l.w*l.h*l.n, thresh, boxes, probs, names, alphabet, l.classes);
|
draw_detections(im, l.w*l.h*l.n, thresh, boxes, probs, names, alphabet, l.classes);
|
||||||
save_image(im, "predictions");
|
save_image(im, "predictions");
|
||||||
show_image(im, "predictions");
|
if (!dont_show) {
|
||||||
|
show_image(im, "predictions");
|
||||||
|
}
|
||||||
|
|
||||||
free_image(im);
|
free_image(im);
|
||||||
free_image(sized);
|
free_image(sized);
|
||||||
free(boxes);
|
free(boxes);
|
||||||
free_ptrs((void **)probs, l.w*l.h*l.n);
|
free_ptrs((void **)probs, l.w*l.h*l.n);
|
||||||
#ifdef OPENCV
|
#ifdef OPENCV
|
||||||
cvWaitKey(0);
|
if (!dont_show) {
|
||||||
cvDestroyAllWindows();
|
cvWaitKey(0);
|
||||||
|
cvDestroyAllWindows();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
if (filename) break;
|
if (filename) break;
|
||||||
}
|
}
|
||||||
@ -859,6 +863,7 @@ void test_detector(char *datacfg, char *cfgfile, char *weightfile, char *filenam
|
|||||||
|
|
||||||
void run_detector(int argc, char **argv)
|
void run_detector(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
int dont_show = find_arg(argc, argv, "-dont_show");
|
||||||
int http_stream_port = find_int_arg(argc, argv, "-http_port", -1);
|
int http_stream_port = find_int_arg(argc, argv, "-http_port", -1);
|
||||||
char *out_filename = find_char_arg(argc, argv, "-out_filename", 0);
|
char *out_filename = find_char_arg(argc, argv, "-out_filename", 0);
|
||||||
char *prefix = find_char_arg(argc, argv, "-prefix", 0);
|
char *prefix = find_char_arg(argc, argv, "-prefix", 0);
|
||||||
@ -900,7 +905,7 @@ void run_detector(int argc, char **argv)
|
|||||||
if(weights)
|
if(weights)
|
||||||
if (weights[strlen(weights) - 1] == 0x0d) weights[strlen(weights) - 1] = 0;
|
if (weights[strlen(weights) - 1] == 0x0d) weights[strlen(weights) - 1] = 0;
|
||||||
char *filename = (argc > 6) ? argv[6]: 0;
|
char *filename = (argc > 6) ? argv[6]: 0;
|
||||||
if(0==strcmp(argv[2], "test")) test_detector(datacfg, cfg, weights, filename, thresh);
|
if(0==strcmp(argv[2], "test")) test_detector(datacfg, cfg, weights, filename, thresh, dont_show);
|
||||||
else if(0==strcmp(argv[2], "train")) train_detector(datacfg, cfg, weights, gpus, ngpus, clear);
|
else if(0==strcmp(argv[2], "train")) train_detector(datacfg, cfg, weights, gpus, ngpus, clear);
|
||||||
else if(0==strcmp(argv[2], "valid")) validate_detector(datacfg, cfg, weights);
|
else if(0==strcmp(argv[2], "valid")) validate_detector(datacfg, cfg, weights);
|
||||||
else if(0==strcmp(argv[2], "recall")) validate_detector_recall(datacfg, cfg, weights);
|
else if(0==strcmp(argv[2], "recall")) validate_detector_recall(datacfg, cfg, weights);
|
||||||
@ -912,6 +917,6 @@ void run_detector(int argc, char **argv)
|
|||||||
char **names = get_labels(name_list);
|
char **names = get_labels(name_list);
|
||||||
if(filename)
|
if(filename)
|
||||||
if (filename[strlen(filename) - 1] == 0x0d) filename[strlen(filename) - 1] = 0;
|
if (filename[strlen(filename) - 1] == 0x0d) filename[strlen(filename) - 1] = 0;
|
||||||
demo(cfg, weights, thresh, cam_index, filename, names, classes, frame_skip, prefix, out_filename, http_stream_port);
|
demo(cfg, weights, thresh, cam_index, filename, names, classes, frame_skip, prefix, out_filename, http_stream_port, dont_show);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
21
src/image.c
21
src/image.c
@ -528,7 +528,7 @@ void show_image_cv(image p, const char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void show_image_cv_ipl(IplImage *disp, const char *name, CvVideoWriter *output_video_writer, int http_stream_port)
|
void show_image_cv_ipl(IplImage *disp, const char *name)
|
||||||
{
|
{
|
||||||
if (disp == NULL) return;
|
if (disp == NULL) return;
|
||||||
char buff[256];
|
char buff[256];
|
||||||
@ -538,24 +538,7 @@ void show_image_cv_ipl(IplImage *disp, const char *name, CvVideoWriter *output_v
|
|||||||
//cvMoveWindow(buff, 100*(windows%10) + 200*(windows/10), 100*(windows%10));
|
//cvMoveWindow(buff, 100*(windows%10) + 200*(windows/10), 100*(windows%10));
|
||||||
++windows;
|
++windows;
|
||||||
cvShowImage(buff, disp);
|
cvShowImage(buff, disp);
|
||||||
|
//cvReleaseImage(&disp);
|
||||||
|
|
||||||
// http mjpeg stream: http://localhost:8090
|
|
||||||
// use URL with the port number stated in your command line instead of 8090
|
|
||||||
if (http_stream_port > 0) {
|
|
||||||
//int port = 8090;
|
|
||||||
int port = http_stream_port;
|
|
||||||
int timeout = 200;
|
|
||||||
int jpeg_quality = 30; // 1 - 100
|
|
||||||
send_mjpeg(disp, port, timeout, jpeg_quality);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(output_video_writer) {
|
|
||||||
cvWriteFrame(output_video_writer, disp); // comment this line to improve FPS !!!
|
|
||||||
printf("\n cvWriteFrame \n");
|
|
||||||
}
|
|
||||||
|
|
||||||
cvReleaseImage(&disp);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user