# Copyright (c) Facebook, Inc. and its affiliates.

# This source code is licensed under the MIT license found in the
# LICENSE file in the root directory of this source tree.

sensor:
  # By default:
  # - Sensor (camera) is placed towards x-axis
  # - Sensor origin is the same as .stl/.obj origin
  
  camera:
    - cam0:
      position: [0, 0, 0.015] # Camera position
      orientation: [90, 0, -90] # Euler angles, "xyz", in degrees; e.g. [0, 0, 0]: towards negative z-axis; [90, 0, -90]: towards x-axis
      yfov: 60 # Vertical field of view in degrees
      znear: 0.001 # Distance to the near clipping plane, in meters
      lightIDList: [0, 1, 2] # Select light ID list for rendering (OpenGL has max limit of 8 lights)
  
  gel:
    origin: [0.022, 0, 0.015] # Center coordinate of the gel, in meters
    width: 1.2 # Width of the gel, y-axis, in meters; Fix me: the gel size have to be large for rendering shadows
    height: 0.8 # Height of the gel, z-axis, in meters; Fix me: the gel size have to be large for rendering shadows
    curvature: True  # Model the gel as curve? True/False
    curvatureMax: 0.005  # Deformation of the gel due to convexity
    R: 0.1 # Radius of curved gel
    countW: 100 # Number of samples for horizontal direction; higher the finer details
  
  lights:
    # Light position & properties. 
    spot: True # pyrender.SpotLight if True else pyrender.PointLight
    shadow: True # enable shadow if True; (based on testing, it requires SpotLight for rendering shadows)

    origin: [0.015, 0, 0.015] # center of the light plane, in meters

    # Light position can be expressed in:
    # - polar coordinates: r and theta. (in y-z plane), and x coordinate of the plane
    # - cartesian coordinates: xyz
    # Only one of the xyz or rtheta is required.
    polar: True # True: apply polar coordinates; False: apply cartesian coordinates;    
    xyz: # cartesian coordinates
      coords: [[0, 0.01732, 0.03], [0, -0.01732, 0.03], [0, 0, -0.03]]
    xrtheta: # polar coordinates in y-z plane
      xs: [-0.010, -0.010, -0.010] # x coordinate of the y-z plane
      rs: [0.027, 0.027, 0.027] # r in polar coordinates
      thetas: [40, 140, 270] # theta in polar coordinates, in degrees
    
    colors: [[0, 1, 0], [1, 0, 0], [0, 0, 1]] # R G B color
    intensities: [2.5, 2.5, 2.5] # light intensity

  noise: # Gaussian noise calibrated on output [0, 255]
    color:
      mean: 0 
      std: 7

  force:
    enable: True # flag for enable force feedback. When enabled, the larger normal force is, the closer object is adjusted to the sensor.
    range_force: [0, 100] # dynamic range of forces used to simulate the elastomer deformation
    max_deformation: 0.0005 # max pose depth adjustment, in meters

