首页 / 专利库 / 人工智能 / 虚拟界面 / Social dilemma software for evaluating online interactive societies

Social dilemma software for evaluating online interactive societies

阅读:657发布:2023-12-23

专利汇可以提供Social dilemma software for evaluating online interactive societies专利检索,专利查询,专利分析的服务。并且Social dilemma virtual world environment (VWE) software facilitates creation and usage of social dilemma tests or exercises for measuring and analyzing online interactive societies. An online interactive society arises whenever two or more people interact through a computer-based communication medium, which may include text or written communication, audio communication, still or motion video communication, or any combination of these communication formats. The social dilemma VWE software and the methodology of the present invention are capable of distinguishing the levels of cooperation and trust that are created by various interface and social factors within online interactive societies. Evaluating with social dilemma VWE software the effects of such social and interface factors on the degree of online cooperation allows such factors to be incorporated into the design and functionality of online interactive societies.,下面是Social dilemma software for evaluating online interactive societies专利的具体信息内容。

What is claimed is:1. In a computer-readable medium, software objects of a social dilemma virtual world environment for evaluating an interactive online society of plural participants, the software objects comprising:one or more social dilemma exercise objects that, when executed on a computer, implement a social dilemma exercise between the participants and logs social factors and interface factors that can be evaluated to determine a level of success of the social dilemma exercise; andone or more computer-based communication objects that, when executed on a computer, selectively provide computer-based communication between participants in the social dilemma exercise.2. The software objects of claim 1 in which the one or more social dilemma exercise objects are distributed between computer readable media associated with a server computer and computer readable media associated with a plurality of client computers operated by corresponding ones of the participants.3. The software objects of claim 2 further comprising user interface objects at the client computers in communication with the one or more social dilemma exercise objects to provide corresponding user interfaces at the client computers.4. The software objects of claim 2, wherein the user interface object enable a different user interface to be provided for each client computer.5. The software objects of claim 1 in which the one or more computer-based communication objects are configured to selectively provide synchronous text chat computer-based communication between the participants.6. The software objects of claim 1, the one or more computer-based communication objects further configured to monitor and log social dilemma exercise interactions between the participants.7. The software objects of claim 6 in which the social dilemma exercise interactions further comprise social factors and interface factors.8. A method of evaluating online interactive communications, comprising:selecting a first set of social factors and interface factors in a distributed social dilemma exercise;selecting a second set of social factors and interface factors in the social distributed social dilemma exercise, at least one of the factors in the first and second sets being different;conducting for plural participants at east one social dilemma exercise utilizing the first and second set of factors; andlogging results of the social dilemma exercise so that the effect of the existence of the different factors can be evaluated.9. The method of claim 8 wherein the social factors include at least one of the following social factors: synchronous text chat; asynchronous text chat; verbal communication; audio communication; video communication; historical information; social information; background information.10. The method of claim 8 wherein the interface factors further comprise format, style and/or layout of a computer-based interactive environment.11. The method of claim 8 wherein the logged results can be evaluated to determine the effects of the social factors and the interface factors on a degree of online cooperation between the participants.12. The method of claim 8 further comprising altering at least one social or interface factor in either the first set of factors or the second set of factors and logging subsequent results of the social dilemma exercise so that the effect of the alteration can be evaluated.13. The method of claim 8 in which the social factors and the interface factors are related to client computers representing the participants, wherein the social dilemma exercise is initiated from a server computer that communicates with the client computers.14. An online interactive communications evaluation system, comprising:one or more social factor objects stored on one or more computer-readable media that, when executed, provide social factors of an online social dilemma exercise to multiple participants;one or more interface factor objects stored on one or more computer-readable media that, when executed, provide interface factors of the online social dilemma exercise to multiple participants;means for providing communication between the online participants;means for monitoring inter-participant communications; andan evaluation object configured to correlate results of the social dilemma exercise with the inter-participant communication.15. The system of claim 14 in which the social factor objects comprise the means for providing the communication between the participants.16. The system of claim 15 in which the social factor objects selectively provide the inter-participant communication between the participants.17. The system of claim 14 in which the interface factor objects are further configured to provide control over a layout and style in which the social dilemma exercise is presented to the participants.18. The system of claim 17 in which the interface factor objects are configurable to provide different presentations of the social dilemma exercise to the participants.19. The system of claim 14 in which the social factor objects and interface factor objects are distributed between computer readable media associated with a server computer and computer readable media associated with plural client computers operated by corresponding ones of the participants.20. The system of claim 19 further comprising user interface objects at the client computers in communication with the social factor objects and interface factor objects to provide corresponding outputs at the client computers.

说明书全文

RELATED APPLICATION

This application claims the benefit of the filing date of U.S. provisional application No. 60/100,423, filed Sep. 15, 1998.

FIELD OF THE INVENTION

The present invention relates to evaluating social aspects of online interactive societies and, in particular, to utilizing an object oriented multi-user domain to provide social dilemma exercises to evaluate interactions between people in online interactive societies.

BACKGROUND AND SUMMARY OF THE INVENTION

An online interactive society arises whenever two or more people interact through a computer-based communication medium, which may include text or written communication, audio communication, still or motion video communication, or any combination of these communication formats. Online interactive societies can include interactions between a customer and a service provider at a commercial or transactional network site, interactions between collaborating workers or professionals, conversational interactions between two or more people, interactions between participants in a game or other recreational activity, etc. Such interactions can occur over a variety of computer connections, including networks such as the Internet, intranets, LANs, WANS, etc.

Online interactive computer systems evolved from prior stand-alone computer systems. The user interface aspects of both types of computer systems have typically focussed on computer system capabilities, user convenience and ease of use, and design aesthetics. These different considerations are often applied to the design of a user interface based upon intuitive conclusions reached by the system designers. While these design considerations may have been adequate for stand-alone computer applications, the social aspect of online interactive computer systems requires additional considerations than those typically applied to stand-alone computer systems.

In an online interactive computer system, the type and format of the interaction or communication between people can be considered a user interface aspect of the system or, more likely, can reach to the core functionality of the system. In view of the importance of the interactive or social aspects of such computer systems, evaluation of the interface and social aspects of online interactive computer systems requires a more quantitative analysis.

One metric social scientists have developed to measure the success of a relationship or group is the level of trust or cooperation between members of the group. Well-defined models and methods have been developed to test the existence and dynamics of cooperation in social relations, including the use of social dilemmas. Social dilemmas are situations in which an individually reasonable decision can result in everyone in the “society” being relatively better or worse off. Models of social dilemmas capture this tension between individually and collectively beneficial outcomes and so can be used to assess the level of cooperation and trust in a group such as an online interactive society.

