



# Self-Aware CPSs

Axel Jantsch

TU Wien, Vienna, Austria

oCPS Webinar February 2019

#### Acknowledgment

Axel Jantsch, David Juhasz, Hedyeh Kholerdi, Amir Rahmani, Nima Taherinejad

TU Wien, Vienna, Austria

Nikil Dutt, Kasra Moazzemi, Amir Rahmani

UC Irvine, California

Anil Kanduri, Arman Anzanpour, Elham Shamsa, Iman Azimi, Maximilian Götzinger, Pasi Liljeberg

University of Turku, Finland



### **Outline**

- Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion



### **Outline**

- **1** Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion



### **The Problem**





 Large number of resources





- Large number of resources
- Many tight constraints



- Large number of resources
- Many tight constraints
- Varying application demands, both within and between applications;



- Large number of resources
- Many tight constraints
- Varying application demands, both within and between applications;
- Functional Aberrations:
  - Design errors or omissions;
  - Malicious attacks:
  - Aging;
  - Soft errors:
- Non-functional Aberrations:
  - Performance;
  - Power consumption;



Varying Application and User Demands

workload phasic behavior user inputs

varving compute, memory, and communication









Santanu Sarma et al. "On-Chip Self-Awareness Using Cyberphysical-Systems-On-Chip (CPSoC)". In: Proceedings of the 12th International Conference on Hardware/Software Codesign and System Synthesis (CODES+ISSS). New Delhi, India, Oct. 2014



























### **Autonomy and Adaptivity**

Autonomy is the ability to operate independently, without external control.

Adaptivity is the ability to effect run-time changes and handle unexpected events.



### **Outline**

- Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion





### **Self-Awareness Architecture**



















#### CPSoC - A Sensor Rich SoC Platform



Santanu Sarma et al. "CyberPhysical-System-On-Chip (CPSoC): A Self-Aware MPSoC Paradigm with Cross-Layer Virtual Sensing and Actuation". In: *Proceedings of the Design, Automation and Test in Europe Conference and Exhibition (DATE)*. Grenoble, France, Mar. 2015



### **CPSoC - A Sensor Rich SoC Platform**



Nikil Dutt, Axel Jantsch, and Santanu Sarma. "Self-Aware Cyber-Physical Systems-on-Chip". In: Proceedings of the International Conference for Computer Aided Design. invited. Austin, Texas, USA, Nov. 2015



#### **Thermal-Aware Performance**



Throughput improvement by 70%-300% for same power and temperature.



Benefit is due to accurate and fine-grain measurement and tight tracking.



### **Outline**

- Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion



## **Observation Pipeline**











Accuracy Systematic errors, a measure of statistical bias.



Accuracy Systematic errors, a measure of statistical bias.

Precision Random errors, a measure of statistical variability.



Accuracy Systematic errors, a measure of statistical bias.

Precision Random errors, a measure of statistical variability.

Data Reliability The extent to which a measuring procedure yields the same results on repeated trials.



Accuracy Systematic errors, a measure of statistical bias.

Precision Random errors, a measure of statistical variability.

Data Reliability The extent to which a measuring procedure yields the same results on repeated trials.

Relevance The quality of being important for the matter at hand.



## **Accuracy and Precision**

Correct value



### **Accuracy and Precision**



High accuracy, high precision





#### **Accuracy and Precision**





#### **Accuracy and Precision**



#### **Accuracy and Precision**





#### **Comprehensive Observation**

### Monitoring

Environment

Self

Inputs

Context

Performance / Behavior

Resources

Interpretation

Nima TaheriNejad, Axel Jantsch, and David Pollreisz. "Comprehensive Observation and its Role in Self-Awareness - An Emotion Recognition System Example". In: Proceedings of the Federated Conference on Computer Science and Information Systems. Gdansk, Poland, Sept. 2016



# **Observation Circle**

Abstraction

Disambiguation

Attention

Observation

Disirability

Confidence

Data Reliability Relevance



#### **Early Warning Score**

