EP4348423A1 - Computersoftwaremodulanordnung, schaltungsanordnung, anordnung und verfahren zur verbesserten autonomen anpassung der softwareüberwachung von echtzeitsystemen - Google Patents
Computersoftwaremodulanordnung, schaltungsanordnung, anordnung und verfahren zur verbesserten autonomen anpassung der softwareüberwachung von echtzeitsystemenInfo
- Publication number
- EP4348423A1 EP4348423A1 EP21730863.4A EP21730863A EP4348423A1 EP 4348423 A1 EP4348423 A1 EP 4348423A1 EP 21730863 A EP21730863 A EP 21730863A EP 4348423 A1 EP4348423 A1 EP 4348423A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- software
- services
- computational resources
- controller
- performance metrics
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims description 20
- 230000006978 adaptation Effects 0.000 title description 7
- 230000008859 change Effects 0.000 claims abstract description 19
- 238000013528 artificial neural network Methods 0.000 claims description 12
- 238000010191 image analysis Methods 0.000 claims description 11
- 230000004044 response Effects 0.000 claims description 11
- 230000001419 dependent effect Effects 0.000 claims description 2
- 238000012544 monitoring process Methods 0.000 description 31
- 238000004891 communication Methods 0.000 description 20
- 238000012545 processing Methods 0.000 description 7
- 238000012549 training Methods 0.000 description 6
- 230000008901 benefit Effects 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000010267 cellular communication Effects 0.000 description 3
- 238000013135 deep learning Methods 0.000 description 3
- 238000007429 general method Methods 0.000 description 3
- 238000010801 machine learning Methods 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 238000013527 convolutional neural network Methods 0.000 description 2
- 230000003247 decreasing effect Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 2
- 238000005192 partition Methods 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 230000009466 transformation Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 238000004883 computer application Methods 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 238000013136 deep learning model Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 238000010946 mechanistic model Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 238000013468 resource allocation Methods 0.000 description 1
- 230000000153 supplemental effect Effects 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/3006—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3442—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for planning or managing the needed capacity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3447—Performance evaluation by modeling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2201/00—Indexing scheme relating to error detection, to error correction, and to monitoring
- G06F2201/865—Monitoring of software
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/501—Performance criteria
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/5011—Pool
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/5019—Workload prediction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/04—Architecture, e.g. interconnection topology
- G06N3/045—Combinations of networks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/08—Learning methods
Definitions
- the present invention relates to an arrangement, an arrangement comprising computer software modules, an arrangement comprising circuits, and a method for providing an improved manner of autonomous adaptation of software monitoring of real-time systems, and in particular to an arrangement, an arrangement comprising computer software modules, an arrangement comprising circuits, and a method for providing an improved manner of autonomous adaptation of monitoring (surveillance and control) of a cloud based system which supports real-time services (RTS).
- RTS real-time services
- cloud computing is the delivery of computing services, such as servers, storage, databases, and networking, over the a network such as the Internet (“the cloud”) to offer flexible resources where a user typically only pays for the cloud services used.
- the services are thus provided as use of computational resources such as processing power (for example processor cores and processing time), memory access (space and access speed) and bandwidth to mention a few examples.
- monitoring systems including surveillance and/or control
- the monitoring systems monitor the performance of one or more services and based on the performance provides the required computational resources.
- the state-of-the-art solutions for providing such monitoring involves developing mechanistic models, both statistical and dynamic ones, which allow a system to predict the performance of the real time services. For instance, such a model might take as input the CPU load, the memory usage, and the rate by which traffic is entering the service in order to predict the processing capacity of the node, and in turn predict whether any violation of a real-time requirement might occur.
- These models would then be used in conjunction with a control unit which decides whether to change some parameters or functionality of the real-time services, in order to affect its real-time performance and thereby mitigate a risk of violating a real-time requirement.
- a key feature with prior art surveillance- and control systems is that they are based on a deep learning framework for predicting future real-time performance of the real-time system(s). As is the case with any deep learning framework, good data is needed in order to train the network to achieve an acceptable level of accuracy for the predictions.
- a problem with the existing solutions is the fundamental nature that whenever one controls/changes the configuration (e.g., scale the CPU, storage, VNFs, etc.) of the underlying system, one will need to account for this while generating the prediction model. The reason is that when one scales the configuration it will also change the real-time performance (e.g., processing a queue will be quicker). Flence, in the previously proposed solutions there has been a need to generate this data and train the prediction model a priori and off-line.
- the inventors have realized that an automated monitoring of the actual monitoring of the real time services would indeed be beneficial as it would allow for detecting that a model utilized is not providing good predictions and based on this, retrain the model dynamically to adapt to any changes in the underlying system or use thereof.
- the inventors have also realized that as the monitoring is to be automated, the exact nature of the real-time data to be collected need not be readable to a human monitor and the inventors further realized that by insightfully utilizing opaque services, that is services that reports performance metrics of an unknown format or alternatively in a normalized format, wherein the performance metrics have no real or at least clear meaning to the monitoring may be used to provide for a faster data collection and that is easier and/or faster to adapt to changes.
- the inventors have also realized that there is an inherent problem in prior art monitoring systems in that as systems grow larger, while maintaining the same timing requirements especially for real-time services, any adaptations of the computational resources for a service(s) may be too slow, thereby affecting the performance of the service.
- real time services operate on timing requirements of milliseconds and microseconds
- resource allocations operate on timings of hundreds of seconds.
- the monitoring may reserve resources ahead of time based on the prediction into a standby pool from which any changes in allocations may be drawn.
- the inventors have further realized that traditional analysis tools are not advanced enough to handle the sizes of real-time service systems, which may be vast indeed, especially if implemented as cloud services.
- the inventors have therefore realized that the most advanced analysis tools available are aimed at image analysis, and are thus proposing to insightfully provide the performance metrics as an image(s), which image(s) may be analyzed using image analysis tools, such as the many various neural network tools and techniques commonly used for image analysis, for example through the use of Convoluted Neural Networks (CNN).
- CNN Convoluted Neural Networks
- a software monitoring arrangement arranged to monitor a software system comprising one or more of computational resources, wherein the software system is configured to execute one or more services each utilizing a portion of the one or more of computational resources and the software system further comprises a live capacity controller configured to receive one or more first performance metrics from the one or more services and to assign the portion of the computational resources to the one or more services based on the first performance metrics, the software monitoring arrangement comprising a controller configured to: receive second performance metrics; execute a state predictor to determine a predicted state of the software system based on the second performance metrics; execute a standby capacity calculator to determine a standby capacity based on the predicted state; and reserve computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller to assign a change in the portion of the computational resources to the one or more services from the standby pool.
- the solution may be implemented as a software solution, a hardware solution or a mix of software and hardware components.
- the controller is further configured to: execute a performance calculator to determine a prediction performance; execute a compensator calculator to determine a compensator based on the prediction performance; and determine the standby capacity based on the compensator.
- the controller is further configured to execute an accuracy calculator to determine a prediction accuracy by comparing the second performance metrics for a specific time period to the previously stored predicted state of the software system for the specific time period, and to determine the prediction performance based on the prediction accuracy.
- controller is further configured to determine the compensator based on a safety factor (k).
- controller is further configured to execute a minimum standby pool calculator to determine a minimum standby pool size based on the predicted state and in response thereto execute the standby capacity calculator to determine the standby capacity based also on the minimum standby pool size.
- the controller is further configured to determine the predicted state based on a system model.
- controller is further configured to determine the predicted state based on the system model utilizing a neural network.
- controller is further configured to store the predicted state; store the received performance metrics; and execute a model trainer to train the system model based on the stored predicted states and the stored received performance metrics.
- the controller is further configured to determine that the prediction performance falls below a threshold and in response thereto train the system model.
- the second performance metrics comprises one or more images representing one or more current states of the one or more services of the software system and wherein the controller is further configured to determine the predicted state of the software system based on image analysis of the one or more images.
- controller is further configured to provide said image analysis to recognize a pattern in the one or more images, which pattern is associated with a known state, wherein the predicted state is determined to be the known state.
- the second performance metrics comprises at least one performance metric from a first service of the one or more services, wherein the performance metric from the first service comprises an opaque data entity.
- the first performance metrics is at least a subset of the second performance metrics.
- controller is further configured to reserve computational resources according to the standby capacity to the standby pool of computational resources enabling the live capacity controller to assign an increase in the portion of the computational resources to the one or more services.
- the solution allows the system to autonomously learn and adapt the software surveillance- and control in a safe way.
- the solution reduces the need to collect and train the deep learning models a priori.
- the solution allows the system to autonomously adapt to new characteristics of the real-time system.
- the solution By continuously monitoring the prediction performance and re-training the prediction models when necessary, the solution reduces the amount of necessary standby capacity for the system, thereby reducing the cost of running the system.
- the solution reduces the amount of resources needed in hot-standby and thereby amounts to significant cost- and resource savings.
- the solution thus allows the system to continuously adapt and update the prediction models in a safe way. Along with this, as the model is improved it continuously reduces the amount of resources needed in hot standby.
- This invention may be used both within and outside a cloud environment.
- the intended target use-case is for the real-time cloud; however it can just as well be used in a closed multi-service environment deployed on local stand-alone hardware.
- One example could be the infotainment system in autonomous cars, actuators and sensors in a manufacturing plant, or in a radio base-station.
- a method for automated software monitoring of a software system comprising one or more of computational resources configured to execute one or more services and a live capacity controller configured to receive performance metrics from the one or more services and to assign a portion of the computational resources to the one or more services based on the performance metrics, wherein the method comprises: receiving the performance metrics; determining a predicted state of the software system; determining a standby capacity based on the predicted state; and reserving computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller to assign a change in the portion of the computational resources to the one or more services from the standby pool.
- a computer-readable medium carrying computer instructions that when loaded into and executed by a controller of a software monitoring of real-time services arrangement enables the software monitoring of real-time services arrangement to implement a method according to herein.
- a software component (or module) arrangement according to an embodiment of the teachings herein.
- the software component arrangement is adapted to be used in a software monitoring of real-time services arrangement as taught herein for automated software monitoring of real-time services as taught herein of a software system comprising a one or more of computational resources configured to execute one or more services and a live capacity controller configured to receive performance metrics from the one or more services and to assign a portion of the computational resources to the one or more services based on the performance metrics
- the software component arrangement comprises: a software component for receiving the performance metrics; a software component for determining a predicted state of the software system; a software component for determining a standby capacity based on the predicted state; and a software component for reserving computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller to assign an increase in the portion of the computational resources to the one or more services from the standby pool.
- an arrangement comprising circuitry for software monitoring of real-time services according to an embodiment of the teachings herein.
- the arrangement comprising circuitry for software monitoring of real-time services is adapted to be used in a software monitoring of real-time services arrangement as taught herein for automated software monitoring of a software system comprising a one or more of computational resources configured to execute one or more services and a live capacity controller configured to receive performance metrics from the one or more services and to assign a portion of the computational resources to the one or more services based on the performance metrics
- the software monitoring arrangement comprises: circuitry arranged to receive the performance metrics; circuitry arranged to determine a predicted state of the software system; circuitry arranged to determine a standby capacity based on the predicted state; and circuitry arranged to reserve computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller to assign an increase in the portion of the computational resources to the one or more services from the standby pool.
- the teachings herein finds use both within and outside a cloud environment.
- One intended target use-case is for a real-time cloud; however the teachings herein may equally well be used in a closed multi-service environment deployed on local stand-alone hardware.
- One example could be the infotainment system in autonomous cars, or actuators and sensors in a manufacturing plant.
- Figure 1A shows a schematic view of a software monitoring of real-time services arrangement according to an embodiment of the present invention
- Figure IB shows a schematic view of a software monitoring of real-time services arrangement according to an embodiment of the present invention
- Figure 2A shows a schematic view of a software monitoring of a software system according to one embodiment of the teachings herein
- Figure 2B shows a schematic view of a software monitoring of a software system according to one embodiment of the teachings herein;
- FIG. 3 shows a flowchart of a general method according to an embodiment of the present invention
- Figure 4 shows a component view for a software component arrangement according to an embodiment of the teachings herein;
- Figure 5 shows a component view for an arrangement comprising circuits according to an embodiment of the teachings herein;
- Figure 6 shows a schematic view of a computer-readable medium carrying computer instructions that when loaded into and executed by a controller of an arrangement enables the arrangement to implement an embodiment of the present invention.
- FIG. 1A shows a schematic view of a software monitoring of real-time services arrangement 100 according to an embodiment of the present invention.
- the software monitoring of real-time services arrangement 100 comprises a controller 101 and a memory 102. It should be noted that the software monitoring of real-time services arrangement 100 may comprise a single device, such as a server, or may be distributed across several devices and apparatuses.
- the controller 101 is configured to control the overall operation of the software monitoring of real-time services arrangement 100.
- the controller 101 is one or more general purpose processors.
- general purpose processors As a skilled person would understand there are many alternatives for how to implement a controller, such as using Field -Programmable Gate Arrays circuits, AISIC, GPU, etc. in addition or as an alternative. For the purpose of this application, all such possibilities and alternatives will be referred to simply as the controller 101.
- the memory 102 is configured to store data and computer-readable instructions that when loaded into the controller 101 indicates how the software monitoring of real-time services arrangement 100 is to be controlled.
- the memory 102 may comprise one or several memory modules, partitions, allocations, units or devices, but they will be perceived as being part of the same overall memory 102. There may be one memory unit for storing data, one memory for the communications interface (see below) for storing settings, and so on. As a skilled person would understand there are many possibilities of how to select where data should be stored and a general memory 102 for the software monitoring of real-time services arrangement 100 is therefore seen to comprise any and all such memory units for the purpose of this application.
- the memory 102 may also be an allocation of a larger memory partition. For the purpose of this application all such alternatives will be referred to simply as the memory 102.
- the software monitoring of real-time services arrangement 100 further comprises a communication interface 103.
- the communication interface may be wired and/or wireless.
- the communication interface may comprise several interfaces.
- the communication interface comprises a USB (Universal Serial Bus) interface.
- the communication interface comprises an analog interface, a CAN (Controller Area Network) bus interface, an I2C (Inter-Integrated Circuit) interface, or other interface.
- the communication interface comprises a radio frequency (RF) communications interface.
- the communication interface comprises a BluetoothTM interface, a WiFiTM interface, a ZigBeeTM interface, a RFIDTM (Radio Frequency I Dentifier) interface, Wireless Display (WiDi) interface, Miracast interface, and/or other RF interface commonly used for short range RF communication.
- the communication interface comprises a cellular communications interface such as a fifth generation (5G) cellular communication interface, an LTE (Long Term Evolution) interface, a GSM (Global Systeme Mobile) interface and/or other interface commonly used for cellular communication.
- the communications interface is configured to communicate using the UPnP (Universal Plug n Play) protocol.
- the communications interface is configured to communicate using the DLNA (Digital Living Network Appliance) protocol.
- the communications interface 103 is configured to enable communication through more than one of the example technologies given above.
- the communications interface 103 may be configured to enable the software monitoring of real-time services arrangement 100 to communicate with services that are part of the (real-time) services for receiving data on (real-time) performance from such (real-time) services.
- the communications interface 103 may be configured to enable the software monitoring of real-time services arrangement 100 to communicate with a cloud service or other alternative for providing the computational resources to a software system (not shown in figure 1A, but referenced 205 and 200 respectively in figure 2A) for communicating requests for reserving computational resources.
- the software monitoring of real-time services arrangement 100 may in some embodiments comprise a user interface 104.
- Figure IB shows a schematic view of one such example of a software monitoring of real-time services arrangement 100 according to an embodiment of the present invention.
- the software monitoring of real-time services arrangement 100 in this example is a desktop computer or work station 100 comprising a housing 105 in which the controller 101, the memory 102 and the communication interface 103 is housed.
- the work station is in this example provided with a user interface 104 comprising a display and a keyboard.
- Figure IB shows a schematic view of one such example of a software monitoring of real-time services arrangement 100 according to an embodiment of the present invention.
- the software monitoring of real-time services arrangement 100 in this example is a cloud service or other network service provided to perform the monitoring, the cloud (or network) thus comprising or providing services for a memory 102, a controller 101 and a communication interface 103 as discussed in the above.
- monitoring arrangement 100 In the following the software monitoring of real-time services arrangement 100 will also be referred to simply as the monitoring arrangement 100. It should be noted that even though the teachings herein are focused on the monitoring of real-time services, the monitoring arrangement 100 may also be used for monitoring other services.
- Figure 2A shows a schematic view of functional components of a software monitoring of a software system 200 to be executed on or performed by a software monitoring arrangement 100 according to one embodiment of the teachings herein.
- the software system 200 comprises a plurality of services 215 to be monitored.
- the services 215 are real-time services 215.
- three groupings of services are shown, but it should be noted that any number of services may be monitored and that the number of groupings and services in each grouping is probably of a higher number than illustrated in figure 2A, and it should be apparent that this (low) number is only for illustrative purposes.
- the real-time services 215 may be connected for sharing data, for cooperating on a task or to be part of a process flow, to mention a few reasons, as indicated by the dotted arrows.
- the services 215 execute on computational resources 205.
- the computational resources are part of a networked or cloud service, they area only shown schematically, but as a skilled person would realize the computational resources 205 may relate to allotted bandwidth, processor cores, processor execution time, memory space, memory access speed and so on to mention a few examples.
- the computational resources 205 are allocated to the various services 215 based on their predicted requirements by a live controller 210, being a software monitoring module arranged or configured to receive performance metrics from one or more of the services 215, analyze the performance and to allocate computational resources 205 accordingly.
- a live controller 210 being a software monitoring module arranged or configured to receive performance metrics from one or more of the services 215, analyze the performance and to allocate computational resources 205 accordingly.
- the live controller only allots or assigns a portion of the computational resources 205 toe a service 205.
- the allocation CR of (at least a portion of) computational resources 205 is shown as going from the live controller 210 to the respective services 215. It should however be noted that there are many variations on how the allocation is to be done and the illustration in figure 2A is only schematic.
- the live controller 210 is, in some embodiments, arranged to operate as per any prior art solution and its internal operations will therefore not be discussed in great detail herein. Suffice to state that the live controller receives performance metrics, analyzes these metrics, possibly based on neural networks or other machine learning algorithm, and allocates computational resources accordingly.
- the live-capacity controller may be referred to as a real-time capacity controller 210.
- FIG 2A there is also shown how a software monitoring arrangement 220 is operatively connected to the software system 200 for monitoring the services 215 of the software system 200.
- the software monitoring component 220 is to be executed by a software monitoring arrangement as in any of figures 1A, IB or 1C and will thus be referred to by the same terminology; software monitoring arrangement.
- the software monitoring arrangement 220 is connected to the software system 200 through the communication interface 103 for example for receiving performance metrics from one or more of the services 215.
- the software monitoring arrangement 220 is connected to the software system 200 by being comprised in the software system 200.
- the software monitoring arrangement 220 receives performance metrics from the one or more of the services 215. It could be noted that the performance metrics received by the live controller 210 are, in some embodiments, different from the performance metrics received by the software monitoring arrangement 220.
- the live controller 210 is thus seen to receive a first set of performance metrics and the software monitoring arrangement 220 is seen to receive a second set of performance metrics.
- the first set is a subset of the second set. In some embodiments the first set is the same as the second set.
- the second set includes performance metrics for all services 215. In some embodiments the second set includes performance metrics for some of the services 215. In some embodiments the second set includes performance metrics for one of the services 215.
- the software monitoring arrangement 220 includes a state predictor 221 that is configured to determine a predicted state 221' of the software system 200 based on the received performance metrics, when executed.
- the state predictor is in some embodiments, configured to operate based on a model and which model is based on machine learning, such as utilizing neural networks. More details on the state predictor will be given with reference to figure 2B below.
- the software monitoring arrangement 220 includes a standby capacity calculator 222 that is configured to determine a standby capacity 222' based on the predicted state 221', when executed.
- the software monitoring arrangement 220 is thus also configured to reserve computational resources 205 into a standby pool of computational resources 206. In figure 2A this is indicted by the Available Computation Resources ACR being determined for the standby pool 206.
- the live controller 210 is thereby enabled to assign any change in the assigned portion of computational resources 205 for any service(s) 215 quickly and effectively from a standby pool 206 of computational resources.
- the change in the assigned portion computational resources 205 for a service 215 relates to an increase in required resources.
- such a change causes the software monitoring arrangement 220 to reserve other additional and/or other more powerful resources.
- the software monitoring arrangement 220 is configured to reserve computational resources according to the standby capacity to the standby pool 206 of computational resources enabling the real-time capacity controller 210 to assign an increase in the portion of the computational resources 205 to the one or more services 215.
- the change in the assigned portion computational resources 205 for a service 215 relates to an adaptation in requirements (for example an increased requirement on bandwidth, while a decreased request on processing power, such as when streaming huge data loads) in required resources.
- a change causes the software monitoring arrangement 220 to reserve other, more suitable, resources (as per the actual case).
- the change in the assigned portion computational resources 205 for a service 215 relates to a decrease in requirements (for example a decreased timing requirement) in required resources.
- a change causes the software monitoring arrangement 220 to reserve other less powerful resources, which may save on the overall costs.
- Figure 2A thus shows a software monitoring arrangement 100, 220 arranged to monitor a software system comprising one or more of computational resources 205, wherein the software system 200 is configured to execute one or more services 215 each utilizing a portion of the one or more of computational resources 205 and the software system further comprises a live capacity controller 210 configured to receive one or more first performance metrics PM from the one or more services 215 and to assign the portion of the computational resources 205 to the one or more services 215 based on the first performance metrics PM, the software monitoring arrangement 100, 220 comprising a controller 101 configured to: receive second performance metrics PM; execute a state predictor 221 to determine a predicted state 221' of the software system 200 based on the second performance metrics PM; execute a standby capacity calculator 222 to determine a standby capacity 222' based on the predicted state 221'; and reserve computational resources according to the standby capacity to a standby pool 206 of computational resources enabling the live capacity controller 210 to assign a change in the portion of the computational resources 205 to the one or
- the performance metrics represent a current measured states of the software system 200.
- Figure 2B shows a schematic view of functional components of a software monitoring of a software system 200 to be executed on or performed by a software monitoring arrangement 100 according to one embodiment of the teachings herein.
- the software monitoring arrangement 220 and the software system 200 of figure 2B are the same as in figure 2A. However, as is shown, additional embodiments of the software monitoring arrangement 220 will be disclosed with reference to figure 2B.
- the inventors have realized several problems regarding errors or inconsistencies in the prediction and scaling of systems.
- the inventors have further realized, that in due to such changes in the system 200 and/or for errors or inconsistencies in the prediction, the predicted state 221' may not always be (highly) accurate which will lead to an incorrectly apportioned standby pool 206 to be maintained, leading to too few or the wrong computational resources being available and/or computational resources being reserved but never used, thus increasing the cost of the system.
- the software monitoring arrangement 220 therefore includes, in some embodiments, a performance calculator 225 configured to determine a prediction performance 225', that is a performance of the state predictor 221.
- the software monitoring arrangement 220 also includes, in some embodiments, a compensator calculator 226 configured to determine a compensator 226' based on the prediction performance 225'. This allows for any prediction errors in predicted state 221' or bad performance of the state predictor 221 to be compensated for based on the compensator 226' when determining the standby capacity.
- the software monitoring arrangement 220 is configured, in some embodiments, to determine the standby capacity based on the compensator 226', as well as on the predicted state 221'.
- the software monitoring arrangement 220 is further configured to store a predicted state 221' of the software system 200 for later determining if the predicted state 221' was accurate or not.
- the software monitoring arrangement 220 includes an accuracy calculator 224 configured to determine a prediction accuracy 224' of the state predictor.
- the accuracy calculator 224 determines the prediction accuracy 24' based on a stored predicted state for a specific time period and the received performance metrics for the specific time period (same, adjacent or overlapping).
- the accuracy calculator 224 determines the prediction accuracy 24' based on the number of times the predicted state has been stored, where a high number gives a higher accuracy.
- the software monitoring arrangement 220 determines the prediction performance 226' based on the prediction accuracy 224'. In cases where a low prediction accuracy is determined, a low prediction performance will also be determined.
- the prediction performance 226' is or corresponds directly to the prediction accuracy 224'. In some such embodiments the prediction performance 226' is determined as the prediction accuracy 224' over time (such as an average over a past time period). In some such embodiments, the accuracy calculator 224 is comprised in the performance calculator 226.
- the software monitoring arrangement 220 is further configured to determine the compensator 226' based on a safety factor (k).
- the safety factor k is, in some embodiments set by the software system 2000. In some embodiments the safety factor k is set by a user of a service 215. In some embodiments the safety factor k is set by a system designer of the software system 200 or of a service 215.
- the safety factor is set dynamically. In some such embodiments the safety factor is set as a function of the prediction performance, where a high (in some aspect) prediction performance results in a lower (in some aspect) safety factor. In some such embodiments the safety factor is set as a function of training the prediction performance. In some such embodiments a safety actor k is set according to how well a model is trained. The models used for the state predictors have been touched upon briefly in the above with reference to figure 2A and will be discussed in more detail in the below.
- the safety factor k is arranged to provide a greater margin of error for the standby pool (i.e. a larger size and/or more powerful resources) in order to ensure or at least increase the likelihood that resources are available by reserving possibly unnecessary resources.
- the safety factor k is arranged to provide a lower cost for the standby pool (i.e. a smaller size and/or cheaper resources) in order to ensure or at least decrease the cost of resources by reserving only (absolutely) necessary resources.
- the software monitoring arrangement 220 further includes, in some embodiments, a minimum standby pool calculator 223 configured to determine a minimum standby pool size 223' when executed.
- the minimum standby pool size 223' is determined based on the predicted state 221'. In some embodiments the minimum standby pool size 223' is determined to ensure that some constraints are indeed satisfied.
- the software monitoring arrangement 220 is further configured to execute the standby capacity calculator 222 to determine the standby capacity 222' based also on the minimum standby pool size 223' ensuring that the minimum size 223' is available.
- the time-horizon for scaling the amount of standby resources is larger than the time-horizon for what resources are needed for the live capacity control.
- the standby capacity calculator or controller 222 must therefore rely on the predicted performance 225' of the state predictor 221.
- the state predictor 221' generates the predicted state which results in an (minimum) amount of standby resources in the standby pool 206. In other words this is based on the minimum amount of resource that the system will need in order to meet the predicted performance levels.
- the actual size of the standby pool 206 used enables for a more adaptable allocation of resources from the standby pool, as more resources than the bare minimum are made available.
- the minimum standby pool size is the standby pool size and the minimum standby pool size calculator 223 is comprised in the standby pool calculator 222.
- size is not to be taken as a simple reference to a total number of resources.
- the size of the standby pool is to be regarded as a matrix of computational resources of varying kind, performance and availability.
- the state predictor is in some embodiments based on a model.
- the software monitoring arrangement 220 of figure 2B is therefore shown as comprising a system model 228' and wherein the predicted state 221' is determined based on the system model 228'
- the system model 228' is a model of the software system 200 and it may be represented in many different manners as would be understood by a skilled person.
- the system model 228' is based on machine learning such as neural networks, and the system model 28' is in some such embodiments represented by a neural network.
- the software monitoring arrangement 220 is configured (when executed by the controller 101) to determine the predicted state 221' through the state predictor 221 utilizing such a neural network.
- the neural network is based on deep learning.
- the neural network is based on convolutional neural networks (CNN). This allows for adapting to a vast number of different possibilities which may only differ in small increments but hade hugely different effects that would be very complicated indeed to provide a mechanistic performance model for.
- CNN convolutional neural networks
- the software monitoring arrangement 220 is configured to (re)train the system model 228'.
- the software monitoring arrangement 220 therefore stores some (for example every other, every tenth, or any such interval) or all state predictions 221' made, at least over a time period of for example 10 ms, 100 ms, 1 s, 10 s, 100 s, 10 minutes, 1 hour, 24 hours.
- the corresponding performance metrics for the predicted states are also stored, possibly along with the predicted states 221'. This allows for a model trainer 228 that is comprised in the software monitoring arrangement 220 to train the system model 228' based on the stored (or at least a subset of the stored) predicted states and the corresponding performance metrics.
- the software monitoring arrangement 220 is, in some embodiments, configured to only store predicted states that show a prediction accuracy exceeding a quality level, for example 70 %, 75%, 80%, 85%, 90%, 95% or 99%.
- the software monitoring arrangement 220 is configured to perform such (re)training when the performance 225' of the state predictor 221 falls below a performance threshold.
- the threshold is dependent on the representation of the accuracy, but may generally be referred to in percentages, and the performance level may thus be any of or in the range of any of for example 70 %, 75%, 80%, 85%, 90%, 95% or 99%.
- the threshold is in some embodiments set by a system designer.
- the threshold is in some embodiments set dynamically by the software monitoring arrangement 220.
- the threshold is set as a level of accuracy thereby being able to adapt to a low accuracy. In some embodiments the threshold is set as a number of miss predictions or predictions of low level of accuracy thereby being able to adapt to a repeatedly low accuracy. In some embodiments the threshold is set as a rate of change in level of accuracy thereby being able to adapt to a change in accuracy.
- the performance metrics reflect or represent a measured state of a service 215, some services 215 or all services 215.
- the performance metrics are representations of performances such as processing times, response times, response accuracy, memory read successes, queue sizes, worker threads, compute units, fan speeds, radio connections, execution frequency, cache allocations and so on to mention a few examples.
- the live-capacity controller 210 receives the performance metrics (or rather the first (subset of) performance metrics in a format that the live- capacity controller 210 is arranged to understand and to determine what computational resources to assign based on the received performance metrics. For example if the response times increase, the live- controller may respond by assigning more CPU time.
- the software monitoring arrangement 220 receives the performance metrics (or rather the second (subset of) performance metrics in a format that the software monitoring arrangement 220 is arranged to understand and to predict a future state based on the received performance metrics.
- the inventors have, however, realized after insightful and inventive reasoning, that this long standing problem can be overcome by transforming all incoming performance metrics into a format where the meaning of the performance metrics is unknown to the state predictor.
- the performance metrics are all (possibly individually) normalized, for example to a value between 0 and 1.
- the transformation may be performed by the providing service 215, the live-controller 210, the state predictor 221 or any component or entity in between. It is not of importance exactly where the performance metrics are formatted or how, and variations are possible.
- One or more of the services 215 are thus opaque services 215 in some embodiments and provide performance metrics comprising at least one opaque data entity.
- an opaque data entity is a data entity whose representation may be known to the service providing the data entity, but is unknown to the software monitoring arrangement 220. It is thereafter possible to recognize and associate patterns of performance metrics, irrespective of the actual meaning of such patterns, with states of the service(s) 215 of the software system 200.
- the system model 228' is thus, in some embodiments, trained to associate such patterns of performance metrics with states, wherein the states represent or corresponds to computational requirements, which may then be fulfilled by the computational resources 205.
- the software monitoring arrangement 220 is thus configured to determine whether a change (such as an increase, a decrease or other change) is to be expected and in response thereto reserve computational resources 205 to the standby pool accordingly.
- a change such as an increase, a decrease or other change
- the terminology of "reserve” or “making reservations” includes cancelling any already existing reserved computational resources, a cancellation thus being treated as a negative reservation.
- a cancellation of a computational resource may be seen as a negative assignment of a resource.
- a negatively assigned resource i.e. a cancelled resource
- the inventors have realized that by providing the performance metrics as images to the state predictor 221 has a great advantage in that already existing power tools may be utilized, namely neural networks arranged for image recognition, object classification or object detection to mention a few examples.
- neural networks arranged for image recognition, object classification or object detection to mention a few examples.
- Convolutional Neural Networks available that may be trained to associate the patterns of the performance metrics with objects being expressed as states of the service(s) 215 of the software system 200.
- the performance metrics may be received as opaque data entities, and in one such embodiment, the data entity may be one or more images.
- an image may be generated so that a (group of) pixel(s) is associated with a performance aspect and is assigned a value regarding how well that aspect performs. This may provide an image with different color or grey scales depending on the performance of the service(s) 215. In such an image an actual pattern may be recognized and associated with a state.
- the images discussed herein need not be visible or comprehensible to a human as they are only processed by computer processors.
- the image(s) may be generated based on opaque data entities in some embodiments.
- the image(s) may be generated based on non-opaque data entities in some embodiments.
- the second (subset of) performance metrics thus comprises one or more images representing one or more current states of the one or more services of the software system.
- the software monitoring arrangement 220 is configured to determine the predicted state 221' of the software system 200 based on image analysis of the one or more images.
- the software monitoring arrangement 220 is further configured to provide said image analysis to recognize a pattern in the one or more images, which pattern is associated with a known state, wherein the predicted state is determined to be the known state, the known state being a previously experienced state that was experienced when the same performance metrics were received.
- the performance metrics present a moment in time.
- the state predictor is trained to associate a moment in time with a predicted state.
- the state predictor 221 is configured to determine the predicted state based on one image for one or more services 215.
- the performance metrics present a series of moments (i.e. a time period) in time.
- the state predictor is trained to associate a time period with a predicted state.
- the pattern may in such embodiments also be a pattern over time.
- the state predictor 221 is configured to determine the predicted state based on a series (or stream) of images for one or more services 215.
- FIG 3A shows a flowchart of a general method according to an embodiment of the teachings herein.
- the method utilizes a monitoring arrangement 100 as taught herein and as disclosed with particular reference to figure 2A.
- the monitoring arrangement 100 receives 310 performance metrics for one or more services 215 of a software system 200 as in figure 2A (or figure 2B).
- the software monitoring arrangement 220 determines 320 a predicted state based on the received performance metrics.
- the software monitoring arrangement 220 also determines 330 a standby capacity of computational resources based on the determined predicted state and reserves 340 computational resources to a standby pool of computational resources 206 accordingly. This allows a live-controller 210 to assign any changes in resources from the standby pool.
- Figure 3B shows a flowchart of a general method according to an embodiment of the teachings herein.
- the method utilizes a monitoring arrangement 100 as taught herein and as disclosed with particular reference to figure 2B.
- the flow chart of figure 3B comprise all processes, steps, actions and functionalities of the method of figure 3A.
- the monitoring arrangement 100 also determines 322 a performance of the prediction of the predicted state 221'.
- the model 228' of the software system 200 is also trained 326 based on the predicted state.
- the training is performed if the performance of the prediction falls below 324 a threshold value.
- a compensator is also determined 328 for adapting the standby capacity based on the performance prediction. Alternatives for these embodiments and more are discussed in the above with reference to figures 2A and 2B.
- Figure 4 shows a component view for a software component (or module) arrangement 400 according to an embodiment of the teachings herein.
- the software component arrangement 400 is adapted to be used in a monitoring arrangement 100 as taught herein for automated software monitoring of (real-time) services as taught herein for automated software monitoring of a software system comprising one or more of computational resources configured to execute one or more services and a live capacity controller configured to receive performance metrics from the one or more services and to assign a portion of the computational resources to the one or more services based on the performance metrics, wherein the software component arrangement 400 comprises: a software component 410 for receiving the performance metrics; a software component 420 for determining a predicted state of the software system; a software component 430 for determining a standby capacity based on the predicted state; and a software component 440 for reserving computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller execute a software component 450 for assigning an increase in the portion of the computational resources to the one or more services from the stand
- a software component may be replaced or supplemented by a software module.
- Figure 5 shows a component view for an arrangement 500 comprising circuitry for monitoring of (real-time) services according to an embodiment of the teachings herein.
- the arrangement 500 comprising circuitry for monitoring of services is adapted to be used in a monitoring arrangement 100 as taught herein of a software system comprising one or more of computational resources configured to execute one or more services and a live capacity controller configured to receive performance metrics from the one or more services and to assign a portion of the computational resources to the one or more services based on the performance metrics, wherein the arrangement 500 of figure 5 comprises circuitry 510 arranged to receive the performance metrics; circuitry 520 arranged to determine a predicted state of the software system; circuitry 530 arranged to determine a standby capacity based on the predicted state; and circuitry 540 arranged to reserve computational resources according to the standby capacity to a standby pool of computational resources enabling the live capacity controller to execute circuitry 550 arranged to assign an increase in the portion of the computational resources to the one or more services from the standby pool.
- the arrangement 500 comprises in some embodiments additional circuitry 560 for performing any of the methods or functions disclosed herein.
- the live capacity controller may be regarded as a real-time controller, especially when controlling real-time services 215.
- Figure 6 shows a schematic view of a computer-readable medium 120 carrying computer instructions 121 that when loaded into and executed by a controller of a software monitoring of (real time) services arrangement 100 enables the software monitoring of (real-time) services arrangement 100 to implement the present invention.
- the computer-readable medium 120 may be tangible such as a hard drive or a flash memory, for example a USB memory stick or a cloud server.
- the computer-readable medium 120 may be intangible such as a signal carrying the computer instructions enabling the computer instructions to be downloaded through a network connection, such as an internet connection.
- a computer-readable medium 120 is shown as being a computer disc 120 carrying computer-readable computer instructions 121, being inserted in a computer disc reader 122.
- the computer disc reader 122 may be part of a cloud server 123 - or other server - or the computer disc reader may be connected to a cloud server 123 - or other server.
- the cloud server 123 may be part of the internet or at least connected to the internet.
- the cloud server 123 may alternatively be connected through a proprietary or dedicated connection.
- the computer instructions are stored at a remote server 123 and be downloaded to the memory 102 of the software monitoring of real-time services arrangement 100 for being executed by the controller 101.
- the computer disc reader 122 may also or alternatively be connected to (or possibly inserted into) a software monitoring of real-time services arrangement 100 for transferring the computer- readable computer instructions 121 to a controller of the software monitoring of real-time services arrangement (presumably via a memory of the software monitoring of real-time services arrangement 100).
- Figure 6 shows both the situation when a software monitoring of (real-time) services arrangement 100 receives the computer-readable computer instructions 121 via a wireless server connection (non-tangible) and the situation when another software monitoring of (real-time)services arrangement 100 receives the computer-readable computer instructions 121 through a wired interface (tangible).
- This enables for computer-readable computer instructions 121 being downloaded into a software monitoring of (real-time) services arrangement 100 thereby enabling the software monitoring of (real-time) services arrangement 100 to operate according to and implement the invention as disclosed herein.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Quality & Reliability (AREA)
- Mathematical Physics (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- Life Sciences & Earth Sciences (AREA)
- Bioinformatics & Cheminformatics (AREA)
- Bioinformatics & Computational Biology (AREA)
- Evolutionary Biology (AREA)
- Debugging And Monitoring (AREA)
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/EP2021/064701 WO2022253417A1 (en) | 2021-06-01 | 2021-06-01 | A computer software module arrangement, a circuitry arrangement, an arrangement and a method for improved autonomous adaptation of software monitoring of realtime systems |
Publications (1)
Publication Number | Publication Date |
---|---|
EP4348423A1 true EP4348423A1 (de) | 2024-04-10 |
Family
ID=76325526
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP21730863.4A Pending EP4348423A1 (de) | 2021-06-01 | 2021-06-01 | Computersoftwaremodulanordnung, schaltungsanordnung, anordnung und verfahren zur verbesserten autonomen anpassung der softwareüberwachung von echtzeitsystemen |
Country Status (3)
Country | Link |
---|---|
US (1) | US20240264916A1 (de) |
EP (1) | EP4348423A1 (de) |
WO (1) | WO2022253417A1 (de) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20230164017A (ko) * | 2021-04-09 | 2023-12-01 | 삼성전자주식회사 | 네트워크에서 애플리케이션 서비스들을 모니터링하기 위한 방법 및 시스템 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
SE537197C2 (sv) | 2012-10-05 | 2015-03-03 | Elastisys Ab | Metod, nod och datorprogram för möjliggörande av automatiskanpassning av resursenheter |
-
2021
- 2021-06-01 US US18/565,945 patent/US20240264916A1/en active Pending
- 2021-06-01 WO PCT/EP2021/064701 patent/WO2022253417A1/en active Application Filing
- 2021-06-01 EP EP21730863.4A patent/EP4348423A1/de active Pending
Also Published As
Publication number | Publication date |
---|---|
US20240264916A1 (en) | 2024-08-08 |
WO2022253417A1 (en) | 2022-12-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11374876B2 (en) | Intelligent cloud platform to host resource efficient edge network function | |
US20230281515A1 (en) | Distributed learning model for fog computing | |
WO2024192952A1 (zh) | 一种基于强化学习的Serverless高效资源分配方法及系统 | |
CN115269108A (zh) | 一种数据处理方法、装置及设备 | |
CN113553160A (zh) | 用于人工智能物联网的边缘计算节点任务调度方法及系统 | |
KR101630125B1 (ko) | 클라우드 컴퓨팅 자원관리 시스템에서의 자원 요구량 예측 방법 | |
CN104467997B (zh) | 一种基于无线信号强度预测的终端节能的方法和装置 | |
US20240264916A1 (en) | Autonomous adaptation of software monitoring of realtime systems | |
CN115080209A (zh) | 系统资源调度方法、装置、电子设备及存储介质 | |
CN116962532A (zh) | 集群任务调度方法、装置、计算机设备及存储介质 | |
CN114466014B (zh) | 一种服务调度方法、装置、电子设备及存储介质 | |
CN116109058A (zh) | 一种基于深度强化学习的变电站巡视管理方法和装置 | |
Kumar et al. | Optimizing resource allocation using proactive scaling with predictive models and custom resources | |
CN115695193A (zh) | 设备能耗控制方法、装置、电子设备、计算机可读介质 | |
Kantardjian et al. | Dynamic Worker Availability Prediction at the Extreme Edge | |
US20220236899A1 (en) | Information processing apparatus, information processing method, and computer-readable recording medium storing information processing program | |
US11979295B2 (en) | Reinforcement learning agent training method, modal bandwidth resource scheduling method and apparatus | |
CN113823011B (zh) | 巡逻机器人的算力分配方法及相关设备 | |
CN118170550B (zh) | Node节点水位线阈值调节方法、装置及相关设备 | |
CN116456558B (zh) | 一种地铁站内照明设备自适应控制方法及系统 | |
US20230385116A1 (en) | Dynamic resource reservation with reinforcement learning | |
US20230359539A1 (en) | Improved software monitoring of real-time services | |
CN118034938B (zh) | 一种作业调度方法、智能计算云操作系统以及计算平台 | |
US20240364640A1 (en) | Resource allocation system and method for a cloud environment | |
JP2024536326A (ja) | モバイルネットワークに対するアプリケーションのサービス品質要求の動的な自己最適化 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: UNKNOWN |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE INTERNATIONAL PUBLICATION HAS BEEN MADE |
|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20231103 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
DAV | Request for validation of the european patent (deleted) | ||
DAX | Request for extension of the european patent (deleted) |