The present invention provides social dilemma virtual world environment (VWE) software that facilitates creation and usage of social dilemma tests or exercises for measuring and analyzing online interactive societies. A virtual world represents a real or imaginary place using graphics, images, video, force feedback, and audio data to define a representation of the place on a computer for one or more users. Typically, the virtual world enables multiple users to simultaneously perceive and interact with the virtual world and with each other through different computers that are connected by a network.

The social dilemma VWE software and the methodology of the present invention are capable of distinguishing the levels of cooperation and trust that are created by various interface and social factors within online interactive societies. Evaluating with social dilemma VWE software the effects of such social and interface factors on the degree of online cooperation allows such factors to be incorporated into the design and functionality of online interactive societies.

Social factors that can be evaluated with the social dilemma VWE software may include the availability or absence of unstructured communications such as with synchronous text chat, asynchronous text chat (e.g., e-mail), verbal or audio communication, still or motion video communication, historical, social, or other background information about others, etc. Interface factors that can be evaluated with the social dilemma VWE software may include the format, style, or layout of the computer-based interactive environment, including interface colors, fonts, font sizes, the presence or absence of graphical user interface components, terminology for user controls or instructions, etc. Two examples of social dilemmas that can be implemented with the social dilemma VWE software are the classic. Prisoner's Dilemma and the continuous Prisoner's Dilemma.

In one implementation a social dilemma virtual world environment has a multi-user virtual social dilemma exercise object (ShowRoom) in which social dilemma exercise component objects (ShowItems) are presented from a server to multiple social dilemma participants at multiple client computers. Each client computer includes interface objects (ShowIets) that communicate with the social dilemma exercise component objects to render corresponding information or exercise features at the participants' client computers (e.g., displays, multimedia information, or other outputs) and to pass to the objects input or communications from the exercise participants.

Additional objects and advantages of the present invention will be apparent from the detailed description of the preferred embodiment thereof, which proceeds with reference to the accompanying drawings.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1

is a block diagram of a computer system that may be used to implement the present invention.

FIG. 2

is a block diagram of a prior art interfaced software object.

FIG. 3

is an exemplary view of the client-server architecture showing the world database maintained by the server computer and local databases maintained by each of n-number of client computers.

FIG. 4

is a schematic illustration of social dilemma virtual world environment (VWE) computer software to aid in the design and study of online interactive societies.

FIG. 5

is an illustration of a participant interface rendered on a display screen associated with a participant client computer in connection with a social dilemma exercise.

FIG. 6

is a flow diagram of a social dilemma exercise method illustrating an exemplary continuous Prisoners Dilemma exercise.

FIG. 7

is a graph illustrating analytical results of social dilemma exercises measuring the levels of social cooperation in the presence or absence of synchronous text chat in the exercises.

FIG. 8

is a block diagram representing hierarchical inheritance relationships between an exemplary set of objects.

FIG. 9

is a block diagram illustrating a sequence of hierarchical inheritance relationships.

FIG. 10

is a flow diagram illustrating a hierarchical inheritance process.

DETAILED DESCRIPTION OF PREFERRED EMBODIMENT

FIG. 1

illustrates an operating environment for an embodiment of the present invention as a computer system

20

with a computer

22

that comprises at least one high speed processing unit (CPU)

24

in conjunction with a memory system

26

, an input device

28

, and an output device

30

. These elements are interconnected by at least one bus structure

32

.

The illustrated CPU

24

is of familiar design and includes an ALU

34

for performing computations, a collection of registers

36

for temporary storage of data and instructions, and a control unit

38

for controlling operation of the system

20

. The CPU

24

may be a processor having any of a variety of architectures including Alpha from Digital, MIPS from MIPS Technology, NEC, IDT, Siemens, and others, x86 from Intel and others, including Cyrix, AMD, and Nexgen, and the PowerPC from IBM and Motorola.

The memory system

26

generally includes high-speed main memory

40

in the form of a medium such as random access memory (RAM) and read only memory (ROM) semiconductor devices, and secondary storage

42

in the form of long term storage mediums such as floppy disks, hard disks, tape, CD-ROM, flash memory, etc. and other devices that store data using electrical, magnetic, optical or other recording media. The main memory

40

also can include video display memory for displaying images through a display device. Those skilled in the art will recognize that the memory

26

can comprise a variety of alternative components having a variety of storage capacities.

The input and output devices

28

and

30

also are familiar. The input device

28

can comprise a keyboard, a mouse, a physical transducer (e.g., a microphone), etc. The output device

30

can comprise a display, a printer, a transducer (e.g., a speaker), etc. Some devices, such as a network interface or a modem, can be used as input and/or output devices.

As is familiar to those skilled in the art, the computer system

20

further includes an operating system and at least one application program. The operating system is the set of software which controls the computer system's operation and the allocation of resources. The application program is the set of software that performs a task desired by the user, using computer resources made available through the operating system. Both are resident in the illustrated memory system

26

.

In accordance with the practices of persons skilled in the art of computer programming, the present invention is described below with reference to acts and symbolic representations of operations that are performed by computer system

20

, unless indicated otherwise. Such acts and operations are sometimes referred to as being computer-executed and may be associated with the operating system or the application program as appropriate. It will be appreciated that the acts and symbolically represented operations include the manipulation by the CPU

24

of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in memory system

26

to thereby reconfigure or otherwise alter the computer system's operation, as well as other processing of signals. The memory locations where data bits are maintained are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits.

FIG. 2

is a block diagram of an exemplary prior art interfaced software object

50

that provides software services such as methods

52

or properties

54

that are accessed by one or more interfaces

56

(multiple shown). A method

52

is typically a function or procedure that performs a specific action and is called via a corresponding interface

56

. Properties

54

(also referred to as states or attributes) typically are information or data and are called via a corresponding interface

56

. Object

50

is implemented in a server that, for example, may be a dynamic link library utilized by software program or may be an entirely separate executable process.

Each object

50

is an instance of a specific class of related objects. Exemplary object

50

also includes the characteristics of encapsulation, polymorphism, and inheritance. Object

50

encapsulates its properties

54

so each property

54

is accessed only through one of methods

52

, thereby protecting the properties (or data) from inappropriate access and errors that can arise therefrom. Object

50

supports polymorphism in that object

50

may present to a software client an interface or a method definition that appears to the client to be the same as an interface or a method definition of another object in a different class. Such interfaces or method definitions of different objects may appear the same to the client of even if the resulting methods have different implementations.

And object

50

also includes interface inheritance in which the definitions of the methods that object

50

supports may be inherited by another object. Interface inheritance simplifies implementation of polymorphism because an object supporting an inherited interface can be treated like the object from which the interface is inherited. Object

50