|                          |     |       |        |         |         |         | 7     |
|--------------------------|-----|-------|--------|---------|---------|---------|-------|
| Score                    | 3   | 2     | 1      | 0       | 1       | 2       | 3     |
| Heart rate <sup>1</sup>  | <40 | 40–51 | 51–60  | 60–100  | 100–110 | 110–129 | >129  |
| Systolic BP <sup>2</sup> | <70 | 70–81 | 81–101 | 101–149 | 149–169 | 169–179 | >179  |
| Breath rate <sup>3</sup> |     | <9    |        | 9–14    | 14–20   | 20–29   | >29   |
| SPO <sub>2</sub> (%)     | <85 | 85–90 | 90–95  | >95     |         |         |       |
| Body temp.4              | <28 | 28–32 | 32–35  | 35–38   |         | 38–39.5 | >39.5 |

<sup>&</sup>lt;sup>1</sup>beats per minute, <sup>2</sup>mmHg, <sup>3</sup>breaths per minute, <sup>4</sup> °C











#### **EWS Improvement**

- Data reliability:
  - Values in reasonable scope
  - Changes in reasonable scope
  - Consistency between sensors
- Situation awareness
- Power efficiency



#### **Enhanced Early Warning Score**



Arman Anzanpour et al. "Self-Awareness in Remote Health Monitoring Systems using Wearable Electronics". In: Proceedings of Design and Test Europe Conference (DATE). Lausanne, Switzerland, Mar. 2017



#### **Enhanced Early Warning Score - Data Reliability**

- 1 Check on the reliability of sensed values
- 2 Check on the reliability of value changes
- 3 Check on consistency between sensor data



#### **Enhanced Early Warning Score - Data Reliability**

- 1 Check on the reliability of sensed values
- 2 Check on the reliability of value changes
- 3 Check on consistency between sensor data





## Enhanced Early Warning Score - Situation Awareness

- 1 Consider the activity mode of person
- 2 Consider time of day
- 3 Consider location



#### Enhanced Early Warning Score - Situation Awareness

- 1 Consider the activity mode of person
- 2 Consider time of day
- 3 Consider location





#### **Enhanced Early Warning Score - Power Efficiency**

Prioritize different situations





#### **Enhanced Early Warning Score - Power Efficiency**

- 1 Prioritize different situations
- 2 Distinguish different modes of urgency

| Emergency Score:0<br>Level: Normal |     | Score:1-3<br>Low |     |       | Score:4-6<br>Medium |       |     |       | Score>6<br>High |       |     |       |  |     |       |     |       |
|------------------------------------|-----|------------------|-----|-------|---------------------|-------|-----|-------|-----------------|-------|-----|-------|--|-----|-------|-----|-------|
|                                    | Ind | oor              | Out | door  | Ind                 | oor   | Out | door  | Ind             | oor   | Out | door  |  | Ind | oor   | Out | door  |
|                                    | Day | Night            | Day | Night | Day                 | Night | Day | Night | Day             | Night | Day | Night |  | Day | Night | Day | Night |
| Sleeping                           | Е   | Е                | E   | E     | С                   | D     | D   | D     | В               | С     | С   | С     |  | Α   | Α     | В   | В     |
| Resting                            | D   | D                | D   | D     | <br>С               | С     | С   | С     | В               | В     | В   | В     |  | Α   | Α     | В   | В     |
| Walking                            | С   | С                | С   | С     | <br>В               | С     | С   | С     | В               | В     | В   | В     |  | Α   | Α     | Α   | В     |
| Jogging                            | С   | С                | С   | С     | В                   | В     | В   | С     | В               | В     | В   | В     |  | Α   | Α     | Α   | В     |
| Running                            | С   | С                | С   | С     | В                   | В     | В   | В     | В               | В     | В   | В     |  | Α   | Α     | Α   | Α     |

# www inf firstien and

#### **Enhanced Early Warning Score - Power Efficiency**

- 1 Prioritize different situations
- 2 Distinguish different modes of urgency
- 3 Define sensing activity for each mode

| State | Respiration Rate<br>Activity   | Blood<br>Pressure                         | Heart Rate,<br>SpO2, and<br>Body Temp. | Transmission Power Consumption |  |  |
|-------|--------------------------------|-------------------------------------------|----------------------------------------|--------------------------------|--|--|
| A     | Continuous                     | Every hour in day<br>Disabled in night    | Every sec.                             | 29 mW                          |  |  |
| В     | 2 min continuous<br>8 min OFF  | Every hour in day<br>Disabled in night    | Every sec.                             | 26.8 mW                        |  |  |
| С     | 2 min continuous<br>3 min OFF  | Every 3 hours in day<br>Disabled in night | Every min.                             | 12.5 mW                        |  |  |
| D     | 2 min continuous<br>8 min OFF  | Every 3 hours in day<br>Disabled in night | Every min.                             | 7 mW                           |  |  |
| E     | 2 min continuous<br>18 min OFF | Disabled                                  | Every min.                             | 4.3 mW                         |  |  |



