MagicMirror Forum

    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • Donate
    • Discord

    Facial Recognition Module - Step by Step Guide

    Troubleshooting
    14
    28
    22955
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • K
      konradwalsh last edited by konradwalsh

      Hi all,

      Due to there being no guide on this and I was looking for one… I have decided to just make one…
      I only start figuring it out last night and so I am still setting up. So I will complete this post as I progress.

      I am using the following hardware

      • Raspberry Pi 3

      • Logitech 1080 HD USB Webcam

      • MagicMirror is installed and confirmed functioning correctly.

      The software I am using to do this is Mobaxterm.
      It might be easier to do all of this on the PI directly.

      The steps I have taken to get this working:

      Set up the tools

      1. Facial Recognition Tools

      on the github page click download as zip
      extract zip and remove -master from the end of the folder. Note: its the internal folder that you want with the same name.
      copy to MagicMirror/modules using your FTP or whatever folder browser you are using.

      run this:

      sudo apt-get update
      sudo apt-get install libopencv-dev python-opencv
      sudo npm install python-shell
      sudo apt-get install python-pip
      

      change to the tools module folder

      cd /MagicMirror/modules/MMM-Facial-Recognition-Tools
      

      run

      sudo npm install
      
      pip install -r requirements.txt
      

      Capturing training images

      Run

      python capture.py
      

      Decide whether you want to capture images from your web cam or convert existing .jpg images.
      Enter the name of the person you are about to capture. Images will be stored in a folder named after the captured person in training_data/.
      Follow screen instructions.

      Training model

      Make sure you have captured all your images. Run ``` python train.py ``` The script will automatically scan the directory training_data/ for your images. Wait. You will end up with a training.xml file in the current directory. Copy down the ['name', 'name2','name3'] part because you will later need it for setting up your mirror's face recognition and to test your face recognition model.
      1. Test your steps so far

      Make sure your training.xml from running train.py is in this directory - /MagicMirror/modules/MMM-Facial-Recognition-Tools

      specify the face recognition algorithm in the environment with

      export FACE_ALGORITHM=1
      

      specify your user labels in the environment with

      export FACE_USERS=Alice,Bob,Casey,Doug
      

      Run

      python facerecognition.py.
      

      Success?

      1. Set up the module for the mirror
        on the github page for the MMM-Facial-Recognition page, click download as zip
        extract zip and remove -master from the end of the folder. Note: its the internal folder that you want with the same name.
        copy to MagicMirror/modules using your FTP or whatever folder browser you are using.

      Visit the terminal window and go to your newly create folder - /MagicMirror/Modules/MMM-Facial-Recognition and run

      sudo npm install
      

      Open your config.js file and add:

      {
      	module: 'MMM-Facial-Recognition',
      	config: {
      		// 1=LBPH | 2=Fisher | 3=Eigen
      		recognitionAlgorithm: 1,
      		// Threshold for the confidence of a recognized face before it's considered a
      		// positive match.  Confidence values below this threshold will be considered
      		// a positive match because the lower the confidence value, or distance, the
      		// more confident the algorithm is that the face was correctly detected.
      		lbphThreshold: 50,
      		fisherThreshold: 250,
      		eigenThreshold: 3000,
      		// force the use of a usb webcam on raspberry pi (on other platforms this is always true automatically)
      		useUSBCam: false,
      		// Path to your training xml
      		trainingFile: 'modules/MMM-Facial-Recognition/training.xml',
      		// recognition intervall in seconds (smaller number = faster but CPU intens!)
      		interval: 2,
      		// Logout delay after last recognition so that a user does not get instantly logged out if he turns away from the mirror for a few seconds
      		logoutDelay: 15,
      		// Array with usernames (copy and paste from training script)
      		users: [],
      		//Module set used for strangers and if no user is detected
      		defaultClass: "default",
      		//Set of modules which should be shown for every user
      		everyoneClass: "everyone",
      		// Boolean to toggle welcomeMessage
      		welcomeMessage: true
      	}
      },
      

      Change the line to the actual location. It’s probably still under the Tools Module

      trainingFile: 'modules/MMM-Facial-Recognition/training.xml',
      

      for me, I changed it to

      trainingFile: 'modules/MMM-Facial-Recognition-Tools/training.xml',
      

      Also, change the line called Users to add you list of users that you set up during the Capture.py section above.

      users: ['Joe'],
      

      Finally, change the line, if applicable

      useUSBCam: True,
      

      FINAL STEP!

      For each module in your config.js, set the profile under which it should load. E.g -
      {
      	module: 'example_module',
      	position: 'top_left',
      	//Set your classes here seperated by a space.
      	//Shown for all users
      	classes: 'default everyone',
      },
      {
      	module: 'example_module2',
      	position: 'top_left',
      	//Set your classes here seperated by a space.
      	//Shown for all users
      	classes: 'Joe',
      },
      

      So now the first example module will load for everyone and the second will only load for Joe.


      THIS IS AS FAR AS I AM .. I AM DOCUMENTING AS I GO

      @paviro
      Module Developer - Please feel free to copy this or use as you see fit. I hope it is helpful to anyone else

      M A 2 Replies Last reply Reply Quote 5
      • K
        konradwalsh last edited by

        reserved

        1 Reply Last reply Reply Quote 0
        • M
          MichiMauch @konradwalsh last edited by

          Hi @konradwalsh Maybe you have an idea for my problem: https://forum.magicmirror.builders/topic/9055/usb-cam-is-not-recognized-but-works

          thanks very much and greeetings
          michael

          M 1 Reply Last reply Reply Quote 0
          • M
            MichiMauch @MichiMauch last edited by

            @michimauch said in Facial Recognition Module - Step by Step Guide:

            Hi @konradwalsh Maybe you have an idea for my problem: https://forum.magicmirror.builders/topic/9055/usb-cam-is-not-recognized-but-works

            thanks very much and greeetings
            michael

            Remember to set the name list environment variable FACE_USERS
            Using default FACE_ALGORITM: 1
            Loading training data...
            mmal: mmal_vc_component_create: failed to create component 'vc.ril.camera' (1:ENOMEM)
            mmal: mmal_component_create_core: could not create component 'vc.ril.camera' (1)
            Exception in thread Thread-1:
            Traceback (most recent call last):
              File "/usr/lib/python2.7/threading.py", line 801, in __bootstrap_inner
                self.run()
              File "/home/pi/MagicMirror/modules/MMM-Facial-Recognition-Tools/lib/picam.py", line 27, in run
                with picamera.PiCamera() as camera:
              File "/usr/lib/python2.7/dist-packages/picamera/camera.py", line 431, in __init__
                self._init_camera(camera_num, stereo_mode, stereo_decimate)
              File "/usr/lib/python2.7/dist-packages/picamera/camera.py", line 460, in _init_camera
                "Camera is not enabled. Try running 'sudo raspi-config' "
            PiCameraError: Camera is not enabled. Try running 'sudo raspi-config' and ensure that the camera has been enabled.
            
            Training data loaded!
            OpenCV Error: Assertion failed (scn == 3 || scn == 4) in cvtColor, file /build/opencv-U1UwfN/opencv-2.4.9.1+dfsg1/modules/imgproc/src/color.cpp, line 3737
            Traceback (most recent call last):
              File "facerecognition.py", line 58, in <module>
                image = cv2.cvtColor(frame, cv2.COLOR_RGB2GRAY)
            cv2.error: /build/opencv-U1UwfN/opencv-2.4.9.1+dfsg1/modules/imgproc/src/color.cpp:3737: error: (-215) scn == 3 || scn == 4 in function cvtColor
            
            I 1 Reply Last reply Reply Quote 0
            • P
              paulGu last edited by

              @konradwalsh said in Facial Recognition Module - Step by Step Guide:

              trainingFile: ‘modules/MMM-Facial-Recognition/training.xml’,

              I got a issue when i add the facial module. the Facial-tools work fine, it’s seems like python script issues.

              Could anyone help me with this issue ?

              Whoops! There was an uncaught exception…
              TypeError: PythonShell is not a constructor
              at Class.python_start (/home/csc/MagicMirror/modules/MMM-Facial-Recognition/node_helper.js:11:21)
              at Class.socketNotificationReceived (/home/csc/MagicMirror/modules/MMM-Facial-Recognition/node_helper.js:40:14)
              at Socket. (/home/csc/MagicMirror/modules/node_modules/node_helper/index.js:113:11)
              at Socket.emit (events.js:182:13)
              at /home/csc/MagicMirror/node_modules/socket.io/lib/socket.js:528:12
              at process._tickCallback (internal/process/next_tick.js:61:11)
              MagicMirror will not quit, but it might be a good idea to check why this happened. Maybe no internet connection?
              If you think this really is an issue, please open an issue on GitHub: https://github.com/MichMich/MagicMirror/issues
              ^CShutting down server…

              S 1 Reply Last reply Reply Quote 1
              • S
                sumrag @paulGu last edited by

                @paulgu Hi I am having the same issue. Were you able to resolve it?

                1 Reply Last reply Reply Quote 0
                • I
                  Irfan ali last edited by

                  I also have same issue can anybody help me

                  Whoops! There was an uncaught exception…
                  TypeError: PythonShell is not a constructor
                  at Class.python_start (/home/pi/MagicMirror/modules/MMM-Facial-Recognition/node_helper.js:11:21)
                  at Class.socketNotificationReceived (/home/pi/MagicMirror/modules/MMM-Facial-Recognition/node_helper.js:40:14)

                  1 Reply Last reply Reply Quote 0
                  • I
                    Irfan ali @MichiMauch last edited by

                    @MichiMauch Are You using Webcam ?

                    A 1 Reply Last reply Reply Quote 0
                    • N
                      naktah last edited by

                      specify your user labels in the environment with

                      export FACE_USERS=Alice,Bob,Casey,Doug

                      im not sure what to do with this. do i have to write this in the terminal? because everytime i restart my pi, the facial recognition doesnt recognize my face

                      S 1 Reply Last reply Reply Quote 0
                      • S
                        sdetweil @naktah last edited by

                        @naktah u need to put that in your logon profile

                        Sam

                        Create a working config
                        How to add modules

                        N 1 Reply Last reply Reply Quote 0
                        • 1
                        • 2
                        • 3
                        • 1 / 3
                        • First post
                          Last post
                        Enjoying MagicMirror? Please consider a donation!
                        MagicMirror created by Michael Teeuw.
                        Forum managed by Paul-Vincent Roll and Rodrigo Ramírez Norambuena.
                        This forum is using NodeBB as its core | Contributors
                        Contact | Privacy Policy