may be implemented by or in accordance with many object-oriented programming tools or models including, for example, the component object model (COM). COM is a foundation for object oriented technologies such as OLE and ActiveX utilized by Microsoft Corporation and others. By way of example, the following description is made with reference to an object

50

implemented according to COM, but is similarly applicable to other object-oriented programming tools or models of similar characteristics.

Interfaces

56

of object

50

may not be changed once object

50

is established, distributed, or promulgated for general use at run-time. Adding new services to or modifying existing services in such an object

50

requires that a new interface be defined. The new interface may inherit services from an existing interface, but the new interface remains distinct and has a unique identifier. As a result, interfaces

56

are static. While being a limit on the extensibility of objects, static interfaces provide stability and predictability in the use of objects.

FIG. 3

is a block diagram illustrating a client-server architecture as an operating environment for a distributed object database according to the present invention. Multiple client computers or clients

72

are in communication with a server computer or server

74

via a network

76

, such as a LAN, WAN, intranet, or the Internet. Clients

72

and server

74

have, for example, the basic configuration illustrated in

FIG. 1

, but may include component variations as is known in the art. As a distributed object database, server

74

maintains a central or world object database

80

while clients

72

maintain local object databases

82

. World object database

80

and local object databases

82

together form a distributed object database

84

. For purposes of illustration, distributed object database

84

will be discussed with reference to a representation of an interactive virtual world environment (VWE) or domain. The VWE represents an environment for conducting social dilemma exercises with multiple, potentially hundreds or thousands of computer users. World object database

84

comprises objects that correspond to particular types of interface or social factors within the environment.

FIG. 4

is a schematic illustration of social dilemma virtual world environment (VWE) computer software

90

to aid in the design and study of online interactive societies. An online interactive society may arise whenever two or more people interact through a computer-based communication medium, which may include text or written communication, audio communication, still or motion video communication, or any combination of these communication formats. Online interactive societies can include interactions between a customer and a service provider at a commercial or transactional network site, interactions between collaborating workers or professionals, conversational interactions between two or more people, interactions between participants in a game or other recreational activity, etc. Such interactions can occur over a variety of computer connections, including networks such as the Internet, intranets, LANs, WANs, etc. Participants in the interactions may or may not have background or historical information about each other.

In one implementation, social dilemma VWE software

90

facilitates creation and usage of social dilemma tests or exercises for measuring and analyzing online interactive societies. Social dilemmas are situations in which an individually reasonable decision can result in everyone in the “society” being relatively better or worse off. Models of social dilemmas capture this tension between individually and collectively beneficial outcomes and so can be used to assess the level of cooperation and trust in a group such as an online interactive society. Social dilemma VWE software

90

and the methodology of the present invention are capable of distinguishing the levels of cooperation and trust that are created by various interface and social factors within online interactive societies. Evaluating with social dilemma VWE software

90

the effects of such social and interface factors on the degree of online cooperation allows such factors to be incorporated into the design and functionality of online interactive societies.

Social factors may include the availability or absence of unstructured communications such as with synchronous text chat, asynchronous text chat (e.g., e-mail), verbal or audio communication, still or motion video communication, historical, social, or other background information about others, etc. Interface factors may include the format, style, or layout of the computer-based interactive environment, including interface colors, fonts, font sizes, the presence or absence of graphical user interface components, terminology for user controls or instructions, etc.

Two examples of social dilemmas that can be implemented with social dilemma VWE software

90

are the classic Prisoner's Dilemma and the continuous Prisoner's Dilemma. Other examples social dilemmas that can be implemented with social dilemma VWE software

90

include common pool resource games, assurance games, and chicken games. In the Prisoner's Dilemma exercises or games, two or more participants play directly against each other in multiple rounds or iterations that together are sometimes referred to as an iterated Prisoner's Dilemma exercise. The following description is made primarily with reference to exercises in which two participants play against each other, but is similarly applicable to exercises in which more than two participants in direct play against each other.

In each round of the Prisoner's Dilemma exercises, each participant is given a choice between cooperating with or defecting against the other participant. At the start of each round, the participants are assigned points: one point each in the classic game and multiple points each in the continuous game. Each participant then independently chooses whether to contribute all or some of points to the other participant. In the classic game, each participant cooperates or defects completely by contributing or retaining his one point. In the continuous game, each participant may contribute or retain any number of his points, thereby allowing degrees of cooperation that better model the degrees of cooperation characteristic of real-world social interactions. Points that are contributed to another participant are multiplied (e.g., doubled), and retained points keep their original value. Each participant's goal is to obtain the greatest number of points.

In an exemplary dyadic (i.e., two-participant) implementation of the continuous Prisoner's Dilemma, each of first and second participants may be presented with the following rules:

At the beginning of each round, you will be given 10 points. During each round you will be asked to decide how many of the 10 points you want to give to the person you are interacting with. The amount you give away will be DOUBLED and given to the other person, However, YOU DO NOT RECEIVE ANY RETURN FROM THE POINTS YOU GIVE OUT. The person you are interacting with is asked to make exactly the same decision. If s/he contributes some points, they will be doubled and you will receive them.

Accordingly, each participant is assigned 10 points at the start of each round. Each participant may retain all 10 of his points or choose to contribute any number of his points to the other participant. In this implementation, the greatest possible return for one participant (e.g., the first participant) would come from that participant totally defecting against the other (i.e., retaining all 10 points) while the other participant completely cooperates (i.e., contributing all 10 points). With the doubling of the contributed points (i.e., to a value of 20), the first participant would achieve a total of 30 points and the second participant would achieve zero points. In contrast, the greatest possible simultaneous return for both participants would come from each of them completely cooperating (i.e., contributing all 10 points), which would be doubled to give each participant a total of 20.

In a client-server arrangement of the type illustrated in

FIG. 3

, for example, social dilemma VWE software

90

supports at a server

74

a social dilemma VWE having a social dilemma exercise (or “ShowRoom”) object

92

for controlling a social dilemma exercise. For purposes of explanation, each social dilemma exercise refers to the typically multiple rounds between two or more participants who are in direct play with each other. The social dilemma VWE can provide an environment for measuring and analyzing an online interactive society by supporting simultaneously multiple (e.g., up to hundreds or thousands) social dilemma exercise (or ShowRoom) objects

92

that each represents a separate social dilemma exercise. The multiple simultaneous social dilemma exercises may or may not all include the same social and interface factors.

Each of the participants in the social dilemma exercises is located at and operates a client computer

72

in communication with the server

74

, which may be implemented by one or more server computers. Software

90

further includes at each client

72

one or more social dilemma client interface or Showlet objects

94

that provide one or more interface elements to the social dilemma exercise. The interface elements provided by the client interface or Showlet objects

94

may be separately associated with implementing the social dilemma exercise and implementing the social interaction variables (e.g., types of participant communication, contextual information about other participants, etc.) used to measure or analyze the social interactions.

