I had a brief conversation with a friend about face recognition, which made me curious about the state of the art. I got interested in this four or five years ago because I saw make-up for avoiding face recognition and I tried to do it, but it didn't worked. I decided to take back the experiment now and it has been interesting. I'm using what I've learned also to design a security challenge for a group of girls studying cybersecurity and for my Mastodon followers.
This time I decided to follow a methodology more exhaustive than just painting my face as the models I watched (I did that, years ago). I wanted to know hot face recognition in general works. For that I read a couple of articles (this one and this one are the best I found for my purpose), and experimented with a library called face_recognition
for python. This was a lot of fun, it can determine if there's a face in a picture or a video and tag the person if recognised. I tried to take stock pictures of a family, tag the persons and see if they are recognised in a different picture.
(the pictures are done by Sharon McCutcheon on Unsplash and they don't require the mention but they are awesome, thanks)
The pictures of the family:
Tagged persons in an image:
After that, I made a script to check different images of a model with sketches above, and I noted down if the pattern affected the face. I firstly went with clear negatives and positives and then slowly approached to the limits in between both of them. If was a lot of fun, also requires a bit of imagination and creativity. The idea was to design something easy to draw on a face with common make-up.
Template basic face:
Obvious negative based on the template:
Successful sketch:
Serious design:
Now, after having a bunch of successful designs, the funniest part: doing the make up. I decided to try on my own, and I realized a trick to guide me: most of the phone and tablet cameras already recognizes the face, so you can start doing some of the designs and then improving them on the go bypassing the camera face recognition. Surprisingly these designs did work both on the python library and the camera face recognition, but on the other hand it's hideous. It's also nice to play with the hair but I'm quite bad at both hair-doing and make-up so...
So, I'd like to create something that automatically create those designs but I'm not very good at ML or anything, so for now I'll trust on my creativity and... lack of embarrassment I guess.
As this was a fun project, privacy is quite important and face recognition is becoming a serious matter for privacy in many places, as well as social networks are saving more and more pictures and data about ourselves. Let's consider this point! in the mean time, keep painting your face :p
Top comments (7)
Neat! I remember last year people figured out that Juggalo makeup (black and white clown facepaint, originated by rap group Insane Clown Posse) defeats facial recognition software pretty soundly too.
aaaah this is awesome
This reminds me - 'adversarial examples' might interest you as well, you seem to have stumbled on them incidentally!
Love the article!!
Also 'more' state of the art would probably be one of the many face recognition apis offered by Microsoft, Google and AWS, you should check those out too!
♥ 🔥
This is really fascinating!
Very cool!
thanks!
Could you please share your scripts?