#### **Enhanced Early Warning Score - Power Efficiency**

Over a day half the energy can be saved.





#### **Enhanced Early Warning Score Summary**

- Considering data reliability improves quality of observation;
- Considering sitation improves quality of observation;
- Collecting needed data only improves efficiency.





- How many temperature measurements are required in an MPSoC?
- It varies over several orders of magnitude depending on activity and current temperature.



- How many temperature measurements are required in an MPSoC?
- It varies over several orders of magnitude depending on activity and current temperature.



Conventional Architecture



Proposed Architecture

Nima TaheriNejad, M. Ali Shami, and Sai Manoj P. D. "Self-aware sensing and attention-based data collection in Multi-Processor System-on-Chips". In: 15th IEEE International New Circuits and Systems Conference (NEWCAS). June 2017, pp. 81–84







Intel Nehalem processor, running Barnes from SPLASH-2 Benchmarks, using Snipersim and Hotspot.

- When only differences  $> \Delta = 1, 2, 5^{\circ}$ C are reported, 7 out of 10 sensors send only 1 value in this experiment.
- Reduction of temperature reports for Memory, ALU and D-Cache:

| $\Delta = 1$ | Imp.    | $\Delta = 2$             | Imp.                           | $\Delta = 5$                               | Imp.                                             |
|--------------|---------|--------------------------|--------------------------------|--------------------------------------------|--------------------------------------------------|
| 13           | 35%     | 9                        | 55%                            | 4                                          | 80%                                              |
| 4            | 80%     | 2                        | 90%                            | 1                                          | 95%                                              |
| 2            | 90%     | 2                        | 90%                            | 1                                          | 95%                                              |
| 1            | 95%     | 1                        | 95%                            | 1                                          | 95%                                              |
|              | 13<br>4 | 13 35%<br>4 80%<br>2 90% | 13 35% 9<br>4 80% 2<br>2 90% 2 | 13 35% 9 55%<br>4 80% 2 90%<br>2 90% 2 90% | 13 35% 9 55% 4<br>4 80% 2 90% 1<br>2 90% 2 90% 1 |







 Rate of temperature reporting can be significantly reduced and fine tuned;



- Rate of temperature reporting can be significantly reduced and fine tuned:
- · Can depend on
  - relative difference,
  - absolute difference,
  - absolute value,
  - system level mode;



- Rate of temperature reporting can be significantly reduced and fine tuned:
- · Can depend on
  - relative difference,
  - · absolute difference,
  - absolute value,
  - system level mode;
- Potential benefits:
  - reduced processing,
  - · reduced communication,
  - · reduced measurements.



#### **Outline**

- Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion



#### **Goals for Dynamic Task Mapping**







#### **Dynamic Task Mapping**





#### **Example 1: Performance Driven Task Mapping**





#### MapPro prefers compact and contiguous regions.

Mohammad-Hashem Haghbayan et al. "MapPro: Proactive Runtime Mapping for Dynamic Workloads by Quantifying Ripple Effect of Applications on Networks-on-Chip". In: *Proceedings of the International Symposium on Networks on Chip.* Vancouver, Canada, Sept. 2015



# Example 2: Throughput- and Power-Constrained Task Mapping



The patterning algorithm disperses mapped cores to maximize the Thermal Safe Power budget.

Anil Kanduri et al. "Dark Silicon Aware Runtime Mapping for Many-core Systems: A Patterning Approach". In: Proceedings of the International Conference on Computer Design (ICCD). New York City, USA, Oct. 2015, pp. 610–617



# Example 3: Lifetime-Reliability-Driven Task Mapping





MapPro: lifetime=5.52 years

Reliability aware mapping: lifetime=12 years

The plots show the reliability of cores at the end of the system's lifetime.

The end of the system's life is reached when the reliability of one core drops below 30%.