FIG. 5

is an illustration of a participant interface

100

rendered on a display screen associated with a participant client

72

. This illustration is based upon a version of the continuous Prisoner's Dilemma in which the participants' selective contributions of 0-10 points are doubled. Accordingly, participant interface

100

includes a social dilemma exercise interface component

102

that renders participant identifying information, a social dilemma exercise interface component

104

by which the participant enters a contribution selection, and a social dilemma exercise interface component

106

that renders the results of an immediately preceding round of the exercise.

It will be appreciated that interface components

102

-

106

could be incorporated into and provided by a single client interface or Showlet object

94

or, alternatively, each of interface components

102

-

106

could be incorporated into and provided by a separate client interface or Showlet object

94

. It will also be appreciated that fewer than all of interface components

102

-

106

could be employed and that additional interface components or entirely different interface components could be employed.

Participant interface

100

further includes a social interaction interface

108

illustrated as a synchronous text chat interface by which participants in a social dilemma exercise may voluntarily have discussions with each other. The subject matter and timing of the discussions are not restricted. In alternative implementations, social interaction interface

108

could provide the participants, either separately or additionally, audio interaction, still or motion video interaction, historical information about the other participant's previous interactions, social or personal information about the other participant, etc. Social interaction interface

108

could be incorporated into and provided by a single client interface or Showlet object

94

with interface components

102

-

106

or, alternatively, could be incorporated into and provided by a client interface or Showlet object

94

separate from the objects

94

for each of interface components

102

-

106

.

The one or more client interface or Showlet objects

94

at the clients

72

of participants in a social dilemma exercise correspond to exercise component (or ShowItem) objects

96

that are associated with social dilemma exercise (or “ShowRoom”) object

92

. Client interface objects

94

are included within an interface object space

98

that cooperates with, but is distinct from, social dilemma exercise object

92

. For each client interface object

94

there is an exercise component object

96

(indicated by dashed lines), and the pair have mutual object references that tie them together.

Social dilemma exercise (or “ShowRoom”) object

92

and exercise component objects

96

are global objects in that they are provided from server

74

to client computers

72

as part of the social dilemma VWE. Exercise component (ShowItem) objects

96

are replicated across server

74

and the clients

72

of all participants and provide a model representing a social dilemma exercise in the social dilemma VWE. Client interface objects

94

exist on each client

72

and provide a view of the social dilemma VWE, with user interface and control elements, which view is separate from the model provided by exercise component objects

96

. Separating the model represented by objects

96

from the user interface and controls provided by objects

94

provides a multi-user object oriented user domain such as a social dilemma VWE that can be rendered easily and efficiently while also allowing information to be obtained from the multiple users. Moreover, client interface objects

94

are a compact and versatile manner of distributing and implementing user interface and control functionality.

In one implementation, one Showlet client interface object

94

corresponds to each ShowItem exercise component object

96

in a social dilemma exercise (or “ShowRoom”) object

92

representing a social dilemma exercise, thereby providing a one-to-one relationship between the respective view and model objects. The separation of the model and the view provides encapsulation of the interface implementation separate from the exercise (i.e., functional) implementation and from other interface objects. This allows independent development of different interface items. It also allows different interfaces to be attached to the same exercise at different times or for different users (e.g., “participant” versus “administrator”). And it allows different technologies to be used for functional and representational items (e.g., scripting or C++ for function, and DHTML for representation). It will be appreciated that in other implementations a one-to-plural relationship could exist between a ShowItem exercise component server object

96

and plural Showlet client interface objects

94

to provide different visualizations of a presentation element, or a plural-to-one relationship could provide a unified view of different presentation elements.

Social dilemma exercise object

92

and exercise component objects

96

are provided by or from one or more exercise administrators who may also be at one or more client computers

72

, who construct a social dilemma VWE to evaluate or analyze social interactions based upon selected social and interface factors as described above. These administrators may be sociologists, behavior scientists, marketers, or others seeking to understand the how different social and interface factors can increase or decrease cooperation in an online society. The analytical results provided by the social dilemma VWE contrast with the intuitive analyses more commonly applied to interface and social factor design considerations.

The effects on social cooperation provided by particular social and interface factors incorporated into social dilemma exercises according to this invention may be incorporated into other online interactive applications, such as commercial or transactional network sites, collaboration software enabling workers or professionals to collaborate with each other, computer-based communication applications such as text, audio, or video chat applications, interactive games or other recreational activity, etc.

With reference to

FIG. 3

, world database

80

maintains a complete and centralized representation of social dilemma exercise object

92

and exercise component server objects

96

within the social dilemma VWE. A first client

72

-

1

of a first participant maintains a first local database

82

-

1

, which includes a subset of the information contained in world database

80

. First local database

82

-

1

need only contain those objects that may potentially affect objects associated with first client

72

-

1

. A second client

72

-

2

maintains a second local database

82

-

2

that contains information about objects that may potentially affect objects associated with that client, and thus may be different in its information content than first local database

72

-

1

. As an illustration of an exercise with more than two participants, server

74

is shown coupled to an N-th client

72

-N having an N-th local database

82

-N, to indicate that an indeterminate number of other clients can be coupled to server

74

for interaction in the social dilemma VWE.

Portions of world database

84

maintained on server computer

74

are downloaded to each of multiple individual client computers

72

and are included in each of multiple corresponding local databases

82

. Objects in the local databases

82

are rendered by an application on a display associated with the corresponding client

72

. The user may view and manipulate the objects, e.g., communicating with or contributing points to other participants. Manipulation of or changes to objects in the local databases

82

are communicated to the world database

84

maintained on the server computer

74

. Updates to the world database

84

due to changes at the client computers

72

are handled automatically and dynamically by server computer

74

.

Each exercise involving direct participants occurs in association with a social dilemma exercise object

92

, which allows server

74

to limit the list of clients

72

that need updating for that exercise. Each client

72

associated with the social dilemma exercise object

92

maintains a local database

82

that includes a subset of the information contained in world database

80

. Each local database

82

need only contain those global objects that may potentially affect objects associated with that client

72

. With regard to the direct participants in a social dilemma exercise, the same portions of world database

84

will typically be downloaded to each participant client computer

72

.

Client interface objects

94

convey information (e.g., render a display) at each viewer client computer

72

according to the methods and properties of the social dilemma exercise object

92

and exercise component objects

96

in the local database

82

. In addition, client interface objects

94

allow a viewer to manipulate social dilemma exercise object

92

and exercise component objects

96

in the local database

82

to pass information from the participant to server computer

74

.

In the illustrated continuous Prisoner's Dilemma, for example, a participant can indicate a contribution to be made to another participant or may communicate (e.g., synchronous text chat) with another participant through one or more client interface objects

