Recent years have seen a significant increase in the use of computing devices to process and communicate data. For example, any number of computing devices may communicate with one another over a communication network by transmitting and/or receiving packets of data between multiple devices within a hierarchy of the communication network. As communication networks grow in size and complexity, it is often difficult to predict or evaluate how packets of data will travel between devices of communication networks. Indeed, implementing updates or changes to applications and/or communication protocols may cause unexpected delays or failed communications.
While network testing systems may attempt to predict how a network may affect how an application communicates over a communication network, conventional systems and techniques that involve testing how network behavior affects applications suffer from a number of drawbacks and difficulties. For example, many testing systems implement A/B testing techniques by testing treatment (i.e., B) against a control (i.e., A) prior to rolling it out to real users. While A/B testing provides real data and an accurate depiction of how a portion of devices and/or applications may perform with respect to devices on a communication network, if the application and/or update results in a negative experience, individuals affected by the A/B testing may associate the negative experience with a provider application. Moreover, because A/B testing is typically done on very few individuals to mitigate or otherwise reduce the scale of negative user experiences, A/B testing is typically done over a long period of time to ensure that the data gathered is statistically significant and therefore indicative of how the application and/or update(s) will affect or be affected by network communications.
Other network testing systems may attempt to use conventional network testbeds. These conventional network testbeds, however, often lack the scale and reach to be representative of actual network behavior. Indeed, as communication networks continue to grow at an incredible rate, and as network behavior evolves, many conventional testing environments fail to accurately simulate or emulate how a modern communication network will actually behave. As a result, using conventional network testbeds often provides overly ideal or less than accurate behavior predictions and ultimately fails to provide accurate estimations for how an application, update, or protocol will affect performance on a modern communication network.
These and other problems exist in evaluating behaviors and performance of new and updated applications and protocols in realistic network settings.
The present disclosure relates to systems and methods for training and implementing a network simulation system to accurately emulate behavior of an application on a network by simulating conditions of a network path between endpoints (e.g., senders and receivers) of a communication network. For example, as will be discussed in further detail below, systems described herein collect real data from network traces to train a network simulation system to simulate various characteristics of a network path between a sender and a receiver of one or more communication packets (or simply “packets”). In particular, and as will be discussed in further detail below, the systems described herein can model various network parameters and characteristics that enable testing an application (e.g., an application update, a communication protocol) to evaluate how the application will behave or otherwise perform on a communication network under a variety of network conditions.
As a first example, one or more embodiments are directed to systems and methods that model a network path between a sender and receiver of a communication network. In this example, a system may identify a sender and a receiver within a communication network. The sender and receiver may be associated with respective sets of user and/or device attributes (or simply “attributes”). The system may further receive or otherwise identify behavior parameters for a network path between the sender and receiver. These behavior parameters may include a variety of network behaviors such as estimated cross traffic, bandwidth, delay, and/or buffer size. The system may apply the network behavior information to a simulation configuration of a network path simulator that is trained to emulate various network behavior(s). The system may further apply the network path simulator to a packet time series to generate an estimated output (e.g., an estimated packet delay, an estimated packet drop rate) for the packet time series when communicated via a network path between the sender and receiver.
As a second example, which may include many of the same features and functionality as the first example above, one or more embodiments described herein are directed to systems and methods that involve a network path simulator that incorporates a machine learning model. For example, a system may receive a collection of packet traces including trace information for a plurality of communications between a set of senders and corresponding set of receivers. The system may additionally train a network path machine learning model (or simply “network path model”) to simulate network path behaviors affecting communications between a given sender and receiver having a corresponding set of user and/or device attributes. The system may further apply the network path model to a packet time series associated with a sender to generate an estimated output for the packet time series via a network path between the sender and a receiver.
The present disclosure provides a number of practical applications that provide benefits and/or solve problems associated with modeling network behavior and accurately evaluating delays and/or successful delivery of packets communicated between senders and receivers of a communication network. Some examples of these applications and benefits are discussed below.
For example, systems described herein incorporate features and functionalities that provide more accurate evaluations for estimating an output of communications between senders and receivers of a communication network. For instance, one or more embodiments of a network simulation system estimate a variety of parameters for a network path based on real data obtained from packet traces in conjunction with communications between senders and receivers of a network environment. This consideration of real data facilitates configuring a network simulation engine based on historical behaviors, thus enabling a network simulation system to realistically emulate various behaviors from the communication network. As will be discussed in further detail below, features and functionalities described herein involve sampling data from a collection of network traces to identify behavior parameters including, by way of example and not limitation, cross traffic, communication bandwidths, communication delays, and buffer sizes.
In addition to considering behavior parameters calculated from sampled data, one or more embodiments of the network simulation system may consider possibly more complex machine-learned parameters learned via a machine learning training process. In particular, a training system may learn various network behaviors that are unrealistic to calculate or sample such as a reordering of network packets from a packet time series, variable bandwidth over durations of time, and random loss of network packets. In one or more embodiments, the network simulation system may consider a combination of calculated network behaviors (e.g., based on sampled data) and machine-learned behaviors.
By training and implementing a network simulation system in accordance with one or more embodiments described herein, systems described herein can avoid some of the drawbacks of AB testing techniques. For example, the network simulation system can accurately evaluate a positive or negative impact on a networking application or protocol, without causing users to experience some of the potentially negative impacts associated with upgrading applications and/or protocols on a network. In addition, by testing new applications, updates, and protocols in accordance with one or more embodiments described herein, the network simulation system can facilitate faster rollout of new applications, application updates, and new communication protocols.
As illustrated in the foregoing discussion, the present disclosure utilizes a variety of terms to describe features and advantages of one or more embodiments of the network simulation system described herein. For example, as used herein, a “communication network” or “network environment” may refer to any collection of computing devices and applications thereon that are configured to communicate via one or more platforms. For example, a communication network may include one or multiple networks that use any communication platform or technology for transmitting data. A communication network may include the Internet or other data link that enables transport of electronic data (e.g., network packets) between respective devices of the communication network.
As used herein a “network path” may refer to a mechanism whereby one or more network packets are communicated between two devices of a communication network. For example, a network path may refer to a path of multiple devices along which network packets of a communication session is communicated from an origin (e.g., a sender) to a destination (e.g., a receiver). As used herein, a network path may refer to a specific or fixed path between a receiver and a sender. Alternatively, a network path may refer to a number of different paths that network packets of a packet time series use throughout the duration of a communication session. As will be discussed below, one or more systems described herein can model a network path as a single bottleneck path between a sender and a receiver.
As used herein, a “packet time series” includes any number of network packets that are communicated between devices of a communication network. In one or more embodiments described herein, a packet time series includes a plurality of network packets that are communicated from a sender to a receiver over a single or multiple communication sessions. In one or more embodiments, a packet time series refers to communication packets that are sent or received using a specific application and/or using a specific protocol or that are otherwise associated with a corresponding set of communication attributes (e.g., user or device attributes, application attributes, protocol attributes).
As noted above, one or more embodiments of the network simulation system may emulate network behavior based on a number of simulated conditions for communications between a given sender and receiver. As used herein, a “sender” may refer to any device and/or application from which a communication originates. Similarly, a “receiver” may refer to any device and/or application for which a communication is intended. Thus, in one or more embodiments, a sender and receiver may refer to a pair of devices, applications, or combination of device and/or application from which a communication originates and for which the communication is intended (e.g., independent of whether the communication arrives at the target destination).
Additional detail will now be provided regarding systems for training and implementing a network behavior model in accordance with one or more embodiments. For example,
For example, as shown in
As shown in
As further shown in
As noted above, the sender(s) and receiver(s) may be associated with corresponding sets of attributes, which may include a variety of features and characteristics descriptive of the devices and/or applications used by an associated sender or receiver. Some non-limiting examples of these various attributes may include type of connectivity of a sender or receiver (e.g., wired, WiFi, cellular, etc.) an Internet service provider (ISP) identifier, and a location (e.g., India, United States, etc.). As will be discussed in further detail below, these attributes enable systems described herein to segregate data as well as build and use more targeted models. As an example in accordance with one or more embodiments described herein, a model may be built specifically for communication paths emanating from cable broadband connected nodes in Europe.
In addition to information about the respective receiver(s) and sender(s), the packet traces may include mapping information between corresponding packet traces. For example, the first set of packet traces associated with the senders may include a destination address (e.g., a sender address) corresponding to an internet protocol (IP) address or device address for the receiver. Similarly, the second set of packet traces associated with the receivers may include address information correlating the packet time series with corresponding packet information for the senders.
As noted above, the training system 106 can train a network behavior model to predict or otherwise evaluate network path behavior between a given sender and receiver of the communication network 110. For example, the training system 106 may analyze information from the first and second sets of packet time series for the plurality of senders and receivers of the communication network 110. The training system 106 may train the network behavior model in a variety of ways. In one or more embodiments, the training system 106 samples select packets from the packet time series to identify trends or calculate behavior parameters for selectively identified subsets of packet time series data. In addition, or as an alternative, the network behavior model refers to a machine learning model based on learned behavior data from the collection of time series packets collected at the training system 106 and used as training data in training and refining machine learned algorithms of the network behavior model. Additional information in connection with these example models will be discussed below.
In both examples of calculated model and/or the machine learning model, the network simulation system 108 can receive the network behavior model and apply the network behavior model to a simulator configuration of the network simulation system 108. In particular, the network simulation system 108 may apply the network behavior model to emulate behaviors of a network path between a sender and a receiver. As will be discussed in further detail below, the network simulation system 108 may cause a simulation engine to emulate different network behaviors (e.g., network behavior parameters). For example, the network simulation system 108 may cause the simulation engine to calculated network path parameters such as cross traffic, bandwidth, packet delay, and buffer size. In addition, or as an alternative, the network simulation system 108 can cause the simulation engine to emulate machine learned network path parameters such as packet reordering, variable bandwidth over time, and random packet loss.
As shown in
The above workflow 100 may be implemented in a variety of computing environments. For example, in one or more embodiments, the training stage 102 and the simulation stage 104 may be implemented on different computing devices or different systems of devices. Alternatively, in one or more embodiments, the training stage and simulation stage may be performed on a single computing device or on a single computing platform, such as a training system 106 and simulation system 108 both implemented on a server device or on multiple server devices of a cloud computing system.
As shown in
The training system 106 may include a data collection manager 204. In one or more embodiments, the data collection manager 204 collects data associated with communications that occur between senders and receivers of the communication network 110. For example, the data collection manager 204 can collect packet traces including trace information for any number of communications between senders and corresponding receivers of the communication network 110. As noted above, the trace information may include any information associated with a sender and/or receiver including, by way of example, an application being used to transmit data, a communication protocol in use by various senders/receivers, and timing information associated with when a communication is sent and/or received by a respective device.
The data collection manager 204 can collect communication data associated with a variety of network communications. For example, the data collection manager 204 may collect trace information from packet traces for communication sessions involving a larger group of users and/or direct communication sessions between individual users. The data collection manager 204 may additionally collect communication data associated with different communication protocols or communications originating and received using a variety of applications on respective computing devices.
In addition to generally collecting communication data, the data collection manager 204 can further categorize or group the data in a variety of ways. For example, the data collection manager 204 can tag or otherwise associate communications with various characteristics. For instance, a communication may be associated with a particular geography, an Internet protocol (IP) address, a communication protocol, an application, a connection speed, or any other characteristic associated with a sender, receiver, or the communication itself. In one or more embodiments, the data collection manager 204 groups the communication data by respective characteristics. In one or more embodiments, the data collection manager 204 simply tags or associates the communication data with respective characteristics.
In one or more embodiments, the data collection manager 204 categorizes and/or stores the communication data by communication sessions. For example, where a communication session includes a call (e.g., audio call, video call) between one or more senders and receivers that involves transmission of many communication packets, the data collection manager 204 can group or otherwise associate the packets for a communication session with one another. The data collection manager 204 can further track timing information for the respective packets. As will be discussed in further detail below, this grouping and categorization of the communication packets enables a network simulation system 108 to effectively simulate or recreate a communication session with one or more modified characteristics in a way that enables the network simulation system 108 to diagnose problems and/or modify one or more network behaviors or communication characteristics of the communication session.
As further shown in
In one or more embodiments, the model training system 206 generates a network behavior model 212 including one or more algorithms based on sampled data from the packet traces. In one or more embodiments, the model training system 206 generates a network behavior model 212 including a machine learning model that learns more complex behaviors of the communication network 110 based on any number of signals associated with respective packet traces for corresponding senders and receivers on the communication network 110. In both cases, the model training system 206 generates a network behavior model 212 based on real data that provides a realistic representation of certain network behaviors that affect communication of data between respective devices on the communication network 110.
As noted above, the model training system 206 can model a variety of different network behaviors. For instance, in one or more embodiments, the model training system 206 facilitates a network behavior model 212 that calculates network behaviors based on sampled traces including, by way of example, a bandwidth of a network path, a delay of the network path, a buffer size of the network path, and/or a cross traffic model for the network path. In addition, or as an alternative, in one or more embodiments, the model training system 206 facilitates a network behavior model 212 including a machine learning model that determines a variety of machine-learned behaviors including, by way of example, reordering of network packets, variable bandwidth over time, and random loss of network packets from a packet time series.
In one or more embodiments, the model training system 206 trains a network behavior model capable of modeling a combination of sampled and machine learned behaviors. For example, in one or more embodiments, the network behavior model may be trained to emulate one or more network behaviors such as variable bandwidth and random loss while also emulating an estimated cross traffic load or other metric illustrative of cross traffic. As will be discussed in further detail below, this combination of behaviors can be particularly useful where a machine learning model erroneously attributes certain observed trends to observed inputs (e.g., erroneously inferring or learning that a low delay environment corresponds to a high sending rate).
As shown in
In one or more embodiments, the simulation configuration manager 208 selectively identifies one or more discrete network behaviors that the simulation engine 210 should emulate. For instance, where an administrator or app developer wishes to determine how high cross traffic or low bandwidth conditions might affect performance of an application or application update, the simulation configuration manager 208 can identify a cross traffic load and/or bandwidth metric to apply to a simulator configuration. In one or more embodiments described herein, a cross traffic load refers to a time series of values or metrics indicative of cross traffic affecting a network path over some period of time.
In one or more embodiments, the simulation configuration manager 208 may determine how to model a network path in simulating a network environment. For example, in one or more embodiments described herein, the simulation configuration manager 208 may model a network path as a single path between a sender and receiver in which the single path functions as a bottleneck having a corresponding set of network parameters. As an illustrative example, the simulation configuration manager 208 may set network parameters including a bandwidth of the modeled path, a modeled delay of the path, and a buffer size of the path. The simulation configuration manager 208 may additionally estimate a cross traffic load for the network path.
In one or more embodiments, the simulation configuration manager 208 determines the respective parameters based on sampling of the collected communication data. As an example, where the network simulation system 108 is being used to test communications between a sender and receiver under specific circumstances, the simulation configuration manager 208 may selectively sample trace data from packet traces corresponding to those specific circumstances. For example, the simulation configuration manager 208 may identify a set of senders from a first geographic location (e.g., Western United States (U.S.) associated with a first regional datacenter) and a set of receivers from a second geographic location (e.g., Eastern U.S. associated with a second regional datacenter) in which the senders and receivers are using a particular combination of applications and/or communication protocols. Other implementations may involve modeling paths between a client and a datacenter, or from any device to any other device at a different location. In this example, the simulation configuration manager 208 may sample and calculate observed bandwidths, delays, and buffer sizes for the identified sample of packet traces to use as configuration parameters.
In the above example, the simulation configuration manager 208 may selectively modify one or more parameters and/or attributes of a configuration to compare results associated with different network parameters. For example, the simulation configuration manager 208 may generate a first configuration based on a first set of attributes and/or parameters and a second configuration based on a second set of attributes and/or parameters in which one or two specific attributes or parameters are changed between the first and second configurations to enable the network simulation system 108 to compare outputs of the simulation engine 210 corresponding to the two similar configurations. Other implementations may involve randomly selecting network parameters in order to get a diverse sample size of configurations to use in accurately determining how an application, update, or protocol will function under a variety of network environments. Indeed, the simulation configuration manager 208 may identify any number of permutations of network parameters to use in determining a simulation configuration to apply to a set of input traces in accordance with one or more embodiments described herein. In one or more embodiments, network parameters may be sampled from a distribution learnt from the data.
As further shown in
In one or more embodiments, the simulation engine 210 runs a simulation of a network path by applying a network behavior model 212 to a packet time series to generate a projected output at a receiver device. In particular, the simulation engine 210 may apply the network behavior model 212 trained to emulate one or more network behaviors (e.g., calculated behavior parameters, machine learned behavior parameters) in order to determine delays, packet drop rates, etc. for a given communication session between a sender and receiver. In one or more embodiments, the simulation engine 210 runs a simulation for the network assuming ideal network conditions while the network behavior model 212 simulates various network behaviors that may vary depending on characteristics of the network over time and/or characteristics of the receiver and sender.
As further shown in
By way of example and not limitation, the data storage 214 may include network data 216 and model data 218. The network data 216 may include any information associated with a communication network 110 including topology data for networked devices that make up the communication network 110 and information about the senders and receivers on the communication network 110. The network data 216 may additionally include information obtained from packet traces derived from communications transmitted over the communication network 110. Indeed, the network data 216 may include any information used to train the network behavior model 212 as well as any information used to run a realistic simulation of the network path environment(s).
The model data 218 may include any information about the network behavior model 212. For example, the model data 218 may include algorithms and/or a machine learning model trained to output network behavior parameters usable by the network simulation system 108 to generate or refine a simulation configuration as well as emulate network behaviors on the simulation engine 210.
It will be appreciated that the components 204-212 of the computing device(s) 202 may include hardware, software, or both. For example, the components 204-212 of the training system 106 and network simulation system 108 may include one or more instructions stored on a computer-readable storage medium and executable by processors of one or more computing devices. When executed by the one or more processors, the computer-executable instructions of one or more computing devices (e.g., server device(s)) can perform one or more methods described herein. Alternatively, the components of the systems 106, 108 may include hardware, such as a special purpose processing device to perform a certain function or group of functions. Additionally, or alternatively, the components of the systems 106, 108 may include a combination of computer-executable instructions and hardware.
Additional detail will now be discussed in connection with an example implementation of the network simulation system 108 in which one or more calculated network behaviors are identified and emulated by a simulation engine in accordance with one or more embodiments. In particular,
In one or more embodiments, the network simulation system 108 models the network path 304 over a period of time to illustrate changing network conditions and behaviors over time.
The network simulation system 108 may determine the network behavior parameters in a number of ways. For example, the network simulation system 108 may determine the buffer size 306, receiving rate 310, delay metric 312 and/or other parameters by sampling data from the packet traces and determining network parameter metrics over time. The network simulation system 108 may calculate an average, median, or other composite of multiple sampled parameters to estimate how a single network path might be modeled to emulate the sampled parameters. The parameters may be determined based on sampled parameters from multiple communication sessions (e.g., from sampled communication sessions having similar characteristics). Alternatively, the parameters may refer to observed parameters for a single communication session from the data collected from the communication network 110.
With respect to the estimated cross traffic load, the network simulation system 108 may estimate or otherwise determine the cross-traffic load in a variety of ways. In one or more embodiments, the network simulation system 108 observes one or more of the above metrics 306-312 and estimates cross traffic based on one or more of the observed behavior metrics. For example, the network simulation system 108 can compare a delay of two packets from a communication. Knowing the size of the queue (e.g., the buffer size) and the flow rate of the queue, the network simulation system 108 can compare the queue occupancy at two times, as observed by packets, to determine a measure of cross traffic that enters the queue between the respective packets. In one or more embodiments, the network simulation system 108 estimates a cross traffic load (Cest) in accordance with the following formula:
C
est
={Q(k)−Q(k−n)+DrainTime*b−Σsi}/Στi
where Q refers to queue occupancy estimated at a kth packet, DrainTime refers to the time for which the queue has been draining, Σsi refers to a sum of all packet sizes from the (k−n)th to the kth, and Στi refers to a sum of all inter packet times in the window. In one or more embodiments, the DrainTime specifically refers to a time when a buffer of the modeled bottleneck path is non-empty and is therefore draining at the peak capacity of the bottleneck link.
The addition of the cross-traffic load enables the network simulation system 108 to output more accurate results. In particular, by considering a combination of the sampled network parameters of buffer size 306, receiving rate 308, and delay metric, the network simulation system 108 can provide estimated delays for a packet time series that provides a general estimate for how data will be transmitted between a given sender and receiver having a corresponding set of characteristics. Adding the cross-traffic metric 304, however, causes the resulting estimation to more accurately resemble real results on the communication network 110 for a variety of protocols and applications.
In contrast, a second result set 320b shows the same set of actual delay results and a different set of estimated delay results shown on a similar graph in which the cross-traffic metric is considered in accordance with one or more embodiments described above. In this example, the estimated results of the second result set 320b are much closer to the actual results than the first result set 320a in which the cross-traffic metric is not considered.
As mentioned above, in one or more embodiments, the training system 106 trains a network behavior model 212 including a machine learning model that is trained to emulate one or more network behaviors. In particular, in one or more embodiments, the network behavior model 212 may be trained to emulate one or more machine-learned behaviors including, by way of example, reordering of network packets from a packet time series, variable bandwidth over a duration of time, and random loss of network packets from the packet time series. Indeed, the network behavior model 212 may be trained to emulate any number of network behaviors that can be learned based on a collection of packet traces from observed communications on the communication network 110.
It will be appreciated that the network behavior model 212 may include a variety of machine learning models. As an example,
As noted above, in one or more embodiments, the network behavior model 212 may be implemented as a combination of a machine learning model and one or more algorithms that do not necessarily employ machine learned algorithms. In particular,
More specifically,
While
In combination with one or more machine learned parameters, a simulation engine 210 may receive a cross-traffic metric in accordance with one or more embodiments described above. Thus, as shown in
Similar to one or more embodiments discussed above in connection with
As shown in
In accordance with one or more embodiments described herein, the training system 106 and network simulation system 108 can incorporate a cross traffic load and infer that the low delay scenarios do not necessarily imply a high sending rate. As a result, the third result set 514 includes a much more accurate set of delay predictions that more closely resemble the ground truth data from the first result set 510.
Turning now to
As further shown, the series of acts 600 includes an act 620 of receiving network behavior parameters for a network path between the sender and the receiver. For example, in one or more embodiments, the act 620 includes receiving one or more network behavior parameters for a network path between the sender and the receiver, the one or more network behavior parameters including an estimated cross traffic load associated with an estimated volume of cross traffic from additional senders and receivers within the communication network.
As further shown, the series of acts 600 may include an act 630 of applying the network behavior parameters to a simulator configuration of a network path simulator trained to emulate the network path behaviors. For example, in one or more embodiments, the act 630 includes applying the network behavior parameters to a simulator configuration of a network path simulator, the network path simulator being trained to emulate network behavior based on the simulator configuration.
As further shown, the series of acts 600 includes an act 640 of applying the network path simulator in accordance with the simulation configuration to a packet time series to generate an estimated output indicating predicted delays for the packet time series. For example, in one or more implementations, the act 640 includes applying the network path simulator in accordance with the simulator configuration to a packet time series to generate an estimated output for the packet time series via the network path environment between the sender and the receiver.
In one or more embodiments, the one or more network parameters include one or more sampled parameters from a collection of network traces derived from previous communications between a plurality of senders and a plurality of receivers within the communication network. In addition, in one or more embodiments, the first set of attributes and the second set of attributes include one or more of types of connectivity, locations of the sender and receiver, and Internet service provider (ISP) identifiers associated with the sender and the receiver. Further, in one or more embodiments, the one or more network behavior parameters includes selectively sampled parameters from the collection of network traces associated with one or more communications between the corresponding sender and receiver.
In some implementations, the one or more network behavior parameters includes the estimated cross traffic load and one or more behavior parameters for a modeled path between the sender and receiver. The one or more network parameters may include one or more of a bandwidth of the modeled path, a modeled delay for the modeled path, and a buffer size of the modeled path. In one or more embodiments, the network path simulator is configured to model the network path environment as a single bottleneck path between the sender and the receiver. In one or more embodiments, the series of acts 600 includes determining the estimated cross traffic load based on sampled behavior data between one or more senders and corresponding receivers.
In one or more embodiments, receiving the one or more network behavior parameters includes randomly sampling a collection of network traces between a plurality of senders and a plurality of receivers. Receiving the parameters may also include learning the one or more network behavior parameters for the network path environment based on the randomly sampled network traces. In one or more embodiments, receiving the behavior parameters includes selectively sampling network traces between a plurality of senders and a plurality of receivers. In one or more embodiments, receiving the behavior parameters includes learning the one or more network behavior parameters for the network path based on the selectively sampled network traces.
As further shown, the series of acts 700 includes an act 720 of training a network path machine learning model to simulate network path behaviors affecting communications between a sender and a receiver based on the trace information. For example, in one or more embodiments, the act 720 includes training a network path machine learning model to simulate network behavior parameters affecting communications between a given sender and a given receiver based on trace information derived from the collection of packet traces for the plurality of communications between the set of senders and the corresponding set of receivers.
As further shown, the series of acts 700 includes an act 730 of applying the network path machine learning model to a packet time series to generate an estimated output indicating predicted delays for the packet time series. For example, in one or more embodiments, the act 730 includes applying the network path machine learning model to a packet time series associated with a sender to generate an estimated output for the packet time series via a network path between the sender and a receiver.
In one or more embodiments, the network path machine learning model includes a deep long short term memory (LSTM) neural network trained to predict delay for communications between the given sender and the given receiver. In one or more embodiments, the network path machine learning model is trained to predict network behavior parameters including one or more of reordering of network packets from the packet time series, variable bandwidth over a duration associated with the packet time series, and/or random loss of network packets from the packet time series.
In one or more embodiments, the series of acts 700 includes estimating a cross traffic load based on sampled behavior data between one or more senders from the set of senders and one or more receivers from the set of receivers and providing the cross traffic load to the network path machine learning model as an estimated behavior of the network path between the sender and the receiver. In one or more embodiments, estimating and providing the cross-traffic load is based on detected instances of high sending rates from the packet time series.
In accordance with one or more embodiments, the one or more network parameters may include one or more sampled parameters from a collection of network traces derived from previous communications between a plurality of senders and a plurality of receivers within the communication network. In one or more embodiments, the one or more network behavior parameters include one or more machine-learned parameters output by a network path machine learning model trained, the machine learning model being trained to output one or more predicted network behavior parameters.
The computer system 800 includes a processor 801. The processor 801 may be a general-purpose single- or multi-chip microprocessor (e.g., an Advanced RISC (Reduced Instruction Set Computer) Machine (ARM)), a special-purpose microprocessor (e.g., a digital signal processor (DSP)), a microcontroller, a programmable gate array, etc. The processor 801 may be referred to as a central processing unit (CPU). Although just a single processor 801 is shown in the computer system 800 of
The computer system 800 also includes memory 803 in electronic communication with the processor 801. The memory 803 may be any electronic component capable of storing electronic information. For example, the memory 803 may be embodied as random access memory (RAM), read-only memory (ROM), magnetic disk storage media, optical storage media, flash memory devices in RAM, on-board memory included with the processor, erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM) memory, registers, and so forth, including combinations thereof.
Instructions 805 and data 807 may be stored in the memory 803. The instructions 805 may be executable by the processor 801 to implement some or all of the functionality disclosed herein. Executing the instructions 805 may involve the use of the data 807 that is stored in the memory 803. Any of the various examples of modules and components described herein may be implemented, partially or wholly, as instructions 805 stored in memory 803 and executed by the processor 801. Any of the various examples of data described herein may be among the data 807 that is stored in memory 803 and used during execution of the instructions 805 by the processor 801.
A computer system 800 may also include one or more communication interfaces 809 for communicating with other electronic devices. The communication interface(s) 809 may be based on wired communication technology, wireless communication technology, or both. Some examples of communication interfaces 809 include a Universal Serial Bus (USB), an Ethernet adapter, a wireless adapter that operates in accordance with an Institute of Electrical and Electronics Engineers (IEEE) 802.11 wireless communication protocol, a Bluetooth wireless communication adapter, and an infrared (IR) communication port.
A computer system 800 may also include one or more input devices 811 and one or more output devices 813. Some examples of input devices 811 include a keyboard, mouse, microphone, remote control device, button, joystick, trackball, touchpad, and lightpen. Some examples of output devices 813 include a speaker and a printer. One specific type of output device that is typically included in a computer system 800 is a display device 815. Display devices 815 used with embodiments disclosed herein may utilize any suitable image projection technology, such as liquid crystal display (LCD), light-emitting diode (LED), gas plasma, electroluminescence, or the like. A display controller 817 may also be provided, for converting data 807 stored in the memory 803 into text, graphics, and/or moving images (as appropriate) shown on the display device 815.
The various components of the computer system 800 may be coupled together by one or more buses, which may include a power bus, a control signal bus, a status signal bus, a data bus, etc. For the sake of clarity, the various buses are illustrated in
The techniques described herein may be implemented in hardware, software, firmware, or any combination thereof, unless specifically described as being implemented in a specific manner. Any features described as modules, components, or the like may also be implemented together in an integrated logic device or separately as discrete but interoperable logic devices. If implemented in software, the techniques may be realized at least in part by a non-transitory processor-readable storage medium comprising instructions that, when executed by at least one processor, perform one or more of the methods described herein. The instructions may be organized into routines, programs, objects, components, data structures, etc., which may perform particular tasks and/or implement particular datatypes, and which may be combined or distributed as desired in various embodiments.
The steps and/or actions of the methods described herein may be interchanged with one another without departing from the scope of the claims. In other words, unless a specific order of steps or actions is required for proper operation of the method that is being described, the order and/or use of specific steps and/or actions may be modified without departing from the scope of the claims.
The term “determining” encompasses a wide variety of actions and, therefore, “determining” can include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” can include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” can include resolving, selecting, choosing, establishing and the like.
The terms “comprising,” “including,” and “having” are intended to be inclusive and mean that there may be additional elements other than the listed elements. Additionally, it should be understood that references to “one embodiment” or “an embodiment” of the present disclosure are not intended to be interpreted as excluding the existence of additional embodiments that also incorporate the recited features. For example, any element or feature described in relation to an embodiment herein may be combinable with any element or feature of any other embodiment described herein, where compatible.
The present disclosure may be embodied in other specific forms without departing from its spirit or characteristics. The described embodiments are to be considered as illustrative and not restrictive. The scope of the disclosure is, therefore, indicated by the appended claims rather than by the foregoing description. Changes that come within the meaning and range of equivalency of the claims are to be embraced within their scope.