Consumerism as a model (system design 1)

Posted by Michael on June 9th, 2006, in Development

It’s funny how thinking about models to drive autonomous characters seems like a philosophical excercise sometimes. Maybe this is only because of the words we use. But we shouldn’t let philosophical preferences influence decisions about what might be effective artistic tools, should we? Consumerism, for example, might be a good model for Drama Princess. But it should be treated only as a starting point, not as a metaphor.

Likewise, we have to use the words we choose (happiness, relationship, fascination, shock, etc) for their symbolic meaning in the context of the design and not for their meaning in natural language. On the other hand, choosing appropriate words does help thinking about the design.

Anyway, there’s a bunch of things that I don’t like about the model described below. So this is definitely not the final design. It has already moved away from its original concept and I thought I’d publish it before it gets mutilated beyond recognition.

INTRODUCTION

A Drama Princess character moves through a world of opportunities. Every object and character in the world advertises the things you can do with it to a global list of opportunities. This list is ordered differently for each character, according to parameters defined by its personality and condition. The character doesn’t make a choice: it just does the thing that is at the top of the list. Doing this thing influences the character’s condition. This leads to changes in the order of the opportunities list as a result of which the character’s behaviour will show variation and growth. At each level of the decision making process, a certain degree of randomness is mixed in, allowing for unexpected behaviour.

Environment, decision making, action and consequences…

1. ENVIRONMENT

Every object in the world comes with a set of opportunities. These are things that you can do with this object. Each opportunity promises a certain level of happiness. This promise is objective: a fixed value given by the author.

The promise is made by the object. It represents, as it were, the opinion of the object about its own capacity to give happiness (as defined by the author).

We use the word object to denote things that can be interacted with, this includes other characters and environments.

Objects are arranged in categories (or classes). Categories also have sets of opportunities that are shared with the same promise of happiness by all objects in it. To this set, each object can add individual opportunities.

E.g. Knife and plate are in the same category, look at, pick up and throw both give equal happiness. But you can only lick the plate and stick the knife in a tree. A spoon and a glass could be added to the same category without any individual opportunities.

Each character starts the game with a relationship value for each category of objects. This is how their personality is defined: they prefer interactions with certain categories of objects better than others. The relationship can be positive (friendship) or negative (hatred).

All opportunities of all objects (probably within a certain radius of the character) are published to an unordered global list of opportunities.

2. DECISION MAKING

The list of opportunities is ordered by each character individually according to a number of parameters. The topmost opportunity will become the goal, i.e. the action that the character will perform.

The parameters for decision making are:

  • an opportunity’s promise of happiness
    The higher the promise of happiness, the more chance the opportunity has to become the goal.
  • a character’s relationship with individual objects and categories
    The better the relationship with an object, the more chance an opportunity advertised by this object has to become the goal.
  • a character’s fascination with individual opportunities
    The more fascinated a character is with an opportunity, the more chance it has to become the goal.
  • a character’s attention span
    The bigger the attention span of the character, the more chance that an opportunity advertised by the previous object interacted with will become the goal.
  • the distance between the object and the character
    The closer an object is to the character, the more chance that one of its opportunities becomes the goal. This is a relative factor so that the distance to other characters can be greater than the distance to objects.

All of these can be expressed in simple values.

The content and the order of the list of opportunities is continuously updated, even when a character is moving towards a goal. This way, another opportunity can become the new goal (i.e. rise to the top of the list) even before the previous one has been achieved. This allows the character to interrupt what it is doing and respond to its environment.

Randomness will be added to ensure that the list order is continuously moving, allowing opportunities to become goals even if they don’t promise the highest level of happiness in the region. Opportunities with high promises just make more chance of becoming goals.

When a character’s relationship with an object is good, an opportunity offered by this particular object will be more likely to become the character’s goal. To prevent the same opportunity continuously becoming the goal, the character loses its fascination for the opportunity very quickly (i.e. it gets bored with doing something). This fascination is expressed in a value that the character attaches to each opportunity it has had as a goal. When an opportunity becomes a goal, the character maximizes its fascination for it. When the goal is achieved, the fascination for this opportunity is minimized. After that, this value goes up automatically until it reaches its maximum again (the speed at which fascination returns, could be different for each character).