94

. The one or more client interface objects

94

on the participant's client computer

72

pass the selected contribution for another participant or the communication to the social dilemma exercise object

92

or an exercise component object

96

on the client computer

72

, and server computer

74

updates world database

80

accordingly. With regard to a selected contribution, for example, server computer

74

typically accumulates contributions from all participants before distributing to the participants corresponding modifications to objects

92

or

96

. With regard to a communication, for example, server computer

74

can distribute corresponding modified objects

92

or

94

substantially immediately or at predetermined times.

FIG. 6

is a flow diagram of a social dilemma exercise method

120

illustrating, for example, the continuous Prisoner's Dilemma exercise between two participants in direct play with each other. Social dilemma exercise method

120

implements a social dilemma exercise designed by an exercise administrator studying the effects of particular interface and social variables. Social dilemma exercise method

120

allows evaluation and analysis of interface and social variables in social dilemma exercises to improve the design and social effectiveness of online interactive applications, such as commercial internet or web sites.

Process block

122

indicates the beginning of a new round in the social dilemma exercise.

Process block

124

indicates that a social dilemma exercise interface (e.g., participant interface

100

shown in

FIG. 5

) is provided at a client computer

72

of each participant. The social dilemma exercise interface is based upon client interface objects

94

and associated exercise component (or ShowItem) objects

96

and includes social dilemma exercise components and may also include participant communication components.

Process block

126

indicates that each participant makes a social dilemma exercise entry at his or her computer

72

. In the exemplary continuous Prisoner's Dilemma exercise, each participant enters a value of between 0 and 10 to be contributed to the other participant. The entry made by the participant is incorporated into the corresponding exercise component object

96

residing at the client computer

72

.

Process block

128

indicates that the participant contribution entries incorporated into the exercise component objects

96

residing at the client computers

72

are duplicated in the exercise component objects

96

at the server

74

.

Process block

130

indicates that the respective participants' contribution entries in the exercise component objects

96

at the server

74

are duplicated at the exercise component objects

96

residing at the client computers

72

to which the contributions are directed. Typically, the participant contribution entries are duplicated at the exercise component objects

96

residing at the client computers

72

only after all the participant contribution entries for a round of the exercise have been received at server

74

.

Process block

132

indicates that a log is maintained in a log file stored in memory at server

74

indicating the social and interface factors associated with the exercise, all participant contributions and, optionally, all communications between participants. The log is available to and reviewed by the administrator of the social dilemma exercise to determine the level of cooperation between the participants and, hence, the effectiveness of the particular social and interface factors utilized in the exercise. The log may be accessed by the administrator during or after the exercise either at the server

74

or, more commonly, from a client

72

with access to server

74

.

Query block

134

represents in inquiry as to whether another round is to be played between the participants. The number of rounds is one of the exercise variables selected by the administrator. Whenever another round is to be played, query block

134

returns to process block

122

. Whenever another round is not to be played, query block

134

proceeds to termination block

136

.

FIG. 7

is a graph

140

illustrating analytical results of a small number (20) of dyadic continuous Prisoner's Dilemma exercises measuring the levels of social cooperation in the presence or absence of synchronous text chat in the exercises. The 20 pairs of participants were randomly divided into two groups. In a first group, the pairs of participants played over 70 rounds of the continuous Prisoner's Dilemma exercise and could also communicate with each other with synchronous text chat, as illustrated in FIG.

5

. In a second group, the pairs of participants played the continuous Prisoner's Dilemma exercise, but could not otherwise communicate with each other.

Graph

140

shows the average contributions to other participants in blocks of five rounds for the first (chat) and second (no chat) groups. Although the average contributions of both groups are initially relatively close (i.e., both between 6 and 7), the averages soon diverged such that the first (chat) group maintained an average contribution of about 8 and the second (no chat) group had generally declining levels of contribution to about 4. This simplified example illustrates the relative effectiveness of synchronous text chat over no chat for maintaining cooperation in an online interactive society. It will be appreciated, however, that larger-scale and more detailed analyses could be conducted to determine relative effectiveness of interface factors and other types of computer-based communication to determine, for example, whether additional costs to provide more complex communication are effective expenditures.

An implementation of the present invention provides that object services like methods or properties are provided to or inherited by objects dynamically during run-time. This dynamic inheritance may be provided within the context of an object model, such as the Component Object Model, that supports only design-time inheritance. As applied in a virtual world environment, for example, dynamic inheritance can provide exercise administrators with increased levels of interaction or control.

In a method of providing dynamic inheritance, hierarchical relationships are defined between multiple objects such that each object references or is referenced by another object. One of the objects is a root object that is referenced by at least one other object but that does not reference another object. A call is made for a particular service (e.g., a method or property) at a selected object. The service is provided directly from the object whenever the service is available therefrom.

Whenever the selected service is unavailable at the selected object, the call is passed to a referenced object (i.e., an object that is referenced by the selected object). The service is provided directly from the referenced object whenever the service is available therefrom or the call is passed to yet another referenced object until the service can be provided. The call may be passed to multiple successive referenced objects until the call reaches the root object, which either provides the service or the service is deemed unavailable.

FIG. 8

is a block diagram illustrating hierarchical inheritance relationships between an exemplary set of objects

210

-

216

for implementing social dilemma exercise (or“ShowRoom”) object

92

and exercise interface components

102

-

106

and social interaction interface

108

(FIG.

5

). Objects

210

-

216

represent abstractions that include data and the operations associated with that data. Exercise interface components

102

-

106

and social interaction interface

108

are represented by instances of objects

210

-

216

of an interactive virtual world environment and correspond to particular types of social dilemma exercise components within the environment. Objects

210

-

214

are based upon an interface

220

(designated I-Thing) that in one implementation is a COM object interface. It will be appreciated, however, that I-Thing interface

220

could alternatively be implemented according to other object models.

Objects

210

-

214

are the basic objects or types from which other objects inherit services and are called the exemplars for the virtual world environment or representation. Object

210

(designated Thing) is the root or core of the set of all interfaces in the representation. Object

212

(designated Room) represents and defines the social dilemma exercise being implemented. Object

214

(designated Exercise Interface) represents and defines exercise interface features that may be varied to evaluate effects on cooperation between participants. Object

216

(designated Communication Interface) represents and defines communication interface features that may be varied to evaluate effects on cooperation between participants.

FIG. 9

is block diagram illustrating a sequence of hierarchical inheritance relationships between Thing object

210

, exemplar Room object

212

, and social dilemma exercise (or “ShowRoom”) object

92

. Objects

210

,

212

and

92

include the characteristics described with reference to objects

56

of object

50

which characteristics are represented as properties

