The embodiments of the present description regard techniques for data-packet analysis implemented, in particular, within one or more computers forming part of a network-security monitoring platform (NSMP), also identified as Security Network Monitoring Platform (SNMP).
a DSL (Digital Subscriber Line) modem,
a mobile communication interface, such as a transceiver of a GSM (Global System for Mobile Communications) type, a CDMA (Code-Division Multiple Access) type, a W-CDMA (Wideband Code-Division Multiple Access) type, a UMTS (Universal Mobile Telecommunications System) type, an HSPA (High-Speed Packet Access) type and/or an
LTE (Long Term Evolution) type,
an Ethernet communication interface (copper and/or optical fibre), and/or va Wi-Fi communication interface, compatible with one of the versions of the IEEE 802.11 standard.
Typically, the router 20 further comprises one or more communication interfaces for connection to the LAN 10. For example, in
a local server SRVL connected to the LAN 10;
a remote server SRVR connected to the WAN 30; and
a server SRVDMZ connected to a so-called demilitarized zone (DMZ) managed by the router 20.
Of course, the person skilled in the art will note that modern computer networks may be much more complex. In fact, the LAN 10 could also be formed by a very large number of local clients DEV, servers SRV and/or SRVDMZ, and further components of the infrastructure of the LAN 10 (for example, switches 100 and/or access points 102, routers 20, etc.). Moreover, the LAN may also comprise a plurality of LAN subnetworks, e.g., connected through a Virtual Private Network (VPN). Again, in order to improve network security, one or more of the devices may be configured as firewalls or, in general, may carry out functions of filtering of the data packets: for example, the switch 100, the access point 102, and the router 20 can implement filtering functions, while the server SRVL and/or the server SRVDMZ can function as firewall.
To improve network security further, modern computer networks frequently rely upon antivirus software, installed on the various computers (DEV, SRVL and/or SRVDMZ). The antivirus software typically monitors the programs that are downloaded and executed by a computer but, also, the traffic generated by the corresponding computer, for the protocols HTTP (Hypertext Transfer Protocol), HTTPS (HyperText Transfer Protocol over Secure Socket Layer/Transport Layer Security), POP (Post Office Protocol), in particular in its version 3 (POP3), IMAP (Internet Message Access Protocol), SMTP (Simple Mail Transfer Protocol), SMB (Server Message Block), etc.
Recently, networks have been enriched with network-security monitoring platforms (NSMP), also identified as Security Network Monitoring Platform (SNMP), which collect, treat, and process data flows observed in near-real time for identifying possible cyber-attacks or anomalous behaviours in the network being monitored, such as the LAN 10 and/or the DMZ.
In particular, as shown in
a port of a so-called Switched Port Analyzer (SPAN) type, or one of its variants, such as Remote SPAN (RSPAN), Port-based SPAN (PSPAN), or VLAN-based SPAN (VSPAN), in which a managed switch 100 is configured to send a copy of the traffic exchanged through the switch 100 to the computer 400;
a router 20 (or a firewall) configured to send a copy of the traffic exchanged through the router 20 (or the firewall) to the computer 400; or
a dedicated passive or active terminal access point (TAP) 404 configured to send a copy of the traffic that passes through the TAP 404 to the computer 400.
Frequently, these data-traffic sensors do not necessarily send a copy of all the traffic, but may send:
a copy of the traffic that meets given rules, for example with reference to the source port and/or destination port of the switch 100, to the source and/or destination IP address, to the TCP or UDP port, to the higher-layer protocol used, such as HTTP, etc.; and/or
pre-processed data, wherein the sensor has already extracted some features from the data traffic, the so-called metadata.
Consequently, the computer 400 receives a copy of the traffic containing data and/or metadata that can be analysed to determine any possible anomalous behaviours. For example, the present applicant markets an SNMP platform with the name aramis®.
An SNMP can incorporate various software components or modules that analyse, in parallel, the various features of the data traffic.
Amongst other things, in the simplest case, a component may verify whether within the data or the metadata of the traffic being monitored there are no indicators of compromise (IoCs) and/or signatures that may be correlated to malicious activities. For example, these IoCs and/or malicious signatures may be downloaded from a remote server SRVR connected to the WAN 30, such as public or proprietary sources. For instance, in the simplest case, the above IoCs may correspond to given predetermined rules, such as IP addresses and/or URLs (Uniform Resource Locators) of websites that distribute malware. On the other hand, the signatures may be used, in a way similar to a traditional antivirus, for comparing the signature of a file downloaded (for example with the protocol HTTP, POP or IMAP) with a list of signatures of malicious files. For example, these file signatures may be calculated with a hash function, such as MDS, SHA-1, SHA-2 (for example SHA-256) or SHA-3.
Recently, machine learning has been applied also in the field of cyber security in order to analyse the network traffic and detect automatically any behaviours that deviate from the normal and legitimate behaviour of the network, i.e., any behaviours that may be indicators of anomalies and/or malicious activities. For example, a machine-learning component may use one or more mathematical models with a supervised or non-supervised approach for modelling the normal behaviour of each computer DEV and/or server SRVL/SRVDMZ within the LAN 10 and/or the DMZ. Some solutions also enable monitoring of sets of devices, for example all the clients DEV that exchange traffic with the
WAN. In general, for the supervised approaches, training of the models may be carried out during specific steps, on request, and/or periodically. Hence, once the mathematical model has been trained, this model may be used for classifying the current behaviour of the data exchange in the network being monitored. Consequently, whereas the first component is deterministic, the machine-learning component automatically adapts to the behaviour of a given network.
Moreover, another component may detect more complex anomalous behaviours by analysing the traffic through more sophisticated advanced analytics referred to as Advanced Cybersecurity Analytics (ACA). The purpose of these analytics is hence to identify sequences of suspect events that with a certain likelihood may be correlated to the phases of an attack. These analytics are typically based on the mathematical modelling of malicious behaviours through statistical and/or machine-learning approaches.
Use of the above three components makes it possible to alert an operator, i.e., a so-called security analyst, in a timely way in the event of an anomaly or attack, for example through the use of display of targeted graphic information and/or by sending notifications to the operator. For example, for this purpose, the computer 400 may be connected to one or more analysis terminals 406. In general, whereas
Consequently, a network-security monitoring platform provides a set of analytics, capable of identifying suspect events that can be put down to an attack.
In this context, irrespective of whether deterministic, probabilistic, and/or machine-learning methods are used, some analytics have the purpose of detecting automatic and systematic communications performed by malware.
The present disclosure hence relates to solutions for detecting systematic, i.e., repetitive and/or periodic, communications that may be an indicator of the presence of malware within the network being monitored. According to one or more embodiments, the above object is achieved through a method having the distinctive elements set forth specifically in the ensuing claims. The embodiments moreover regard a corresponding device, as well as a corresponding computer program product, which can be loaded into the memory of at least one computer and comprises portions of software code for implementing the steps of the method when the product is run on a computer. As used herein, reference to such a computer program product is understood as being equivalent to reference to a computer-readable means containing instructions for controlling a processing system in order to co-ordinate execution of the method. Reference to “at least one computer” is clearly intended to highlight the possibility of the present disclosure being implemented in a distributed/modular way.
The claims form an integral part of the technical teaching of the description provided herein.
As mentioned previously, various embodiments of the present disclosure regard a method and a corresponding SNMP for detecting systematic communications in a communications network. In particular, the SNMP is configured for repeating a series of operations, for each data packet—of a sequence of a plurality of data packets—sent through the communications network from a respective source to a respective destination.
In particular, in various embodiments, the SNMP obtains metadata of the data packet, where the metadata include both data that identify the source and/or the destination and data that identify a sending time t when the data packet has been sent.
In various embodiments, the SNMP then verifies whether the data packet belongs to a specific type of communication by checking whether the metadata indicate the fact that the data packet has been sent by a given source and/or received by a given destination. For example, for this purpose, the SNMP may verify whether the data packet: has been sent from a given IP source address to a given IP destination address or to a given destination port; is an ARP (Address Resolution Protocol) request sent from a MAC source address and/or from an IP source address, or is an ICMP (Internet Control Message Protocol) echo request sent from a MAC source address and/or from an IP source address.
In various embodiments, the SNMP then calculates a value of variance for the given type of communication, compares the value of variance with a threshold, and possibly generates a notification that indicates the fact that the given type of communication is systematic.
In particular, in various embodiments, the SNMP uses an iterative approach for calculating the value of variance. In particular, as will be described in greater detail hereinafter, the SNMP may manage for this purpose an orderly list for storing the sending times t, and can compute the value of variance as a function of a quadratic sum, the difference between the sending time of the last element of the orderly list and the sending time of the first element of the orderly list, and the number of elements present in the orderly list.
In particular, in various embodiments, once the metadata of the data packet have been obtained, and in particular the sending time t of the respective data packet, the SNMP verifies whether the orderly list is empty. In the case where the orderly list is empty, the SNMP adds the sending time t as first element of the orderly list, and sets the value of a quadratic sum to zero. Instead, in the case where the orderly list is not empty, the SNMP compares the sending time with the sending times stored in the orderly list.
In particular, in various embodiments, in the case where the sending time t is greater than the sending time of the last element in the orderly list, the SNMP computes the difference between the sending time t and the sending time of the last element of the orderly list. Moreover, the SNMP updates both the orderly list by adding the sending time t as new last element at the end of the orderly list and the value of the quadratic sum by adding the square of the difference.
Instead, in the case where the sending time t is less than the sending time of the first element in the orderly list, the SNMP computes the difference between the sending time of the first element of the orderly list and the sending time t. Moreover, the SNMP updates both the orderly list by adding the sending time t as new first element at the beginning of the orderly list and the value of the quadratic sum by adding the square of the difference.
Finally, in the case where the sending time t is greater than the sending time of the first element in the orderly list and less than the sending time of the last element in the orderly list, the SNMP determines a position j for entry of the sending time t. This position j corresponds to the position of the element in the orderly list that has a sending time greater than the sending time t and less than the sending time of the immediately preceding element. The SNMP then computes a first difference between the sending time of the element of the orderly list in position j and the sending time t. Next, the platform computes a second difference between the sending time t and the sending time of the element of the orderly list in the position that precedes the position j. Finally, the SNMP determines a third difference between the sending time of the element of the orderly list in position j and the sending time of the element of the orderly list in the position that precedes the position j.
For example, the SNMP may calculate the third difference by computing the difference between the sending time stored in the element of the orderly list in position j and the sending time stored in the element of the orderly list in the position that precedes the position j.
Alternatively, to determine the various differences, the SNMP can store the differences in a list. In particular, in the case where the sending time t is greater than the sending time of the last element in the orderly list, the SNMP may store the difference between the sending time t and the sending time of the last element of the orderly list with the new last element of the updated orderly list. Instead, in the case where the sending time t is less than the sending time of the first element in the orderly list, the SNMP may store the difference between the sending time of the first element of the orderly list and the sending time t with the old first element of the (non-updated) orderly list. Consequently, in the case where the sending time t is greater than the sending time of the first element in the orderly list and less than the sending time of the last element in the orderly list, the SNMP may obtain the third difference by reading the difference stored in the element of the orderly list in position j. However, in this case, the SNMP stores the second difference in the new element of the updated orderly list in position j, and stores the first difference as difference of the old element of the orderly list in position j.
Moreover, in the case where the sending time t is greater than the sending time of the first element in the orderly list and less than the sending time of the last element in the orderly list, the SNMP updates the orderly list by adding the sending time t as new element in the position j of the orderly list and updates the value of the quadratic sum by adding the square of the first difference and the square of the second difference and subtracting the square of the third difference.
In various embodiments, the SNMP is moreover able to determine the number of elements present in the orderly list and compute the difference between the sending times contained in the last element and in the first element of the updated orderly list. Finally, the SNMP computes the value of variance as a function of the quadratic sum, the difference, and the number of elements.
For example, to determine the difference between the sending time of the last element of the updated orderly list and the sending time of the first element of the updated orderly list, the SNMP can increment sequentially a partial sum. In particular, in the case where the orderly list is empty, the SNMP can set the value of the partial sum to zero. In the case where the sending time t is greater than the sending time of the last element in the orderly list, the
SNMP can update the value of the partial sum by adding the difference between the sending time t and the sending time of the last element of the orderly list. Instead, in the case where the sending time t is less than the sending time of the first element in the orderly list, the SNMP can update the value of the partial sum by adding the difference between the sending time of the first element of the orderly list and the sending time t.
The embodiments of the present disclosure will now be described with reference to the annexed drawings, which are provided purely by way of non-limiting example, and in which:
In the ensuing description, numerous specific details are provided to enable an in-depth understanding of the embodiments. The embodiments may be implemented without one or more of the specific details, or with other methods, components, materials, etc. In other cases, operations, materials or structures that are well known are not represented or described in detail so that the aspects of the embodiments will not be obscured.
Reference throughout this description to “an embodiment” or “one embodiment” means that a particular characteristic, distinctive element, or structure described with reference to the embodiment is comprised in at least one embodiment. Hence, the use of the phrase “in an embodiment” or “in one embodiment” in various parts of this description do not necessarily refer all to one and the same embodiment. Moreover, the particular characteristics, the distinctive elements, or the structures may be combined in any way in one or more embodiments.
The references appearing herein are provided only for convenience and do not define the sphere of protection or the scope of the embodiments.
In the ensuing
As mentioned previously, the present disclosure provides solutions for detecting systematic communications, which may be an indicator of the presence of malware. In fact, unlike human behaviour, the communications made by malicious software may be characterized by a low latency and a marked periodicity.
After a starting step 1000, the computer 40a receives in a step 1002 data packets DP from one or more data-traffic sensors. For example, as explained previously, these data packets DP may be supplied by a SPAN port 402 of a switch 100, a router and/or a firewall 20, a TAP 404, etc. In general, the computer 40a may also be integrated directly in one of the data-traffic sensors, for example within a firewall with a sufficient computational capacity.
For example, with reference to data packets DP compliant with the IP (Internet Protocol), each IP (IPv4 or IPv6) packet comprises an IP source address and an IP destination address. Moreover, each IP packet may comprise:
ICMP (Internet Control Message Protocol) control data; or
data of a transport protocol, which comprises a payload and possibly further routing information, for example a TCP (Transmission Control Protocol) or the UDP (User Datagram Protocol) port.
In general, the data packets DP may even be data packets at the level of network access (link layer), for example, directly the respective Ethernet frames or requests compliant with the Address Resolution Protocol (ARP). For instance, with reference to the ARP, an ARP request makes it possible to obtain the MAC (Media Access Control) address associated to a given IP address. Consequently, in general, each data packet DP typically comprises the data that identify the source of the data packet DP, for example the MAC address and/or the IP address.
Consequently, in a step 1004, the computer 40a may process the data packet DP and extract data characterizing the data packet DP. For example, a typical data packet DP may comprise, in addition to the Ethernet and/or IP headers, also a header at the level of transport protocol, such as TCP or UDP. Consequently, in various embodiments, the computer 40a may extract from these headers routing information, such as:
in the case where the data packet DP is included in an Ethernet frame, the MAC source address and possibly the MAC destination address;
in the case where the data packet DP comprises an IP packet (possibly included in an Ethernet frame), the IP source address and the IP destination address; and
in the case where the data packet DP comprises a TCP or UDP packet (possibly included in an IP packet), the respective port.
In various embodiments, the computer 40a may also extract other information from the header or headers of the data packet DP. For instance, in various embodiments, the computer 40a is configured to classify the data packets as ICMP, ARP messages, or data transmissions.
In various embodiments, the computer 40a may also process the payload of the data packet DP. For example, in various embodiments, the computer 40a may calculate a signature (e.g., a hash code) for the payload.
These characteristic data correspond thus to metadata MD that describe the data packet DP. For instance, the computer 40a may store the above metadata MD in a memory 408, for example implemented with a database. In general, the database 408 may be implemented by the computer 408 itself or by one or more further computers.
In particular, in various embodiments, the metadata MD also comprise a timestamp t. For example, for this purpose, the computer 40a may be configured with a so-called real-time clock (RTC). Consequently, when the computer 40a receives a data packet DP, the computer 40a itself may obtain the instant of reception from the RTC and store this value along with the metadata MD for the aforesaid data packet DP. Consequently, in general, the computer may associate to each data packet DP a respective time in which communication of the respective packet DP occurs.
In general, as explained previously, the data-traffic sensors may already process the data packets DP and generate (at least in part) the metadata MD; i.e., the computer 40a could receive in step 1002 directly metadata MD, and optionally also the respective data packets DP or only the respective payload. In this case, the computer 40a could even only store in step 1004 the metadata MD received.
In various embodiments, the computer 40a then determines in a step 1006 an orderly timestamp sequence T
T:=[t0, t1, . . . , t(n−1)]
where a timestamp ti is the instant in time at position i corresponding to communication of the respective data packet DP.
In particular, the computer 40a is configured for determining the sequence T for a given type of communication, such as ARP requests that comprise one and the same MAC source address, an ICMP echo request (the so-called ping), IP packets that comprise one and the same IP source address, etc. Consequently, for this purpose, the computer 40a may be configured for:
managing a plurality of sequences T, where each sequence T is associated to a respective rule for the metadata MD; and
determining whether the metadata MD of the last data packet DP(n−1) processed correspond to one of the rules and, if they do, adding the respective timestamp t, associated to the last data packet DP(n−1) to the respective sequence T.
In particular, considering that the data packets DP may have different dimensions, and/or may be processed by different computers or different processors of one and the same computer, processing of the data packets DP may require a different processing time. Furthermore, the data-traffic sensors may send the data with different propagation times. For this reason, the timestamp ti of the last data packet DP(n−1) processed does not necessarily correspond to the last element t(n−1) of the orderly sequence T, but the computer 40a is configured for inserting the timestamp in the sequence T in a position j, with 0≤j≤(n−1), in such a way that the sequence T is ordered.
Consequently, in various embodiments, the computer 40a may manage different sequences T for different source and/or destination addresses (e.g., MAC and/or IP addresses), and possibly different sequences T for the same source, for example with reference to the protocol used, etc.
For instance, to detect a so-called LAN scan, the computer 40a may be configured for managing a respective sequence T for at least one from among:
ARP requests sent by the same source;
ICMP echo requests sent by the same source; and
TCP or UDP requests for connection to a given port sent by the same source.
For example, in various embodiments, the source is identified via the respective MAC address or IP address, or the combination of the respective MAC address and IP address. Consequently, in this way, it is possible to monitor communications sent by the same source that are able to detect other computers that can be reached within the LAN 10.
Instead, to detect a so-called port scan of the same destination, the computer 40a may be configured for managing a respective sequence T for TCP or UDP connection requests sent from the same source to the same destination. For example, the source and the destination may be identified via the respective MAC address and/or IP address. Moreover, to detect brute-force attacks carried out to obtain an unauthorized access to a computer, the computer 40a may be configured for managing a respective sequence T of authentication requests between the same source and the same destination, such as authentication requests in accordance with the protocols POP3, SMTP, IMAP, HTTP, HTTPS, and/or SMB.
In general, the computer 40a could also enable specification of additional rules, for example through the terminal 406. For instance, in various embodiments, these rules may comprise one or more of the metadata MD.
In the embodiment considered, the computer 40a then computes in a step 1008 the difference between each timestamp and the previous timestamp, thus determining a sequence S:
S:=[t1-t0, t2-t1, . . . , t(n−1)-t(n−2)]=[S0, S1, . . . , S(n−2)]
In general, in the case where the computer 40a manages a number of sequences T, the computer 40a computes for each sequence T a respective sequence S.
In various embodiments, to determine the periodicity of the communication, the computer 40a computes in a step 1010 the variance Var(S) of each sequence S; namely,
where
Consequently, in a step 1012, the computer 40a may verify the value of the variance Var(S) of each sequence S. In particular, in the case of automatic requests, the variance Var(S) should be low.
Consequently, in the case where the value of the variance Var(S) of a sequence S is less than a threshold TH (output “N” from the verification step 1012), the computer 40a proceeds to a step 1014, where it notifies the event to an operator, for example by sending a notification to the terminal 406 (see
Instead, in the case where the value of the variance Var(S) of all the sequences S is greater than the threshold TH (output “Y” from the verification step 1012), the computer 40a may return directly to step 1002 to receive the next data packet DP and/or metadata MD.
In various embodiments, the threshold TH for each sequence S may be fixed, programmable, or determined by analysing the communications made in the absence of malware. For example, for this purpose, the computer 40a may calculate, during a training step and/or periodically, a value of variance Var(S) (as described with reference to steps 1006-1010) for a sequence S and calculate the threshold TH by multiplying the aforesaid value by a coefficient c, i.e., TH=c·Var(S), with c<1, for example c=0.8.
In general, the computer 40a may also use statistical approaches. For example, in the simplest case, the computer 40a may monitor in time different sequences S, choose the minimum value Varmin(S), and calculate the threshold TH by multiplying the aforesaid minimum value Varmin(S) by the coefficient c.
In general, the threshold TH may be determined also via a machine-learning algorithm. For instance, in this case, a machine-learning algorithm, such as a neural network, may be trained for predicting an expected variance for a certain period of time of a given day of the week. Consequently, the mathematical model (for example, the trained neural network) receives as input the time and a datum that identifies the day of the week and supplies as output an estimate of the expected variance. Hence, the threshold TH may be calculated by multiplying the above expected variance by the coefficient c.
Consequently, in various embodiments, the computer 40a may store one or more values of variance Var erasing each time the elements of the orderly list T, and determine the threshold TH as a function of this value or these values of variance Var. In particular, for this purpose, the elements may be erased explicitly from the orderly list or implicitly by generating a new orderly list.
Consequently, through calculation of the variance, the computer 40a is able to detect the communications that occur in a systematic way. However, as explained previously, the computer 40a may even manage numerous sequences T for the various types of communications to be monitored. Moreover, each sequence T may comprise an even extremely large number of elements. Consequently, calculation of the values of the mean S and the variance Var(S) in real time may become complex.
The inventors have noted that the computational time could be reduced using an iterative calculation scheme for the variance. However, this is not easy to apply to the sequence S, since the timestamps of the data packets DP received/processed may be out of order, which would also affect the sequence of differences S.
Consequently,
Also in this case, the computer 40a is configured to obtain the metadata MD of a data packet DP. For the corresponding description reference may be made to the description of steps 1002 and 1004 of
In the embodiment considered, a step 1022 is moreover represented, in which the computer 40a analyses the metadata MD to determine whether the data packet DP belongs to one or more communication sequences to be monitored, i.e., whether the metadata MD correspond to one or more rules. In fact, as explained previously, one and the same data packet DP could satisfy a number of rules that are associated to different communication sequences, for example:
for monitoring a LAN scan, requests having the same source and the same destination port but having different destinations; and
for monitoring a port scan, requests having the same source and different destination ports but having the same destination.
In fact, as described previously, the computer 40a should calculate for each communication sequence to be monitored a respective value of variance. For example, to distinguish the various communication sequences, the computer 40a may be configured for associating to each sequence a respective univocal code.
In particular, in the embodiment considered, the steps 1006, 1008 and 1010 have been combined in a single procedure of calculation of the variance for a given communication. Consequently, in the case where the data packet DP belongs to a number of sequences to be monitored, the procedure 1024 is carried out for each sequence. For example, to identify the sequence to which the data packet DP belongs, the computer 40a may pass, to the procedure 1024, also the univocal code that identifies a given communication sequence.
In particular, in various embodiments, the computer 40a is configured for updating the value of variance Var for a given sequence (for example, identified via a respective univocal code) in an iterative way as a function of the timestamp t of the current data packet DP that is being analysed.
Consequently, also in this case, the computer 40a may proceed to a step 1012 for comparing the value or values of variance Var that has/have been updated with respective thresholds TH, i.e., the respective threshold TH associated to the communication sequence that is being updated, and possibly may generate a notification signal in step 1014.
As explained previously, in various embodiments, the computer 40a is configured for updating the value of variance Var for a given sequence (for example, identified via a respective univocal code) in an iterative way as a function of the timestamp t of the current data packet DP that is being analysed.
Specifically, in various embodiments, the variance is calculated using the following simplified equation:
which enables separate calculation of a partial sum
and a quadratic sum
In this context, the times t of the data packets DP are not necessarily in order. For example, considering the following sequence V of times of arrival t (expressed for simplicity in milliseconds) of data packets DP of a given communication sequence:
V=[251, 450, 678, 553, 660, 719, 824, 876, 602, 184]
the corresponding orderly sequence T would be:
T=[184, 251, 450, 553, 602, 660, 678, 719, 824, 876]
Instead, the corresponding sequence S would be:
S=[67, 199, 103, 49, 58, 18, 41,105, 52]
In particular, in various embodiments, to manage sequential entry of a new element t, the computer 40a may manage a list D:
D:=[d0, d1 . . . ]=[[t0,0],[t1, s0], . . . ]
In general, instead of managing a single list D, the computer 40a could also manage one list T (for the times t) and one list S (for the differences s). However, this case is not considered specifically hereinafter, since it is only a question of a separation of the elements of the list D into two lists T and S.
Instead, as will be described in greater detail hereinafter, in various embodiments, the computer 40a may not store the differences s in the list D (or S), but only the times tin the list D. In this case, the list D hence corresponds to the list T.
Consequently, in the embodiment considered, after the step 1024 of start of the procedure, the computer 40a checks in a step 1026 whether the procedure has been started for the first time for the communication sequence that is being updated, for example whether the procedure has been started for the first time for a given univocal code. For instance, the computer 40a may check in step 1026 whether the respective list D (or likewise the list T) is empty and/or has a number of elements k equal to zero.
In the case where the procedure has been started for the first time (output “Y” from the verification step 1026), the computer 40a proceeds to an initialization step 1028, in which it initializes the list D or the list T, in particular by adding the first element:
D:=[d0]=[[t, 0]] or T:=[to]=[t]
i.e., the time t is stored as the first element do of the list D or likewise the first element t0 of the list T. For example, this is schematically shown in
In the embodiment considered, the computer 40a then proceeds to a step 1050, in which it increments the counter k, which hence indirectly indicates also the number of iterations i, that is, the number of the elements in the list D (or likewise T) at the next iteration. In general, the number of elements in the list D (or likewise T) could be obtained also by analysing explicitly the content of the list.
Finally, the procedure terminates in a step 1052. Consequently, with reference to the numeric example, the computer 40a adds at the first iteration (i=0) the first element d0=[251, 0] to the list D, as shown in
Instead, in the case where the procedure has been started not for the first time (output “N” from the verification step 1026), the computer 40a proceeds to a verification step 1032, in which it determines whether:
the timestamp received t is less than the timestamp t0 of the first element of the list, i.e., t<t0; and
the timestamp received t is greater than the timestamp tk−1 of the last element of the list, i.e., t>tk−1.
In the case where the current timestamp t received is greater than the timestamp tk−1 of the last element of the list (output “LA” from the verification step 1032), the computer 40a updates in a step 1034 the list D (or likewise the list T) by adding a new element at the end of the list D or of the list T. The lists updated during a given iteration are denoted hereinafter, respectively, as D′ or as T, where:
D′=[d′0, . . . ]=[[6,0], . . . ], or T″=[t′0, . . . ].
The above list D′ (or likewise the list T′) does not correspond to a new list as compared to the list D (or likewise to the list T). In fact, at the next iteration the list D (or T) corresponds to the updated list D′ (or r) of the previous iteration, i.e., D(i) =D′(i−1) or T(i)=T′(i−1).
For example, as shown in
D′=[d0, . . . dk−1, d′k]
where the new element d′k can be calculated as:
d′k=[t′k, s′k−1]=[t, t−tk−1]
For instance, with reference to the numeric example, the computer 40a adds, at the second iteration (with i=1), the element d′1=[450, 199] at the end of the list D.
Likewise, the computer 40a could then add, at the end of the list T, a new element t′k=t. However, also in this case, the computer 40a computes the value s′k-1=t−tk−1, i.e., the difference between the sending time t and the sending time tk−1 of the last element of the list T.
Next, the computer 40a computes, in a step 1044, the values of the partial sum ssp(i) and of the quadratic sum ssq(i) of the current iteration (i), updating respectively the values of the partial sum ssp(i−1) and of the quadratic sum ssq(i−1) of the previous iteration (i−1) by adding, respectively, the value s′k−1 and the square of the value s′k−1:
s
sp(i)=ssp(i−1)+s′j−1(i)
s
sq(i)=ssq(i−1)+s′j−1(i)2
Consequently, with reference to the numeric example, the computer 40a updates the value ssp to 199 and the value ssq to 39,601.
Next, the computer 40a updates, in a step 1046, the value of the variable/variance Var(i) at the iteration (i) by applying the following equation:
which in any case yields, at the second iteration i=1, once again Var(1)=0, since ssq(1)=ssp(1)2. In general, in this equation, the number k refers to the number of differences s that are taken into account, which corresponds to the number of elements of the (non-updated) list D.
In the embodiment considered, the computer 40a then proceeds to step 1050 for updating the value k of the elements in the list D (or likewise in the list T) for the next iteration. Consequently, in the case where the updated number k′ is used, which hence indicates the number of elements of the updated list D′, the equation used in step 1046 corresponds to:
Likewise, the computer 40a, at the third iteration (with i=2), adds at the end of the list D the element d2=[678, 228], and updates the value ssp(2) to 427 and the value ssq(2) to 91,585, in this case updating also the variable Var(2) to 210.25.
Instead, in the case where the current time t received is less than the time to of the first element of the list (output “FI” from the verification step 1032), the computer 40a adds, in a step 1034, a new element at the beginning of the list D, or likewise at the beginning of the list T, i.e.,
d′0=[t, 0], or t′0=t
Consequently, in this way the other elements of the list are shifted. However, in this case, it is necessary to update the value of difference s of the old first element do, which is now in the position of the new second element d′1 of the updated list D′. Consequently, in various embodiments, the computer 40a recalculates the value of the difference of the second element d′1 as a function of the timestamp t′1 of the new second element (which corresponds to the timestamp to of the old first element do) and of the timestamp t′o of the new first element (which corresponds to the timestamp t)
d′1=[t′1, s′0]=[t0, t0−t]
In general, updating can be carried out for the element d0, i.e., prior to entry of the element d′0, or of the element d′1, i.e., after entry of the element d′0. Consequently, for a generic list D with k elements, the updated list D′ corresponds to
D′=[d′0, d′1, d1, . . . dk−1]
For example, this is shown in
Likewise, the computer 40a could then add at the start of the list T a new element t′0=t. However, also in this case, the computer 40a computes the value s′0=t0−t, i.e., the difference between the sending time t0 of the first element of the (non-updated) list D and the sending time t.
Next, the computer 40a computes, in a step 1036, the values of the partial sum ssp(i) and of the quadratic sum ssq(i) of the current iteration (i), updating respectively the values of the partial sum ssp(i - 1) and of the quadratic sum ssq(i−1) of the previous iteration (i−1). In particular, in this case, the computer 40a adds, respectively, the value s′0 and the square of the value s′0:
s
sp(i)=ssp(i−1)+s′0(i)
s
sq(i)=ssq(i−1)+s′0(i)2
Consequently, with reference to the numeric example, the computer 40a updates, at the instant i=9, the value ssp from 625 to 692 and the value ssq from 71,709 to 76,198. Next, the computer 40a again updates, in step 1046, the value of the variable/variance Var(i) at the iteration (i) from 2860.11 to 2554.54.
Finally, in the case where the current timestamp t received is greater than the timestamp t0 of the first element of the list and less than the timestamp tk−1 of the last element of the list (output “IN” from the verification step 1032), the computer determines a position j in the list D (or likewise the list T) in which the element t is to be inserted. In particular, the position j corresponds to the position between two consecutive elements in the list D (or T) that have, respectively, a timestamp less than and a timestamp greater than the current value of t, namely, t1−1≤t≤tj, i.e., j: tj=min(t*) with t*≥t.
Consequently, as also shown in
d′j=[t′j, s′j−1]=[t, t−tj−1]
The subsequent elements of the list D are consequently in turn shifted. Also in this case, it is necessary to update the value of difference s of the old element dj in position j, which now corresponds to the element d′j+1 in position (j+1) of the list D′, namely,
d′j+1, [t′j+1, s′j]=[tj−t]
In general, updating may be carried out for the element dj, i.e., prior to entry of the element d′j, or for the element d′j+1, i.e., after entry of the element d′j.
For example, this is shown in
Likewise, the computer 40a may then add in position j of the list T a new element t′j=t. However, also in this case, the computer 40a computes the following values:
s′j=tj−t, i.e., the difference between the sending time tj of the element in position j and the timestamp t, and
s′j=tj−1, i.e., the difference between the timestamp t and the sending time tj-1 of the element of the orderly list D in position (j−1).
Moreover, the computer determines the value sj−1=tj−tj−t=t′j+1−t′j−1, i.e., the difference between the sending time t1 of the element dj of the (non-updated) list D in position j and the sending time tj−1 of the element dj−1 of the (non-updated) list D in position (j−1). In particular, using the list D, the aforesaid value is saved for the (non-updated) element dj=[tj, sj−1] and may thus be read before the element 4, is updated as element d′ij+1. Instead, using the list T, the aforesaid value sj−1 may be calculated. In general, this calculation may be made for the elements tj and tj−1, i.e., prior to entry of the element t′j, or for the elements t′j+1 and t′j-1, i.e., after entry of the element t′j.
Next, the computer 40a computes, in a step 1040, the values of the partial sum ssp(i) and of the quadratic sum ssq(i) of the current iteration (i), updating, respectively, the values of the partial sum ssp(i−1) and of the quadratic sum ssq(i−1) of the previous iteration (i−1). In particular, considering the entry of the new element d′j(t′j), the computer 40a is configured for adding respectively the (new) difference s′j or the square of the difference sj−12. In addition, considering updating of the element dj/d′j+1(tj/t′j+1), the computer 40a is configured for adding respectively the (new) difference sj−1 or the square of the difference sj−12, and removing respectively the old difference sj−1 or the square of the difference sj−12; i.e., the computer 40a implements the following equations:
s
sp(i)=ssp(i−1)+s′j−1(i)−sj−1(i)
s
sq(i)=ssq(i−1)+s′j−1(i)2+s′j(i)2−sj−1(i)2
In particular, since s′j+s′j−1=sj−1, in various embodiments, the computer 40a uses the following formula for the partial sum ssp:
s
sp(i)=ssp(i−1)
Consequently, the computer 40a may even not update the partial sum ssp when an intermediate element is inserted in the list. In fact, the value ssp corresponds to the difference between the time t′k of the last element of the updated list D′ (or T) and the time t′0 of the first element of the updated list D′ (or T), i.e., ssp=t′k−t′0. Consequently, in various embodiments, instead of using the iterative scheme, the computer 40a may compute the above difference between the maximum value and the minimum value also directly on the basis of these values.
Next, the computer 40a proceeds to step 1046 for updating the value of the variable/variance Var(i) at the iteration (i). Consequently, in the considered embodiment, the computer 40a adds the timestamps t in an orderly way in the list D (or likewise 7) and possibly updates accordingly the differences s in the list D. Furthermore, the computer 40a corrects also the values of the partial sum ssp(i) and of the quadratic sum ssq(i) of the current iteration (i), taking into account any possible shifts between the elements.
Consequently, the performance depends not so much upon recalculation of the values of the partial sum ssp(i), of the quadratic sum ssq(i), and of the variance Var(i), as upon the time required for finding the correct position (0, j or k) for inserting an element tin the list. For example, since new elements are likely to be inserted for the most part at the end of a list D (or T), in various embodiments, the search for the position j in step 1038 is carried out starting from the end of the list D (or T). For example, for this purpose, the list D (or T) may be implemented with a list that comprises for each element d (or t) a pointer to the previous element (the so-called reverse-linked list), or pointers to the previous element and to the next element (the so-called doubly-linked list). For instance, for a description of the connection between the elements of a list by means of pointers reference may be made to https://en.wikipedia.org/wiki/Linked list.
Of course, without prejudice to the principles underlying the invention, the details of construction and the embodiments may vary widely with respect to what has been described and illustrated herein purely to way of example, without thereby departing from the scope of the present invention, as defined in the ensuing claims.
Number | Date | Country | Kind |
---|---|---|---|
102021000011267 | May 2021 | IT | national |