M. H. Haghbayan et al. "A lifetime-aware runtime mapping approach for many-core systems in the dark silicon era". In: Design, Automation Test in Europe Conference Exhibition (DATE). Mar. 2016, pp. 854–857



1 Single objective; Design time;



- 1 Single objective; Design time;
- 2 Multiple objectives; Design time;



- 1 Single objective; Design time;
- 2 Multiple objectives; Design time;
- 3 Multiple objectives; Run time;



- 1 Single objective; Design time;
- 2 Multiple objectives; Design time;
- 3 Multiple objectives; Run time;
- 4 Multiple, hierarchical objectives; Run time;



# **Hiararchical Goal Management**





# **Supervisory Control**



Amir M. Rahmani et al. "SPECTR - Formal Supervisory Control and Coordination for Many-core Systems Resource Management". In: Proceedings of the 23rd ACM International Conference on Architectural Support for Programming Languages and Operating Systems. Williamsburg, VA, USA, Mar. 2018; T. R. Mück et al. "Design Methodology for Responsive and Robust MIMO Control of Heterogeneous Multicores". In: IEEE Transactions on Multi-Scale Computing Systems PP.99 (2018), pp. 1–1



















## **Hierarchical Goal Mangement**



- The system's requirements changes over its lifetime.
- Different objectives are invoked at different time.



# **Goal Driven Autonomy**





## **State Detection**

#### State vector:

• Power: Violation: TDP < p

Potential Violation:  $0.8 \text{ TDP} \leq p \leq \text{TDP}$ 

No Violation:  $p \le 0.8 \text{ TDP}$ 

• User Command: High Performance

Low Power

Performance per application:

 Maximum times

[Min run time, Max run time]



# **Priority Assignment**

- Primary goals: thermal safety
- Secondary goals: User experience
- Tertiary goals: Application requirements



# **Priority Assignment - Urgency**

Urgency is the extent of a violation of a parameter:

$$U_{Pow} = \frac{P_{cur}}{P_{ref}}$$

 $P_{cur}$  is the instantaneous power consumption;

 $P_{ref}$  is the fixed upper bound on power (TDP)



# **Priority Assignment - Urgency**

$$U_{perf} = \frac{perf_{max} - perf_{curr}}{perf_{max} - perf_{ref}}$$

*perf*<sub>max</sub> the maximum required application performance;

perf<sub>curr</sub> the instantaneous measured performance;

$$perf_{ref} = \begin{cases} \frac{perf_{max} + perf_{min}}{2} & \text{if User Command} = \text{High Performance} \\ perf_{min} & \text{if User Command} = \text{Low Power} \end{cases}$$



#### **Goal Enforcement**

- Selects action that most likely will satisfy the highest priority goal;
- Action = Resource allocation policy;
- Initial action is randomly selection;
- Actions are assessed in a reinforcement learning loop;
- Reinforcement learning is based on a reward function.



## **Reward Calculation**

Reward = 
$$W_0 \times R_0 + W_1 \times R_1 + W_2 \times R_2 + ... + W_n \times R_n$$

E.g. with two goals for power and performance:

$$egin{aligned} Reward &= W_{Power} imes R_{Power} + W_{Perf} imes R_{Perf} \ R_{Power} &= rac{P_{ref} - P_{curr}}{P_{ref}} \ R_{Perf} &= rac{1}{n} \sum_{i=1}^{n} rac{Perf_i - Perf_{min}}{Perf_{max} - Perf_{min}} \end{aligned}$$

Perf: n W;

the measured performance of the  $i_{th}$  application Perf<sub>min</sub>, Perf<sub>max</sub> minimum and maximum required performance the total number of applications running assigned by the priority re-assigner.



# **Experiments**