210

a,

212

a,

and

92

a

and methods

210

b,

212

b,

and

92

b,

respectively.

Thing object

210

is the root or parent exemplar of the set of objects and is the direct exemplar to Room object

212

. Room object

212

is the direct exemplar to ShowRoom object

92

, which represents a particular exercise in the virtual world environment.

Thing object

210

defines properties

210

a

and methods

210

b

shared by all other objects in the representation or virtual world environment, including exemplars

212

and

92

. Properties

210

a

include for a particular object an exemplar property that refers to the exemplar or parent of the particular object, a name property that lists the name of the particular object, and a description property that includes a text description of the particular object.

Properties and methods are associated with object interfaces during a design time phase when a developer creates them. The interfaces of objects defined under the component object model, for example, cannot be modified after the interfaces have been established, distributed, or promulgated. New functionality or other modifications typically are applied by adding a new interface at a design time phase. Interfaces are fixed or static during a run-time phase when the interfaces are used by or executed on behalf of a user.

ShowRoom object

92

is an exemplar for ShowRoom instances and inherits properties

154

a

and methods

154

b

from Room object

154

. ShowRoom object

92

contains a social dilemma exercise that can be an active, running exercise, one under construction, one ready to run or be copied, or one that has already been completed. The contents of a ShowRoom object

92

are the ShowItem objects

96

used in the exercise. ShowItem objects

96

can be used as present or potential exercise elements. ShowRoom object

92

includes the following properties

92

a

and methods

92

b.

A ShowElements property lists the past and future ShowItem objects

96

of the social dilemma exercise. The listing may be in the form of an IPropertyList that is a property inherited from Thing object

150

. The IPropertyList is an ordered list of values (i.e., properties). A CurrentTopShowItem property contains the currently displayed ShowItem object

96

. With the exercise displayed as multiple levels of a network site or page (e.g., an Internet or intranet page), the CurrentTopShowItem property contains the currently displayed ShowItem object

96

for a top level of the page. A CurrentElement property is an index into ShowElements of the last ShowItem displayed.

A CurrentRoleMap property lists the current role that a system user is filling in this exercise. The map key is the user's name or other identifier, and the value is the current role for that user. Roles may include “administrator” and “participant”, and may include other roles for other applications. If there is no entry for a user in the map, the “participant” role is assumed. The listing may be in the form of an IPropertyMap that is a property inherited from Thing object

150

. The IPropertyMap is an unordered list of name-value pairs in which for a given name or “key” the corresponding object or value is returned.

An AuthorizedPresenters property lists the names of users that can assume the role of administrator. The listing may be in the form of an IPropertyList. A createAndAddShowItem(showItemType) method of ShowRoom object

92

creates and adds a new ShowItem instance. A ShowItemType parameter is the type of ShowItem to create (i.e., the ShowItem sub-exemplar type). Examples of ShowItem types include Meter (a sliding meter that allows participants to select a rating by moving a graphical slider), Chooser (a text question with a list of radio buttons and text answers for the participants to select from), QuestionQueue (a list of participant-generated questions), etc.”

A CloneShowItem(showItem) method makes a copy of a ShowItem object

96

and moves it into this ShowRoom. A CloneShowRoom(showRoom) method makes a copy of an entire ShowRoom object

92

. This includes calling a CloneShowItem method for each of the ShowItem objects

96

in the contents of original ShowRoom object

92

. An InsertShowItemAt(showElementsIndex) method inserts a ShowItem object

96

in as exercise ShowItems list at the index specified. A NextElement( ) method increments a CurrentItem property, but not past the end of the list. If the next element is a top-level element (i.e., it replaces the entire page, as described below), the CurrentTopShowItem property is set to the new ShowItem object

96

.

ShowItem object

96

is an exemplar for ShowItem instances, which are elements of a social dilemma exercise. A ShowItem can be an entire new page (template), or an element within a page. Each feedback element, such as a question and answer form to be completed by a participant, has a single ShowItem. Each exercise element also has a single ShowItem. For example, exercise elements may be an object or system for broadcasting live or on-demand audio, video, or multimedia components. An example of a format for such objects or systems is NetShow, a platform for streaming multimedia over networks available from Microsoft Corporation. ShowItems also can record the history of the exercise. For example, ShowItems can be used to replay the events in an exercise, to study the participant responses to the exercise, and to provide log information for external processing.

Showlet interface objects

94

are compatible with and rendered by a graphics and multimedia-capable application such as a network browser (e.g., Internet Explorer from Microsoft Corporation) to display information to viewers and accept input from them. Showlet interface objects

94

may be written in any of a variety of languages including JAVA, Dynamic HTML (DHTML), Visual Basic, etc. For purposes of illustration, the following description is made with reference to Showlet interface objects

94

written in Dynamic HTML, but may be similarly applied to other programming or scripting languages.

Dynamic HTML is an extension of standard HTML introduced by Microsoft Corporation and specified in the Internet Client Software Development Kit (SDK) published by Microsoft Corporation. DHTML enables authors to dynamically change the rendering and content of a document by modifying the current document and automatically reformatting and redisplaying the document to show changes. It does not need to reload the document or load a new document, or require a distant server to generate new content. The HTML elements, attributes, and styles in DHTML are based on standard HTML and cascading style sheet CSS) specifications.

Dynamic HTML includes an object model for providing interfaces that allow scripts and components to access DHTML features. Using the object model, HTML elements in a document are available as individual objects, and the elements and their attributes can be examined and modified by reading and setting properties and by calling methods. The object model also makes user actions, such as pressing a key and clicking the mouse, available as events.

Each exercise element (ShowItem) object

96

represents a different functional piece of a social dilemma exercise, although an exercise object

92

might include several exercise components. Within the context of Showlet interface objects

94

, ShowItem objects

96

include the following properties and methods. A ShowletID property of each ShowItem object

96

is a DHTML identifier that indicates where to display in a DHTML page (i.e., for a participant) the Showlet interface object

94

corresponding to the ShowItem object

96

. The ShowletID property for each interface object

94

on a DHTML page is unique, even if several Showlet objects are nested hierarchically on the page.

A ShowletMap property of each ShowItem object

96

includes a key of a role (e.g., participant or administrator) and a value of the name or other identifier of the Showlet interface object

94

to be used for users filling that role. The ShowletMap property maps from a role to a Showlet name. Each Showlet interface object

94

has a unique Uniform Resource Locator (URL) for locating and accessing the object. The URL of the Showlet interface object

94

is found by looking up its name in a ShowletURLMap property, which maps from the Showlet name to its URL. A Showlets property lists by name all of the Showlets that can be used with the ShowItem. Any of the listed Showlets, but only these Showlets, can be added to the ShowletMap for a particular role to use. The ShowletMap, World.Global.ShowletURLMap, and Showlets properties may each be an IPropertyMap.