Since fascination is not connected to objects, this leaves open the possibility of a character becoming bored with a certain type of actions. E.g. if it gets bored with eating carrots, it may also be bored with eating anything else. It is the eating it gets bored with, not the carrot. This also allows for the character to play with its food when it gets bored with eating it, for instance.

A character’s current goal will cause a high fascination with the corresponding opportunity in the list, thus ensuring the motivation of the character to achieve its goal. This fascination diminishes over time, so that if a goal cannot be achieved or if it takes too long, the characters loses interest and selects a new goal.

While fascination ensures that a character does not repeat the same action, attention span assures that the character does not keep interacting with the same object. Attention span is a single value owned by the character that decreases every time a character achieves a goal offered by the same object (but more slowly than fascination). The more the character likes the object (i.e. the better a character’s relationship is with it), the less it decreases. The lower attention span becomes, the lower the opportunities advertised by the current object sink in the list, i.e. the more chance exists that the character will choose to interact with a different object.

The more the character interacts with an object, the more it will like the object. When the relationship jumps a certain step, the attention span is increased to the maximum again. When the character starts interacting with a different object, ditto.
When the relationship has reached its optimum value, attention span does not decrease anymore (i.e. when the character is in love, it will want to spend all of its time with the object and it will not care for other objects anymore). Except through shock.

Shock replaces the dynamic list of opportunities with a specific one, forcing the character to choose a goal from one of the opportunities offered in the shock’s list. When that goal has been achieved, the dynamic list takes over again. shock also minimizes the attention span of the character, allowing it to select another object.

Shock can, for example, force the character to run away from its lover. Or to interact with another object.

A relationship is defined in a value: -1 is hostile, 0 is neutral, 1 is optimum. When a relationship with an object reaches its optimum value, interactions with it will continue to increase it. The longer the relationship lasts (i.e. the more the value rises above 1), the higher the risk of breaking up becomes. When a break-up happens, the relationship is set back to a random state (either friendly or hostile), from which it can start growing again. A break-up will probably also generate a “shock”.

Relationships modify the promise of happiness: when the character likes the object (relation more than, say, 0.5), the happiness offered by the opportunity will seem greater to the character than when the character does not like the object much (relation of 0.2). When the character hates or fears the object (relation less than 0), the happenins offered by the opportunity will seem reversed to the character, therefore this opportunity is very low in the list (unlikely to be chosen as a goal).

For example: the wolf advertises “stroke my tummy” with a promise of 0.6 happiness and “run away from me” with a promise of -0.5. If the girl likes the wolf, it will choose to stroke its tummy but if the girl really despises the wolf, her relationship of -1 will modify the promise of happiness so that “stroke my tummy” becomes -0.6 and “run away from me” become 0.5, i.e. the highest promise and therefore the chosen goal.

As a side effect, oddly, running away from a wolf that you hate will improve your relationship with the wolf because you achieved a goal that was advertised by the wolf. So next time you meet him, your response may be milder. This way, relationships can turn around. That kind of growth may be interesting dramatically.

3. ACTION

The opportunity at the top of the list is called the character’s goal. There may be multiple ways to achieve this goal but they are always tied to a specific object (or character, or environment).

Drama Princess does not have goals like “eat something” but it has goals like “eath this particular carot”. The way in which the character gets to the carrot and the way in which it eats the carrot can be different every time and for every character.

When a character has chosen a goal, Activity coordinates the action of the character with the object from whose set of opportunities the goal was chosen. If this object was also a character, its list of opportunities will be replaced by the goal to respond to the action performed by the other character. So basically it will drop whatever it was doing, to respond. In some cases, this may mean that Activity will have to make the initiating character wait until the other is ready.
This same applies to objects but it is simpler since objects don’t have a goal to interrupt. Objects often do need to animate in response to an action.

Certain goals imply a specific response from the object. Hugging, e.g., but also hitting (causes the object to fall e.g.). Other goals allow the object (always a character) to select a response from a pre-defined list of possible responses to the opportunity. The selection will be made in the same way as selections from the global list. Some goals don’t require a response from the object at all (“look at”, e.g.). In that case, Activity is not required, or the response goal is defined as “ignore”.

Since every character is “naturally” inclined to continue interacting with the previous object, a sort of conversation can start to happen if the two participants were both characters. After the goal has been achieved, Activity releases both participants and the first one who chooses a new goal with the other character “wins”. Every time they achieve a goal, their relationship is improved.

