art.c 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include "darknet.h"
  2. #include <sys/time.h>
  3. void demo_art(char *cfgfile, char *weightfile, int cam_index)
  4. {
  5. #ifdef OPENCV
  6. network *net = load_network(cfgfile, weightfile, 0);
  7. set_batch_network(net, 1);
  8. srand(2222222);
  9. void * cap = open_video_stream(0, cam_index, 0,0,0);
  10. char *window = "ArtJudgementBot9000!!!";
  11. if(!cap) error("Couldn't connect to webcam.\n");
  12. int i;
  13. int idx[] = {37, 401, 434};
  14. int n = sizeof(idx)/sizeof(idx[0]);
  15. while(1){
  16. image in = get_image_from_stream(cap);
  17. image in_s = resize_image(in, net->w, net->h);
  18. float *p = network_predict(net, in_s.data);
  19. printf("\033[2J");
  20. printf("\033[1;1H");
  21. float score = 0;
  22. for(i = 0; i < n; ++i){
  23. float s = p[idx[i]];
  24. if (s > score) score = s;
  25. }
  26. score = score;
  27. printf("I APPRECIATE THIS ARTWORK: %10.7f%%\n", score*100);
  28. printf("[");
  29. int upper = 30;
  30. for(i = 0; i < upper; ++i){
  31. printf("%c", ((i+.5) < score*upper) ? 219 : ' ');
  32. }
  33. printf("]\n");
  34. show_image(in, window, 1);
  35. free_image(in_s);
  36. free_image(in);
  37. }
  38. #endif
  39. }
  40. void run_art(int argc, char **argv)
  41. {
  42. int cam_index = find_int_arg(argc, argv, "-c", 0);
  43. char *cfg = argv[2];
  44. char *weights = argv[3];
  45. demo_art(cfg, weights, cam_index);
  46. }