Skip to content

Experimental GUI for scripting robot behaviors (for the Hanson Robotics Eva head)

License

Notifications You must be signed in to change notification settings

ragulkanth/ros-behavior-scripting

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Performance Scripting Interface

Experimental user interface for creating performance scripts to control the Hanson Robotics Eva robot head. See:

Goal: Create a Web UI that will allow theatrical performance artists to script theatrical performances for the Eva head. An example of a simple theatrical performance might be ''When a someone enters the room, briefly glance thier way, give a faint smile, then resume with the previous activity.''

The output of the script should be sequences of ROS messages that control the Eva head (turn, look, smile), as well as the timing, pitch and modulation of speech.

Creating the above might be a relatively straight-forward prorammming task, were it not for one additional requirement: the scripts should be executable within the OpenCog Atomspace framework. This is because we want, as a long-range goal, for OpenCog to be able to control the robot behavior itself, starting with more basic Psi-Theory urges and desires, rather than having Eva be an animated puppet.

This means that the authoring tool needs to be able to work with not just some convenient scripting language, but it should work very explicitly with a certain OpenCog-based scripting language.

Status

This is version 0.0.1 of the project. Almost nothing is here yet. There's going to be lots of miscellaneous experiments and a mish-mash of code.

Running

  • Use the scripts/eva.sh file, after adjusting paths in it for your installation. Or use the below:

  • Start the webcam, pi_vision, and tf2 tracking nodes as usual.

  • Start the Eva blender node, as usual.

  • Start the cogserver.

  • Load the scripts shown in scripts/eva.sh

  • Start the opencog face-tracking node in the face_track directory.

Owyl implementation

The previous implementation used Owyl trees to represent behaviors. There was no GUI or API for this: the behaviors are hard-coded in python. It can be found here:

https://github.com/hansonrobotics/eva_behavior Here's a summary of the behaviors it scripts:

  • If the scene was empty and someone arrives, Eva interacts with the new arrival. Start by showing 'surprised' expression.

  • If Eva is currently interacting with someone, and someone else arrives, she will either (dice-roll): glance at the newcomer or ignore them. The probability of a glance increases if she has been interacting for a while.

  • If the person she is interacting with leaves, show a frustrated emotion. Frustrated emotions are: sad, confused, recoil, surprised.

  • If someone else leaves, glance at that last location, or ignore the departure.

  • While interacting with someone: -- randomly display one of: happy, comprehending, engaged -- Ocasionally glance at other faces in the room. -- If the interaction has been long-running, then switch and pay attention to someone new

  • If the room is empty: -- showed bored expression (one of bored, sad, happy) -- look around the room -- If room still empty, yawn, blink-sleepy -- Go to sleep. Periodically wake. Wake gestures: shake-2, shake-3, blink

Resources:

About

Experimental GUI for scripting robot behaviors (for the Hanson Robotics Eva head)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 74.8%
  • Scheme 18.9%
  • Shell 6.3%