Skip to content

Latest commit

 

History

History
75 lines (49 loc) · 2.9 KB

README.md

File metadata and controls

75 lines (49 loc) · 2.9 KB

AvatarSim

This repository contains an avatar environment that can be programaticly controlled from Python via AirSim (https://github.com/Microsoft/AirSim).

Executable:

The executable (avatarsim.exe) includes the avatar envrionment. It is compiles for Windows 10 and runs best Nvidia GTX 1080i GPU or higher. An AirSim settings file is also included that is necessary.

The AirSim setting file should be saved as follows: C:\Users[user]\Documents\AirSim\settings.json

The executable is large (1.3GB) and can be downloaded by clicking on the following LINK.

Alt text

Avatar Control Scripts:

Python scripts are included in the repository that illustrate how to control the avatar's facial pose and expressions in order to generate face images for testing face detection algorithms. Parameters that can be controlled programmaticly are: skin tone, age, head pose, head position, facial actions based on the Facial Action Coding System (FACS).

In your python script import airsim and initialize a VehicleClient that will be the avatar:

import airsim

client = airsim.VehicleClient()
client.confirmConnection()

Head Pose and Position:

Pitch, yaw and roll of the head can be set in radians:

# Set Head Position:
q = airsim.to_quaternion(0, math.radians(opt.roll), math.radians(opt.yaw))
client.simCharSetHeadRotation(q)                # Set the head rotation.

The positions of "bones" can be set. "Bones" do not correspond to physical bones but rather landmarks on the face, the position of which can be controlled in 3D space: Alt text

# Set Bone Position:
EyeLid = airsim.Pose()
EyeLid.position = airsim.Vector3r(0, 0, 0)
EyeLid.orientation = airsim.to_quaternion(-1.5, 0, 0)
bone_setting = {'LUpperEyelid' : EyeLid}    
client.simCharSetBonePoses(bone_setting)

The skin tone and age of the avatar can be set (values from 0 (light skin tone) to 1 (dark skin tone), 0 (young appearance) to 1 (old appearance):

# Set Skin Tone:
client.simCharSetSkinDarkness(0.2)              # Set skin tone.

Present configurations of 24 facial actions (based on the Facial Action Coding System (FACS)) can be set:

FACS_values = {'FACS_01' : 0.0,  'FACS_02': 1.0, 'FACS_04': 0.0,
               'FACS_05' : 0.0,  'FACS_06': 0.0, 'FACS_07': 0.0,
               'FACS_09' : 0.0,  'FACS_10': 0.0, 'FACS_11': 0.0,
               'FACS_12' : 0.0,  'FACS_13': 0.0, 'FACS_14': 0.0,
               'FACS_15' : 0.0,  'FACS_16': 0.0, 'FACS_17': 0.0,
               'FACS_18' : 0.0,  'FACS_20': 0.0, 'FACS_22': 0.0,
               'FACS_23' : 0.0,  'FACS_24': 0.0, 'FACS_25': 0.0,
               'FACS_26' : 0.0,  'FACS_27': 0.0, 'FACS_28': 0.0}

client.simCharSetFacePresets(FACS_values)