Perhaps their relationship could also be reduced, depending on chance and the level of their relationship (if their relationship is good, the chance that a goal reduces it is smaller).

4. CONSEQUENCES

Achieving a goal will

  • improve the relationship with the object that advertised the opportunity
  • minimize the fascination for that opportunity
  • maximize the attention span of the character if this was the first interaction with an object, reduce the attention span a bit, otherwise

Failing to achieve a goal will

  • reduce the relationship with the object that advertised the opportunity
  • minimize the attention span of the character

Achieving goals advertised by individual objects (or characters, or environments) will improve the relationship that the character has with these objects as individuals, outside of their category. This will allow characters to grow and to even start liking things that don’t really match their personality if given enough exposure to them.
We distinguish between objects and characters by setting the optimum relationship with objects lower than that with characters (perhaps a modifier can be added to allow for fetishists).

The character’s relationships with categories will be influenced by its relationships with individual members from these categories. So that if a character develops a good relationship with a sparrow, next time it sees any bird, it will be more positive towards it.

When a character is seperated from an object, its relationship with it reduces. When the character experiences a “shock” -e.g. when a relationship with a character breaks off-, all its relationships will be affected, causing something of a depression in the character.

Note that a character does not have a mood. Its overall happiness is determined by the relationships it has and fairly irrelevant: the character can be mostly unhappy and still enjoy interacting with certain objects or characters.

DIAGRAM

Consumerism
Objects advertise their set of opportunities to a global list (1). This global list is ordered according to the opportunities’ promises of happiness, modified by the characters’ relationship, fascination, attention span, distance and some randomness (2). The topmost opportunity becomes the goal (3). When a goal has been achieved, the characters’ relationship with the object that had advertised the opportunity is improved (4).

CONCLUSION

Consumerism is a top-down approach. Rather than constraining randomness, it starts with a fixed system of constraints that can be randomized where desired. I’d say that every condition parameter should be used with a certain measure of randomness, to allow for unexpected behaviour. Some rules will need to be prone to being broken more often than others. We’ll have to experiment with the values. Perhaps these values can also be an expression of personality.

QUESTIONS

These questions mostly express areas of discomfort with the design above and will be used when redesigning the system.

How can a character find an object to use with another object (key in door, food for hungry character, etc)?
A door would advertise “open me with a key”. If this goal is chosen, the character would try to find a key. If the character cannot find a key (i.e. if it chooses a new goal), the character would make a note that a key is a desirable object and it remembers the position of this door. Next time a character sees a key, it might pick it up. Perhaps the key advertises “use me to open door A”. The character knows where door A is. Seems like a lot of fuss. Is it worth it?

Can fascination be merged with attention span? Or perhaps with the promise of happiness (making it dynamic)?
Perhaps you could copy the complete list of opportunities with their promises of happiness to each character at the beginning of the game. Then the character can directly alter the promise of happiness values, rather than having to modify them with a second value. So rather than the attention span going up and down, the promise of happiness itself would go up and down. For goal selection, a dynamic list that only contains opportunities relevant to the situation, should still be used. This list would not contain promises of happiness. The character would need to find these in its own local copy of the list of all opportunities in the game.
Alternatively, the promise of happiness of each opportunity could be stored as an array with a column for each character.

What if a character, rather than simply choosing the happiest opportunity, chooses the one that matches its relationship with the object best?
If you hate the object, you would choose to do things that the object does not like. And vice versa.
If the happines level of the opportunity is higher than your relationship, your relationship will improve. And vice versa.
Then the opportunities advertised by the object are not promises to the character but desires of the object, arranged according to what would make the object happy.

How can characters interact with an object together for an amount of time?
For example: sitting together on a bench or the floor, riding together in a car, playing together with a toy. Perhaps the list of opportunities should be less global and be compiled with respect to the situation.

Shouldn’t the list of opportunities depend on the situation?
When a character is sitting in a tree or is locked up in a cage, a lot of opportunities in the global list would become unachievable. With the current model, a modifier would need to be added so that all of those opportunities can be excluded (unless we want the character to become depressed…). It’s probably smarter to create a context-sensitive list of opportunities to begin with (like we already do with shock and activity).

