The present disclosure relates to communication networks, and more specifically, to neural network learning methods to identify network ports responsible for packet loss or delay.
A communication network may include network elements that route packets through the network. Some network elements may include a distributed architecture, wherein packet processing may be distributed among several subsystems of the network element (e.g., line cards). Thus, network elements may be modular and may include various sub-systems and sub-elements, which may include a shelf, a slot, a port, a channel, or various combinations thereof.
In particular, a network element can be abstracted as a generalized network node having ports that provide input and output paths to other ports on other nodes. Any communications network can, in turn, be represented using the node/port abstraction to make the large number of ports in the network visible.
Because the typical communications network comprises a large number of ports, the performance of each network port may be determinative for the performance and operation of network paths in the network. When the performance of a port is physically degraded, the port may exhibit packet loss or packet delay for all network paths passing through the port, which is undesirable. Therefore, the actual performance of individual ports in a communications network is an important factor in operating a communications network.
For a more complete understanding of the present invention and its features and advantages, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
In one aspect, a method for identifying network ports responsible for packet loss or delay is disclosed. The method may include modeling a network in terms of edge nodes, core nodes, ports, links, and paths. In the method, edge nodes are connected to external entities and to one core node, each link connects to two nodes, the nodes comprising edge nodes or core nodes, each link connects to a node using a port at the node, and each path begins and ends at an edge node. The method may further include, for a network path, defining a set x as {x1, x2, x3. . . , xN} for N number of total ports in the network, where xi=1 when the network path passes through port i, otherwise xi=0 when the network path does not pass through port i. The method may also include, for the network path, defining a binary value function ƒ(x) indicating whether a bad port criterion is satisfied for the network path, where ƒ(x)=1 when the bad port criterion is satisfied, and ƒ(x)=0 when the bad port criterion is not satisfied. The method may still further include applying an iterative procedure to determine a neural network function {circumflex over (ƒ)}(x) for every ƒ(x) corresponding to a plurality of network paths in the network, the neural network function {circumflex over (ƒ)}(x) given by {circumflex over (ƒ)}(x)=0[Σi=0Nwixi]. In the method, wi is a weight factor for each xi, and o is a general step function given by
The method may further include, upon convergence of the weight factors wi using the iterative procedure, determining ƒ(x) based on {circumflex over (ƒ)}(x) to identify ports in the network satisfying the bad port criteria as bad ports, and sending a service notification to a network administrator of the network, the service notification indicating the bad ports.
In any of the disclosed embodiments of the method, applying the iterative procedure may further include determining the weight factors wi using the iterative procedure with previous weight factors wi and next weight factors wi, according to the equation w(next)=w(previous)−η*x*e(x). In the method, w is the set of weight factors wi over N, η is a positive learning rate (η>0), and e(x) is a function given by e(x)={circumflex over (ƒ)}(x)−ƒ(x).
In any of the disclosed embodiments of the method, for a first iteration, w(previous) includes randomly selected values, and for i=0, xo is defined as a bias term.
In any of the disclosed embodiments, the method may further include using the iterative procedure with a training set having a known output to determine w, the set of weight factors wi over N, where the iterative procedure converges on the set w, and the known output comprises the binary value function ƒ(x).
In any of the disclosed embodiments, the method may further include, after convergence of the iterative procedure on the set w, selecting a set x* corresponding to a first network path in the network for which the binary value function ƒ(x*) is unknown, determining the neural network function {circumflex over (ƒ)}(x*) based on the set w, and determining the binary value function ƒ(x*) based on the neural network function {circumflex over (ƒ)}(x*). Based on ƒ(x*), the method may include identifying ports in the first network path satisfying the bad port criteria.
In any of the disclosed embodiments of the method, the bad port criterion may be whether a port exhibits packet loss or does not exhibit packet loss.
In any of the disclosed embodiments of the method, the bad port criterion may be whether a port exhibits a delay greater than a threshold delay or does not exhibit the delay.
In any of the disclosed embodiments of the method, defining the set x may further include receiving port information from a routing module, the port information indicative of individual ports at nodes in the network. The method may also include receiving path information from a path computation engine for the network, the path information indicative of nodes and ports through which the paths propagate through the network, and generating the set x based on the port information and the path information.
In any of the disclosed embodiments, the method may further include, sending an alarm message to each one of the bad ports.
Additional disclosed aspects for neural network learning methods to identify bad ports include a system comprising a processor configured to access non-transitory computer readable memory media, and an article of manufacture comprising non-transitory computer readable memory media storing processor-executable instructions.
In the following description, details are set forth by way of example to facilitate discussion of the disclosed subject matter. It should be apparent to a person of ordinary skill in the field, however, that the disclosed embodiments are exemplary and not exhaustive of all possible embodiments.
As used herein, a hyphenated form of a reference numeral refers to a specific instance of an element and the un-hyphenated form of the reference numeral refers to the collective or generic element. Thus, for example, widget 12-1 refers to an instance of a widget class, which may be referred to collectively as widgets 12 and any one of which may be referred to generically as a widget 12.
As noted above, when the performance of a network port is physically degraded, the network port may exhibit packet loss or packet delay for all network paths passing through the network port, which is undesirable. Therefore, monitoring the performance of individual network ports in a network may be an important aspect in keeping networks operating at optimum performance.
Typically, the performance of network ports can be monitored using physical sensors, such as a pass-through device on each port, or another type of sensor. However, because of the large numbers of network ports in many communication networks, numbering in the thousands or more, using physical sensors to monitor each individual port is not economically feasible because of the resource usage involved, including the sensors, software, and manpower. Thus, physical monitoring of each individual network port is not economically scalable and, therefore, is not desirable.
As will be disclosed in further detail herein, neural network learning methods may be used to identify network ports responsible for packet loss or delay, also referred to herein as “bad ports”. The neural network learning methods to identify bad ports disclosed herein may rely upon neural network learning algorithms to iteratively analyze existing data for individual network paths passing through a plurality of ports in the network. Because more than one network path may pass through each individual port, the existing data, such as latency information, collected at terminal nodes of each network path may be processed to identify individual ports exhibiting packet loss or delay.
Turning now to the drawings,
Each transmission medium 12 may include any system, device, or apparatus configured to communicatively couple network devices 102 to each other and communicate information between corresponding network devices 102. For example, a transmission medium 12 may include an optical fiber, an Ethernet cable, a T1 cable, a WiFi signal, a Bluetooth signal, or other suitable medium.
Network 100 may communicate information or “traffic” over transmission media 12. As used herein, “traffic” means information transmitted, stored, or sorted in network 100. Such traffic may comprise optical or electrical signals configured to encode audio, video, textual, and/or any other suitable data. The data may also be transmitted in a synchronous or asynchronous manner, and may be transmitted deterministically (also referred to as ‘real-time’) and/or stochastically. Traffic may be communicated via any suitable communications protocol, including, without limitation, the Open Systems Interconnection (OSI) standard and Internet Protocol (IP). Additionally, the traffic communicated via network 100 may be structured in any appropriate manner including, but not limited to, being structured in frames, packets, or an unstructured bit stream.
Each network element 102 in network 100 may comprise any suitable system operable to transmit and receive traffic. In the illustrated embodiment, each network element 102 may be operable to transmit traffic directly to one or more other network elements 102 and receive traffic directly from the one or more other network elements 102. Network elements 102 will be discussed in more detail below with respect to
Modifications, additions, or omissions may be made to network 100 without departing from the scope of the disclosure. The components and elements of network 100 described may be integrated or separated according to particular needs. Moreover, the operations of network 100 may be performed by more, fewer, or other components.
In operation, as will be described in further detail herein, network elements 102 may comprise network ports for coupling to other network elements 102. Network ports in network elements 102 responsible for packet loss or delay in network 100 may be identified using the neural network learning methods described herein.
Referring now to
As depicted in
In
As shown in
In various embodiments, network element 102 may be configured to receive data and route such data to a particular network interface 204 and port 206 based on analyzing the contents of the data or based on a characteristic of a signal carrying the data (e.g., a wavelength or modulation of the signal). In certain embodiments, network element 102 may include a switching element (not shown) that may include a switch fabric (SWF).
Referring now to
As shown in
Also shown included with network management system 300 in
In certain embodiments, network management system 300 may be configured to interface with a person (i.e., a user) and receive data about the signal transmission path. For example, network management system 300 may also include and/or may be coupled to one or more input devices or output devices to facilitate receiving data about the signal transmission path from the user and outputting results to the user. The one or more input and output devices (not shown) may include, but are not limited to, a keyboard, a mouse, a touchpad, a microphone, a display, a touchscreen display, an audio speaker, or the like. Alternately or additionally, network management system 300 may be configured to receive data about the signal transmission path from a device such as another computing device or a network element (not shown in
As shown in
As shown in
Path computation engine 302 may be configured to use the information provided by routing module 310 to database 304 to determine transmission characteristics of the signal transmission path. The transmission characteristics of the signal transmission path may provide insight on how transmission degradation factors may affect the signal transmission path. When the network is an optical network, the transmission degradation factors may include, for example: chromatic dispersion (CD), nonlinear (NL) effects, polarization effects, such as polarization mode dispersion (PMD) and polarization dependent loss (PDL), amplified spontaneous emission (ASE) and/or others, which may affect optical signals within an optical signal transmission path. To determine the transmission characteristics of the signal transmission path, path computation engine 302 may consider the interplay between various transmission degradation factors. In various embodiments, path computation engine 302 may generate values for specific transmission degradation factors. Path computation engine 302 may further store data describing the signal transmission path in database 304.
In
In
Referring now to
In general, a communications network may be modeled using edge nodes 406 (shown as squares in
Edge nodes 406, which are at the boundary of network model 400, may be connected to customer equipment or to other networks, which are not shown in
Core nodes 404, which are shown in network 402, may represent internal nodes where no customer equipment is connected. As used herein, core nodes 404 are not source nodes or destination nodes (i.e., terminal nodes) for a network path.
In
Based on the above characteristics of network model 400, neural network learning methods to identify network ports responsible for packet loss or delay are described below in further detail. Based on the fact that packet loss or delay is recorded for each network path at edge nodes 406 for the network path, the recorded information can be used to determine which individual ports 410 are bad ports.
Using network model 400, let x define a set {x1, x2, x3, . . . , xN} for N number of total ports in network model 400 for each network path, where xi=1 when the network path passes through port i, otherwise xi=0 when the network path does not pass through port i. It is noted that, in some embodiments, port information indicative of individual ports at nodes in the network may be received from routing module 310, while path information indicative of nodes and ports through which the paths propagate through the network may be received path computation engine 302. Then, the set x may be generated based on the port information and the path information received for a plurality of network paths.
Furthermore, let ƒ(x) define a binary value function of x for each network path indicating whether packet loss or delay is measured for that network path, such that ƒ(x)=1 when packet loss or delay occurs along the network path, and ƒ(x)=0 when no packet loss or delay occurs along the network path. It is noted that other conditions for ƒ(x) may be used to modify the problem being solved (bad ports) into a binary condition. For example, to solve for a particular delay value, the binary condition for ƒ(x) might be defined as ƒ(x)=1 when a delay>50 ms is observed, else ƒ(x)=0. It will be understood that 50 ms is an arbitrary threshold delay value, and that other threshold delay values may be used.
Then, a mapping relationship may be obtained by learning the dataset {(x, ƒ(x)} for all optical paths. For example, if it is determined that ƒ(x)=xl x3 x5 (where “” is the OR operator), then a network path modeled using network model 400 experiences packet loss/delay if and only if the network path passes through ports 1, 3, and 5; ergo ports 1, 3, and 5 may be identified as bad ports.
Specifically, Equation 1 defines a neural network function with a weight factor wi for each xi.
{circumflex over (ƒ)}(x)=0[Σi=0Nwixi] Equation (1)
In Equation 1:
wi is a weight factor for each xi; and
o is a general step function given by
In Equation 1, for i=0, x0 may be defined as a bias term. Furthermore, the weight factors wi may be determined by iteration using Equation 2.
w(next)=w(previous)−η*x*e(x) Equation (2)
In Equation 2:
w is the set of weight factors over N;
η is a positive learning rate (η>0); and
e(x) is a function given by e(x)={circumflex over (ƒ)}(x)−ƒ(x).
For example, for the initial iteration, the weight factors wi may be populated with random numbers. Then, Equation 2 is used to update values for the weight factors wi for each next iteration based on the values from the previous iteration. The iteration may be performed a certain number of times, or may be performed until the values for the weight factors wi converge (i.e., no longer change with iteration). Because the function ƒ(x) can be represented using OR operators, the function ƒ(x) is linear separable and will converge such that every ƒ(x) can be represented by {circumflex over (ƒ)}(x).
In application of neural network learning methods to identify bad network ports, a training set with known inputs and outputs may be initially used to first determine the weight factors wi. Then, once the weight factors wi are known, given any new set x*, ƒ(x*) can be estimated using {circumflex over (ƒ)}(x*).
In a first example of using and validating a training set, let N=7 and let a first path x1={1, 0, 1, 1, 0, 0, 1} have ƒ(x1)=0, and let a second path x2={0, 1, 0, 1, 0, 0, 1} have ƒ(x2)=1. Furthermore, let the bias value xo=−0.3 and η=0.2, and assume initial values w(previous)={1, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5, 0.5}. Then, the neural network learning method may be applied to a next iteration of {circumflex over (ƒ)}(x1) to train the values for the weight factors wi, as shown in Equation 3.
{circumflex over (ƒ)}(x1)=o(1*−0.3+0.5*1+0.5*0+0.5*1+0.5*1+0.5*0+0.5*0+0.5*1)=o(1.7)=1 Equation (3)
Then, for a next iteration for the first path, e(x1)={circumflex over (ƒ)}(x1)−{circumflex over (ƒ)}(x1)=1−0=1. Applying Equation 2 yields the next iterative values in the first example as w(new)={1.06, 0.8, 0.5, 0.3, 0.3, 0.5, 0.5, 0.3}. Then, the w(new) values may be validated using the second path, as shown in Equation 4.
{circumflex over (ƒ)}(x2)=o(1.06*−0.3+0.8*0+0.5*1+0.3*0+0.3*1+0.5*0+0.5*0+0.3*1)=o(0.782)=1 Equation (4)
Then, for a next iteration for the second path, e(x2)={circumflex over (ƒ)}(x2)−ƒ(x2)=1−1=0, which results in no change in the weight factors wi, or convergence. Although the above procedure in the first example has been shown for N=7 and for two network paths, it will be understood that the same methods are applicable for any value of N and may be repeated for any number of network paths until convergence is attained.
In a second example, after a training set, as shown above in the first example, has been iterated, then for every x there exists {circumflex over (ƒ)}(x)=ƒ(x), and the set w is known. Based on Equation 1, given any new set x*, {circumflex over (ƒ)}(x*) can be used to estimate ƒ(x*). In the second example, the set x* can be used to mask individual ports and determine which ports are bad ports, where
The neural network learning method described above may be evaluated using various performance metrics. An ‘accuracy’ may be defined as a proportion of identified bad ports from all actual bad ports. A ‘relevancy’ may be defined as a proportion of validated bad ports from the identified bad ports. For example, if there are actually 5 bad ports in a network, and 4 of the 5 actual bad ports are identified, then the accuracy is 4/5 or 80%. If another two identified bad ports are determined not to be bad ports, the relevancy is 4/6 or 67%.
Various simulations have been performed to validate the neural network learning methods to identify network ports responsible for packet loss or delay described herein. For example, in a network model having 20 nodes, 96 ports, 10% core nodes of all nodes, and 5 bad ports, 100% accuracy may be attained after analyzing about 300 randomly chosen network paths among all possible network paths. With 13 bad ports, ˜100% accuracy may be attained after analyzing about 2,000 randomly chosen network paths. The simulation results demonstrate the viability and desirability of the neural network learning methods to identify network ports responsible for packet loss or delay described herein.
The neural network learning methods to identify network ports responsible for packet loss or delay described herein may provide a fast and efficient method for identifying bad ports that does not rely upon measurement using sensors at each port and relies on existing and available data. The neural network learning methods to identify network ports responsible for packet loss or delay described herein may enable network operators to quickly and reliably identify bad ports and may reduce or eliminate resources used in trying to diagnose or find bad ports. The neural network learning methods to identify network ports responsible for packet loss or delay described herein may provide a computationally tractable method that can be economically implemented and scaled to any desired network complexity or size.
Turning now to
In
As disclosed herein, a computational method and system for identifying bad ports in a network may use a neural network learning function based on available network path data that is already collected. In this manner, bad ports in the network may be identified without having to measure each individual port using sensors.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments which fall within the true spirit and scope of the present disclosure. Thus, to the maximum extent allowed by law, the scope of the present disclosure is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.