Please note that for existing customers services will continue to operate as usual for the immediate period and you do not need to take any action.
BPMN Vs

Conversation vs. Collaboration vs. Choreography

Published: December 8, 2014
Share on:

BPMN diagrams are commonly treated as synonymous with process diagrams. However, this is only partially true since BPMN 2.0 supports three other types of diagrams: collaboration, choreography, and conversation. 

This short article will present the last three types of BPMN diagrams and describe the possibilities for their everyday use.

BPMN

Collaboration Diagrams

Collaboration diagrams represent interactions between two or more processes, where each process represents a person, role, or system. A collaboration diagram is quite commonly used and is easily recognized because it consists of more than one Pool. A Pool may be empty, a black box, or may show a process within.

BPMN Collaboration

The following diagrams represent a Help-desk diagram consisting of three participants (i.e., Pools).

The above diagram consists of a white-box pool (i.e., help-desk centre) with a defined help-desk centre process and two black-box processes (i.e., customer and expert). The most common BPMN elements in a collaboration diagram are process flow elements (i.e., activities, gateways, events) and message flows, which are used to exchange data and coordinate work between collaborating participants.

All combinations of pools, processes, and choreography are allowed in collaboration.

agileBA 1024x125 1

Conversation Diagrams

Conversation diagrams were introduced in BPMN 2.0 and represent a particular usage of, and an informal description of, a collaboration diagram. In general, a conversation diagram is a simplified version of a collaboration diagram. A conversation diagram provides an overview of which partners of a specific domain cooperate on which tasks.

The conversation diagram ‘view’ of a collaboration diagram includes two additional graphical elements that do not exist in other BPMN views: conversation node elements (hexagon) and a conversation link (double line).

The following conversation diagram presents the‘ main players’ in a help-desk environment and their everyday conversations (e.g., tasks, and topics).

BPMN Collaboration

On a more detailed level, conversation diagrams can be modeled in a choreography diagram or collaboration diagram.

As an example, the message flow of the conversation ‘problem solving’ is described by the collaboration diagram in figure 1 as a series of two message flows between the customer and the help-desk centre. However, it is not required for a collaboration or choreography diagram to specify precisely one conversation.

Combining the message flows from two or more conversations in one diagram is also possible. As presented below, collaboration and conversation diagrams can also be combined on a single diagram.

BPMN Collaboration

Choreography Diagram

Choreography diagrams were introduced in BPMN 2.0 and focus on between-processes interactions and message flows. Another way to look at choreography is to view it as a type of business ‘contract’ between two or more organizations.

BPMN Banner

Choreography is a process that differs in purpose and behaviour from a standard BPMN Process. A standard (orchestration) process defines the flow of activities of a specific participant or organization. In contrast, choreography formalizes the way participants coordinate their interactions. Thus the focus is not on the orchestration of the work performed by these participants but instead on the exchange of information (messages) between these participants.

A choreography diagram can be used to analyze how participants exchange information to coordinate their interactions. The following figure represents the help-desk process, modelled as a choreography.

BPMN Collaboration

A key to understanding choreography diagrams and how they are used in BPMN is their relationship to pools. Choreography diagrams exist outside of, or in between, pools. A process within a pool represents the work of a specific entity or role. A choreography process, on the other hand, is a different kind of process.

A choreography process defines the sequence of interactions between participants. Thus, a choreography process does not exist in a single pool and is not the purview of a single participant. Each step in the choreography process involves two or more participants. These steps are called ‘choreography activities’.

Choreography can be included in a collaboration diagram. A collaboration specifies how the participants and message flow in a choreography process are matched up with the participants, and the message flows in the collaboration.

Conclusion

This article presented three types of diagrams (i.e., models) which are, besides process diagrams, supported in BPMN 2.0: collaboration diagrams, conversation diagrams, and choreography diagrams. The most commonly used are collaboration diagrams, which represent message-based interactions between different participants (i.e., BPMN pools).

Thus, a collaboration diagram always consists of several pools (processes). A specific, top-level view of a collaboration diagram is a conversation diagram consisting of process participants (pools) and common conversations between them (defined as conversation nodes). Most commonly, conversation diagram pools are black-box. A conversation diagram is easily recognized since it includes two specific elements: conversations (hexagons) and conversation links (double lines).

A conversation diagram can be combined with collaboration diagrams in a typical diagram. Choreography diagrams also represent a specific view of collaboration focused on between-process activities. Since choreography represents between-process interactions, they ‘exist’ outside pools, where the choreography diagrams are populated with specific choreography tasks. Choreography can also be included in a collaboration diagram, meaning that all three presented diagrams can be used in a typical diagram.

Spot the Mistake: BPMN Diagrams