How are “shocks” generated?
Breaking up a relationship has been mentioned.
Perception could generate shocks: when an object enters the radius around the character, a shock could happen. This radius should be wider for other characters than for objects and environments.
Perhaps every time an opportunity that is the current goal disappears from the list, a shock shoud be generated, allowing a character to express its disappointment or distraction.

How do you prevent characters from choosing a goal from an object which another character is interacting with?
When an object is busy, it does not advertise its opportunities to the global list. But only to the list of the character that is interacting with it. Or perhaps it only advertises opportunities that do not interfere with the interaction (like “look at”).
Characters should be able to interrupt the interaction between other characters, though. Interactions with characters may need to be preceeded by an invitation. So that when the character chooses a goal with another character, it advertises its invitation to interact with a high promise of happiness. This invitation should be advertised only to the list of opportunities of the pertaining character. It cannot be an open invitation because the character does not have the same relationship with all characters present.
Perhaps invitiation can replace activity.

What happens when a character moves towards an object to interact with it, and another character gets to the object first?
When the object becomes unavailable, i.e. when its opportunity is no longer in the list, the character would automatically forget about the goal and choose a new one from the opportunities that are available.

Shouldn’t “look at” be seperated from opportunities?
“Look at” popped up several times as a special opportunity. If there aren’t any other opportunities in this case, it’s probably wise to have “look at” be a seperate system.
You can look at things without interrupting your interaction. A character should, e.g., look at a tree it passes by on its way to a mushroom it has chosen to pick, without forgetting about the mushroom. From observation I know that people look around all the time. In fact, they rarely look at their target. Even when people talk with each other, they keep looking around at other things.
Sometimes looking can be a vital part of the interaction, though. Like when reading a book, aiming at a target or doing fine needlework.

Do characters express emotion? How can they if all of their actions are interactions with objects?
Mood can be expressed by opportunities that the environment advertises, especially if we select goals according to compatibility with relationship.
Shocks can also offer emotional response opportunities. Perhaps the system of shocks should be expanded. How wide depends in part on the character: some characters display emotions more than others.
Purely facial expression can be driven by the combination of relationship and goal. If a goal from an object with a high relationship is selected, the character will smile. Perhaps this can be expanded to a animation modifier that makes the whole body smile, as it were (by changing speed, jerkiness and posture).
More specific emotional states could be expressed by additional graphics that represent these states (clouds for sadness, flowers for happiness, etc -as is done in Animal Crossing).
Enthusiasm for a chosen goal could be expressed in the invitation mentioned above.

Comment by andrew stern

Posted on June 10, 2006 at 6:04 am

Are you aware you’ve quite accurately described the Sims’ behavior model?

And that the Sims design is often considered an implementation of consumerist ideology, and that Will Wright himself thinks of it as a parody of consumerism?

Pingback by Drama Princess » Blog Archive » Decision filters

Posted on June 10, 2006 at 7:56 am

[…] This is a refinement of the decision making process suggested in Consumerism. […]

Comment by Michael

Posted on June 10, 2006 at 8:45 am

I wasn’t aware that I described The Sims 😳 . I hope this doesn’t mean that Drama Princess characters will be as nasty as they are. I didn’t mean for the system to express anything, least of all consumerism. I just meant it as a structure. The true expression will depend on the content (the kind of opportunities that are offered by objects). I hope.

Thanks for the links! 🙂

Comment by Michael

Posted on June 10, 2006 at 8:58 am

I have read the text about The Sims.
Now I remember that I did know about objects being labeled for Sims to read. Perhaps this slipped in subconsciously because I remember thinking that was very clever. But I had no idea that they were as active as in my model or that the same word “advertising” was used or of any of the other similarities (like objects containing interaction possibilities or categories or activity/conversation manager). I must be a genius! 😉

Anyway, apart from mine being infinitely simpler, there’s one big difference between my consumerism model and The Sims’: The Sims choose opportunities (my term) based on their own individual wants, needs and desires. Drama Princess characters use the relationship that they have with the object as the most important decision factor. I hope this make the Drama Princes and Princesses more social. 🙂
(guess The Sims are -appropriately- more true to the metaphor of consumerism)
Also, in The Sims, objects have complex ways of fullfilling the motives of the characters. In Drama Princess, interacting with objects simply alters your relationship with the object.

