I use to use UML use cases and I have to model a system using Archimate.
I need to model the features of the system, and I guess that I can do that using the business layer of Archimate.
In this business layer, a service seems may correspond to a use case. It is possible to model a service in a service: that could be seen as a use case inclusion.
But is there a way to model something like a use case extension in Archimate ?
There is not a one-to-one mapping, as there are subtle semantic differences between the related UML and Archimate concepts.
Use cases in Archimate
UML Use cases are:
The closest concept in Archimate is the service:
but it could also be business services, depending on the subject considered:
These services expose behaviors to their environment, for a purpose, without internal details. More about UML to Archimate mapping here.
Inclusion and extension
In UML, inclusion and extensions are relationships between use-cases :
Take for example:
There is no direct equivalent in Archimate, because its meta model allows direct relationships between services only to model a flow ("triggers / flows to").
For modeling inclusion and extension in Archimate, you'd need to show the reuse of behaviors (the initial purpose of inclusion/extension when use cases were invented) by making a difference between:
Application services expose behavior to the external environment for a given purpose, equivalent to real use cases
Application functions correspond to internal behaviour that would be combined to realize a service (the same function being represented for several services):
So the translated example would show that same functions can be used to realise several services:
A similar principle could be used for extension.
Isn't this cumbersome?
The more complex Archimate equivalent has some advantages: it forces to make the difference between behaviors exposed directly (real use cases), and reusable application functions (pseudo use cases that mainly serve a functional decomposition without being user-goal oriented - something that is anyway not recommended in use-case modelling). Moreover it leads to a more visual differentiation between different levels of abstraction.