To satisfy the needs and demands of users of mobile and non-mobile communication device users, providers of communication services continue to improve available services. One aspect of such improvements includes determining user Quality of Experience (QoE) and various network performance parameters, such as key performance indicators (KPIs).
Some parameters can be determined at a particular network element and/or within a portion of the network. For example, a base station may be able to determine signal-to-noise ratios of its wireless signals, throughputs, network traffic, etc.
The following detailed description refers to the accompanying drawings. The same reference numbers in different drawings may identify the same or similar elements.
As described herein, a Platform and Infrastructure for Measurement (PIM) system provides network diagnostics and measurement capabilities. The capabilities include providing an overview of all network elements connected to a core network and automatically measuring and reporting on the network quality and link status of each node.
The PIM addresses a number of problems that many network service providers face. Some of the problems occur during day-to-day tasks to activate, verify, and troubleshoot data circuits in a production environment. The problems stem from, for example, issues such as:
(1) The currently existing applications for verifying subscriber speeds and isolating data related issues need to be triggered by a technician or a customer in order to verify the speeds of the circuit.
(2) Packet loss, latency and throughput values can only be measured during an active test. However, because there are no appropriate recordings of these test values, there are no reference points to go back and validate an issue that has started or determine its impact on the services.
(3) With currently available testing applications, multiple login screens, tools and devices must be used to identify potential issues for different network elements, such as an Optical Network Terminal or Optical Network Translator (ONT), an Optical Line Terminal (OLT), a Gateway Router (GWR), etc.
(4) With currently available testing applications, a comparison of one circuit to another must be done manually through different portals and it is not easy to make correlations between similar issues for different customers on the same passive optical network (PON).
(5) The current applications do not provide graphical representations of the issues in the network responsible for service impacting changes, and network operators must manually identify the issues and correlate them to a working circuit. This process can take several hours to just identify the problem of high packet loss or excessive latency.
(6) The currently available applications do not provide visual representation of the detected issues, for any of the connected hops/elements, so that they can be easily spotted for automated recovery process.
(7) There is no system that can generate end-to-end network status reports for the operators.
To address the above-listed and other issues, the PIM provides network access and reachability reports and alerts/alarms on network status to the operators.
Network 100, which may also be referred to as a provider network 100, may include a local area network (LAN), a wide area network (WAN), a metropolitan area network (MAN), an optical network, a cable television network, a satellite network, a wireless network (e.g., a Code Division Multiple Access (CDMA) network, a general packet radio service (GPRS) network, a Long Term Evolution (LTE) network (e.g., 4th Generation (4G) network), a 5th Generation (5G) network, an ad hoc network, a telephone network (e.g., the Public Switched Telephone Network (PSTN) or a cellular network), an intranet, or a combination of networks. Provider network 100 may allow the delivery of Internet Protocol (IP) services to various customer devices, such as mobile devices (e.g., smart phones), Customer Premises Equipment (CPE), etc., and may interface with other external networks, such as a packet data network. In some implementations, provider network 100 may include one or more packet data networks.
A packet data network may include a network that supports Internet Protocol (IP)-based communications. A packet data network may include, for example, an IP Multimedia Subsystem (IMS) network, which may provide voice and multimedia services.
Endpoint 102 includes a software agent responsible for generating packets and transmitting them to a respective data collector 104 or for receiving packets from data collector 104. A typical endpoint 102 may be installed on a user device, such as a Broadband Home Router (BHR), a Gateway Router (GWR), or another CPE device that is located in the customer premises.
Endpoint 102 may be implemented in low level languages, such as C or assembly, for speed and a small footprint. In some implementations, endpoint 102 may adhere to the Portable Operating System Interface (POSIX) standard for its management function. Examples of the management function includes: the activate client function and the deactivate client function.
When the activate client function is invoked for a particular endpoint 102, the endpoint 102 may send a test request message to load balancer 108, to obtain a network address of a particular data collector 104 to which the endpoint 102 is assigned. Upon receipt of the address from load balancer 108, the endpoint 102 may instantiate a connection to the assigned data collector 104 and begin collecting test parameter values in accordance with its schedule. In one implementation, an active endpoint 102 may perform the tests periodically (e.g., every 60 seconds).
During a test, an endpoint 102 may transmit and receive packets to and from data collector 104 to accurately measure the theoretical throughputs for downloads and uploads, latency, round trip times (RTTs), packet loss, a retransmission rate, etc. If an endpoint 102 obtains network statistics, the endpoint 102 may transmit them to the data collector 104. In many tests, endpoint traffic may not adversely impact customer services or the CPE performance. During a test, if a packet is lost, the endpoint 102 may retransmit the lost packet.
When the deactivate client function is invoked for a particular endpoint 102, the endpoint 102 may complete ongoing tests and abandon scheduled tests. Thereafter, the endpoint 102 may return to the disabled state, until the endpoint 102 receives another call to return to the active state through either a system call (e.g., an Operating System (OS) call at the device on which endpoint 102 is installed) or an Application Programming Interface (API) call from remote hosts.
In addition to supporting the management functions, an endpoint 102 may also provide APIs or mechanisms for setting a number of parameters that are needed to perform tests. Such parameters include, for example: a port number of the data collector 104 assigned to the endpoint 102 (e.g., port 9000); a test location identifier (ID), which may be assigned by an Operations Support System (OSS); an Optical Network Terminal/Translator (ONT) ID; an Optical Line Terminal (OLT) ID; a Gateway Router (GWR) ID; a test protocol (e.g., Transport Control Protocol (TCP), User Datagram Protocol (UDP), Hypertext Transport Protocol (HTTP); Secure File Transfer Protocol (SFTP), etc.); a results port, which is the port of the data collector 104 assigned to the endpoint 102 for uploading the test results. These parameters are described below with reference to
For bookkeeping purposes, endpoint 102 may maintain a rotating log. The endpoint 102 may not allow the log to accumulate over a certain limit, depending on the CPE device capacity and available storage. In the logs, the endpoint 102 may record its status, transmission dates and times, port numbers that it uses, the address of the data collector 104 assigned to the endpoint 102, errors or warnings related to its status, etc.
Data collector 104 may include logical components to calculate the values of performance metrics, convert them into a human readable format, and forward the results to data lake 106 that houses all critical network related parameter values from individual endpoints 102. Data collector 104 may also have the ability to manage Service Level Agreements (SLAs) for endpoints 102. Values of SLA-related variables are determined on a periodic basis; and alerts and notifications are generated and sent to network operators through network analyst 110 if SLAs are violated.
In some implementations, data collector 104 may be implemented/developed in Java and deployed on bare metal hardware strategically located in network 100 (e.g., at the edge). In operation, when data collector 104 is contacted by an endpoint 102, data collector 104 may place the endpoint 102 in the active queue, to indicate that the endpoint 102 is reachable and is ready to start a test.
When endpoint 102 is ready to start a test, endpoint 102 may send a request to establish a connection to the data collector 104. When data collector 104 receives the request and the testing begins, data collector 104 may record the endpoint 102's status as “testing,” to indicate that the endpoint 102 is active and running. Thereafter, data collector 104 may collect packets in real time and extract values of parameters such as a packet size, time, latency, a throughput (per upload and download) and any other parameters defined in the SLA. When transmitting, data collector 104 may mark packets with a common identifier based on the type of device from which the packets are generated. During a test, data collector 104 may use the first packet and the last packet from an endpoint 102 to determine whether the endpoint 102 is reachable.
Data collector 104 may collect data from an endpoint 102 until instructed otherwise by the network operator or until the endpoint 102 stops responding. At such times, the data collector 104 may probe the endpoint 102 at regular time intervals (e.g., every 60 seconds). With every consecutive failed attempt to obtain a response from the endpoint 102, however, data collector 104 may double the probing time interval. After a threshold number of attempts, the data collector 104 may place the endpoint 102 in the inactive queue. Data collector 104 may record each of its attempts to probe the endpoint 102.
Upon placing the endpoint 102 in the inactive queue, the data collector 104 may not further probe the endpoint 102, until the endpoint 102 sends a message to the data collector 104. In response to the message, the data collector 104 may move the endpoint 102 from the inactive queue to the active queue. The data collector 104 may then resume its calculations of the parameter values for the endpoint 102. The data collector 104 may present the endpoint 102 status and its historical data to the operator via network analyst 110, via the data lake 106. The parameter values may be in a text format, such as the JavaScript Object Notation (JSON), the YAML Ain′t Markup Language (YAML), or the Extensible Markup Language (XML).
In some implementations, a data collector 104 may determine the network status of an endpoint 102 based on the first packet or series of packets transmitted from the endpoint 102 within a single collection period. During its own transmission to an endpoint 102, if a packet is lost, the data collector 104 may retransmit the lost packet.
Like an endpoint 102, a data collector 104 may maintain a rotating log. The data collector 104 may limit its log size below a particular threshold (e.g., 1 MB), depending on its storage capacity and availability. In the logs, data collector 104 may record an endpoint status, transmission dates and times, port numbers, endpoint addresses, and errors or warnings.
Data lake 106 may include a database of parameter values received from data collectors 104. In one implementation, the database may include unstructured data arranged in a table for each endpoint 102 registered with a data collector 104. Prior to accepting data from a data collector 104, however, data lake 106 may first onboard the data collector 104 over a predetermined messaging bus. At data lake 106, data for each data collector 104 may be identified by the data collector hostname, its IP address, a port associated with the data collector 104, and/or another type of identifier specified by network analyst 110. These identifiers may be used to aggregate data from a single endpoint 102, even if the data was collected by different data collectors 104.
Data lake 106 may accept different network API calls from data collectors 104 to receive data. For example, data collectors 104 may invoke RESTful APIs when uploading data to data lake 106 in the JSON format.
Load balancer 108 may include logic for assigning a particular data collector 104 to each endpoint 102. In assigning a data collector 104, load balancer 108 may take into consideration various factors, such as data collector 104 loads, network traffic, delay, etc. to evenly balance the loads over multiple data collectors 104. Each endpoint 102 may be provided with a load balancer network address, which the endpoint 102 may use to send a request to the load balancer 108 to have the load balancer 108 assign a data collector 104 to the endpoint 102. In response, the load balancer 108 may provide a network address of the data collector 104 assigned to the endpoint 102.
Network analyst (NA) 110 may include logic to provide visual representations of the data from data collectors 104 (e.g., via a web interface). In one implementation, a single instance of network analyst 110 may service all operators of network 100; and another instance of network analyst 110 may serve as a backup. In other implementations, network analyst 110 may include additional instances, for example, to increase processing efficiency.
In some implementations, network analyst 110 may render a geographical map of the city, the state and the country overlaid with data collector 104 images at appropriate locations on the map. Alternatively, network analyst 110 may display the data in a tabular format.
When presenting data along with the map, network analyst 110 may indicate the health status of each connected endpoint 102 (e.g., different colors represent different health levels). Likewise, if an endpoint 102 has violated an SLA, network analyst 110 may indicate the presence of the violation through different colors (e.g., green endpoint 102 to indicate that the endpoint 102 has not violated the SLA; a yellow endpoint 102 to indicate that one or more of the SLA conditions have been violated and to indicate that the values of the parameters associated with the SLA violations are available based on the last data collection; and a red endpoint 102 to indicate that all SLA conditions have been violated and that the endpoint 102 maybe offline.
In addition to color coding the status of network elements, network analyst 110 may provide visual warnings based on collected data. For example if an SLA for latency is violated at one or more endpoints 102, network analyst 110 may generate visual alerts. Furthermore, based on the level of impact the violation has on network 100, network analyst 110 may contact the operator (e.g., send emails or text messages or place calls to the operator). Network analyst 110 may provide a high-level daily report on connection status for endpoints 102 and data collectors 104 and on quality of links for all regions. Network analyst 110 may export the report in the Portable Document Format (PDF), Comma Separated Values (CSV) format, or the PowerPoint Presentation (PPT) format, etc. If an endpoint 102 has a problem, network analyst 110 may indicate the problem and/or steps to resolve the problem; and provide an easy-to-identify warnings to the operators.
Because network analyst 110 is coupled to data lake 106 and all data collectors 104 in network 100 send their data to data lake 106, a network operator may examine any data collector 104 and/or endpoint 102 data by using network analyst 110. Network analyst 110 may also provide views of historical data and/or statistical information for a particular endpoint 102. Network analyst 110 may display data even for an endpoint 102 that is in the inactive state, until the endpoint 102 is disconnected from network 100 or is not detectable from within network 100.
When network analyst 110 displays a data collector 104, network analyst 110 may offer options for the operator to expand data collector 104 details, to view information related to endpoints 102 that sent data to the data collector 104. When the view is expanded, network analyst 110 may display results of ongoing endpoint tests as well as historical data. Network analyst 110 may indicate the next scheduled test times, as well as the last test results (e.g., completed, failed or inconclusive) in a color coded format.
Network analyst 110 may also allow the user to visually inspect the number of tests performed by an endpoint 102 and provide grid/or chart options for further analysis. Once the endpoint 102 responds to its assigned data collector 104, the status indicated at network analyst 110 may reflect the changes at the endpoint 102.
In addition to providing visual representations of test results, network analyst 110 may provide mechanisms for controlling network elements, such as endpoints 102, data collectors 104, devices hosting the endpoints 102 or data collectors 104, load balancer 108, etc. More specifically, network analyst 110 may provide functions to connect to and manage different network elements, such as, for example Optical Line Terminals, Gateway Routers, and other elements in network 100. In addition, network analyst 110 may provide the standard set of REST APIs for queries, status checks or configuration of the network elements.
Depending on the implementation, network environment 100 may include additional, fewer, different, or a different arrangement of components than those illustrated in
Central office 202 may include a site that houses telecommunication equipment, including switches, optical line terminals, etc. Central office 202 may provide telecommunication services to subscribers, such as telephone service, access to the Internet, cable television programs, etc., via optical line terminals. The optical line terminals may be assigned an identifier, herein referred to as an OLT ID, by an Operation Support System (OSS).
Dwelling units 204 may include apartments, condominiums, town houses, single detached houses, and/or other types of living units. Feeder optical fiber cables 206 may include optical fiber cable bundles that interconnect dwelling units 204 to optical line terminals in central office 202.
Feeder optical fiber cable 206 splits into, through various fiber distribution components, drop cables 208. Drop cable 208 may include an optical fiber that carries optical signals from feeder optical fiber cable 206 to optical network terminal 212 through walls, floors, and/or other components of dwelling units 204.
Optical network terminal 212, which may also be called optical network translator 212, may receive optical signals via drop cable 208 and convert the received optical signals into electrical signals that are further processed or carried over, for example, wires to one or more living units 210. In some implementations, optical network terminal 212 may be placed within a living unit, and devices that use services offered by central office 202 may be directly connected to optical network terminal 212. Optical network terminal 212 may be associated with an identifier, herein referred to as an ONT ID. The ONT ID may have been assigned to optical network terminal 212 by the OSS.
Living unit 210 may include a partitioned space that a tenant or an owner of the living unit 210 may occupy. Living unit 210 may house devices that are attached directly or indirectly, via wires or Radio Frequency (RF) signals, to optical network terminal 212 to receive services that central office 202 provides. Such devices may include a gateway router (GWR) 214. Devices such as a set-top box (STB) 216 or a computer may connect to the gateway router 214 through wires or wirelessly. Gateway router 214 may be associated with an identifier, herein referred to as a GWR ID. The GWR ID may have been assigned to gateway router 214 by the OSS.
As shown, network device 300 may include a processor 302, memory/storage 304, input component 306, output component 308, network interface 310, and communication path 312. In different implementations, network device 300 may include additional, fewer, different, or different arrangement of components than the ones illustrated in
Processor 302 may include a processor, a microprocessor, an Application Specific Integrated Circuit (ASIC), a Field Programmable Gate Array (FPGA), programmable logic device, chipset, application specific instruction-set processor (ASIP), system-on-chip (SoC), central processing unit (CPU) (e.g., one or multiple cores), microcontrollers, and/or other processing logic (e.g., embedded devices) capable of controlling device 300 and/or executing programs/instructions.
Memory/storage 304 may include static memory, such as read only memory (ROM), and/or dynamic memory, such as random access memory (RAM), or onboard cache, for storing data and machine-readable instructions (e.g., programs, scripts, etc.).
Memory/storage 304 may also include a floppy disk, CD ROM, CD read/write (R/W) disk, optical disk, magnetic disk, solid state disk, holographic versatile disk (HVD), digital versatile disk (DVD), and/or flash memory, as well as other types of storage device (e.g., Micro-Electromechanical system (MEMS)-based storage medium) for storing data and/or machine-readable instructions (e.g., a program, script, etc.). Memory/storage 304 may be external to and/or removable from network device 300. Memory/storage 304 may include, for example, a Universal Serial Bus (USB) memory stick, a dongle, a hard disk, off-line storage, a Blu-Ray® disk (BD), etc. Memory/storage 304 may also include devices that can function both as a RAM-like component or persistent storage, such as Intel® Optane memories.
Depending on the context, the term “memory,” “storage,” “storage device,” “storage unit,” and/or “medium” may be used interchangeably. For example, a “computer-readable storage device” or “computer-readable medium” may refer to both a memory and/or storage device.
Input component 306 and output component 308 may provide input and output from/to a user to/from device 300. Input/output components 306 and 308 may include a display screen, a keyboard, a mouse, a speaker, a microphone, a camera, a DVD reader, USB lines, and/or other types of components for obtaining, from physical events or phenomena, to and/or from signals that pertain to device 300.
Network interface 310 may include a transceiver (e.g., a transmitter and a receiver) for network device 300 to communicate with other devices and/or systems. For example, via network interface 310, network device 300 may communicate over a network, such as the Internet, an intranet, a terrestrial wireless network (e.g., a WLAN, WIFI®, WIMAX®, etc.), a satellite-based network, optical network, etc. Network interface 310 may include a modem, an Ethernet interface to a LAN, and/or an interface/connection for connecting device 300 to other devices (e.g., a BLUETOOTH® interface).
Communication path 312 may provide an interface through which components of device 300 can communicate with one another.
Network device 300 may perform the operations described herein in response to processor 302 executing software instructions stored in a non-transient computer-readable medium, such as memory/storage 304. The software instructions may be read into memory/storage 304 from another computer-readable medium or from another device via network interface 310. The software instructions stored in memory/storage 304, when executed by processor 302, may cause processor 302 to perform processes that are described herein, such as functions performed by endpoints 102, data collectors 104, data lake 106, load balancer 108, and/or network analyst 110.
Process 400 may further include activating an endpoint 102 (block 404). Depending on the particular use case, an endpoint 102 may be activated through a console command, by a Remote Procedure Call (RPC) from a remote host or the network analyst 110. When activated, the endpoint 102 may send a test request packet to a load balancer 108 (block 406).
MAC address field 504 carries the MAC address of the endpoint 102 sending the request packet 500. Reserved field 506 is reserved for future use. Test location ID field 508 carries a location ID received by the endpoint 102 from the OSS. The test location ID identifies the geographical location of the endpoint 102. Data collector URL field 510 and Test Request Interval field 512 are left empty.
Returning to
After the receipt of the reply packet, endpoint 102 sends a test location packet to the assigned data collector 104 (block 410). The test location packet informs data collector 104 of endpoint 102 parameters.
MAC address field 604, IP address field 606, and device serial number field 608 may include, respectively, the MAC address of the device hosting the endpoint 102, the IP address of the endpoint 102, and the serial number of the host device. Test location ID field 610 may include the test location ID received from the OSS. GWR ID field 612, OLT ID field 614, and ONT ID field 616 may include, respectively, the GWR ID, the OLT ID, and the ONT ID that the endpoint 102 received from the OSS.
Returning to
HTTP test 702, TCP test 704, and UDP test 706 may include upload and download tests, respectively, of HTTP messages, TCP segments, and UDP packets. As shown, these tests may be intrusive, semi-intrusive, and highly intrusive to the operation of the device on which the endpoint 102 is installed.
HTTP test 702 may be intrusive for when requested on demand. HTTP GET/PUT is used by the endpoint 102 to satisfy the test requirement. The test is time based (for a specific duration) or a size based (for specific amount of file to download and upload).
TCP test 704 involves a connection between an endpoint 102 and the data collector 104. The test is performed using bit streams under the TCP using variable length data sets to achieve the highest possible throughput values. The total data transmitted may be set to a predetermined value. Because TCP test 704 is semi-intrusive, the test 704 may be used when inconclusive test results are returned by non-intrusive tests.
UDP test 706 may be used in conjunction with TCP/HTTP tests 704, 702. When performed, UDP test 706 may saturate the communication path to reach the maximum number of transmission packets, without taking into account the background traffic and the user generated traffic. Accordingly, the test 706 may be highly intrusive and may result in performance issues for the user during the test 706.
TCP TMT test 708 may obtain theoretical throughput values. Each of these may be obtained based on transmitting and receiving a single IP packet from a source to the destination. In a single test cycle, the test 708 may use multiple data sets for validity and repeatability of the network conditions. The test 708 may identify anomalies and outliers based on the data sets and present throughput values. Within a cycle, each test iteration may be associated with a header that includes attributes (e.g., expected number of packets, host/server identifiers, etc.) and a trailer which summarizes the test result. Data collector 104 may calculate the results and average them through the entire test cycle. More specifically, data collector 104 may use a TMT calculation algorithm to identify the maximum throughput during a particular test cycle. According to one implementation, a formula for calculating the TCP TMT is given by the expression:
Throughput=Total Bytes Received×8/(BOM−EOM)/1,000,000 (1)
In expression (1), BOM and EOM correspond to the time of the beginning of measurement and the time of the end of measurement.
UDP TMT test 710 may provide the same level of throughput measurements at client and server sides. At the start of test 710, the client may establish a connection to the server and provide details of each test iteration via a header that indicates the number of packets in the transmission queue and the queue size. The header may also include packet sequence numbers generated by the client.
With receipt of the header information, the server has details of the buffer size, the number of packets expected during the test iteration, and the order of the packets. When all UDP packets have been transmitted to the server, the server may assess the number of packets received and may compare the results with information provided in the header packet. If discrepancies are detected during the test, the server may notify the client by sending a trailer packet that indicates the number of bits/Bytes/packets received, the order in which the packets were received, and the packet loss.
UDP TMT test 710 is different from TCP TMT test 708. For example, UDP TMT test 710 is less resource intensive than TCP TMT test 708. UDP TMT test 710 may not significantly contribute to the congestion of the line. The expression for computing the throughput for UDP TMT test is the same expression (1) for the TCP TMT test 708.
Referring back to
MAC address 802 and IP address 804 may include, respectively, the MAC address of the device hosting the endpoint 102 and the IP address of the endpoint 102. The data collector 104 may send MAC address 802 and IP address 804 as, respectively, an unsigned integer and a string to the data lake 106. ONT ID 806, OLT ID 808, and GWR ID 810 are the Optical Network ID, Optical Line Terminal ID, and the Gateway Router ID that the endpoint 102 received from the OSS. These IDs are sent by data collector 104 to data lake 106 as unsigned integers. As described above with reference to
Download 812 and upload 814 include the upload and download speeds determined based on the number of bits transmitted and received by endpoint 102 and data collector 104. In one implementation, download 812 and upload 814 are sent as strings that express the speeds in MB/S.
BOM 816 and EOM 818 indicate the dates and the times at which, respectively, the first packet and the last packet of the test were transmitted by endpoint 102 and data collector 104. Send buffer 820 and receive buffer 822 indicate the sizes of the transmission buffer and the receive buffer at the client and the server, as unsigned integers. Packets sent 824 and packets received 826 include the number of packets sent and received, respectively, at the client and the server, as unsigned integers.
Direction 828 may indicate the direction (e.g., “UPLOAD” or “DOWNLOAD”) in which the test packets were sent to/from the client or the server. Status 830 may indicate, as a string, the result of a test. Possible values for status 830 include: Completed Status, Initialization Error, and Processing Error. The Completed Status indicates that the test has been performed without any error. The Initialization Error Status indicates that the test has been completed but with initialization errors. The Processing Error Status indicates that the test has failed during processing of the packets by the client or the server. Latency 832 may indicate, as an unsigned integer, the total round trip time (RTT) of the test packets. The RTT may be calculated using SYN and SYN-ACK packets.
In this specification, various preferred embodiments have been described with reference to the accompanying drawings. It will be evident that modifications and changes may be made thereto, and additional embodiments may be implemented, without departing from the broader scope of the invention as set forth in the claims that follow. The specification and drawings are accordingly to be regarded in an illustrative rather than restrictive sense.
In the above, while a series of blocks have been described with regard to the processes illustrated in
It will be apparent that aspects described herein may be implemented in many different forms of software, firmware, and hardware in the implementations illustrated in the figures. The actual software code or specialized control hardware used to implement aspects does not limit the invention. Thus, the operation and behavior of the aspects were described without reference to the specific software code—it being understood that software and control hardware can be designed to implement the aspects based on the description herein.
Further, certain portions of the implementations have been described as “logic” that performs one or more functions. This logic may include hardware, such as a processor, a microprocessor, an application specific integrated circuit, or a field programmable gate array, software, or a combination of hardware and software.
To the extent the aforementioned embodiments collect, store or employ personal information provided by individuals, it should be understood that such information shall be collected, stored, and used in accordance with all applicable laws concerning protection of personal information. The collection, storage and use of such information may be subject to consent of the individual to such activity, for example, through well known “opt-in” or “opt-out” processes as may be appropriate for the situation and type of information. Storage and use of personal information may be in an appropriately secure manner reflective of the type of information, for example, through various encryption and anonymization techniques for particularly sensitive information.
No element, block, or instruction used in the present application should be construed as critical or essential to the implementations described herein unless explicitly described as such. Also, as used herein, the articles “a,” “an,” and “the” are intended to include one or more items. Further, the phrase “based on” is intended to mean “based, at least in part, on” unless explicitly stated otherwise.