Conzalo Frasco points this out as well: “The Sims is not as much about human relationships as it is about life administration”.

Another difference is that my “activity” runs in instances per social interaction, while their “conversation manager” apparently deals with all social interactions at once. There are some problems with instancing “activity” in my model -in fact the current description is already one step away from the original version (which was even more similar to model in The Sims). I’ll consider a single conversation manager, but I was already moving away from this idea in favor of model of collaboration (considered to be too complex for The Sims but perhaps manageable in my much simpler system).
I’d like to know a bit more on how their conversation manager works. If anyone has any links, please post them.

The reason why Drama Princess is so much simpler that The Sims is that we hope that the imagination of the player will fill in the gaps. We hope this will lead to an interpretation of the characters as being much more intelligent and emotionally rich than is programmed for. Basically, we invite people to project their own ideas and emotions onto the characters.

Pingback by Drama Princess » Blog Archive » Imitation as expression

Posted on June 13, 2006 at 8:53 am

[…] So it seems that it would help believabilty if characters would express the effect of an interaction with each other through body language (rather than by having plus or minus signs float above their heads as in The Sims). So that when the interaction (i.e. “achieving the goal” in Consumerism speak) results in a positive effect on the relationship, the characters briefly imitate each other’s posture. Or when the effect was negative, they pursposely don’t. Perhaps the animation sequence that is played during such an interaction can end in a certain pose (it has to go back to some neutral stance anyway) which is an invitation for the other character to either immitate or ignore. […]

Pingback by Drama Princess » Blog Archive » Romanticism (system design 2)

Posted on June 14, 2006 at 9:04 am

[…] This is basically a new version of Consumerism, named after a suggestion by Patrick. I’ll try to be brief for the sake of clarity. The details can be dealt with in seperate posts. […]

Comment by Matt

Posted on June 20, 2006 at 12:49 pm

With social interactions for the sims, a seperate (invisble) object is created to control that interaction.

So that if one sim is to kiss another, the starting script (or “tree” as maxis calls them and that would be a opportunity in your terms) is attached to the sim. Once this is selected, the sim who is doing the kissing, runs that script which then creates the seperate control object and goes on to calls another script/opportunity in that control object, it also tells the sim that is being kissed to run a (different) script from the control object.

So you have the two sims (and the control object), with each sim running a different script that is part of the control object. These two scripts use internal variables of the control object to synchronize the play back of the animations. (so one sim will wait until the other sim moves next to them (and sets a variable saying it has reached the position), before they both play back the kissing animation).

As for converstations, as far as I can remember they work in a similar way except that more than two sims can be involved in the converstation. For each converstation a converstation manager object is created which then controls that converstation.

Comment by Michael

Posted on June 20, 2006 at 1:53 pm

Thank you for your comments, Matt. Where did you learn about this?

This sounds similar to Richard Evans’s “activity things“. And something that I have repeatedly considered (in Etiquette bubbles e.g.). But somehow I couldn’t bring myself to create an extra object.

So currently, in Drama Princess, an actor, after having chosen to interact with another character, will offer the other character a list of possible actions to perform as their part of the interaction (often, as in the case of kissing, there will only be a single opportunity to choose from). Then the characters just have to make sure that they start performing the action at the same moment and in the correct position. The actor who initiated the interaction controls this and basically tells the other character (or object) what to do.
The reasoning behind this is that the basis of Drama Princess is relationships that characters develop together. Drama Princess actors have no individual influence on the relationship. Relationships always develop simultaneously in both partners.

This model only allows for simple interactions. It can only deal with sequences of actions that are perfectly timed, without variables. This may be sufficient for our current needs. But it does deserve a bit more thought.

Comment by Michael

Posted on June 20, 2006 at 2:10 pm

Longer action sequences, like conversations, may already have been taken care of by the very structure of Drama Princess. Our actors are highly motivated to continue interacting with the same object for a while, especially if they like that object. This may automatically lead to the appearance of a conversation, where the synchronization comes from starting each seperate interaction together. Sometimes one actor will “lead”, sometimes the other.

Comment by Matt

Posted on June 20, 2006 at 5:37 pm

I learned about how the sims work because I used to be involved in the Sims 2 modding community so have created a few objects for the sims (I actually got involved to see how the AI did work in it). Also there was a university which did a course on creating objects for the sims 2 (maxis provided them with their in-house creation tools) and they had a (public) wiki which had maxis reference notes on (however this site is no longer active).

