LoginSignup
21
10

More than 1 year has passed since last update.

【Python×機械学習×React】 マッチングアプリを利用している・興味のある人向けのサービス 『マッチングアプリ プロフィール写真診断』 を作りました。 (男性向け) 【個人開発】

Last updated at Posted at 2022-04-24

サービス概要

マッチングアプリ プロフィール写真診断 トップページ.png
対応端末はPCスマホどちらも対応しております。

URL:https://profile-diagnostic.com/
Github:https://github.com/ryuki7/dating-apps-master-image-diagnostic

マッチングアプリを利用している・利用しようか迷っているが女子受けの良いプロフィール写真が分からない、マッチングアプリを利用したら自分がどれくらいモテるのかを知りたい人に
マッチングアプリのプロフィール写真に設定した場合のモテ度を教えてくれる
マッチングアプリのプロフィール写真診断サービスです。

このサービスを作った背景

私が以前開発したマッチングアプリ完全攻略サービスである、マッチングアプリマスターの運用をする中で、ユーザーから「プロフィール写真にどの写真を載せたら良いのか分からない」というフィードバックをいただいたことがきっかけです。

 マッチングアプリマスターにも、どのようなプロフィール写真を載せるのが良いのかを説明してはいるのですが、言葉だけでは分からないと思います。
そこで、画像認識AIを自作して利用し、あなたの選択した写真をマッチングアプリのプロフィール写真に設定した場合、どれくらいモテるのかを診断することで、適切なプロフィール写真を知ることができると思い、開発いたしました。

使い方

1.トップページを開いたら、「診断する」ボタンをタップ

トップページ.jpg

2.診断画面に遷移する為、ページ上部にある「写真を選択」ボタンをタップし、診断する写真を選択する

診断画面1.jpg

3.写真を選択し、下にスクロールして「写真の種類」を選択する

診断画面2.jpg

4.「写真の種類」を選択し、下にスクロールして「写真の傾き」を選択する

診断画面3.jpg

5.「写真を選択」・「写真の種類」・「写真の傾き」の3つの項目を選択すると、ページ下部に「診断」ボタンが表示されるので、「診断」ボタンをタップする

診断画面4.jpg

6.「診断」ボタンをタップすると、診断が開始されます(ロード画面)

診断中画面(ロード中).jpg

7.診断(ロード)が終わると、診断結果が表示されます

診断結果画面.jpg

診断結果を知り合いにシェアしよう!

主な使用技術

  • Python
  • Flask
  • JavaScript
  • React
  • TensorFlow(機械学習に用いるためのソフトウェアライブラリ)
  • Keras(深層学習ライブラリ)
  • NumPy(数値計算ライブラリ)
  • OpenCV(画像処理ライブラリ)
  • Gunicorn
  • Heroku

工夫したポイント

1.画像認識AIを自作し、そのAIを利用して診断結果を算出(学習済モデルに予測させる)

学習済モデルの構築

下記3種類の学習済モデルを構築しました。(Google Colaboratoryを利用)

  • faceモデル => 顔(マスク無し)
  • face_masukuモデル => 顔(マスク有り or 半顔)
  • vibeモデル => 雰囲気(スタイル)
【学習済モデルの構築の流れ】

1.各モデルに学習させる画像を2種類(モテる・モテない)ずつ収集する。
2.OpenCVを利用して、各種カスケード型識別器を使用して必要な情報のみを認識し、画像を切り取る。
※ 写真の対象に角度がついていると認識できない為、認識できなかった場合は写真を回転させて認識できるようにしている。
3.ニューラルネットワークの構築をする。
4.各モデルに切り取った画像(学習データ)正解を与えて学習させる。(教師あり学習
5.学習済モデルにテストデータを与えて予測させ、精度の確認をする。
6.精度の確認が取れたら学習済モデルの構築を完了とする。

2.SPAアプリケーションとして開発

実務に近い開発方法として、フロントエンドをReact、バックエンドをAPIとしてPythonFlask)で実装しました。

Reactは最先端のフロントエンド技術であり、海外では導入企業が多く、今後日本でも需要が高まることが予想されておりますので、学んでおいて損はないと思い、学習しました。

また、Reactはページを更新する際、ページ全体を更新せずに変更箇所のみを更新する仕組みになっており、Webページの表示速度が速いです。
※ 最初のアクセス時は、通常より読み込むデータ量が多い為、タイムラグが生じる可能性があります。
Webページの表示速度の速さは、UI/UXにおいて重要であり、少しでも速く表示されるよう改善することで離脱率を下げることに繋がります。

今後追加してみたい機能等

  • 女性向けのプロフィール写真診断機能
  • ユーザー毎の診断データの記録・履歴保存(後から見返せるようにする)

おわりに

マッチングアプリを利用している・興味はあるが女子受けの良いプロフィール写真が分からない方、マッチングアプリを利用したら自分がどれくらいモテるのかを知りたい方は、ぜひ『マッチングアプリ プロフィール写真診断』を利用してみてください!

今後も引き続き、改善できることは改善していくつもりですので、フィードバック等をいただけると幸いです。

最後まで読んでいただき、ありがとうございました!

21
10
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
21
10