Experiments with a set of microkernel benchmarks; Hardkernel Odroid XU3 board, with two clusters (4 big (A15) and 4 little (A7) CPU cores; Performance in heartbeats/sec.



# **Comparison**

| Tech.     | Obj     | Cmd | Pwr viol. | Perf. viol. | Avg. pwr |
|-----------|---------|-----|-----------|-------------|----------|
| LP policy | Power   | Х   | 3%        | 65%         | 2.99     |
| HP policy | Perf.   | Х   | 67%       | 0%          | 3.8      |
| GDA       | Dynamic | ✓   | 20%       | 34%         | 3.2      |

66

## **Goal Driven Autonomy**



Elham Shamsa et al. "Goal-Driven Autonomy for Efficient On-chip Resource Management: Transforming Objectives to Goals", In: Proceedings of the Design and Test Europe Conference (DATE), Florence, Italy, Mar. 2019

Elham Shamsa et al. "Goal Formulation: Abstracting Dynamic Objectives for Efficient On-chip Resource Allocation". In: IEEE Nordic Circuits and Systems Conference (NorCAS), Tallinn, Estonia, Oct. 2018

Axel Jantsch et al. "Hierarchical Dynamic Goal Management for IoT Systems". In: Proceedings of the IEEE International Symposium on Quality Electronic Design (ISQED 2018). USA, Mar. 2018



## **Outline**

- Motivation
- 2 Architecture for Awareness
- 3 Comprehensive Observation
- 4 Goal Management
- 6 Conclusion



# **Self-Aware Control Loop**







Human-in-the-loop computing has its limits. What must we do differently to prepare for the networking of thousands of embedded processors per person? And how do we move from human-centered to human-supervised computing?

David Tennenhouse. "Proactive Computing". In:

 ${\it Communications~of~the~ACM~43.5~(May~2000), pp.~43-50}$ 



· Let's get physical



David Tennenhouse. "Proactive Computing". In: Communications of the ACM 43.5 (May 2000), pp. 43–50



- · Let's get physical
- Let's get real



human-centered to human-supervised computing?

David Tennenhouse. "Proactive Computing". In: Communications of the ACM 43.5 (May 2000), pp. 43–50



- Let's get physical
- · Let's get real
- Let's get out

#### **PROACTIVE** COMPLITING Human-in-the-loop computing has its limits. What must we do differently to prepare for the networking of thousands of embedded processors per person? And how do we move from

human-centered to human-supervised computing?

David Tennenhouse. "Proactive Computing". In: Communications of the ACM 43.5 (May 2000), pp. 43-50













# **Design of Self-Aware Chips**





# **Design of Self-Aware Chips**





# **Questions?**



## References I



Robin Arbaud, Dávid Juhász, and Axel Jantsch. "Management of Resources for Mixed-Critical Systems on Multi-Core Platforms with explicit consideration of Communication". In: *Proceedings of the Euromicro Conference on Digital System Design (DSD)*. invited tutorial. Sept. 2018.



Arman Anzanpour et al. "Self-Awareness in Remote Health Monitoring Systems using Wearable Electronics". In: *Proceedings of Design and Test Europe Conference (DATE)*. Lausanne, Switzerland, Mar. 2017.



Nikil Dutt, Axel Jantsch, and Santanu Sarma. "Self-Aware Cyber-Physical Systems-on-Chip". In: *Proceedings of the International Conference for Computer Aided Design*. invited. Austin, Texas, USA, Nov. 2015.



Nikil Dutt, Axel Jantsch, and Santanu Sarma. "Towards Smart Embedded Systems: A Self-Aware System-on-Chip Perspective". In: ACM Transactions on Embedded Computing Systems, Special Issue on Innovative Design Methods for Smart Embedded Systems 15.2 (Feb. 2016). invited, pp. 22–27.



Nikil Dutt, Amir M. Rahmani, and Axel Jantsch. "Empowering Autonomy through Self-awareness in MPSoCs". In: *Proceedings of the IEEE NEWCAS Conference*. Strasbourg, France, June 2017.



## References II



Mohammad-Hashem Haghbayan et al. "MapPro: Proactive Runtime Mapping for Dynamic Workloads by Quantifying Ripple Effect of Applications on Networks-on-Chip". In: *Proceedings of the International Symposium on Networks on Chip.* Vancouver, Canada, Sept. 2015.



M. H. Haghbayan et al. "A lifetime-aware runtime mapping approach for many-core systems in the dark silicon era". In: *Design, Automation Test in Europe Conference Exhibition (DATE)*. Mar. 2016, pp. 854–857.



Axel Jantsch et al. "Hierarchical Dynamic Goal Management for IoT Systems". In: *Proceedings of the IEEE International Symposium on Quality Electronic Design (ISQED 2018)*. USA, Mar. 2018.



Axel Jantsch, Nikil Dutt, and Amir M. Rahmani. "Self-Awareness in Systems on Chip – A Survey". In: *IEEE Design Test* 34.6 (Dec. 2017), pp. 1–19.



Axel Jantsch and Kalle Tammemäe. "A Framework of Awareness for Artificial Subjects". In: *Proceedings of the 2014 International Conference on Hardware/Software Codesign and System Synthesis.* CODES '14. New Delhi, India: ACM, 2014, 20:1–20:3.



## References III



Anil Kanduri et al. "Dark Silicon Aware Runtime Mapping for Many-core Systems: A Patterning Approach". In: *Proceedings of the International Conference on Computer Design (ICCD)*. New York City, USA, Oct. 2015, pp. 610–617.



S. Kounev et al., eds. Self-Aware Computing Systems. Springer, 2017.



Hedyeh A. Kholerdi, Nima TaheriNejad, and Axel Jantsch. "Enhancement of Classification of Small Data Sets Using Self-awareness - An Iris Flower Case-Study". In: *Proceedings of the IEEE International Symposium on Circuits and Systems (ISCAS)*. Florence, Italy, May 2018.



Peter R. Lewis et al. "Architectural Aspects of Self-aware and Self-expressive Computing Systems". In: *IEEE Computer* (Aug. 2015).



Peter R. Lewis et al., eds. Self-Aware Computing Systems: An Engineering Approach. Springer, 2016.



Kasra Moazzemi et al. "Trends in On-Chip Dynamic Resource Management". In: *Proceedings of the Euromicro Conference on Digital System Design (DSD)*. invited. Prague, Czech Republic, Sept. 2018.



## References IV



T. R. Mück et al. "Design Methodology for Responsive and Robust MIMO Control of Heterogeneous Multicores". In: *IEEE Transactions on Multi-Scale Computing Systems* PP.99 (2018), pp. 1–1.



Amir M. Rahmani et al. "SPECTR - Formal Supervisory Control and Coordination for Many-core Systems Resource Management". In: Proceedings of the 23rd ACM International Conference on Architectural Support for Programming Languages and Operating Systems. Williamsburg, VA, USA, Mar. 2018.



Amir M. Rahmani, Axel Jantsch, and Nikil Dutt. "HDGM: Hierarchical Dynamic Goal Management for Many-Core Resource Allocation". In: *IEEE Embedded Systems letters* 10.3 (Sept. 2018).



Santanu Sarma et al. *CyberPhysical-System-On-Chip (CPSoC): Sensor-Actuator Rich Self-Aware Computational Platform.* Tech. rep.
CECS Technical Report No: CECS TR–13–06. Irvine, CA 92697-2620,
USA: Center for Embedded Computer Systems University of
California, Irvine, May 2013.



Santanu Sarma et al. "On-Chip Self-Awareness Using Cyberphysical-Systems-On-Chip (CPSoC)". In: *Proceedings of the* 12th International Conference on Hardware/Software Codesign and System Synthesis (CODES+ISSS). New Delhi, India, Oct. 2014.



## References V



Santanu Sarma et al. "CyberPhysical-System-On-Chip (CPSoC): A Self-Aware MPSoC Paradigm with Cross-Layer Virtual Sensing and Actuation". In: *Proceedings of the Design, Automation and Test in Europe Conference and Exhibition (DATE)*. Grenoble, France, Mar. 2015



Elham Shamsa et al. "Goal Formulation: Abstracting Dynamic Objectives for Efficient On-chip Resource Allocation". In: *IEEE Nordic Circuits and Systems Conference (NorCAS)*. Tallinn, Estonia, Oct. 2018.



Elham Shamsa et al. "Goal-Driven Autonomy for Efficient On-chip Resource Management: Transforming Objectives to Goals". In: *Proceedings of the Design and Test Europe Conference (DATE)*. Florence, Italy, Mar. 2019.



David Tennenhouse. "Proactive Computing". In: *Communications of the ACM* 43.5 (May 2000), pp. 43–50.



Nima TaheriNejad, Axel Jantsch, and David Pollreisz. "Comprehensive Observation and its Role in Self-Awareness - An Emotion Recognition System Example". In: *Proceedings of the Federated Conference on Computer Science and Information Systems*. Gdansk, Poland, Sept. 2016.