When a given ShowItem object

96

is to be displayed, a URL for the user's role in the ShowRoom

92

(as given in the CurrentRoleMap property of the ShowRoom, the ShowletMap property of the ShowItem, and the ShowletURLMap property of World.Global) is placed in the location given by the ShowletID DHTML idenitifier. Showlet identifiers are added to the page primarily by previous ShowItems, which are sometimes referred to as template ShowItems.

One identifier is predefined as “TopShowlet” and is the entire initial DHTML page. Showlet identifiers that replace the “TopShowlet” identifier are special in that they replace all Showlets on the display page. This means that previously displayed ShowItems are no longer relevant to the current display. A SubShowItemMap property lists the ShowItems that are currently being displayed within the ShowItem (such as a exercise element within a layout). This is based on the DHTML identifier indicating where the element is displayed, and the value is the ShowItem being displayed there. The SubShowItemMap property indicates the current state of the exercise.

User responses from a Showlet corresponding to a ShowItem object are communicated to the ShowItem via sub-exemplar-specific, server-side method calls. The Showlet calls a server-side method on the ShowItem. That method updates the state of the ShowItem appropriately, and then causes UpdateShowItem to be called on all client Showlets. The Showlet then updates its display to reflect the new state. This allows the ShowItem to decide what, if any, of the data communicated to it from the client should be redistributed to the other clients, either directly or in digested or collated form.

While ShowItem properties are being updated, a property UpdatingShowItem is set to true to prevent Showlets from accessing potentially inconsistent sets of properties. When UpdatingShowItem is set to false again, an OnUpdatingShowItemChanged method on the ShowItem object

96

calls an UpdateShowItem method on the corresponding Showlet. In another implementation a pair of method calls StartUpdate and EndUpdate are used rather than directly setting the UpdatingShowItem property. The Showlet then renders the updated ShowItem properties for the viewer.

A ResponseHistory property of ShowItem is an IPropertyList that includes all of the viewer responses to the ShowItem, with date/time stamps. For each response, there are several entries in the list. A first entry is the date/time stamp. A second entry is the name of the user that responded. A third entry is the name of the ShowItem method that was called to communicate the response. A fourth entry is a parameter count indicating how many parameters there are. Following these entries may be an arbitrary number of items that are used as parameters to the method call.

Participant Operation

When new users log onto the social dilemma exercise system, they are presented with a social dilemma exercise ShowRoom that represents one social dilemma exercise. The ShowRoom may be one of multiple ShowRooms representing varying social and interface factors and identified in a list taken from a World.Global.OpenShowRooms property, which as an IPropertyMap includes the room name as the key and the ShowRoom as the value. Each participant enters one of the listed exercises as assigned (e.g., randomly) by an administrator.

In one implementation, each user has one and only one role in a given ShowRoom. The role can be “participant” or “administrator” and may be listed according to the name for the user in the CurrentRoleMap property. If the name for a user is not found in the CurrentRoleMap property, the user is assigned a defaults role of “participant”.

When a user enters a ShowRoom, the system activates or initiates a top level Showlet as directed by the CurrentTopShowItem property. This Showlet, in turn, activates sub-ShowItems according to the SubShowItemMap property. Activating a ShowItem involves finding a URL for a corresponding Showlet. The ShowletMap property translates from the user's role to a Showlet name. The World.Global.ShowletURLMap property translates from the Showlet name to a URL for the Showlet. The resulting URL is incorporated into a DHTML element indicated by the ShowletID property. As a result, a Showlet is created for each active ShowItem and the user is shown all the active ShowItems.

The Showlet updates its display to match the current state of the exercise for the corresponding ShowItem and response properties. However, the Showlet first checks the UpdatingShowItem property to confirm that those properties are consistent. If the are inconsistent, the Showlet is not updated, but an UpdateShowItem call soon be made to cause the appropriate update.

An administrator can add a new ShowItem to the ShowRoom or advance the exercise to the next ShowItem in the ShowElements list. The administrator can also edit a ShowItem and control it. Editing and control are specific to the ShowItem sub-exemplar being shown. When a new ShowItem is displayed, it will often displace one that previously had the same DHTML identifier.

When a user responds to a ShowItem, its Showlet calls a server-side method on the ShowItem that may digest the response and set a variety of properties. When done, UpdateShowItem methods on each of the client Showlets updates the display as seen by the users. The ShowItem also stores the response in the ResponseHistory property, together with the time and the name of the user. Sometimes, the digested responses are not immediately redistributed to the clients. Instead, they are stored until the administrator has the system distribute them.

Administrator Operation

A ShowRoom can be used to create a new exercise on-the-fly or the exercise can be prepared ahead of time by the administrator with a list of ready-made ShowItems. Exercises that are given multiple times can be created, and the ShowRoom for the exercise cloned each time a new instance of the exercise is needed. ShowRooms and ShowItems are cloned and edited to create and modify exercises. This cloning and editing can be performed beforehand or during the course of the exercise. Users that have a ShowRoomCreator property set to true get additional controls on the room selection page, allowing them to create a new room by cloning an existing room. The list of cloneable ShowRooms is stored in the World.Global.CloneableShowRooms propertymap, with the key being the room name and the value being the ShowRoom. A “blank” room exists in the list to create new exercises.

Once a new ShowRoom is created, any user with the role “administrator” can create new ShowItems within that room, allow different ShowItems to be rendered, or edit existing ShowItems. Changes by the administrator cause the Showlets to update as well. The room creator is automatically set as an administrator in the room, and any administrator can make other users administrators as well. ShowItems are created by cloning existing ShowItems in the same room. Each room has “blank” instances of each type of available ShowItem. This does not create excessive system overhead because there are relatively few ShowItem types, and unmodified versions are relatively small. Most of the information is contained in the exemplar. As a result, having blank copies of each type of ShowItem is not excessively expensive. As one alternative, a global prototype list that lists the exemplars that could be used to create new items. As another alternative, a wizard-based approach could be used.

ShowItems can be created in various stages of readiness, and then completed and cloned at preparation time or the time of the exercise. The default administrator view of the ShowItem allows the administrator to edit the text of the item, and to select the Showlet to be used for each role. Once a ShowRoom exercise is complete, the administrator can mark it as “open” can leave it unopen and clone it for each actual exercise to be given. ShowItems collect a complete history of the participant's responses, allowing later replay or analysis of the exercise.

In one implementation, each Showlet interface object

94

