Tuesday, 27 November 2007
Recent Activity
My intention is to try and get the emotion engine complete or close over Christmas, as well as building on the VR project (mentioned below) to start the framework for the visual interface.
Quick update: Despite Prologs flexibility, it will be easier to program the emotion framework in C++, given that I can load emotion states from external files, and also change emotional reaction to stimuli. This shows evolution of emotions and learning etc.
Thursday, 8 November 2007
Emotion Design 2
Further Emotion Engine Design
Now comes the time of actually attempting to put the design into Prolog. It's been a while since I last used prolog, so this process is something of trial and error. I'm going attempt to keep a record of this process, though I'm likely to forget to record something.
In addition, following a recent lecture, it seemed that a further emotion was missing from the emotion engine - Desire. Desire drives us in many aspects of our lives, particularly in the early part of our development.
In fact, it seems to me that disgust is the opposite of desire, so the relate that way. I just need to make sure that when a negative disgust is activated (i.e. desire) this should have an effect on the emotional state.
An additional aspect that came to my mind following the above thought was "learning". In order to be an "intelligent" character, does my character need to include learning?
Emotions stand as this, given as Positive/Negative: [Happiness/Sadness], [Peace/Anger], [Love/Hate], [Friendliness/Hostility], [Desire/Disgust].
All emotions will be 0-100 scale, whereby 0 is the negative, 49-50 is neutral and 100 is positive
Right, new rules, including desire:
1. increased anger increases sadness (or decreases happiness)
2. increased sadness doesn't affect anger
3. increased happiness decreases anger
4. the character can be calm (i.e. not angry) without being happy
5. anger should wear off
6. consistently happy character should lead to increased love
7. consistently sad/angry character should lead to hate (anger should affect more than sadness)
8. certain words should evoke love/hate response
9. strong love/hate emotions should lead to increased emotional response elsewhere
* NB. Strong love increases happiness, reduces anger, reduces hostility, reduces disgust
Strong hate decreases happiness and increases hostility
10. love above a certain level should activate flirtatiousness (?)
11. hate above a certain level should activate hostility
12. disgust should reduce all other emotions, so that it takes priority
New rules:
13. love increases desire
14. hate reduces desire
15. happiness increases desire
16. sadness reduces desire (minimally, not enough to increase disgust as such)
Interesting thought:
Emotions usually have two dimensions, their degree (i.e. what emotion and how strong) and their focus. For instance, I love this, I hate that. So far this idea of focus isn't employed. This could probably be employed in the overlying C "brain" program - focus could be set by the input, the emotional response calculated (the highest emotional level wins).
Emotion Design 1
Emotion Engine Design
Emotion needs to take a current state and a set of actions (may only be one action) and process the actions to give a new emotional state
Emotion is given as a function with several elements. These elements could come from my own approximation given on my blog: happiness, anger, love and hostility
Or alternatively use an adaptation of Ekman's model [1] as noted in AlphaWolves etc: fear, anger, sadness, happiness, disgust and surprise. Ekman's model seems to assume that you feel one emotion at a time.
My model lacks something of Ekmans, however it is simpler in one sense. A new model, improving on my own in light of Ekmans might be this: Happiness, Anger, Love, Hostility, Disgust. It seems unlikely that anything will be able to "surprise" the character, so including this emotional aspect only complicates the processing; also, I have chosen not to give my character fear (both in the interests of simplification and kindness).
The rules that I created for my emotional rules are below. These will need to be manipulated or added to in light of the additional aspect of Disgust.
1. increased anger increases sadness (or decreases happiness)
2. increased sadness doesn't affect anger
3. increased happiness decreases anger
4. the character can be calm (i.e. not angry) without being happy
5. anger should wear off
6. consistently happy character should lead to increased love
7. consistently sad/angry character should lead to hate (anger should affect more than sadness)
8. certain words should evoke love/hate response
9. strong love/hate emotions should lead to increased emotional response elsewhere
* NB. Strong love increases happiness, reduces anger, reduces hostility, reduces disgust
Strong hate decreases happiness and increases hostility
10. love above a certain level should activate flirtatiousness (?)
11. hate above a certain level should activate hostility
New rules:
12. disgust should reduce all other emotions, so that it takes priority
The Prolog action/emotion processor should be created using these rules.
Look ahead: Next step would be the Next Action function, taking received action and new emotional state to decide on a response. Responses would be limited, so it would need to choose most appropriate.
References:
[1] EKMAN, P. 1992. An Argument for Basic Emotions.
Basic Emotions. N. Stein, and Oatley, K.
Hove, UK, Lawrence Erlbaum: 169-200.
Thursday, 25 October 2007
VR and Project
So it seems my issues regarding actually creating the character may have been solved by allowing someone more talented than me to create it. Interestingly, Simant suggested that my character might not necessarily by humanoid, as I had always referred to it until that point. I guess I had always assumed that it would be easier to generate an emotive response with a humanoid character.
Speech (or rather text) is looking more and more like it won't be possible in the alloted time, so the interface is looking more like a character and a selection of buttons representing actions - this actions might include things like smiling or poking and words/phrases like "Hello!" and "You smell!" etc. As you do something to the character it will respond with gestures, and perhaps some stock phrases (e.g. "I'm sad").
The prolog Emotion Engine will hopefully be started today, or tomorrow morning.
Project Specification
I've decided to make all of my documents available online, so a link is included below. The most interesting part is Section B, the "Overall Programme" which is supposed to give an overview of my project. At the advice of my supervisor I have made this fairly vague.
www.twinklebob.f2s.com/files/project_spec.pdf
Thursday, 4 October 2007
More changes
My project supervisor brought this article on the bbc website to my attention: http://news.bbc.co.uk/2/hi/technology/6992613.stm
It talks about an AI character which lives in Second Life.
As I read the article, it just seems that this would solve a lot of my character issues, allowing me to spend even more of my time looking at the brains of this character. I've also been advised by my project supervisor that included natural language in the character may make it much more difficult, and that perhaps I should just concentrate on making the character autonomous in it's action. I'm not too sure about that yet, because that would require me to completely change my aim. Much thought to come!
Monday, 17 September 2007
Make Human
This is a 3D human which exists in C++. Will that then save me a task? Hmmm...
If it is flexible enough, it may just work. More research required. After lunch probably...
Emotions
Given that I have done some work with Prolog in my AI module last year, it seems to me that it would make sense to manage the emotional state of my character in this way. It might be easier to plug a Prolog "emotion engine" into a C++ program than program something nearly as effective in C++ itself.
The current emotional state at any moment will be given by the previous emotional state, response to certain words and perhaps response the person themselves. It seems that the best way to encode the emotions are in pairs, these are the pairs I've thought of so far (don't want too many as this will over complicate things):
- happy/sad
- angry/calm
- love/hate
- flirtatious/hostile
These emotions will also be related in certain ways. Again, the ones I have thought of so far are listed here:
- increased anger increases sadness (or decreases happiness)
- increased sadness doesn't affect anger
- increased happiness decreases anger
- the character can be calm (i.e. not angry) without being happy
- anger should wear off
- consistently happy character should lead to increased love
- consistently sad/angry character should lead to hate (anger should affect more than sadness)
- certain words should evoke love/hate response
- strong love/hate emotions should lead to increased emotional response elsewhere
- love above a certain level should activate flirtatiousness (?)
- hate above a certain level should activate hostility
With regards to response to words, the character should respond not only to words spoken to it, but to the words that the chatbot generate. I think at present that the words coming into the character should have twice the strength of words being spoken. I think it is also important that the character includes some learning ability, whereby it can add words to the love/hate lists.
I mentioned about response to the user. It would seem a good idea that the character remembers a user, even if all it does is remember the emotional state it was in when the user last finished. That way, it will appear to have emotional memory and it's response to a user will be affected by the way the user treats it.
Two last thoughts:
The "speech" of the character should also be affected by the emotional response. An angry person would not answer a question the same way as a flirtatious one.
Last but not least, I've just thought that I've been thinking about speech and emotions, but the character will exist in 3D, it will also need to have gestures! Yet another thing to think about!
We have a name!
However, this does give me one slight problem. Generi, though not entirely sexually defined (because he is a blue alien) does have a slightly more masculine look to him (thus I've been calling it a "him"). So I'm now going to have to search out another character which will work within version 6 of Maya 3D.
Thursday, 13 September 2007
Animating Generi
All that remains now is trying to make him work. You see, the problem that I have discovered is that he's going to be difficult to control. From within Maya itself it's fairly easy to modify his pose an element at a time, with the intention of creating a frame by frame animation. However, I want my character to be live and autonomous. I am somehow going to have to embed the character I have into a program, and control him from that. Keeping him within the Maya "editing" space would just look too cluttered.
I may have to wait until I can speak to someone better at 3D animation before I do that. It just so happens that I have a module this coming term on Virtual Reality - hopefully this will lead to me to an expert in this field. It looks like my research will have to move onto the AI of the character.
Animation worries relieved!
I have now come across some pre-made characters on the internet, which will remove the need to create it out of my list of tasks - this therefore gives me more time to explore the "brains" behind the autonomous character and also the interface to control the animation!
It's worth mentioning that the project supervisor (one Simant Prakoonwit) made it clear to me that the animation wasn't the real purpose of the project and that any quality of animation would be acceptable. Therefore it seems unlikely that the use of a premade character will cause any problems.
Here are just a few of the sites I have found. It seems quite likely at first look that I may use a character called Generi (from the first site listed) as this is also released for non-profit use.
My Aim
So this is the aim that I came up with, this is what I personally want to investigate with my project:
Aim: To investigate and explore whether emotion and low level communication (i.e. body language) can help communication between computers and humans (particularly in that direction)
This aim may still be edited slightly in the next few weeks or months, but it basically shows where I want to go.
Third Year Project
The aim of this blog is for me to keep an easy record of the progress on my third year project. I'm a student at the University of Reading, studying for a batchelors degree in Artificial Intelligence and Cybernetics. For the third year, rather than a dissertation we are required to do a third year project.
The aim of this blog is to record my progress at various stages (which may be useful later when doing reports etc.) and also to give me a way to share some of what I find. Also, I guess it will give me a chance to think aloud about my project.
I suppose I should mention a little of the project too. The project, titled simply "Virtual Character" is a potentially rather large project through which I should choose my own path. The general idea is to create a virtual humanoid character (or "avatar") with the capacity to communicate with more than words alone.
This is the given blurb:
The aim of the project is to construct an intelligent 3D virtual character that has intelligent behaviour. The avatar should demonstrate personality, emotions and goals.... The characters can be used in many applications, e.g. computer games, films [or] communication interfaces.