Some other research, in relation to objects which have behaviours attached to them, is work by Daniel Thalmann and Marcelo Kallmann on their “smart objects” (the first of their papers predates the original sims). While you could say their goal is to build a virtual human so its different to what you want to do (where you want to avoid that). I do think that you might find some of their papers interesting.

You can find some of their papers at the following sites:

http://faculty.ucmerced.edu/mkallmann/publications.html

http://vrlab.epfl.ch/Publications/publications_index.html

While your own approach is different to the ones I have tired and plan to try, I do think for a lot of cases that your approach could work very good, however I do wonder how you plan to handle certain situations when the virtual characters are “empty shells” (and I take have no knowledge of their past actions).

Say you have a husband who is working on his car, when his wife comes home and has been hurt in an attack. The first thing is how would your system handle the situation of making sure the husband went to the aid of his wife but first made sure he stopped what he was doing in a safe manor (say whatever he was doing might be dangerous if he just stopped suddenly). So how would priorities work and how would one action be stopped more quickly than normal (but not stopped suddenly). Next what if instead of his wife, it was someone just walking past his house who had got hurt. Should the priorities be different because that person doesn’t mean as much to him? (Maybe he would be more careful in stopping what he is doing) What if it was someone he really disliked? Would your system of relationships and fondness be enough to deal with situations like these?

Now what if it was actually him who had paid someone to attack his wife (maybe they were meant to have killed her). If he has no knowledge of his past actions, how would he know he had done this and how would his actions change (like if he had paid someone, then you would think that he might be much slower in reacting to her returning injured and might be angry because his plan failed).

Comment by Michael

Posted on June 20, 2006 at 6:00 pm

Thank you for the links, Matt!

I’m curious to hear more about your own current work.

Note that the answers to your questions rely on developments to the system that happened after the post to which this is a comment happened. The most important change being that actors choose opportunities that match their relationship with the object, and not simply, as in Consumerism, things that would make them the happiest.

In the case of the wounded wife, her entry on the scene would most likely cause a narrative “shock” which would force the husband to respond immediately. He might not end the action that he was working on properly given the current model. That is true. (We have been considering a hierarchical rules system that should be able to handle this sort of thing. We’ll get to that later when we design the action sequence that is the result of goal selection.)

In the case of the unknown person, the game could still produce a “shock”. Shocks are scripted triggers that are defined on a case by case basis. They are not emergent. It’s sort of like a mini-drama manager, I guess. 🙂

If there was no shock and the man loved his car more than the person, he would continue to work on his car until his “attitude” (or attention span) for the car had dropped so low to make the stranger seem more interesting than the car. So the some extent, like you suggested, he would indeed keep doing what he’s doing for a while before he helps the stranger.

If he disliked the wounded person, he would choose an opportunity that matches his relationship with the person. A bad relationship would make him do something nasty (i.e. pick an opportunity that was advertised by the wounded man as something he does not want to happen to him).

The complex psychology of a man hiring somebody to kill his wife would never be programmed by us. This kind of depth in the narrative is something we want the player to fantasize about. We want to allow for these fantasies to take place, perhaps even stimulate them. But we have not intention of representing such complex narratives (on purpose).

So all the player would see was a husband who perhaps responds a bit too slowly or too coldly to his wife’s problem (through a random decision of the system). It’s up to the player to imagine why this would be the case. We have no ambition to explain this.

In general, the kind of games and narratives that we want to build with Tale of Tales, are never this (melo-)dramatic or clearly defined. If for some exceptional reason, we would want such an event, we would probably script it. Or if we would want to create a game where this sort of thing happens all the time, we would make a special version of Drama Princess to deal with this.

Thank you for these example tests! This is very helpful. 😀

Pingback by Drama Princess » Blog Archive » Romanticism vs comfort and hanging out

Posted on July 30, 2006 at 10:47 am

[…] In the first model of Drama Princess, Consumerism, our actors are very selfish. They choose to do the things that give them the most pleasure. In the second model, Romanticism, they prefer to do things with objects that they like and they would choose to do things with these objects that feel comfortable (i.e. that match the relationship that they have with them the best). […]

Leave a comment

You must be logged in to post a comment.