The computer-readable medium 102 and other computer readable mediums discussed in this paper are intended to include all mediums that are statutory (e.g., in the United States, under 35 U.S.C. 101), and to specifically exclude all mediums that are non-statutory in nature to the extent that the exclusion is necessary for a claim that includes the computer-readable medium to be valid. Known statutory computer-readable mediums include hardware (e.g., registers, random access memory (RAM), non-volatile (NV) storage, to name a few), but may or may not be limited to hardware.
The computer-readable medium 102 and other computer readable mediums discussed in this paper are intended to represent a variety of potentially applicable technologies. For example, the computer-readable medium 102 can be used to form a network or part of a network. Where two components are co-located on a device, the computer-readable medium 102 can include a bus or other data conduit or plane. Where a first component is co-located on one device and a second component is located on a different device, the computer-readable medium 102 can include a wireless or wired back-end network or LAN. The computer-readable medium 102 can also encompass a relevant portion of a WAN or other network, if applicable.
The devices, systems, and computer-readable mediums described in this paper can be implemented as a computer system or parts of a computer system or a plurality of computer systems. In general, a computer system will include a processor, memory, non-volatile storage, and an interface. A typical computer system will usually include at least a processor, memory, and a device (e.g., a bus) coupling the memory to the processor. The processor can be, for example, a general-purpose central processing unit (CPU), such as a microprocessor, or a special-purpose processor, such as a microcontroller.
The memory can include, by way of example but not limitation, random access memory (RAM), such as dynamic RAM (DRAM) and static RAM (SRAM). The memory can be local, remote, or distributed. The bus can also couple the processor to non-volatile storage. The non-volatile storage is often a magnetic floppy or hard disk, a magnetic-optical disk, an optical disk, a read-only memory (ROM), such as a CD-ROM, EPROM, or EEPROM, a magnetic or optical card, or another form of storage for large amounts of data. Some of this data is often written, by a direct memory access process, into memory during execution of software on the computer system. The non-volatile storage can be local, remote, or distributed. The non-volatile storage is optional because systems can be created with all applicable data available in memory.
Software is typically stored in the non-volatile storage. Indeed, for large programs, it may not even be possible to store the entire program in the memory. Nevertheless, it should be understood that for software to run, if necessary, it is moved to a computer-readable location appropriate for processing, and for illustrative purposes, that location is referred to as the memory in this paper. Even when software is moved to the memory for execution, the processor will typically make use of hardware registers to store values associated with the software, and local cache that, ideally, serves to speed up execution. As used herein, a software program is assumed to be stored at an applicable known or convenient location (from non-volatile storage to hardware registers) when the software program is referred to as “implemented in a computer-readable storage medium.” A processor is considered to be “configured to execute a program” when at least one value associated with the program is stored in a register readable by the processor.
In one example of operation, a computer system can be controlled by operating system software, which is a software program that includes a file management system, such as a disk operating system. One example of operating system software with associated file management system software is the family of operating systems known as Windows® from Microsoft Corporation of Redmond, Wash., and their associated file management systems. Another example of operating system software with its associated file management system software is the Linux operating system and its associated file management system. The file management system is typically stored in the non-volatile storage and causes the processor to execute the various acts required by the operating system to input and output data and to store data in the memory, including storing files on the non-volatile storage.
The bus can also couple the processor to the interface. The interface can include one or more input and/or output (I/O) devices. Depending upon implementation-specific or other considerations, the I/O devices can include, by way of example but not limitation, a keyboard, a mouse or other pointing device, disk drives, printers, a scanner, and other I/O devices, including a display device. The display device can include, by way of example but not limitation, a cathode ray tube (CRT), liquid crystal display (LCD), or some other applicable known or convenient display device. The interface can include one or more of a modem or network interface. It will be appreciated that a modem or network interface can be considered to be part of the computer system. The interface can include an analog modem, ISDN modem, cable modem, token ring interface, satellite transmission interface (e.g. “direct PC”), or other interfaces for coupling a computer system to other computer systems. Interfaces enable computer systems and other devices to be coupled together in a network.
The computer systems can be compatible with or implemented as part of or through a cloud-based computing system. As used in this paper, a cloud-based computing system is a system that provides virtualized computing resources, software and/or information to end user devices. The computing resources, software and/or information can be virtualized by maintaining centralized services and resources that the edge devices can access over a communication interface, such as a network. “Cloud” may be a marketing term and for the purposes of this paper can include any of the networks described herein. The cloud-based computing system can involve a subscription for services or use a utility pricing model. Users can access the protocols of the cloud-based computing system through a web browser or other container application located on their end user device.
A computer system can be implemented as an engine, as part of an engine or through multiple engines. As used in this paper, an engine includes one or more processors or a portion thereof. A portion of one or more processors can include some portion of hardware less than all of the hardware comprising any given one or more processors, such as a subset of registers, the portion of the processor dedicated to one or more threads of a multi-threaded processor, a time slice during which the processor is wholly or partially dedicated to carrying out part of the engine's functionality, or the like. As such, a first engine and a second engine can have one or more dedicated processors or a first engine and a second engine can share one or more processors with one another or other engines. Depending upon implementation-specific or other considerations, an engine can be centralized or its functionality distributed. An engine can include hardware, firmware, or software embodied in a computer-readable medium for execution by the processor. The processor transforms data into new data using implemented data structures and methods, such as is described with reference to the figures in this paper.
The engines described in this paper, or the engines through which the systems and devices described in this paper can be implemented, can be cloud-based engines. As used in this paper, a cloud-based engine is an engine that can run applications and/or functionalities using a cloud-based computing system. All or portions of the applications and/or functionalities can be distributed across multiple computing devices, and need not be restricted to only one computing device. In some embodiments, the cloud-based engines can execute functionalities and/or modules that end users access through a web browser or container application without having the functionalities and/or modules installed locally on the end-users' computing devices.
As used in this paper, datastores are intended to include repositories having any applicable organization of data, including tables, comma-separated values (CSV) files, traditional databases (e.g., SQL), or other applicable known or convenient organizational formats. Datastores can be implemented, for example, as software embodied in a physical computer-readable medium on a specific-purpose machine, in firmware, in hardware, in a combination thereof, or in an applicable known or convenient device or system. Datastore-associated components, such as database interfaces, can be considered “part of” a datastore, part of some other system component, or a combination thereof, though the physical location and other characteristics of datastore-associated components is not critical for an understanding of the techniques described in this paper.
Datastores can include data structures. As used in this paper, a data structure is associated with a particular way of storing and organizing data in a computer so that it can be used efficiently within a given context. Data structures are generally based on the ability of a computer to fetch and store data at any place in its memory, specified by an address, a bit string that can be itself stored in memory and manipulated by the program. Thus, some data structures are based on computing the addresses of data items with arithmetic operations; while other data structures are based on storing addresses of data items within the structure itself. Many data structures use both principles, sometimes combined in non-trivial ways. The implementation of a data structure usually entails writing a set of procedures that create and manipulate instances of that structure. The datastores, described in this paper, can be cloud-based datastores. A cloud-based datastore is a datastore that is compatible with cloud-based computing systems and engines.
Returning to the example of
In a specific implementation, the IoT devices 104 act as stations. A station, as used in this paper, can be referred to as a device with a media access control (MAC) address and a physical layer (PHY) interface to a wireless medium that complies with the IEEE 802.11 standard. Thus, for example, the network devices can be referred to as stations, if applicable. IEEE 802.11a-1999, IEEE 802.11b-1999, IEEE 802.11g-2003, IEEE 802.11-2007, and IEEE 802.11n TGn Draft 8.0 (2009) are incorporated by reference. As used in this paper, a system that is 802.11 standards-compatible or 802.11 standards-compliant complies with at least some of one or more of the incorporated documents' requirements and/or recommendations, or requirements and/or recommendations from earlier drafts of the documents, and includes Wi-Fi systems. Wi-Fi is a non-technical description that is generally correlated with the IEEE 802.11 standards, as well as Wi-Fi Protected Access (WPA) and WPA2 security standards, and the Extensible Authentication Protocol (EAP) standard. In alternative embodiments, a station may comply with a different standard than Wi-Fi or IEEE 802.11, may be referred to as something other than a “station,” and may have different interfaces to a wireless or other medium.
In a specific implementation, the IoT devices 104 are configured to access network services in compliance with IEEE 802.3. IEEE 802.3 is a working group and a collection of IEEE standards produced by the working group defining the physical layer and data link layer's MAC of wired Ethernet. This is generally a local area network technology with some wide area network applications. Physical connections are typically made between nodes and/or infrastructure devices (hubs, switches, routers) by various types of copper or fiber cable. IEEE 802.3 is a technology that supports the IEEE 802.1 network architecture. As is well-known in the relevant art, IEEE 802.11 is a working group and collection of standards for implementing wireless local area network (WLAN) computer communication in the 2.4, 3.6 and 5 GHz frequency bands. The base version of the standard IEEE 802.11-2007 has had subsequent amendments. These standards provide the basis for wireless network products using the Wi-Fi brand. IEEE 802.1 and 802.3 are incorporated by reference.
In a specific implementation, the IoT devices 104 are purposefully built or configured IoT devices. In being purposely built IoT devices, the IoT devices 104 are built to have specific operational parameters. For example, a thermometer may be built to provide signals from a temperature sensor. In being purposely configured IoT devices, the IoT devices 104 can be configured to operate according to specific operational parameters in accordance with input from a human or artificial agent. For example, an IoT device of the IoT devices 104 can be a thermostat configured to control an air conditioner to cool a room to a configurable temperature at a configurable time. As another example, an agent can specify an IoT device should not communicate with a specific data source, and the IoT device can be configured to refrain from communicating with the specific data source as part of purposeful configuration.
In the example of
In the example of
In a specific implementation, at least a portion of the progressive risk assessment system 108 is implemented remotely relative to IoT devices for which the system determines risk levels. For example, at least a portion of the progressive risk assessment system 108 can be implemented as cloud based systems. Portions of the progressive risk assessment system 108 implemented remotely relative to IoT devices can receive data associated with the IoT devices through virtual private network (hereinafter “VPN”) tunnels. For example, the progressive risk assessment system 108 can receive outbound network traffic sent from IoT devices over a VPN tunnel. Additionally, VPN tunnels through which the progressive risk assessment system 108 can send and receive data can be maintained using dedicated networking equipment. For example, the progressive risk assessment system 108 can receive data associated with the IoT devices 104 using dedicated routers for communicating with the IoT devices 104.
Instead or in addition, at least a portion of the progressive risk assessment system 108 can be implemented through a mirror in a gateway, one or more local agents, or on one or more IoT devices; i.e., intelligence can be distributed. A local agent includes software implemented on a physical device locally coupled to IoT devices. Local coupling involves operationally connecting the local agent via a LAN interface (or a smaller network interface, such as a PAN interface) to IoT devices. It should be noted enterprise networks can include geographically distributed LANs coupled across WAN segments. In a distributed enterprise network, the local agents may be local at each LAN (each LAN is sometimes referred to as a Basic Service Set (BSS) in IEEE 802.11 parlance, though no explicit requirement is suggested here) or localized using, e.g., VLAN tunneling (the connected LANs are sometimes referred to as an Extended Service Set (ESS) in IEEE 802.11 parlance, though no explicit requirement is suggested here). Depending upon implementation-specific or other considerations, the progressive risk assessment system 108 can include wired communication interfaces and wireless communication interfaces for communicating over wired or wireless communication channels. The progressive risk assessment system 108 can be, at least in part, a device provided by an Internet service provider directly purchased by a consumer and acting as a conduit between networks. Depending upon implementation or other considerations, the progressive risk assessment system 108 can be implemented as part of a private cloud. A private cloud implementing the progressive risk assessment system 108, at least in part, can be specific to an entity.
In a specific implementation, the progressive risk assessment system 108 functions to determine undesired behavior in IoT device operation, or otherwise abnormal IoT device behavior in operation, as described in more detail later. Undesired behavior is defined by an institutional or security system as undesirable. It may be noted that an IoT device with a good personality can exhibit anomalous behavior and still be considered to have a good personality, and an IoT device with a bad personality need not exhibit anomalous behavior to still be considered to have a bad personality. This is made of note because techniques used to identify undesired behavior can include anomaly detection, but anomaly detection is not the universe of undesired behavior detection. As used in this paper, a personality includes mathematically modelled behavior patterns, with institutional knowledge built into the personality model. Examples of bad personality include behavior associated with bots, C&C centers (botnet), or servers taken over by malware, to name three, all of which can have recognizable behaviors.
In the example of
In a specific implementation, the progressive risk alert engine 110 generates event-related threat alerts in response to policy violation or threat alerts (e.g., potential attack in notification). Policy violation and/or threat alerts may or may not increase a progressive risk score, depending upon the perceived risk associated with the non-incident alerts. As used in this paper, policy violation and threat alerts are “non-incidents” in that they are generated in response to something other than a modification of a device on a network. The confidence with which a threat alert can be indicative of an attack can be treated as somewhere between 1% and 99% (where 0% would trigger no alert at all and 100% would mean actual modification is detected on a device). Presumably, incident alerts, which indicate a device has been subjected to unauthorized modification and which would be considered when updating the progressive risk score at the progressive risk assessment system 108, trigger some form of countermeasures. It should be mentioned, however, that because some devices are more important than others, higher alert severity is correlated with incident alerts, but is but not determined by whether an incident or non-incident alert is generated.
The activities leading up to an incident can include network enumeration, vulnerability analysis, and exploitation. Network enumeration is the discovery of hosts or devices on a network. Network enumeration tends to use overt discovery protocols such as ICMP and SNMP to gather information (a network scan). It may also scan various ports on remote hosts for looking for well-known services (a service scan) in an attempt to further identify the function of a remote host. Vulnerability analysis is used to discover the weaknesses of a network using authenticated and/or unauthenticated scans (a vulnerability scan). Exploitation is attempting to compromise a system by employing the vulnerabilities found through vulnerability analysis. Network enumeration and vulnerability analysis may be referred to collectively as “recon.” Recon is generally required before exploitation can occur, but could conceivably be skipped if a threat actor, such as an attacker, knew the network or performed “physical access recon.” An initiator is a device that performs network enumeration, vulnerability analysis, and/or exploitation (and/or code drop, C&C, or launch). A responder is a device that responds to the initiator, but when a code drop occurs, a responder can be considered to have been converted into an initiator.
In a specific implementation, the progressive risk alert engine 110 monitors both an initiator and a responder (or at least communications therebetween) and, depending upon priorities and rules, generates non-incident alerts of variable severity (e.g., info, caution, warning, and danger) when spotting potential network enumeration, vulnerability analysis, and/or exploitation attempts or other undesirable activity. As was discussed previously, events need not be discrete. For example, each of the following events may not have an associated risk, but in the aggregate can be associated with risk: 1) a user login with username and email to create an account, 2) server sends token that is used for future login, 3) update email address (which could be that of a cracker) when see token, 4) server updates email with new email address. For this example aggregated event, it would be desirable, for example, to put in a check to prevent takeover.
In a specific implementation, the progressive risk alert engine 110 monitors both an initiator and a responder (or at least communications therebetween) and, depending upon priorities and rules, generates incident alerts of variable severity (e.g., info, caution, warning, and danger) when spotting unauthorized code drops, command & control (C&C), or a responder launching as an initiator. An example of a code drop is infection with a bot (usually delivered via a Trojan or exploit kit. Some examples of C&C botnets are telnet botnets, IRC-based botnets, and P2P botnets.
In a specific implementation, the progressive risk alert engine 110 generates and updates a progressive risk score using activity graphs. Recognizing each activity has a sequence of events (e.g., updating software involves locating a site, opening a connection, downloading, . . . ), at least conceptually a risk graph can be created for each activity. Reinforcement learning provides reward points for a path of an activity graph. For example, each behavior can have a behavior risk score. A behavior risk score is a weighted sum of associated activity risk scores; an activity risk score is a sum of reward points acquired at each event in a defining sequence of events. In practice, an agent (evaluator) makes an immediate decision about a reward. For certain factors, the reward is a relative value compared to other factors. Reward points can be calculated or predicted using a model (e.g., probability of spam if using email, probability of phishing attack in email, etc.). Advantageously, reward points, once added, are relatively stable, so you don't generally have to go back to change old risk factors. More detail regarding reward points is discussed below with respect to
In the example of
In the example of
In the example of
In a specific implementation, the progressive risk assessment system 108 functions to correlate risk factors from the baseline risk provisioning subsystem 112, the threat vector assessment subsystem 114, and the behavioral risk evaluation subsystem 116 to generate a progressive risk assessment score.
In the example of
In the example of
In the example of
In the example of
In the example of
In the example of
In the example of
In the example of
In the example of
In a specific implementation, the network datastore 402 includes event parameters (data or metadata) obtained by analyzing data packets, such as via packet header analysis or deep packet inspection (DPI). For example, if a data packet can be correlated with a specific application, then the network datastore 402 can include an event parameter of the specific application executed in association with an IoT device. As another example, if DPI is used, payload of a data packet sent from an IoT device can be analyzed to identify an event parameter from the data packet.
In a specific implementation, the network datastore 402 includes one or a combination of device sensor events, session events, application events, user events, protocol events, and status events included as part of a context of an IoT device in operation. Device sensor events can include events that occur at the physical layer of the physical layer or data link layer of the open system interconnection (hereinafter referred to as “OSI”) model. For example, device sensor events can include a virtual LAN (hereinafter referred to as “VLAN”) used by an IoT device to communicate with a specific data source. Session events can include events that occur at either the network layer or the transport layer of the OSI model. For example, session events can include a specific network type used by an IoT device to communicate with a source. Application events include events that occur at one or a combination of the session layer, the presentation layer, and the application layer of the OSI model. For example, application events can include an identification of an application executed at an IoT device in accessing network services. Device events can include events that occur at a specific device. User events can include events that occur in associated with a specific user interacting with an IoT device. For example, user events can include specific instances in which a specific user interacts with IoT devices. Status events can include events associated with whether an IoT device is operating. For example, status events can include an event indicating whether an IoT device is operating within a given operational efficiency range.
In the example of
In the example of
In a specific implementation, the machine learning analytics engine 406 functions to aggregate determined events for purposes of determining undesired behavior in IoT device operation. The machine learning analytics engine 406 can aggregate events based on context, such as by way of a profile-based aggregation. For example, the machine learning analytics engine 406 can aggregate events based on recipients of data packets transmitted from an IoT device. In another example, the machine learning analytics engine 406 can aggregate events based on an IoT device ID or a port used transmit data packets from which the events are translated. Further, the machine learning analytics engine 406 can aggregate events based on contexts associated with events. For example, the machine learning analytics engine 406 can aggregate events based on whether the events are one or a combination of device sensor events, session events, application events, user events, protocol events, and status events.
In a specific implementation, the machine learning analytics engine 406 can aggregate events of IoT devices in operation using common factor aggregation machine learning. Common factor aggregation creates various aggregations and transformations from the incoming data events leveraging on supervised classification, unsupervised clustering-based machine learning, and multi-layer deep learning to model various behavior patterns of IoT devices so the IoT devices can be grouped/labelled based on their behaviors. For example, an ultrasound machine running windows OS and connecting to its home servers in Europe would be tagged with, in this example, 2 different behavior aggregation factors and the correlation of these behaviors can help accurately identify the device as an ultrasound machine of a specific model.
In a specific implementation, the machine learning analytics engine 406 can aggregate events of IoT devices in operation using common factor aggregation machine learning. For example, if, through machine learning, common factors of an IoT device being hacked are identified, then the machine learning analytics engine 406 can group events of IoT devices being hacked based on the common factors identified through machine learning. Alternatively or in addition, the machine learning analytics engine 406 can use common factor aggregation machine learning to identify common factors of contexts of IoT devices in operation, for use in aggregating events based on context. For example, if events related to operation of IoT devices by a particular user share a specific common factor, identified through machine learning, then the machine learning analytics engine 406 can group events of the user operating IoT devices together based on the specific common factor.
To allow comparison of events for common factor aggregation, a harmonized framework of events (e.g., a common methodological framework) is desirable, which can be implemented as a huge amount of data that is analyzed for commonalities. The analysis takes more or less work depending upon the type of data (e.g., comparing sources and destinations is relatively straight-forward, while comparing values identified using deep packet inspection of payload is relatively less straight-forward). Reducing factors to a common baseline is impractical due to the number of different aggregations that are relevant in an IoT network comprising a large number of devices; reduction to a common baseline is useless for predictive purposes. Multiple aggregations are necessary and may not even be easily identifiable to a human because the common factors are not easily categorized by the human mind and, due to their numbers, will, in practice, likely go without human-understandable aggregations of common factors. Indeed, it is a hopeless task for a human given the number and frequency of communications IoT networks are already generating, even if all of the aggregations were uniquely describable to a human. So a computer must be used to find the large number of common factors necessary to yield predictable, and therefore actionable, intelligence; humans can, of course, help in categorization or other tasks after being augmented by the computer.
In a specific implementation, the machine learning analytics engine 406 functions to drop specific determined features or events from consideration in determining whether an IoT device is operating in an undesirable manner. In dropping specific features from consideration in determining whether an IoT device behavior is undesirable, the machine learning analytics engine 406 can filter out irrelevant factors to only keep IoT compatible features for purposes of determining whether the IoT device behavior is undesirable. For example, the machine learning analytics engine 406 can filter out features associated with human factors in IoT device operation for purposes of determining whether the IoT device behavior is undesirable.
In a specific implementation, the machine learning analytics engine 406 functions to filter out features for use in detecting undesired device behavior based on either or both a personality of an IoT device and a profile of a group of IoT devices including the IoT device. A personality of an IoT device includes applicable data describing operation of an IoT device for purposes of detecting undesired behavior of the IoT device in operation. For example, a personality of an IoT device can include normal operating behavior patterns of an IoT device and undesired operating behavior patterns of an IoT device. A profile of a group of IoT devices includes application data describing operation of IoT devices in the group for purposes of detecting undesired behavior of the IoT devices in operation. For example, a profile of a group of IoT devices can include normal operating behavior patterns of IoT devices in the group and undesired operating behavior patterns of the IoT devices in the group. IoT devices can be grouped together to form a profile, based on one or a combination of characteristics of the IoT devices, operational characteristics of the IoT devices, and contexts of the IoT devices in operation. For example, all thermostat IoT devices of a specific manufacturer can be grouped together to form a profile. In filtering out features for use in detecting undesired device behavior based on either or both a personality of an IoT device and a profile of a group of IoT devices, the machine learning analytics engine 406 can filter out normal operating behaviors of the IoT device of the group of IoT devices using the personality of profile.
In a specific implementation, the machine learning analytics engine 406 functions to add aggregated events and features into an event buffer. An event buffer includes a collection of events and features that are held for a period of time and analyzed to determine whether an IoT device is exhibiting undesired behavior in operation. An event buffer can be specific to a context associated with an IoT device in operation. For example, an event buffer can be associated with or specific to an application and can be used to determine whether an IoT device is exhibiting undesired behavior in operation when the application is executing at the IoT device. In another example, an event buffer can be associated with IoT devices of a specific device type and can be used to determine whether an IoT device of the device type is exhibiting undesired behavior in operation. The machine learning analytics engine 406 can buffer aggregated events and features into event buffers based on contexts associated with aggregated events and features, e.g. contexts of an IoT device in operation. For example, the machine learning analytics engine 406 can buffer aggregated events and features into an event buffer based on whether the events are one or a combination of device sensor events, session events, application events, user events, protocol events, and status events.
In a specific implementation, the machine learning analytics engine 406 trains models, represented by the models datastore 408, which are subsequently used to determine undesired behavior in IoT device operation through application of a context-based undesired behavior detection model to events and features of an IoT device. A context-based undesired behavior detection model includes applicable data describing either or both normal and abnormal behavior patterns or portions of behavior patterns of one or a plurality of IoT devices in operation. Specifically, a context-based undesired behavior detection model can include a modeled set of features indicating all or a portion of a behavior pattern. For example, a context-based undesired behavior detection model can include a combination of behavior events each indicated by a single modeled feature to form a behavior pattern. A context-based undesired behavior detection model is specific to a context of an IoT device. For example, a context-based undesired behavior detection model can indicate normal behavior patterns of an IoT device in interacting with a specific remote system. In applying a context-based undesired behavior detection model to determine undesired behavior in IoT device operation, the machine learning analytics engine 406 can apply the model to compare current or past operating of an IoT device, e.g. indicated by aggregated events and features, with normal or abnormal behavior patterns indicated by the model. Subsequently, by comparing the current or past operating of the IoT device with normal or abnormal behavior patterns, undesired behavior in IoT device operation can be detected.
In a specific implementation, a context-based undesired behavior detection model is included as part of a personality of an IoT device or a profile of a group of IoT devices. For example, a context-based undesired behavior detection model can include normal behavior patterns of IoT devices manufactured by the same manufacturer. In another example, a context-based undesired behavior detection model can include normal behavior patterns of a specific IoT device when a streaming music application is executed on the IoT device.
In a specific implementation, the machine learning analytics engine 406 performs personality classification for IoT devices through application of a plurality of context-based undesired behavior detection models to events and features of IoT device operation. A behavior pattern of an IoT device can be represented by a plurality of context-based undesired behavior detection models. Accordingly, the machine learning analytics engine 406 can apply the plurality of context-based undesired behavior detection models to aggregated events and features of an IoT device in operation to determine IoT device personality. For example, if a first context-based undesired behavior detection model indicates a first aspect of a behavior pattern of an IoT device and a second context-based undesired behavior detection model indicates a second aspect of the behavior pattern of the IoT device, then the machine learning analytics engine 406 can apply both the first and second models to classify the IoT device as having a bad personality.
In a specific implementation, the machine learning analytics engine 406 functions to apply a context-based undesired behavior detection model to aggregated events and features of an IoT device collected in event buffers in IoT device personality classification. Advantageously, aggregation based on remote, per application, per IP, or other factors can be on a granular level. For example, the machine learning analytics engine 406 can apply a context-based undesired behavior detection model to aggregated events and features in a buffer, in an order of the events and features in the buffer. The machine learning analytics engine 406 can apply specific context-based undesired behavior detection models to events and features based on a specific event buffer in which the events and features are collected. For example, if aggregated events are in an event buffer associated with applications executing on an IoT device, then the machine learning analytics engine 406 can apply context-based undesired behavior detection models for IoT device personality classification when applications are executed at the IoT device. In another example, if aggregated events are in an event buffer associated with session events, then the machine learning analytics engine 406 can apply context-based undesired behavior detection models for IoT device personality classification at a network layer level.
In a specific implementation, the machine learning analytics engine 406 functions to apply a context-based undesired behavior detection model to aggregated events and features based on a context of an IoT device in operating to generate the events. For example, the machine learning analytics engine 406 can apply a context-based undesired behavior detection model to aggregated events based on a port used in communicating data packets used to determine the events. In applying a context-based undesired behavior detection model to aggregated events based on a context of an IoT device, the machine learning analytics engine 406 can apply a context-based undesired behavior detection model based on an undesired behavior detection model in which the events are buffered. For example, the machine learning analytics engine 406 can apply a context-based undesired behavior detection model for analyzing device events to events buffered into an event buffer associated with detecting undesired behavior in events that occur at a specific device layer.
In a specific implementation, the machine learning analytics engine 406 functions to maintain context-based undesired behavior detection models for use in detecting undesired behavior in IoT device operation. In maintaining a context-based undesired behavior detection model for use in detecting undesired behavior in IoT device operation, the machine learning analytics engine 406 can create and update a context-based undesired behavior detection model. For example, the machine learning analytics engine 406 can update a context-based undesired behavior detection model as an IoT device continues to operate. The machine learning analytics engine 406 can maintain a context-based undesired behavior detection model based on operation of an IoT device within a specific data window. For example, the machine learning analytics engine 406 can adjust a context-based undesired behavior detection model offline daily based on IoT device operation during the day.
In a specific implementation, the machine learning analytics engine 406 functions to maintain a context-based undesired behavior detection model based on events determined based on operation of one or a plurality of IoT devices. For example, the machine learning analytics engine 406 can maintain a context-based undesired behavior detection model based on feature values of events occurring during operation of an IoT device. Additionally, the machine learning analytics engine 406 can maintain a context-based undesired behavior detection model based on aggregated events occurring during operation of one or a plurality of IoT devices. For example, the machine learning analytics engine 406 can update a context-based undesired behavior detection model based on feature values of events during operation of one or a plurality of IoT devices. Further in the example, the machine learning analytics engine 406 can maintain the context-based undesired behavior detection model based on the feature values of the events aggregated together using common factor aggregation based on contexts of the one or a plurality of the IoT devices in operation.
In a specific implementation, the machine learning analytics engine 406 functions to determine behavior patterns of an IoT device in operation for use in maintaining a context-based undesired behavior detection model. The machine learning analytics engine 406 can determine behavior patterns of an IoT device in operation based on aggregated events of the IoT device in operation. For example, if an IoT device exchanges data with a source every night, as indicated by aggregated events of the IoT device in operation, then the machine learning analytics engine 406 can determine a behavior pattern of the IoT device is exchanges data with the source at night. The machine learning analytics engine 406 can use an applicable machine learning mechanism to determine a behavior pattern of an IoT device in operation.
In a specific implementation, the machine learning analytics engine 406 functions to maintain a context-based undesired behavior detection model based on contexts of one or a plurality of IoT devices in operation. Specifically, the machine learning analytics engine 406 can maintain a context-based undesired behavior detection model based on a context of an IoT device in operating to generate aggregated events used to maintain the model. For example, if aggregated events of the IoT device in operation a created when a specific application is executing, then the machine learning analytics engine 406 can associate a context-based undesired behavior detection model generated using the events with the specific application. Further in the example, the context-based undesired behavior detection model can be applied by the machine learning analytics engine 406 to aggregated events generated when the specific application is executing at the IoT device to determine undesired behavior in the operation of the IoT device.
In a specific implementation, the machine learning analytics engine 406 functions to maintain a context-based undesired behavior detection model as part of either or both a personality of an IoT device and a profile group of IoT devices. For example, the machine learning analytics engine 406 can maintain a context-based undesired behavior detection model based on operation of an IoT device and subsequently include the context-based undesired behavior detection model as part of a personality of the IoT device. In maintaining a context-based undesired behavior detection model as part of a profile group of IoT devices, the machine learning analytics engine 406 can group together the IoT devices based on context of the IoT devices in operation. For example, the machine learning analytics engine 406 can group together IoT devices of a specific type, e.g. a context, into a profile group and subsequently add context-based undesired behavior detection models generated based on operation of the IoT devices into the profile group of the IoT devices.
In an example of operation of the example system shown in
In the example of
If the events at the data root node 502 indicate the X-ray machine is not sending the images via a browser, the activity graph 500 follows the path to “no browser” node 504. In the example of
The other paths of the activity graph 500 pass first through the browser node 508, which has −1 associated reward points. A first of the three paths from the browser node 508 is through the LAN node 510, which has no associated reward points, and to the −1 RP leaf node 512. A second of the three paths from the browser node 508 is through the email node 514, which has −3 associated reward points, the unknown [email application] node 516, which has −3 associated reward points, and to the −7 RP leaf node 518; or from the browser node 508 through the email node 514, which has −3 associated reward points, the gmail node 520, which has no associated reward points, and to the −4 RP leaf node 522. A third of the three paths from the browser node 508 is through the Internet node 524, which has −2 associated reward points, the Microsoft node 526, which has no associated reward points, and to the −3 RP leaf node 528; or from the browser node 508 through the Internet node 524, which has −2 associated reward points, the malware node 530, which has −5 associated reward points, and to the −8 RP leaf node 532.
Although the activity graph 500 is intentionally simplified for illustrative purposes, it is worth pointing out that CVE scores can be inserted into the graph as additional nodes as identified by the dotted box 534. The set of CVE scores can include reward points that vary depending upon the specific CVE and one of the CVE node reward points could be 0 for when, e.g., browser version doesn't matter given the events associated with the activity (or, equivalently, the activity graph 500 could omit the nodes if they do not change the reward points). It may further be noted the root node 502 can be considered a null node and the leaf nodes 536 need not be represented as nodes (because they are simply reward point sums in this example).
In a specific implementation, baseline risk graphs and threat vector graphs can be created in a manner similar to that described with reference to the example of
Alerts can be used to train a model to determine reward points. Different activities can be ranked and a triggered alert can be mapped back to an activity and sequence of events. Through training, it is possible to determine how to assign reward points at each event of an activity and rank events and assign reward points based on the ranking.
In the progressive risk prediction graph 600, permutations of the input layer features 604 are connected to hidden layer identity relationship node 606-1 to hidden layer identity relationship node 606-3 (collectively the hidden layer identity relationship nodes 606). The incoming connections to the hidden layer identity relationship nodes 606 can be characterized as part of a baseline risk layer and a threat vector layer. For example, the 16-point stars (subnodes) illustrated in the example of
In the progressive risk prediction graph 600, the hidden layer identity relationship nodes 606 are connected to an output layer 608, which has an associated progressive risk score. As such, the progressive risk prediction graph 600 can be used in a reinforcement learning-based IoT risk evaluation system.
The example system shown in
The example system shown in
When a personality is matched, an IoT device can be characterized as exhibiting behavior consistent with the matched personality. While
The personality aware enrichment engine 702 is intended to represent an engine that functions to enrich raw event metadata received based on operation of an IoT device. The personality aware enrichment engine 702 can receive raw metadata in the form of data packets or portions of data packets transmitted to and from an IoT device in operation of the IoT device. In enriching raw event metadata, the personality aware enrichment engine 702 can identify an IoT device and assign a context to the IoT device.
The IoT device demographics generation engine 704 is intended to represent an engine that receives enriched metadata to maintain demographics of IoT devices including the IoT device. The IoT device demographics generation engine 704 receives the enriched metadata from the personality aware enrichment engine 702. In maintaining demographics of IoT devices based on enriched metadata, the IoT device demographics generation engine 704 can establish profiles of groups of IoT devices. For example, the IoT device demographics generation engine 704 can group together IoT devices that share a common context together to form a profile of a group of the IoT devices. Additionally, in maintaining demographics of IoT devices, the IoT device demographics generation engine 704 can aggregate and create permutations of the enriched metadata to generate aggregated metadata permutations. For example, the IoT device demographics generation engine 704 can group together all enriched metadata related to streaming events at the IoT device together to generate aggregated metadata permutations.
The IoT personality definition engine 706 is intended to represent an engine that functions to define a personality of the IoT device. The IoT personality definition engine 706 can define a personality of the IoT device by generating and updating IoT personality data stored in the IoT personality datastore 708. Additionally, the IoT personality definition engine 706 can define a personality of the IoT device using aggregated metadata permutations received from the IoT device demographics generation engine 704. More specifically, the IoT personality definition engine 706 can identify feature values indicating behaviors of the IoT device in operation based on aggregated metadata permutations received from the IoT device demographics generation engine 704.
The offline modeling engine 710 is intended to represent an engine that functions to build a context-based undesired behavior detection model for use in detecting undesired behavior in the operation of the IoT device. The offline modeling engine 710 can build a context-based undesired behavior detection model based on feature values indicating behaviors of the IoT device in operation, as determined by the IoT personality definition engine 706. Additionally, the offline modeling engine 710 can use an applicable machine learning mechanism to recognize behavior patterns in the feature values to build the context-based undesired behavior detection model. For example, the offline modeling engine 710 can use either or both learned state transition-based learning and deep learning to identify behavior patterns of the IoT in operation for purposes of maintaining a context-based undesired behavior detection model.
The personality aware undesired behavior detection engine 712 is intended to represent an engine that functions to apply a context-based undesired behavior detection model to feature values for purposes of detecting undesired behavior in the operation of the IoT device. The personality aware undesired behavior detection engine 712 can apply a context-based undesired behavior detection model maintained by the offline modeling engine 710 to feature values of the IoT device identified by the IoT personality definition engine 706. In applying the model to feature values, the personality aware undesired behavior detection engine 712 generate a signal comparing actual behaviors of the IoT device in operation to modeled behaviors of the IoT device.
The signal correlation engine 714 is intended to represent an engine that functions to generate and send undesirable behavior alerts. The signal correlation engine 714 can generate and send undesirable behavior alerts based on actual behaviors of the IoT device in operation to modeled behaviors of the IoT device, as received from the personality aware undesired behavior detection engine 712. The signal correlation engine 714 can send an undesirable behavior alert indicating how the IoT device deviated from normal behavior patterns, e.g. benign behavior patterns, in exhibiting undesired behavior in operation.
The new personality profile discovery engine 716 is intended to represent an engine that functions to identify a personality profile of the IoT device. The new personality profile discovery engine 716 can detect whether an IoT personality profile exists for the IoT device based on one or a combination of raw metadata received at the personality aware enrichment engine 702, enriched raw metadata received at the IoT device demographics generation engine 704, aggregated metadata permutation received at the IoT personality definition engine 706, and feature values determined by the IoT personality definition engine 706. The new personality profile discovery engine 716 can inform the IoT personality definition engine 706 whether an IoT personality profile exists for the IoT device for purposes of defining the IoT personality for the IoT device.
The flowchart 800 continues to module 804 with obtaining domain knowledge, including knowledge regarding bad IoT personalities, from a network administration engine. An example of an engine that can perform module 804 is the IoT personality definition engine 706 of
The flowchart 800 continues to module 806 with defining a personality, including feature values associated with the personality, using the aggregated metadata permutations, the domain knowledge, and prior personality data set feedback from a new personality profile discovery engine. An example of an engine that can perform module 806 is the IoT personality definition engine 706 of
The flowchart 800 continues to module 808 with classifying the personality using the feature values and IoT personality models, wherein the personality has a signal associated therewith. An example of an engine that can perform module 808 is the personality classification engine 712 of
The flowchart 800 continues to module 810 with correlating the signal to reach a verdict and, if the personality is a bad personality, generate a bad personality alert for provisioning to the network administration engine. An example of an engine that can perform module 810 is the signal correlation engine 714 of
The flowchart 800 continues to module 812 with discovering, at the new personality profile discovery engine, new personality data set feedback from the classified personality and the verdict. An example of an engine that can perform module 812 is the new personality profile discovery engine 716 of
These and other examples provided in this paper are intended to illustrate but not necessarily to limit the described implementation. As used herein, the term “implementation” means an implementation that serves to illustrate by way of example but not limitation. The techniques described in the preceding text and figures can be mixed and matched as circumstances demand to produce alternative implementations.
The present application is a continuation of U.S. patent application Ser. No. 16/712,981 filed Dec. 12, 2019 and entitled “Iot Device Risk Assessment and Scoring,” which claims priority to U.S. Provisional Patent Application Ser. No. 62/778,810 filed Dec. 12, 2018 and entitled “IoT Device Risk Modeling,” each of which is hereby incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
6142682 | Skogby | Nov 2000 | A |
6877146 | Teig | Apr 2005 | B1 |
8146133 | Moon | Mar 2012 | B2 |
8159966 | Mabee | Apr 2012 | B1 |
8331229 | Hu | Dec 2012 | B1 |
8671099 | Kapoor | Mar 2014 | B2 |
8683598 | Cashin | Mar 2014 | B1 |
8850588 | Kumar | Sep 2014 | B2 |
8874550 | Soubramanien | Oct 2014 | B1 |
8891528 | Moriarty | Nov 2014 | B2 |
8898788 | Ashar | Nov 2014 | B1 |
8973088 | Leung | Mar 2015 | B1 |
9324119 | Singh | Apr 2016 | B2 |
9516053 | Muddu | Dec 2016 | B1 |
9548987 | Poole | Jan 2017 | B1 |
9584536 | Nantel | Feb 2017 | B2 |
9600571 | Shaashua | Mar 2017 | B2 |
9609003 | Chmielewski | Mar 2017 | B1 |
9661011 | Van Horenbeeck | May 2017 | B1 |
9692784 | Nenov | Jun 2017 | B1 |
9774604 | Zou | Sep 2017 | B2 |
9807110 | Harlacher | Oct 2017 | B2 |
9891907 | Searle | Feb 2018 | B2 |
9961096 | Pierce | May 2018 | B1 |
9984344 | Singh | May 2018 | B2 |
10038700 | Duchin | Jul 2018 | B1 |
10043591 | LaBorde | Aug 2018 | B1 |
10122747 | Mahaffey | Nov 2018 | B2 |
10191794 | Smith | Jan 2019 | B2 |
10204312 | Singh | Feb 2019 | B2 |
10212176 | Wang | Feb 2019 | B2 |
10212178 | Cheng | Feb 2019 | B2 |
10229269 | Patton | Mar 2019 | B1 |
10237875 | Romanov | Mar 2019 | B1 |
10320613 | Cam-Winget | Jun 2019 | B1 |
10348739 | Greenspan | Jul 2019 | B2 |
10459827 | Aghdaie | Oct 2019 | B1 |
10489361 | Sisk | Nov 2019 | B2 |
10511620 | Schwartz | Dec 2019 | B2 |
10623389 | Childress | Apr 2020 | B2 |
10630728 | Ghosh | Apr 2020 | B2 |
10764315 | Carroll | Sep 2020 | B1 |
10885393 | Sirianni | Jan 2021 | B1 |
10887306 | Gupta | Jan 2021 | B2 |
11005839 | Shahidzadeh | May 2021 | B1 |
11070568 | Ektare | Jul 2021 | B2 |
11115799 | Du | Sep 2021 | B1 |
11310247 | Manadhata | Apr 2022 | B2 |
11455641 | Shahidzadeh | Sep 2022 | B1 |
20040243835 | Terzis | Dec 2004 | A1 |
20060265397 | Bryan | Nov 2006 | A1 |
20080059536 | Brock | Mar 2008 | A1 |
20100284282 | Golic | Nov 2010 | A1 |
20120065749 | Hunter | Mar 2012 | A1 |
20120102543 | Kohli | Apr 2012 | A1 |
20120240185 | Kapoor | Sep 2012 | A1 |
20130086261 | Lim | Apr 2013 | A1 |
20130173621 | Kapoor | Jul 2013 | A1 |
20130247190 | Spurlock | Sep 2013 | A1 |
20130305357 | Ayyagari | Nov 2013 | A1 |
20140006479 | Maloo | Jan 2014 | A1 |
20140244834 | Guedalia | Aug 2014 | A1 |
20140281912 | Doi | Sep 2014 | A1 |
20140325670 | Singh | Oct 2014 | A1 |
20140337862 | Valencia | Nov 2014 | A1 |
20150039513 | Adjaoute | Feb 2015 | A1 |
20150055623 | Li | Feb 2015 | A1 |
20150161024 | Gupta | Jun 2015 | A1 |
20150229654 | Perier | Aug 2015 | A1 |
20150262067 | Sridhara | Sep 2015 | A1 |
20150271192 | Crowley | Sep 2015 | A1 |
20150293954 | Hsiao | Oct 2015 | A1 |
20150295945 | Canzanese, Jr. | Oct 2015 | A1 |
20150324559 | Boss | Nov 2015 | A1 |
20150356451 | Gupta | Dec 2015 | A1 |
20160028750 | Di Pietro | Jan 2016 | A1 |
20160036819 | Zehavi | Feb 2016 | A1 |
20160048984 | Frigo | Feb 2016 | A1 |
20160119372 | Borlick | Apr 2016 | A1 |
20160128043 | Shuman | May 2016 | A1 |
20160173446 | Nantel | Jun 2016 | A1 |
20160173495 | Joo | Jun 2016 | A1 |
20160182497 | Smith | Jun 2016 | A1 |
20160196558 | Mercille | Jul 2016 | A1 |
20160212099 | Zou | Jul 2016 | A1 |
20160218949 | Dasgupta | Jul 2016 | A1 |
20160261465 | Gupta | Sep 2016 | A1 |
20160267406 | Bodo | Sep 2016 | A1 |
20160267408 | Singh | Sep 2016 | A1 |
20160277435 | Salajegheh | Sep 2016 | A1 |
20160301707 | Cheng | Oct 2016 | A1 |
20160301717 | Dotan | Oct 2016 | A1 |
20160337127 | Schultz | Nov 2016 | A1 |
20160352685 | Park | Dec 2016 | A1 |
20160366141 | Smith | Dec 2016 | A1 |
20160366181 | Smith | Dec 2016 | A1 |
20170006028 | Tunnell | Jan 2017 | A1 |
20170006135 | Siebel | Jan 2017 | A1 |
20170011406 | Tunnell | Jan 2017 | A1 |
20170013005 | Galula | Jan 2017 | A1 |
20170055913 | Bandyopadhyay | Mar 2017 | A1 |
20170063774 | Chen | Mar 2017 | A1 |
20170093915 | Ellis | Mar 2017 | A1 |
20170118237 | Devi Reddy | Apr 2017 | A1 |
20170118240 | Devi Reddy | Apr 2017 | A1 |
20170124660 | Srivastava | May 2017 | A1 |
20170126704 | Nandha Premnath | May 2017 | A1 |
20170149813 | Wright | May 2017 | A1 |
20170180380 | Bagasra | Jun 2017 | A1 |
20170180399 | Sukhomlinov | Jun 2017 | A1 |
20170188242 | Ghosh | Jun 2017 | A1 |
20170200061 | Julian | Jul 2017 | A1 |
20170230402 | Greenspan | Aug 2017 | A1 |
20170232300 | Tran | Aug 2017 | A1 |
20170235585 | Gupta | Aug 2017 | A1 |
20170235783 | Chen | Aug 2017 | A1 |
20170244737 | Kuperman | Aug 2017 | A1 |
20170251007 | Fujisawa | Aug 2017 | A1 |
20170272554 | Kwan | Sep 2017 | A1 |
20170279685 | Mota | Sep 2017 | A1 |
20170289184 | C | Oct 2017 | A1 |
20170331671 | Olsson | Nov 2017 | A1 |
20170331906 | Choi | Nov 2017 | A1 |
20170339178 | Mahaffey | Nov 2017 | A1 |
20170344407 | Jeon | Nov 2017 | A1 |
20170346677 | Suryanarayana | Nov 2017 | A1 |
20180007058 | Zou | Jan 2018 | A1 |
20180012227 | Tunnell | Jan 2018 | A1 |
20180018684 | Orr | Jan 2018 | A1 |
20180027006 | Zimmermann | Jan 2018 | A1 |
20180078843 | Tran | Mar 2018 | A1 |
20180115574 | Ridley | Apr 2018 | A1 |
20180117446 | Tran | May 2018 | A1 |
20180117447 | Tran | May 2018 | A1 |
20180139227 | Martin | May 2018 | A1 |
20180144139 | Cheng | May 2018 | A1 |
20180191729 | Whittle | Jul 2018 | A1 |
20180191746 | De Knijf | Jul 2018 | A1 |
20180191848 | Bhattacharya | Jul 2018 | A1 |
20180205793 | Loeb | Jul 2018 | A1 |
20180212768 | Kawashima | Jul 2018 | A1 |
20180234302 | James | Aug 2018 | A1 |
20180234519 | Boyapalle | Aug 2018 | A1 |
20180248902 | Dãnilã-Dumitrescu | Aug 2018 | A1 |
20180255084 | Kotinas | Sep 2018 | A1 |
20180261070 | Stevens | Sep 2018 | A1 |
20180264347 | Tran | Sep 2018 | A1 |
20180285234 | Degaonkar | Oct 2018 | A1 |
20180293387 | Bar-El | Oct 2018 | A1 |
20180295148 | Mayorgo | Oct 2018 | A1 |
20180302440 | Hu | Oct 2018 | A1 |
20180349598 | Harel | Dec 2018 | A1 |
20180349612 | Harel | Dec 2018 | A1 |
20180357556 | Rai | Dec 2018 | A1 |
20180375887 | Dezent | Dec 2018 | A1 |
20190019249 | Bhattacharjee | Jan 2019 | A1 |
20190081961 | Bansal | Mar 2019 | A1 |
20190089747 | Wang | Mar 2019 | A1 |
20190098028 | Ektare | Mar 2019 | A1 |
20190098058 | Ikegami | Mar 2019 | A1 |
20190109717 | Reddy | Apr 2019 | A1 |
20190121978 | Kraemer | Apr 2019 | A1 |
20190138512 | Pourmohammad | May 2019 | A1 |
20190182278 | Das | Jun 2019 | A1 |
20190268305 | Xu | Aug 2019 | A1 |
20190349426 | Smith | Nov 2019 | A1 |
20190361917 | Tran | Nov 2019 | A1 |
20190373472 | Smith | Dec 2019 | A1 |
20190387399 | Weinberg | Dec 2019 | A1 |
20200036603 | Nieves | Jan 2020 | A1 |
20200076846 | Pandian | Mar 2020 | A1 |
20200076853 | Pandian | Mar 2020 | A1 |
20200117690 | Tran | Apr 2020 | A1 |
20200156654 | Boss | May 2020 | A1 |
20200162278 | Delaney | May 2020 | A1 |
20200177485 | Shurtleff | Jun 2020 | A1 |
20200177589 | Mangalvedkar | Jun 2020 | A1 |
20200213146 | Kodam | Jul 2020 | A1 |
20200409957 | Zhang | Dec 2020 | A1 |
Number | Date | Country |
---|---|---|
102025577 | Jul 2012 | CN |
107862468 | Mar 2018 | CN |
108650133 | Oct 2018 | CN |
107135093 | May 2020 | CN |
108306911 | Dec 2020 | CN |
3136297 | Mar 2017 | EP |
2018513467 | May 2018 | JP |
2019218874 | Nov 2019 | WO |
Entry |
---|
Charu C. Aggarwal, Outlier Analysis, Retrieved from the Internet, URL: https://web.archive.org/web/20130210212057/http://charuaggarwal.net/outlierbook.pdf. |
Arash Fasihi, Rule Based Inference and Action Selection Based on Monitoring Data in IoT, Dec. 1, 2015. |
Cramer et al., Detecting Anomalies in Device Event Data in the IoT, Proceedings of the 3td International Conference on Internet of Things, Big Data and Security, Mar. 21, 2018, pp. 52-62. |
Midi et al., Kalis—A System for Knowledge-driven Adaptable Intrusion Detection for the Internet of Things, 2017 IEEE 37th International Conference on Distributed Computing Systems, pp. 656-666. |
Al-Shaer et al., Design and Implementation of Firewall Policy Advisor Tools, 2002. |
Al-Shaer et al., Firewall Policy Advisor for Anomaly Discovery and Rule Editing, Integrated Network Management VIII, 2003. |
Author Unknown, Cisco Encrypted Traffic Analytics, Feb. 10, 2021. |
Blackstock et al., IoT Interoperability: A Hub-based Approach, 2014, IEEE International Conference on the Internet of Things (IOT), pp. 80-84. |
Charyyev et al., Locality-Sensitive IoT Network Traffic Fingerprinting for Device Identification, IEEE Internet of Things Journal, 2020, vol. 8, No. 3, pp. 1272-1281. |
Du et al., A Lightweight Flow Feature-Based IoT Device Identification Scheme, Security and Communication Networks, 2022. |
Fredj et al., A Scalable IoT Service Search Based on Clustering and Aggregation, 2013 IEEE International Conference on Green Computing and Communication and IEEE Internet of Things and IEEE Cyber, Physical and Social Computing, pp. 1-8. |
International Application No. PCT/US2016/025661, International Search Report and Written Opinion dated Jul. 7, 2016. |
Li et al., A Distributed Consensus Algorithm for Decision Making in Service-Oriented Internet of Things, Old Dominion University, ODU Digital Commons, 2014. |
Liu et al., A Lightweight Anomaly Mining Algorithm in the Internet of Things, 2014 IEEE 5th International Conference on Software Engineering and Service Science, 2014, pp. 1142-1145. |
Martin et al., Requirements and Recommendations for CWE Compatibility and CWE Effectiveness, Version 1.0, Jul. 28, 2011. |
Miloslavskaya et al., Ensuring Information Security for Internet of Things, 2017, IEEE 5th International Conference of Future Internet of Things and Cloud, pp. 62-69. |
National Electrical Manufacturers Association, Manufacturer Disclosure Statement for Medical Device Security, HIMSS/NEMA Standard HN Jan. 2013, 2013. |
Nguyen et al., A Software-Defined Model for IoT Clusters: Enabling Applications on Demand, Faculty of Engineering and IT, University of Technology Sydney, Australia, IEEE Xplore, Apr. 23, 2018. |
Sivanathan et al., Classifying IoT Devices in Smart Environments Using Network Traffic Characteristics, IEEE, TMC, No. 8, pp. 1745-1759, Aug. 2018. |
Sivanathan et al., Detecting Behavioral Change of IoT Devices Using Clustering-Based Network Traffic Modeling, IEEE LCN 2019, Mar. 30, 2020. |
Sivanathan et al., Inferring IoT Device Types from Network Behavior Using Unsupervised Clustering, IEEE ICN 2019, Oct. 2019. |
Zhao et al., A Few-Shot Learning Based Approach to IoT Traffic Classification, IEEE Communications Letters, 2021. |
Chen et al., A Model-Based Validated Autonomic Approach to Self-Protect Computing Systems, IEEE Internet of Things Journal, Oct. 2014, pp. 446-460, vol. 1, No. 5. |
Number | Date | Country | |
---|---|---|---|
20220311799 A1 | Sep 2022 | US |
Number | Date | Country | |
---|---|---|---|
62778810 | Dec 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16712981 | Dec 2019 | US |
Child | 17840234 | US |