/SimpNet-Deep-Learning-in-a-Shader

A trainable convolutional neural network inside a fragment shader

Primary LanguageGLSLMIT LicenseMIT

SimpNet

Fig. 1 - Basic network structure

Fig. 2 - Training the network to output Apples for an apple

Overview

  • Three version of SimpNet: Python, C++, HLSL
  • Python + Keras version is the high level overview of the network structure, also does the offline training.
  • C++ + OpenCV version is a low level version to help me convert the network into HLSL.
  • HLSL version is the one used in-game in VRChat.
  • Four pre-trained networks included: Fruits, Age Classification, Hololive VTubers, and VRC Devs.

Fig.3 - The age classifier does not work well with anime faces

Live Demo

Setup for VRChat

Prerequisites

Avatars

  1. Import the SimpNet.unitypackage in Releases
  2. In Prefabs folder, put SimpNetAvatarPrefab.prefab on your avatar
  3. Unpack the prefab and put HandCamera on your hands
  4. I suggest having them off by default

Worlds

  1. Clone the repository
  2. Open the Unity project
  3. Import VRCSDK2
  4. Remove any missing scripts (Post Processing V2)

OR

  1. Open a new Unity project
  2. Import VRCSDK2
  3. Import the SimpNet.unitypackage in Releases
  4. Remove any missing scripts (Post Processing V2)

I will be converting everything to Udon at some point.

Python Code

If you wish to run the Python code, here's what you need.

  • Anaconda 1.19.12
  • Python 3.7
  • TensorFlow 1.14.0
  • Keras 2.3.1

I suggest following a guide on Keras + Anaconda installations like this one https://inmachineswetrust.com/posts/deep-learning-setup/

C++ Code

If you wish to run the C++ code.

You can follow a guide on OpenCV + Visual Studio here https://www.deciphertechnic.com/install-opencv-with-visual-studio/

How it Works

Fig. 4 - The render texture that contains the current state of the network for all the weights, outputs, and even the intermediate steps