is in the form of a scriplet, which is a DHTML page that can be used as a control in any application that supports controls. Properties, methods, or events in the scriptlet are based upon scripts that may be written in common active scripting languages such as JavaScript, Visual Basic Scripting Edition (VBScript), or another language. The scripts rely on the scripting capabilities of DHTML, which gives a complete object model for elements on the scriptlet including use of the standard OBJECT tag that is used to insert and work with any other object on an html document. The use of and format of scriptlets is specified with Dynamic HTML in the Internet Client Software Development Kit (SDK) published by Microsoft Corporation.

FIG. 10

is a flow diagram illustrating a dynamic inheritance process

260

as a run-time use of objects. For purposes of illustration, dynamic inheritance process

260

is described with reference to the sequence of hierarchical inheritance relationships shown in FIG.

9

.

Process block

262

indicates that a reference or call is made to a selected service (e.g., a property or a method) at a selected object (e.g., object

92

), thereby making the selected object the current object. The reference or call may be made in the conventional manner that properties and methods of an object are referred to or called.

Query block

264

represents a query as to whether the current object receiving the reference or call (e.g., object

92

) supports the selected property or method. Whenever the current object (e.g., object

92

) supports the selected property or method, query block proceeds to process block

266

. Otherwise, query block

264

proceeds to process block

270

.

Process block

266

indicates that the selected property or method is provided by the current object. Process block

266

proceeds to termination block

268

.

Process block

270

indicates that the reference or call to the selected property or method is passed to the direct exemplar of the current object (e.g., object

212

) and the direct exemplar is redesignated the current object. Process block

270

returns to query block

264

.

Process

260

provides a mechanism for dispatching properties and methods to exemplars. Process

260

supports dynamic inheritance of other properties and methods at run-time by allowing intervening exemplars to be added to a hierarchy of objects.

With reference to

FIG. 8

, in one implementation I-Thing interface

220

also defines, supports, or implements methods

220

b

that include the dynamic inheritance methods set forth in Table 1. Methods

220

b

in Table 1 are available to each object of which I-Thing interface

220

is the root exemplar (e.g., objects

210

-

216

and

92

).

TABLE 1

Name

Action

AddMethod

Adds a designated method to make the

method available to the object

RemoveMethod

Removes a designated method to make the

method unavailable to the object

AddProperty

Adds a designated property to make the

property available from the object

RemoveProperty

Removes a designated property to make the

property unavailable from the object

GetMethod

Returns a designated method including the

number and types of the method parameters

GetProperty

Returns a designated method including the

number and types of the property parameters

PutMethod

Puts a designated value or designated values

in the parameters of a designated method

PutProperty

Puts a designated value or designated values

in the parameters of a designated property

InvokeMethod

Invokes a designated method

For example, methods and properties available for implementation or access by the dynamic inheritance methods of I-Thing interface

220

are in a dynamic inheritance listing, such as a table, that indicates the names of the methods and properties, defines the services they provide, and includes unique identifiers for them. The unique identifiers may be of the form of integer values like the dispatch identifiers (DISPIDs) used with the dispatch interface of the IDispatch interface used in COM automation.

The AddMethod and the AddProperty methods allow methods and properties, respectively, to be added to the dynamic inheritance listing so that the listing may be modified during run-time. These methods pass the name and a definition of the method or property to be added to the dynamic inheritance table and assign a corresponding unique identifier for the method or property. The RemoveMethod and the RemoveProperty methods remove methods and properties from the dynamic inheritance listing. The InvokeMethod method allows a user to execute the designated method. The GetMethod and the GetProperty methods return the designated method and property, respectively, from the dynamic inheritance listing. The PutMethod and the PutProperty methods allow a user to set the method or property.

The dynamic inheritance methods of Table 1, as well as the dynamic inheritance process

260

of

FIG. 10

, allow methods and properties to be dynamically added to or changed within otherwise conventional static interfaces. The adding of the methods and properties includes accessing information about the methods and properties, setting values in and retrieving values from them, and invoking the methods. Methods and properties may be added in effect by accessing them from an exemplar to a particular interface or object according to dynamic inheritance process

260

. In addition, methods and properties may be added by adding them to the set of methods and properties available at an exemplar, such as the root exemplar I-Thing.

These features allow inheritance to be dynamic and provide a seamless scripting environment in programmable applications like virtual world environments. Moreover, the dynamic inheritance methods of Table 1 and dynamic inheritance process

260

of

FIG. 10

may be used together as described hereinabove, or either may be used alone to provide dynamic inheritance functionality.

The dynamic inheritance method InvokeMethod is similar to the Invoke method of the IDispatch interface used in COM automation. The IDispatch::Invoke method allows a software client to invoke a designated software method available from another application. The methods available from the other application are specified in a dispatch interface (often called a dispinterface). Dispatch identifiers (DISPIDs) identify the available methods. The similarity between the dynamic inheritance of this invention and the IDispatch interface used in COM automation extends no farther.

The dynamic inheritance of this invention allows methods and properties to be added to or removed from the set of available methods and properties. In contrast, IDispatch interface used in COM automation is a conventional COM interface and is immutable once it has been established. Methods and properties are not added to an IDispatch interface after it has been established. It will be appreciated, therefore, that changing the methods and properties available to an interface like the I-Thing interface

220

after it has been established is a major improvement upon the prior functionality of objects with fixed interfaces (e.g., COM objects) like the IDispatch interface.

Having described and illustrated the principles of our invention with reference to an illustrated embodiment, it will be recognized that the illustrated embodiment can be modified in arrangement and detail without departing from such principles. It should be understood that the programs, processes, or methods described herein are not related or limited to any particular type of computer apparatus, unless indicated otherwise. Various types of general purpose or specialized computer apparatus may be used with or perform operations in accordance with the teachings described herein. Elements of the illustrated embodiment shown in software may be implemented in hardware and vice versa.

In view of the many possible embodiments to which the principles of our invention may be applied, it should be recognized that the detailed embodiments are illustrative only and should not be taken as limiting the scope of our invention. Rather, we claim as our invention all such embodiments as may come within the scope and spirit of the following claims and equivalents thereto.

高效检索全球专利

专利汇是专利免费检索,专利查询,专利分析-国家发明专利查询检索分析平台,是提供专利分析,专利查询,专利检索等数据服务功能的知识产权数据服务商。

我们的产品包含105个国家的1.26亿组数据,免费查、免费专利分析。

申请试用

分析报告

专利汇分析报告产品可以对行业情报数据进行梳理分析,涉及维度包括行业专利基本状况分析、地域分析、技术分析、发明人分析、申请人分析、专利权人分析、失效分析、核心专利分析、法律分析、研发重点分析、企业专利处境分析、技术处境分析、专利寿命分析、企业定位分析、引证分析等超过60个分析角度,系统通过AI智能系统对图表进行解读,只需1分钟,一键生成行业专利分析报告。

申请试用

QQ群二维码
意见反馈